.navbar-brand[data-v-e98caea4]{display:flex;align-items:center;text-decoration:none;gap:10px}.brand-logo[data-v-e98caea4]{height:32px;width:auto}.brand-text[data-v-e98caea4]{font-size:15px;font-weight:700;color:#00479c;letter-spacing:-.3px;white-space:nowrap}.navbar-nav[data-v-e98caea4]{display:flex;align-items:center;gap:6px;flex:1;margin-left:var(--space-8)}.nav-link[data-v-e98caea4]{font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:8px 16px;border-radius:var(--radius-base);transition:all .15s ease}.nav-link[data-v-e98caea4]:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-link.active[data-v-e98caea4]{color:var(--primary-600);background:var(--primary-50);font-weight:600}.nav-arrow[data-v-e98caea4]{font-size:10px;margin-left:2px;transition:transform .15s ease}.nav-dropdown-wrap[data-v-e98caea4]{position:relative}.nav-dropdown-wrap .nav-link[data-v-e98caea4]{cursor:pointer;display:flex;align-items:center;gap:2px;-webkit-user-select:none;user-select:none}.nav-dropdown[data-v-e98caea4]{position:absolute;top:calc(100% + 6px);left:0;min-width:140px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:8px;box-shadow:var(--shadow-4);padding:4px;z-index:200}.nav-dropdown-item[data-v-e98caea4]{display:block;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:6px;transition:all .1s ease;white-space:nowrap}.nav-dropdown-item[data-v-e98caea4]:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-dropdown-item.active[data-v-e98caea4]{color:var(--primary-600);background:var(--primary-50)}.navbar-end[data-v-e98caea4]{display:flex;align-items:center;gap:var(--space-3)}.navbar-search[data-v-e98caea4]{position:relative;display:flex;align-items:center}.navbar-search[data-v-e98caea4] .p-iconfield{width:200px}.navbar-search[data-v-e98caea4] .p-inputtext{height:32px;font-size:12px;padding-left:34px;padding-right:30px;background:var(--bg-secondary);border:none;border-radius:8px}.navbar-search[data-v-e98caea4] .p-inputtext:focus{background:var(--bg-elevated);box-shadow:0 0 0 2px var(--primary-400)}.navbar-search[data-v-e98caea4] .p-inputicon{color:var(--text-tertiary);font-size:13px}.search-clear-btn[data-v-e98caea4]{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;background:var(--bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-tertiary);font-size:10px;transition:all .15s ease;padding:0}.search-clear-btn[data-v-e98caea4]:hover{background:var(--border-medium);color:var(--text-primary)}.search-kbd[data-v-e98caea4]{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--text-tertiary);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:4px;padding:1px 5px;font-family:var(--font-family-mono, monospace);line-height:1;pointer-events:none}.search-dropdown[data-v-e98caea4]{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:8px;box-shadow:var(--shadow-4);padding:4px;z-index:100}.search-result-item[data-v-e98caea4]{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .1s}.search-result-item[data-v-e98caea4]:hover{background:var(--bg-secondary)}.search-result-label[data-v-e98caea4]{font-size:13px;font-weight:500;color:var(--text-primary)}.navbar-notifications[data-v-e98caea4]{position:relative}.notif-btn[data-v-e98caea4]{position:relative;width:34px;height:34px;color:var(--text-secondary)}.notif-badge[data-v-e98caea4]{position:absolute;top:2px;right:2px;font-size:10px;min-width:16px;height:16px;line-height:16px}.user-avatar[data-v-e98caea4]{cursor:pointer;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;font-size:13px;font-weight:600;width:32px;height:32px;transition:box-shadow .15s ease}.user-avatar[data-v-e98caea4]:hover{box-shadow:0 0 0 3px #2196f333}.notif-popover .p-popover-content{padding:0}.notif-panel{width:320px}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border-light)}.notif-panel-title{font-size:14px;font-weight:600;color:var(--text-primary)}.notif-count-badge{font-size:11px}.notif-panel-list{max-height:280px;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;cursor:pointer;transition:background .1s}.notif-item:hover{background:var(--bg-secondary)}.notif-item.unread{background:#2196f30a}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-500);flex-shrink:0;margin-top:5px}.notif-item-content{flex:1;min-width:0}.notif-item-title{font-size:13px;color:var(--text-primary);margin:0;line-height:1.4}.notif-item-time{font-size:11px;color:var(--text-tertiary);margin-top:2px;display:block}.notif-panel-footer{padding:10px 16px;border-top:1px solid var(--border-light);text-align:center}.view-all-link{font-size:12px;color:var(--primary-600);text-decoration:none;font-weight:500}.view-all-link:hover{text-decoration:underline}.user-popover .p-popover-content{padding:0}.user-panel{width:280px}.user-panel-header{display:flex;align-items:center;gap:12px;padding:20px 16px 16px;background:linear-gradient(135deg,#2196f30f,#2196f305)}.user-panel-avatar{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;font-size:18px;font-weight:600}.user-panel-info{min-width:0}.user-panel-name{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.user-panel-role{font-size:12px;color:var(--text-secondary);margin:3px 0 0}.user-panel-meta{padding:12px 16px;border-top:1px solid var(--border-light)}.meta-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.meta-label{font-size:12px;color:var(--text-tertiary)}.meta-value{font-size:13px;color:var(--text-primary);font-weight:500}.user-panel-footer{padding:12px 16px;border-top:1px solid var(--border-light)}.user-panel-footer .logout-btn{width:100%;font-size:13px}.user-panel-views{padding:12px 16px;border-top:1px solid var(--border-light)}.user-panel-views-title{font-size:12px;color:var(--text-tertiary);margin:0 0 8px;font-weight:500}.user-panel-views-list{display:flex;flex-direction:column;gap:4px}.view-switch-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border:none;border-radius:6px;background:transparent;font-size:13px;font-weight:500;color:#344054;cursor:pointer;transition:background .15s ease;font-family:var(--font-family-base);text-align:left;white-space:nowrap;width:100%}.view-switch-item i{font-size:14px;color:#667085}.view-switch-item:hover{background:var(--bg-secondary)}.view-switch-item.active{background:var(--primary-50, #eff6ff);color:var(--primary-600, #2563eb)}.view-switch-item.active i{color:var(--primary-600, #2563eb)}.toast[data-v-1ccc427a]{position:fixed;top:64px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:10px;font-size:14px;font-weight:500;z-index:3000;box-shadow:#00000026 0 4px 16px}.toast--info[data-v-1ccc427a]{background:#1d1d1f;color:#fff}.toast--success[data-v-1ccc427a]{background:#34c759;color:#fff}.toast--error[data-v-1ccc427a]{background:#ff3b30;color:#fff}.toast--warning[data-v-1ccc427a]{background:#f5a623;color:#fff}.toast-enter-active[data-v-1ccc427a],.toast-leave-active[data-v-1ccc427a]{transition:opacity .25s,transform .25s}.toast-enter-from[data-v-1ccc427a],.toast-leave-to[data-v-1ccc427a]{opacity:0;transform:translate(-50%) translateY(-12px)}@font-face{font-family:primeicons;font-display:block;src:url(/assets/primeicons-DMOk5skT.eot);src:url(/assets/primeicons-DMOk5skT.eot?#iefix) format("embedded-opentype"),url(/assets/primeicons-C6QP2o4f.woff2) format("woff2"),url(/assets/primeicons-WjwUDZjB.woff) format("woff"),url(/assets/primeicons-MpK4pl85.ttf) format("truetype"),url(/assets/primeicons-Dr5RGzOO.svg?#primeicons) format("svg");font-weight:400;font-style:normal}.pi{font-family:primeicons;speak:none;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.pi:before{--webkit-backface-visibility:hidden;backface-visibility:hidden}.pi-fw{width:1.28571429em;text-align:center}.pi-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}@media (prefers-reduced-motion: reduce){.pi-spin{-webkit-animation-delay:-1ms;animation-delay:-1ms;-webkit-animation-duration:1ms;animation-duration:1ms;-webkit-animation-iteration-count:1;animation-iteration-count:1;-webkit-transition-delay:0s;transition-delay:0s;-webkit-transition-duration:0s;transition-duration:0s}}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.pi-folder-plus:before{content:""}.pi-receipt:before{content:""}.pi-asterisk:before{content:""}.pi-face-smile:before{content:""}.pi-pinterest:before{content:""}.pi-expand:before{content:""}.pi-pen-to-square:before{content:""}.pi-wave-pulse:before{content:""}.pi-turkish-lira:before{content:""}.pi-spinner-dotted:before{content:""}.pi-crown:before{content:""}.pi-pause-circle:before{content:""}.pi-warehouse:before{content:""}.pi-objects-column:before{content:""}.pi-clipboard:before{content:""}.pi-play-circle:before{content:""}.pi-venus:before{content:""}.pi-cart-minus:before{content:""}.pi-file-plus:before{content:""}.pi-microchip:before{content:""}.pi-twitch:before{content:""}.pi-building-columns:before{content:""}.pi-file-check:before{content:""}.pi-microchip-ai:before{content:""}.pi-trophy:before{content:""}.pi-barcode:before{content:""}.pi-file-arrow-up:before{content:""}.pi-mars:before{content:""}.pi-tiktok:before{content:""}.pi-arrow-up-right-and-arrow-down-left-from-center:before{content:""}.pi-ethereum:before{content:""}.pi-list-check:before{content:""}.pi-thumbtack:before{content:""}.pi-arrow-down-left-and-arrow-up-right-to-center:before{content:""}.pi-equals:before{content:""}.pi-lightbulb:before{content:""}.pi-star-half:before{content:""}.pi-address-book:before{content:""}.pi-chart-scatter:before{content:""}.pi-indian-rupee:before{content:""}.pi-star-half-fill:before{content:""}.pi-cart-arrow-down:before{content:""}.pi-calendar-clock:before{content:""}.pi-sort-up-fill:before{content:""}.pi-sparkles:before{content:""}.pi-bullseye:before{content:""}.pi-sort-down-fill:before{content:""}.pi-graduation-cap:before{content:""}.pi-hammer:before{content:""}.pi-bell-slash:before{content:""}.pi-gauge:before{content:""}.pi-shop:before{content:""}.pi-headphones:before{content:""}.pi-eraser:before{content:""}.pi-stopwatch:before{content:""}.pi-verified:before{content:""}.pi-delete-left:before{content:""}.pi-hourglass:before{content:""}.pi-truck:before{content:""}.pi-wrench:before{content:""}.pi-microphone:before{content:""}.pi-megaphone:before{content:""}.pi-arrow-right-arrow-left:before{content:""}.pi-bitcoin:before{content:""}.pi-file-edit:before{content:""}.pi-language:before{content:""}.pi-file-export:before{content:""}.pi-file-import:before{content:""}.pi-file-word:before{content:""}.pi-gift:before{content:""}.pi-cart-plus:before{content:""}.pi-thumbs-down-fill:before{content:""}.pi-thumbs-up-fill:before{content:""}.pi-arrows-alt:before{content:""}.pi-calculator:before{content:""}.pi-sort-alt-slash:before{content:""}.pi-arrows-h:before{content:""}.pi-arrows-v:before{content:""}.pi-pound:before{content:""}.pi-prime:before{content:""}.pi-chart-pie:before{content:""}.pi-reddit:before{content:""}.pi-code:before{content:""}.pi-sync:before{content:""}.pi-shopping-bag:before{content:""}.pi-server:before{content:""}.pi-database:before{content:""}.pi-hashtag:before{content:""}.pi-bookmark-fill:before{content:""}.pi-filter-fill:before{content:""}.pi-heart-fill:before{content:""}.pi-flag-fill:before{content:""}.pi-circle:before{content:""}.pi-circle-fill:before{content:""}.pi-bolt:before{content:""}.pi-history:before{content:""}.pi-box:before{content:""}.pi-at:before{content:""}.pi-arrow-up-right:before{content:""}.pi-arrow-up-left:before{content:""}.pi-arrow-down-left:before{content:""}.pi-arrow-down-right:before{content:""}.pi-telegram:before{content:""}.pi-stop-circle:before{content:""}.pi-stop:before{content:""}.pi-whatsapp:before{content:""}.pi-building:before{content:""}.pi-qrcode:before{content:""}.pi-car:before{content:""}.pi-instagram:before{content:""}.pi-linkedin:before{content:""}.pi-send:before{content:""}.pi-slack:before{content:""}.pi-sun:before{content:""}.pi-moon:before{content:""}.pi-vimeo:before{content:""}.pi-youtube:before{content:""}.pi-flag:before{content:""}.pi-wallet:before{content:""}.pi-map:before{content:""}.pi-link:before{content:""}.pi-credit-card:before{content:""}.pi-discord:before{content:""}.pi-percentage:before{content:""}.pi-euro:before{content:""}.pi-book:before{content:""}.pi-shield:before{content:""}.pi-paypal:before{content:""}.pi-amazon:before{content:""}.pi-phone:before{content:""}.pi-filter-slash:before{content:""}.pi-facebook:before{content:""}.pi-github:before{content:""}.pi-twitter:before{content:""}.pi-step-backward-alt:before{content:""}.pi-step-forward-alt:before{content:""}.pi-forward:before{content:""}.pi-backward:before{content:""}.pi-fast-backward:before{content:""}.pi-fast-forward:before{content:""}.pi-pause:before{content:""}.pi-play:before{content:""}.pi-compass:before{content:""}.pi-id-card:before{content:""}.pi-ticket:before{content:""}.pi-file-o:before{content:""}.pi-reply:before{content:""}.pi-directions-alt:before{content:""}.pi-directions:before{content:""}.pi-thumbs-up:before{content:""}.pi-thumbs-down:before{content:""}.pi-sort-numeric-down-alt:before{content:""}.pi-sort-numeric-up-alt:before{content:""}.pi-sort-alpha-down-alt:before{content:""}.pi-sort-alpha-up-alt:before{content:""}.pi-sort-numeric-down:before{content:""}.pi-sort-numeric-up:before{content:""}.pi-sort-alpha-down:before{content:""}.pi-sort-alpha-up:before{content:""}.pi-sort-alt:before{content:""}.pi-sort-amount-up:before{content:""}.pi-sort-amount-down:before{content:""}.pi-sort-amount-down-alt:before{content:""}.pi-sort-amount-up-alt:before{content:""}.pi-palette:before{content:""}.pi-undo:before{content:""}.pi-desktop:before{content:""}.pi-sliders-v:before{content:""}.pi-sliders-h:before{content:""}.pi-search-plus:before{content:""}.pi-search-minus:before{content:""}.pi-file-excel:before{content:""}.pi-file-pdf:before{content:""}.pi-check-square:before{content:""}.pi-chart-line:before{content:""}.pi-user-edit:before{content:""}.pi-exclamation-circle:before{content:""}.pi-android:before{content:""}.pi-google:before{content:""}.pi-apple:before{content:""}.pi-microsoft:before{content:""}.pi-heart:before{content:""}.pi-mobile:before{content:""}.pi-tablet:before{content:""}.pi-key:before{content:""}.pi-shopping-cart:before{content:""}.pi-comments:before{content:""}.pi-comment:before{content:""}.pi-briefcase:before{content:""}.pi-bell:before{content:""}.pi-paperclip:before{content:""}.pi-share-alt:before{content:""}.pi-envelope:before{content:""}.pi-volume-down:before{content:""}.pi-volume-up:before{content:""}.pi-volume-off:before{content:""}.pi-eject:before{content:""}.pi-money-bill:before{content:""}.pi-images:before{content:""}.pi-image:before{content:""}.pi-sign-in:before{content:""}.pi-sign-out:before{content:""}.pi-wifi:before{content:""}.pi-sitemap:before{content:""}.pi-chart-bar:before{content:""}.pi-camera:before{content:""}.pi-dollar:before{content:""}.pi-lock-open:before{content:""}.pi-table:before{content:""}.pi-map-marker:before{content:""}.pi-list:before{content:""}.pi-eye-slash:before{content:""}.pi-eye:before{content:""}.pi-folder-open:before{content:""}.pi-folder:before{content:""}.pi-video:before{content:""}.pi-inbox:before{content:""}.pi-lock:before{content:""}.pi-unlock:before{content:""}.pi-tags:before{content:""}.pi-tag:before{content:""}.pi-power-off:before{content:""}.pi-save:before{content:""}.pi-question-circle:before{content:""}.pi-question:before{content:""}.pi-copy:before{content:""}.pi-file:before{content:""}.pi-clone:before{content:""}.pi-calendar-times:before{content:""}.pi-calendar-minus:before{content:""}.pi-calendar-plus:before{content:""}.pi-ellipsis-v:before{content:""}.pi-ellipsis-h:before{content:""}.pi-bookmark:before{content:""}.pi-globe:before{content:""}.pi-replay:before{content:""}.pi-filter:before{content:""}.pi-print:before{content:""}.pi-align-right:before{content:""}.pi-align-left:before{content:""}.pi-align-center:before{content:""}.pi-align-justify:before{content:""}.pi-cog:before{content:""}.pi-cloud-download:before{content:""}.pi-cloud-upload:before{content:""}.pi-cloud:before{content:""}.pi-pencil:before{content:""}.pi-users:before{content:""}.pi-clock:before{content:""}.pi-user-minus:before{content:""}.pi-user-plus:before{content:""}.pi-trash:before{content:""}.pi-external-link:before{content:""}.pi-window-maximize:before{content:""}.pi-window-minimize:before{content:""}.pi-refresh:before{content:""}.pi-user:before{content:""}.pi-exclamation-triangle:before{content:""}.pi-calendar:before{content:""}.pi-chevron-circle-left:before{content:""}.pi-chevron-circle-down:before{content:""}.pi-chevron-circle-right:before{content:""}.pi-chevron-circle-up:before{content:""}.pi-angle-double-down:before{content:""}.pi-angle-double-left:before{content:""}.pi-angle-double-right:before{content:""}.pi-angle-double-up:before{content:""}.pi-angle-down:before{content:""}.pi-angle-left:before{content:""}.pi-angle-right:before{content:""}.pi-angle-up:before{content:""}.pi-upload:before{content:""}.pi-download:before{content:""}.pi-ban:before{content:""}.pi-star-fill:before{content:""}.pi-star:before{content:""}.pi-chevron-left:before{content:""}.pi-chevron-right:before{content:""}.pi-chevron-down:before{content:""}.pi-chevron-up:before{content:""}.pi-caret-left:before{content:""}.pi-caret-right:before{content:""}.pi-caret-down:before{content:""}.pi-caret-up:before{content:""}.pi-search:before{content:""}.pi-check:before{content:""}.pi-check-circle:before{content:""}.pi-times:before{content:""}.pi-times-circle:before{content:""}.pi-plus:before{content:""}.pi-plus-circle:before{content:""}.pi-minus:before{content:""}.pi-minus-circle:before{content:""}.pi-circle-on:before{content:""}.pi-circle-off:before{content:""}.pi-sort-down:before{content:""}.pi-sort-up:before{content:""}.pi-sort:before{content:""}.pi-step-backward:before{content:""}.pi-step-forward:before{content:""}.pi-th-large:before{content:""}.pi-arrow-down:before{content:""}.pi-arrow-left:before{content:""}.pi-arrow-right:before{content:""}.pi-arrow-up:before{content:""}.pi-bars:before{content:""}.pi-arrow-circle-down:before{content:""}.pi-arrow-circle-left:before{content:""}.pi-arrow-circle-right:before{content:""}.pi-arrow-circle-up:before{content:""}.pi-info:before{content:""}.pi-info-circle:before{content:""}.pi-home:before{content:""}.pi-spinner:before{content:""}:root{--primary-50: #e3f2fd;--primary-100: #bbdefb;--primary-200: #90caf9;--primary-300: #64b5f6;--primary-400: #42a5f5;--primary-500: #2196f3;--primary-600: #1e88e5;--primary-700: #1976d2;--primary-800: #1565c0;--primary-900: #0d47a1;--text-primary: #1d1d1f;--text-secondary: rgba(0,0,0,.68);--text-tertiary: rgba(0,0,0,.48);--text-disabled: rgba(0,0,0,.28);--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #f0f2f5;--bg-elevated: #ffffff;--border-light: rgba(0,0,0,.06);--border-medium: rgba(0,0,0,.12);--border-strong: rgba(0,0,0,.2);--success-bg: #e8f5e9;--success-text: #2e7d32;--success-main: #4caf50;--warning-bg: #fff3e0;--warning-text: #e65100;--warning-main: #ff9800;--error-bg: #ffebee;--error-text: #c62828;--error-main: #f44336;--info-bg: #e3f2fd;--info-text: #1565c0;--info-main: #2196f3;--status-draft: #9e9e9e;--status-pending: #ff9800;--status-approved: #2196f3;--status-doing: #03a9f4;--status-done: #4caf50;--status-rejected: #f44336;--status-closed: #607d8b;--shadow-0: none;--shadow-1: 0 1px 2px 0 rgba(0,0,0,.05);--shadow-2: 0 1px 3px 0 rgba(0,0,0,.08), 0 1px 2px -1px rgba(0,0,0,.06);--shadow-3: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -2px rgba(0,0,0,.08);--shadow-4: 0 10px 15px -3px rgba(0,0,0,.12), 0 4px 6px -4px rgba(0,0,0,.1);--shadow-5: 0 20px 25px -5px rgba(0,0,0,.14), 0 8px 10px -6px rgba(0,0,0,.12);--shadow-6: 0 25px 50px -12px rgba(0,0,0,.25);--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", "Fira Code", Consolas, "Courier New", monospace;--font-family-number: "SF Pro Text", "Segoe UI", -apple-system, sans-serif;--space-0: 0px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-none: 0px;--radius-sm: 4px;--radius-base: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1);--duration-instant: .1s;--duration-fast: .15s;--duration-base: .25s;--duration-slow: .35s;--duration-slower: .5s;--nav-height: 48px;--sidebar-width: 200px;--sidebar-collapsed-width: 64px;--content-max-width: 1920px;--content-padding-pc: 40px;--content-padding-h5: 16px;--color-blue: var(--primary-500);--color-blue-link: var(--primary-600);--color-bg: var(--bg-secondary);--color-surface: var(--bg-elevated);--color-text: var(--text-primary);--color-text-secondary: var(--text-secondary);--color-text-tertiary: var(--text-tertiary);--color-text-primary: var(--text-primary);--color-border: var(--border-medium);--color-divider: var(--border-light);--shadow-card: var(--shadow-2);--shadow-sm: var(--shadow-1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:auto;font-family:var(--font-family-base);font-size:14px;line-height:1.57;letter-spacing:0;color:var(--text-primary);background:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}table{border-collapse:separate;border-spacing:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:#0000003d}::selection{background:var(--primary-100);color:var(--primary-900)}.t-display-large{font-family:var(--font-family-base);font-size:48px;font-weight:700;line-height:56px;letter-spacing:-.5px}.t-display{font-family:var(--font-family-base);font-size:36px;font-weight:700;line-height:44px;letter-spacing:-.5px}.t-headline{font-family:var(--font-family-base);font-size:28px;font-weight:600;line-height:36px;letter-spacing:-.4px}.t-title-large{font-family:var(--font-family-base);font-size:22px;font-weight:600;line-height:28px;letter-spacing:-.3px}.t-title{font-family:var(--font-family-base);font-size:18px;font-weight:600;line-height:24px;letter-spacing:-.2px}.t-body-large{font-size:16px;font-weight:400;line-height:24px;letter-spacing:-.1px}.t-body{font-size:14px;font-weight:400;line-height:22px;letter-spacing:0}.t-caption{font-size:12px;font-weight:400;line-height:18px;letter-spacing:0;color:var(--text-secondary)}.t-overline{font-size:11px;font-weight:500;line-height:16px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);border:none;cursor:pointer;font-family:var(--font-family-base);font-size:14px;font-weight:600;letter-spacing:0;border-radius:var(--radius-base);padding:10px 24px;transition:all var(--duration-fast) var(--ease-out-quart);white-space:nowrap;text-decoration:none;-webkit-user-select:none;user-select:none}.btn:hover{box-shadow:var(--shadow-1)}.btn:active{transform:scale(.96);transition-duration:var(--duration-instant)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary-500);color:#fff}.btn-primary:hover{background:var(--primary-600)}.btn-secondary{background:transparent;color:var(--primary-500);border:1.5px solid var(--primary-300);padding:9px 24px}.btn-secondary:hover{background:var(--primary-50);border-color:var(--primary-500)}.btn-text{background:transparent;color:var(--primary-500);padding:8px 12px}.btn-text:hover{background:var(--primary-50)}.btn-danger{background:var(--error-main);color:#fff}.btn-danger:hover{background:var(--error-text)}.btn-pill{border-radius:var(--radius-full);background:var(--primary-500);color:#fff;font-size:13px;padding:6px 18px}.btn-pill-outline{border-radius:var(--radius-full);background:transparent;color:var(--primary-500);border:1.5px solid var(--primary-500);font-size:13px;padding:5px 18px}.btn-pill-outline:hover{background:var(--primary-50)}.btn-lg{font-size:16px;padding:12px 32px;height:48px}.btn-sm{font-size:13px;padding:5px 16px;height:32px}.btn-mini{font-size:12px;padding:4px 12px;height:24px}.btn-filter{font-size:13px;padding:5px 14px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);border:none;cursor:pointer;font-family:var(--font-family-base);font-weight:500;transition:all var(--duration-fast) var(--ease-out-quart)}.btn-filter:hover{background:var(--primary-100);color:var(--primary-700)}.btn-filter.active{background:var(--primary-500);color:#fff}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-1);letter-spacing:0}.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-primary);border:1.5px solid var(--border-medium);border-radius:var(--radius-base);padding:10px 14px;font-family:var(--font-family-base);font-size:14px;letter-spacing:0;color:var(--text-primary);outline:none;transition:all var(--duration-base) var(--ease-out-quart)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-strong)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50);background:var(--bg-elevated)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--bg-tertiary);color:var(--text-disabled);cursor:not-allowed}.form-textarea{min-height:80px;resize:vertical;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4)}.status-pill{display:inline-flex;align-items:center;gap:var(--space-1);font-size:12px;font-weight:500;letter-spacing:0;border-radius:var(--radius-full);padding:2px 10px;white-space:nowrap}.status-draft{background:#9e9e9e1f;color:var(--status-draft)}.status-pending{background:var(--warning-bg);color:var(--warning-text)}.status-approved{background:var(--info-bg);color:var(--info-text)}.status-doing{background:#03a9f41f;color:var(--status-doing)}.status-done{background:var(--success-bg);color:var(--success-text)}.status-rejected{background:var(--error-bg);color:var(--error-text)}.status-closed{background:#607d8b1f;color:var(--status-closed)}.status-success{background:var(--success-bg);color:var(--success-text)}.status-warning{background:var(--warning-bg);color:var(--warning-text)}.status-error{background:var(--error-bg);color:var(--error-text)}.status-info{background:var(--info-bg);color:var(--info-text)}.status-wait{background:var(--warning-bg);color:var(--warning-text)}.status-overdue{background:var(--error-bg);color:var(--error-text)}.status-warn{background:var(--warning-bg);color:var(--warning-text)}.transition-all{transition:all var(--duration-base) var(--ease-out-quart)}.transition-fast{transition:all var(--duration-fast) var(--ease-out-quart)}.transition-slow{transition:all var(--duration-slow) var(--ease-out-expo)}.card-hover{transition:all var(--duration-base) var(--ease-out-quart)}.card-hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-3)}.card-hover:active{transform:translateY(0) scale(.98);box-shadow:var(--shadow-2)}.list-item-interactive{transition:background-color var(--duration-fast) var(--ease-out-quart)}.list-item-interactive:hover{background-color:var(--bg-secondary)}.list-item-interactive:active{background-color:var(--bg-tertiary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn var(--duration-base) var(--ease-out-quart)}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in-up{animation:slideInUp var(--duration-slow) var(--ease-out-expo)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.slide-in-down{animation:slideInDown var(--duration-slow) var(--ease-out-expo)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.slide-in-left{animation:slideInLeft var(--duration-slow) var(--ease-out-expo)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-in-right{animation:slideInRight var(--duration-slow) var(--ease-out-expo)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.scale-in{animation:scaleIn var(--duration-slow) var(--ease-out-expo)}@keyframes modalEnter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-enter{animation:modalEnter var(--duration-slow) var(--ease-out-expo)}@keyframes modalBackdropEnter{0%{opacity:0}to{opacity:1}}.modal-backdrop-enter{animation:modalBackdropEnter var(--duration-base) var(--ease-standard)}@keyframes drawerEnterLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.drawer-enter-left{animation:drawerEnterLeft var(--duration-base) var(--ease-out-quart)}@keyframes drawerEnterRight{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-enter-right{animation:drawerEnterRight var(--duration-base) var(--ease-out-quart)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.5s var(--ease-in-out) infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}*:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px;border-radius:var(--radius-sm)}button:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.stagger-fade-in>*{opacity:0;animation:fadeIn var(--duration-base) var(--ease-out-quart) forwards}.stagger-fade-in>*:nth-child(1){animation-delay:0ms}.stagger-fade-in>*:nth-child(2){animation-delay:50ms}.stagger-fade-in>*:nth-child(3){animation-delay:.1s}.stagger-fade-in>*:nth-child(4){animation-delay:.15s}.stagger-fade-in>*:nth-child(5){animation-delay:.2s}.stagger-fade-in>*:nth-child(6){animation-delay:.25s}.stagger-fade-in>*:nth-child(7){animation-delay:.3s}.stagger-fade-in>*:nth-child(8){animation-delay:.35s}.stagger-fade-in>*:nth-child(9){animation-delay:.4s}.stagger-fade-in>*:nth-child(10){animation-delay:.45s}table tbody tr{animation:none!important}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.page-root{display:flex;flex-direction:column;height:100vh;background:var(--bg-secondary)}.page-body{display:flex;flex:1;padding-top:var(--nav-height)}.page-content{flex:1;display:flex;flex-direction:column;padding:var(--space-5) var(--space-6);overflow-y:auto;min-height:calc(100vh - var(--nav-height));max-width:var(--content-max-width);margin:0 auto;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-5);margin-bottom:var(--space-6);border-bottom:1px solid var(--border-light)}.page-header-left{display:flex;flex-direction:column;gap:var(--space-1)}.page-header-meta{font-size:13px;color:var(--text-tertiary);letter-spacing:0;line-height:1.4}.page-header-actions{display:flex;align-items:center;gap:var(--space-3)}.page-tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border-light);margin-bottom:var(--space-6);padding-bottom:0}.page-tab{padding:var(--space-2) var(--space-4);font-size:14px;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;cursor:pointer;letter-spacing:0;margin-bottom:-1px;transition:all var(--duration-fast) var(--ease-out-quart);background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font-family-base)}.page-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.page-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);font-weight:600}.section-title{font-family:var(--font-family-base);font-size:22px;font-weight:600;line-height:28px;letter-spacing:-.3px;margin-bottom:0;color:var(--text-primary)}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-4{gap:var(--space-1)}.gap-8{gap:var(--space-2)}.gap-12{gap:var(--space-3)}.gap-16{gap:var(--space-4)}.gap-24{gap:var(--space-6)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.mt-4{margin-top:var(--space-1)}.mt-8{margin-top:var(--space-2)}.mt-12{margin-top:var(--space-3)}.mt-16{margin-top:var(--space-4)}.mt-24{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-1)}.mb-8{margin-bottom:var(--space-2)}.mb-16{margin-bottom:var(--space-4)}.mb-24{margin-bottom:var(--space-6)}.p-16{padding:var(--space-4)}.p-24{padding:var(--space-6)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-primary-color{color:var(--primary-500)}.text-right{text-align:right}.text-center{text-align:center}.font-mono{font-family:var(--font-family-mono)}.font-number{font-family:var(--font-family-number);font-variant-numeric:tabular-nums}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link{color:var(--primary-600);text-decoration:none;cursor:pointer;transition:color var(--duration-fast) var(--ease-out-quart)}.link:hover{color:var(--primary-700);text-decoration:underline}.divider{height:1px;background:var(--border-light);margin:var(--space-4) 0}.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:#ffffffe0;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-light);display:flex;align-items:center;padding:0 var(--space-8);gap:var(--space-8);z-index:1001}.sidebar{width:var(--sidebar-width);background:var(--bg-elevated);border-right:1px solid var(--border-light);padding:var(--space-4) var(--space-3);flex-shrink:0;overflow-y:auto;max-height:calc(100vh - var(--nav-height))}.sidebar-title{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-tertiary);padding:var(--space-2) var(--space-3) var(--space-1)}.sidebar-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-base);font-size:14px;font-weight:500;letter-spacing:0;color:var(--text-primary);cursor:pointer;text-decoration:none;transition:all var(--duration-fast) var(--ease-out-quart)}.sidebar-item:hover{background:var(--bg-secondary)}.sidebar-item.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}.sidebar-icon{font-size:18px;width:20px;text-align:center}.card{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-2);padding:var(--space-6);transition:all var(--duration-base) var(--ease-out-quart)}.card:hover{box-shadow:var(--shadow-3);transform:translateY(-2px)}.card-sm{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-1);padding:var(--space-4) var(--space-5)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-family:var(--font-family-base);font-size:18px;font-weight:600;line-height:24px;letter-spacing:-.2px;color:var(--text-primary)}.kpi-card{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-2);padding:var(--space-5) var(--space-6);transition:all var(--duration-base) var(--ease-out-quart)}.kpi-card:hover{box-shadow:var(--shadow-3);transform:translateY(-2px)}.kpi-label{font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:0;margin-bottom:var(--space-1)}.kpi-value{font-family:var(--font-family-base);font-size:36px;font-weight:700;line-height:44px;letter-spacing:-.5px;color:var(--text-primary)}.kpi-unit{font-size:18px;font-weight:400;margin-left:var(--space-1);color:var(--text-secondary)}.kpi-sub{font-size:12px;color:var(--text-tertiary);margin-top:var(--space-1)}.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4)}.kpi-card-v2{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-2);padding:var(--space-5) var(--space-5) var(--space-4);display:flex;flex-direction:column;gap:0;transition:all var(--duration-base) var(--ease-out-quart)}.kpi-card-v2:hover{box-shadow:var(--shadow-3);transform:translateY(-2px)}.kpi-card-v2.kpi-future{opacity:.42;pointer-events:none}.kpi-v2-label{font-size:12px;font-weight:500;letter-spacing:.2px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:var(--space-3)}.kpi-v2-primary{display:flex;align-items:baseline;gap:var(--space-1);margin-bottom:var(--space-1);line-height:1}.kpi-v2-number{font-family:var(--font-family-base);font-size:34px;font-weight:700;letter-spacing:-1px;color:var(--text-primary)}.kpi-v2-unit{font-size:15px;font-weight:400;color:var(--text-secondary)}.kpi-v2-secondary{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:var(--space-3);flex:1}.kpi-v2-footer{min-height:20px;display:flex;align-items:center}.kpi-trend{display:inline-flex;align-items:center;font-size:11px;font-weight:500;border-radius:var(--radius-full);padding:2px 9px;white-space:nowrap}.kpi-trend.positive{background:var(--success-bg);color:var(--success-text)}.kpi-trend.negative{background:var(--error-bg);color:var(--error-text)}.kpi-trend.neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.alert-card{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-1);padding:var(--space-5);border-left:4px solid var(--primary-500)}.alert-card--danger{background:var(--error-bg);border-left-color:var(--error-main)}.alert-card--warning{background:var(--warning-bg);border-left-color:var(--warning-main)}.alert-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.alert-card-title-group{display:flex;align-items:center;gap:var(--space-2)}.alert-badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.alert-badge-dot--red{background:var(--error-main);box-shadow:0 0 0 3px #f4433626}.alert-badge-dot--orange{background:var(--warning-main);box-shadow:0 0 0 3px #ff980026}.alert-card-title{font-size:15px;font-weight:600;letter-spacing:-.2px;color:var(--text-primary)}.alert-card-subtitle{font-size:12px;color:var(--text-secondary)}.alert-empty{color:var(--text-tertiary);font-size:13px;padding:var(--space-3) 0;text-align:center}.alert-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px;transition:background-color var(--duration-fast) var(--ease-out-quart)}.alert-item:last-child{border-bottom:none}.alert-item-name{color:var(--text-primary);font-weight:500}.alert-item-meta{color:var(--text-secondary);font-size:12px;margin-top:2px}.alert-item-badge{font-size:12px;font-weight:600;color:var(--primary-600)}.alert-count-pill{font-size:12px;font-weight:700;color:var(--error-text);background:var(--error-bg);border-radius:var(--radius-full);padding:2px 10px}.alert-list{list-style:none;margin:0;padding:0}.alert-item-title{color:var(--text-primary);font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alert-item-time{color:var(--text-tertiary);font-size:12px;flex-shrink:0;margin-left:var(--space-3)}.demo-banner{display:flex;align-items:center;gap:var(--space-2);padding:10px 16px;margin-bottom:var(--space-4);background:var(--warning-bg);border:1px solid var(--warning-main);border-radius:var(--radius-md);font-size:13px;color:var(--warning-text)}.demo-banner-icon{font-size:16px;flex-shrink:0}.data-table-wrap{background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-2);overflow:hidden;border:1px solid var(--border-light)}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.data-table th{background:var(--bg-secondary);font-size:12px;font-weight:600;letter-spacing:0;color:var(--text-secondary);padding:12px var(--space-4);text-align:left;border-bottom:1px solid var(--border-medium);white-space:nowrap}.data-table td{padding:14px var(--space-4);border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background-color var(--duration-fast) var(--ease-out-quart)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table .col-action{text-align:right;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:modalBackdropEnter var(--duration-base) var(--ease-standard)}.modal{background:var(--bg-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-6);width:560px;max-width:calc(100vw - 48px);max-height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:hidden;animation:modalEnter var(--duration-slow) var(--ease-out-expo)}.modal-sm{width:400px}.modal-lg{width:760px}.modal-xl{width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-4);border-bottom:1px solid var(--border-light)}.modal-title{font-size:18px;font-weight:600;line-height:24px;letter-spacing:-.2px;color:var(--text-primary)}.modal-close{width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out-quart)}.modal-close:hover{background:var(--border-medium);color:var(--text-primary)}.modal-close:active{transform:scale(.95)}.modal-body{padding:var(--space-5) var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:var(--space-3)}.filter-bar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.search-input-wrap{position:relative;flex:1;min-width:240px;max-width:400px}.search-input{width:100%;background:var(--bg-secondary);border:1.5px solid var(--border-light);border-radius:var(--radius-full);padding:8px 36px 8px 38px;font-size:14px;letter-spacing:0;color:var(--text-primary);outline:none;font-family:var(--font-family-base);transition:all var(--duration-base) var(--ease-out-quart)}.search-input:hover{border-color:var(--border-medium)}.search-input:focus{border-color:var(--primary-500);background:var(--bg-elevated);box-shadow:0 0 0 3px var(--primary-50)}.search-input::placeholder{color:var(--text-tertiary)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:16px;pointer-events:none}.search-icon-pi{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:14px;pointer-events:none}.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:13px;cursor:pointer;padding:4px;border-radius:50%;transition:all var(--duration-fast) var(--ease-out-quart)}.search-clear:hover{color:var(--text-primary);background:var(--bg-tertiary)}.filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}.quarter-bar{display:flex;align-items:center}.quarter-switcher{display:inline-flex;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-1);gap:2px}.quarter-btn{display:flex;flex-direction:column;align-items:center;padding:7px 22px;border-radius:var(--radius-base);border:none;background:transparent;cursor:pointer;font-family:var(--font-family-base);transition:all var(--duration-fast) var(--ease-out-quart);gap:2px}.quarter-btn:hover{background:#ffffffb3}.quarter-btn.active{background:var(--bg-elevated);box-shadow:var(--shadow-1),0 0 0 1px var(--border-light)}.quarter-btn-label{font-size:14px;font-weight:600;letter-spacing:-.2px;color:var(--text-primary);line-height:1}.quarter-btn-range{font-size:11px;color:var(--text-tertiary);line-height:1}.quarter-btn.active .quarter-btn-label{color:var(--primary-600)}.quarter-btn.active .quarter-btn-range{color:var(--primary-400)}.sign-area{background:var(--bg-secondary);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);overflow:hidden;position:relative}.sign-canvas{display:block;cursor:crosshair;touch-action:none}.sign-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;color:var(--text-tertiary);pointer-events:none;transition:opacity var(--duration-fast) var(--ease-out-quart)}.sign-actions{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-light)}.kanban-board{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.kanban-col{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-3);min-height:200px}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.kanban-col-title{font-size:13px;font-weight:600;letter-spacing:-.08px;color:var(--text-primary)}.kanban-count{background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:12px;padding:1px 8px;color:var(--text-secondary)}.kanban-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3) 14px;margin-bottom:var(--space-2);box-shadow:var(--shadow-1);cursor:pointer;transition:all var(--duration-fast) var(--ease-out-quart)}.kanban-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-3)}.kanban-card-id{font-size:11px;color:var(--text-tertiary);margin-bottom:4px}.kanban-card-device{font-size:13px;font-weight:500;margin-bottom:4px;color:var(--text-primary)}.kanban-card-meta{font-size:12px;color:var(--text-secondary)}.kanban-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-light);border-radius:var(--radius-md);overflow:hidden}.kanban-summary-col{background:var(--bg-elevated);padding:var(--space-5) var(--space-6);text-align:center;cursor:pointer;transition:background var(--duration-fast) var(--ease-out-quart)}.kanban-summary-col:hover{background:var(--bg-secondary)}.kanban-summary-count{font-family:var(--font-family-base);font-size:40px;font-weight:700;letter-spacing:-1px;color:var(--text-primary);line-height:1;margin-bottom:6px}.kanban-summary-label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.kanban-summary-hint{font-size:11px;color:var(--text-tertiary)}.page-title{font-family:var(--font-family-base);font-size:22px;font-weight:700;letter-spacing:-.3px;color:var(--text-primary);margin:0}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-left:var(--space-3)}.list-group{display:flex;flex-direction:column}.list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-light);transition:background-color var(--duration-fast) var(--ease-out-quart)}.list-item:last-child{border-bottom:none}.list-item-main{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex:1}.list-item-id{font-size:12px;font-weight:600;color:var(--primary-600);white-space:nowrap}.list-item-text{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-end{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;margin-left:var(--space-3)}.list-item-time{font-size:12px;color:var(--text-tertiary)}.list-item-meta{font-size:12px;color:var(--text-secondary)}.status-tag{display:inline-flex;align-items:center;font-size:12px;font-weight:500;padding:2px 10px;border-radius:var(--radius-full);white-space:nowrap}.status-tag--info{background:var(--primary-50);color:var(--primary-600)}.status-tag--success{background:var(--success-bg);color:var(--success-text)}.status-tag--warning{background:var(--warning-bg);color:var(--warning-text)}.status-tag--danger{background:var(--error-bg);color:var(--error-text)}.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.alert-dot--danger{background:var(--error-main)}.alert-dot--warning{background:var(--warning-main)}.alert-dot--info{background:var(--primary-500)}.card-action-link{font-size:12px;font-weight:500;color:var(--primary-600);text-decoration:none;transition:color var(--duration-fast) var(--ease-out-quart)}.card-action-link:hover{color:var(--primary-700);text-decoration:underline}.link-primary{color:var(--primary-600);text-decoration:none;font-weight:500}.link-primary:hover{color:var(--primary-700);text-decoration:underline}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-tertiary);font-size:14px}.mb-20{margin-bottom:var(--space-5)}mark.search-hl{background:#fff176;padding:0 1px;border-radius:2px;color:inherit;font-weight:600}:root{--p-primary-50: var(--primary-50);--p-primary-100: var(--primary-100);--p-primary-200: var(--primary-200);--p-primary-300: var(--primary-300);--p-primary-400: var(--primary-400);--p-primary-500: var(--primary-500);--p-primary-600: var(--primary-600);--p-primary-700: var(--primary-700);--p-primary-800: var(--primary-800);--p-primary-900: var(--primary-900);--p-primary-color: var(--primary-500);--p-primary-contrast-color: #ffffff;--p-text-color: var(--text-primary);--p-text-muted-color: var(--text-secondary);--p-surface-0: var(--bg-primary);--p-surface-50: var(--bg-secondary);--p-surface-100: var(--bg-tertiary);--p-surface-200: #e9ecef;--p-surface-300: #dee2e6;--p-surface-400: #ced4da;--p-surface-500: #adb5bd;--p-surface-600: #6c757d;--p-surface-700: #495057;--p-surface-800: #343a40;--p-surface-900: #212529;--p-content-border-color: var(--border-light);--p-content-hover-background: var(--bg-secondary);--p-border-radius: 8px}.p-button{border-radius:8px;font-family:var(--font-family-base);font-size:13px;font-weight:500;transition:all .15s ease}.p-button:not(.p-button-secondary):not(.p-button-success):not(.p-button-warn):not(.p-button-danger):not(.p-button-text):not(.p-button-outlined){background:var(--primary-500);border-color:var(--primary-500)}.p-button:not(.p-button-secondary):not(.p-button-success):not(.p-button-warn):not(.p-button-danger):not(.p-button-text):not(.p-button-outlined):hover{background:var(--primary-600);border-color:var(--primary-600)}.p-inputtext{border-radius:8px;border-color:var(--border-medium);font-family:var(--font-family-base);font-size:13px}.p-inputtext:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #2196f31a}.p-select{border-radius:var(--radius-base, 8px);border:1.5px solid var(--border-medium);background:var(--bg-primary);font-size:14px;min-height:40px;transition:all var(--duration-base) var(--ease-out-quart)}.p-select:hover{border-color:var(--border-strong)}.p-select.p-focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.p-select .p-select-label{padding:8px 12px;font-size:14px;color:var(--text-primary)}.p-select .p-select-label.p-placeholder{color:var(--text-tertiary)}.form-group .p-select{width:100%}.p-datatable{display:flex;flex-direction:column;flex:1;min-height:0}.p-datatable .p-datatable-header{background:var(--bg-secondary);border:none;padding:12px 16px}.p-datatable .p-datatable-thead>tr>th,.p-datatable.p-datatable-gridlines .p-datatable-thead>tr>th{background:#f0f2f5!important;color:var(--text-primary);font-size:13px;font-weight:600;letter-spacing:.2px;border-color:var(--border-light);padding:12px 16px}.p-datatable .p-datatable-tbody>tr>td{font-size:13px;padding:10px 16px;border-color:var(--border-light)}.p-datatable .p-datatable-tbody>tr:hover{background:var(--bg-secondary)}.p-datatable .p-datatable-table-container{flex:1;overflow-y:auto}.p-datatable .p-datatable-empty-message td{height:400px;text-align:center;vertical-align:middle;color:var(--text-tertiary);font-size:14px}.p-toolbar{background:var(--bg-primary);border:1px solid var(--primary-100);border-radius:8px;padding:12px 16px;flex-shrink:0}.p-toolbar .p-toolbar-end .p-button,.p-toolbar .p-toolbar-start .p-button{margin-left:8px}.p-toolbar .p-toolbar-end .p-button:first-child,.p-toolbar .p-toolbar-start .p-button:first-child{margin-left:0}.p-dialog{border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-5);max-height:calc(100vh - 80px)}.p-dialog .p-dialog-header{padding:18px 24px;border-bottom:1px solid var(--border-light);font-size:16px;font-weight:600}.p-dialog .p-dialog-content{padding:24px;overflow-y:auto}.p-dialog .p-dialog-content .form-group{margin-bottom:16px}.p-dialog .p-dialog-content .form-group:last-child{margin-bottom:0}.p-dialog .p-dialog-content .form-row{margin-bottom:16px}.p-dialog .p-dialog-content .form-row:last-child{margin-bottom:0}.p-dialog .p-dialog-footer{padding:14px 24px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:8px}.p-tag{border-radius:6px;font-size:12px;font-weight:500;padding:3px 8px}.p-toast .p-toast-message{border-radius:10px;box-shadow:var(--shadow-4)}.p-tooltip .p-tooltip-text{border-radius:6px;font-size:12px}.p-card{border-radius:12px;box-shadow:var(--shadow-2);border:1px solid var(--border-light)}.p-paginator{font-size:13px;border:none;padding:8px 0;margin-bottom:20px;flex-shrink:0}@media print{.navbar,.sidebar,.btn,.filter-bar,.page-tabs,.no-print{display:none!important}.page-body{padding-top:0}.page-content{height:auto;overflow:visible;padding:0}.card,.card-sm{box-shadow:none;border:1px solid #ddd;break-inside:avoid}.data-table{font-size:12px}.data-table th,.data-table td{padding:6px 10px}body{background:#fff;color:#000;font-size:12px}}.h5-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg-secondary)}.h5-tabbar{position:fixed;bottom:0;left:0;right:0;height:56px;background:#ffffffe0;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:.5px solid var(--border-light);display:flex;align-items:center;justify-content:space-around;z-index:1000}.h5-tab-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;min-width:64px;min-height:44px;justify-content:center;color:var(--text-tertiary);font-size:10px;font-weight:500;transition:color var(--duration-fast) var(--ease-out-quart);-webkit-tap-highlight-color:transparent;cursor:pointer;-webkit-user-select:none;user-select:none}.h5-tab-item.active{color:var(--primary-500)}.h5-tab-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.h5-tab-icon svg{width:22px;height:22px;fill:currentColor}.h5-content{flex:1;overflow-y:auto;padding:var(--space-4);padding-bottom:72px;background:var(--bg-secondary);-webkit-overflow-scrolling:touch}.h5-page-enter-active,.h5-page-leave-active{transition:opacity var(--duration-base) var(--ease-out-quart),transform var(--duration-base) var(--ease-out-quart)}.h5-page-enter-from{opacity:0;transform:translateY(8px)}.h5-page-leave-to{opacity:0;transform:translateY(-4px)}.ios-group{background:var(--bg-elevated);border-radius:var(--radius-md);margin:0 0 var(--space-4);overflow:hidden;box-shadow:var(--shadow-1)}.ios-group-title{font-size:13px;font-weight:400;color:var(--text-tertiary);padding:var(--space-3) var(--space-4) var(--space-1)}.ios-group-item{display:flex;align-items:center;min-height:44px;padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-light);gap:var(--space-3)}.ios-group-item:last-child{border-bottom:none}.ios-group-item-label{flex:1;font-size:15px;color:var(--text-primary)}.ios-group-item-value{font-size:15px;color:var(--text-tertiary)}.ios-group-item-arrow{width:7px;height:12px;color:var(--text-disabled)}.h5-segmented{display:flex;background:var(--bg-tertiary);border-radius:var(--radius-base);padding:2px}.h5-segmented-item{flex:1;text-align:center;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);border:none;background:transparent;cursor:pointer;transition:all var(--duration-fast) var(--ease-out-quart);-webkit-tap-highlight-color:transparent}.h5-segmented-item.active{background:var(--bg-elevated);color:var(--primary-600);box-shadow:var(--shadow-1)}.h5-fab{position:fixed;bottom:76px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--primary-500);color:#fff;box-shadow:var(--shadow-4);display:flex;align-items:center;justify-content:center;font-size:24px;border:none;cursor:pointer;z-index:900;transition:transform var(--duration-fast) var(--ease-out-quart),box-shadow var(--duration-fast) var(--ease-out-quart);-webkit-tap-highlight-color:transparent}.h5-fab:active{transform:scale(.92);box-shadow:var(--shadow-2)}.h5-fab svg{width:24px;height:24px;fill:currentColor}.h5-sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-secondary);z-index:1100;display:flex;flex-direction:column}.h5-sheet-enter-active{animation:sheetSlideUp var(--duration-slow) var(--ease-out-expo)}.h5-sheet-leave-active{animation:sheetSlideDown var(--duration-base) var(--ease-in-out)}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.h5-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--bg-elevated);border-bottom:.5px solid var(--border-light);flex-shrink:0}.h5-sheet-title{font-size:17px;font-weight:600;color:var(--text-primary)}.h5-sheet-body{flex:1;overflow-y:auto;padding:var(--space-4);-webkit-overflow-scrolling:touch}.h5-form-group{margin-bottom:var(--space-4)}.h5-form-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-1);padding-left:var(--space-1)}.h5-form-input{width:100%;min-height:44px;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-base);font-size:15px;color:var(--text-primary);box-sizing:border-box;transition:border-color var(--duration-fast)}.h5-form-input:focus{outline:none;border-color:var(--primary-400)}.h5-form-input::placeholder{color:var(--text-disabled)}.h5-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-1)}.h5-card-title{font-size:13px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:var(--space-3)}.h5-progress-bar{height:3px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;margin:var(--space-4) 0}.h5-progress-fill{height:100%;background:var(--primary-500);border-radius:2px;transition:width var(--duration-slow) var(--ease-out-expo)}.h5-btn-block{display:flex;align-items:center;justify-content:center;width:100%;min-height:50px;border-radius:var(--radius-md);font-size:16px;font-weight:600;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-fast),transform var(--duration-fast)}.h5-btn-block:active{transform:scale(.98)}.h5-btn-block--primary{background:var(--primary-500);color:#fff}.h5-btn-block--primary:disabled{background:var(--primary-200);cursor:not-allowed}.h5-btn-block--secondary{background:var(--bg-elevated);color:var(--primary-600);border:1px solid var(--border-medium)}.h5-pill-bar{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.h5-pill-bar::-webkit-scrollbar{display:none}.h5-pill{flex-shrink:0;padding:6px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;border:1px solid var(--border-medium);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--duration-fast) var(--ease-out-quart);-webkit-tap-highlight-color:transparent}.h5-pill.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.h5-record-item{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-1);display:flex;align-items:center;gap:var(--space-3)}.h5-record-meta{flex:1;min-width:0}.h5-record-time{font-size:12px;color:var(--text-tertiary)}.h5-record-value{font-size:15px;font-weight:600;color:var(--text-primary);margin-top:2px}.h5-record-sub{font-size:12px;color:var(--text-tertiary);margin-top:2px}.h5-chart-wrap{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:var(--shadow-1)}.h5-chart-area{width:100%;height:280px}.h5-layout .btn,.h5-layout button{min-height:44px}.h5-profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--primary-100);color:var(--primary-700);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.h5-empty{text-align:center;padding:60px var(--space-4);color:var(--text-tertiary);font-size:14px}@supports not (backdrop-filter: blur(1px)){.h5-tabbar{background:#fffffff5}}
