:root{--color-primary: #4a90e2;--color-primary-light: #e6f0fd;--color-primary-dark: #2c6db5;--color-primary-bg: #c8dff8;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-dark: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-dark: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #991b1b;--color-info: #38bdf8;--color-info-light: #e0f2fe;--color-info-dark: #0c4a6e;--color-purple: #8b5cf6;--color-purple-light: #f5f3ff;--color-accent-gold: #f59e0b;--color-mismatch: #e91e8c;--color-success-mid: #86efac;--color-success-text: #064e3b;--color-danger-mid: #fca5a5;--color-danger-text: #7f1d1d;--color-info-mid: #7dd3fc;--color-info-text: #0c4a6e;--color-white: #ffffff;--color-gray-50: #f0f6ff;--color-gray-100: #e4eeff;--color-gray-200: #d1e2f8;--color-gray-300: #a8c4e8;--color-gray-400: #7aa3d0;--color-gray-500: #5580a8;--color-gray-600: #3d6080;--color-gray-700: #2a4560;--color-gray-800: #1a2d48;--color-gray-900: #0f1e30;--text-primary: #1a2d48;--text-secondary: #4a6a8a;--text-muted: #7aa3c0;--text-inverse: #ffffff;--bg-page: rgba(235,246,255,.55);--bg-card: rgba(255,255,255,.82);--bg-hover: rgba(255,255,255,.95);--border-color: rgba(74,144,226,.2);--border-light: rgba(74,144,226,.1);--sidebar-bg: #1a3360;--sidebar-hover: rgba(74,144,226,.22);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 20px;--shadow-sm: 0 2px 8px rgba(74,144,226,.1);--shadow-md: 0 4px 20px rgba(74,144,226,.16);--shadow-lg: 0 8px 40px rgba(74,144,226,.22);--card-blur: blur(12px) saturate(1.4);--card-blur-heavy: blur(20px) saturate(1.6);--font-xs: 11px;--font-sm: 12px;--font-base: 13px;--font-md: 14px;--font-lg: 16px;--font-xl: 20px;--font-2xl: 26px;--el-color-primary: #4a90e2;--el-color-primary-light-3: #7aaee8;--el-color-primary-light-5: #a4c5ef;--el-color-primary-light-7: #c8dcf5;--el-color-primary-light-8: #d8e9f8;--el-color-primary-light-9: #e6f0fd;--el-color-primary-dark-2: #2c6db5;--el-color-success: #10b981;--el-color-success-light-9: #d1fae5;--el-color-warning: #f59e0b;--el-color-warning-light-9: #fef3c7;--el-color-danger: #ef4444;--el-color-danger-light-9: #fee2e2;--el-color-info: #38bdf8;--el-border-radius-base: 8px}html.dark,:root[data-theme=dark]{--color-primary: #87b5ff;--color-primary-dark: #5a8de0;--color-primary-light: #162644;--color-primary-bg: #1e3a6e;--color-accent-gold: #ffc547;--color-success-light: #064e3b;--color-success-dark: #a7f3d0;--color-warning-light: #78350f;--color-warning-dark: #fcd34d;--color-danger-light: #7f1d1d;--color-danger-dark: #fca5a5;--color-info-light: #0c4a6e;--color-info-dark: #bae6fd;--color-gray-50: #1a2844;--color-gray-100: #1e3050;--color-gray-200: #243860;--color-gray-300: #2e4a78;--color-gray-400: #4a6a98;--color-gray-500: #6888b8;--text-primary: #e8f0fe;--text-secondary: #9ab0d0;--text-muted: #5a7898;--text-inverse: #0a1628;--bg-page: #0a1628;--bg-card: rgba(20,38,72,.8);--bg-hover: rgba(30,55,100,.7);--border-color: rgba(135,181,255,.15);--border-light: rgba(135,181,255,.08);--sidebar-bg: #0d1829;--sidebar-hover: rgba(135,181,255,.14);--shadow-sm: 0 2px 8px rgba(0,0,0,.4);--shadow-md: 0 4px 20px rgba(0,0,0,.55);--shadow-lg: 0 8px 40px rgba(0,0,0,.65);--el-color-primary: #87b5ff;--el-color-primary-light-3: #a5c6ff;--el-color-primary-light-5: #b8d3ff;--el-color-primary-light-7: #cce0ff;--el-color-primary-light-8: #d9e9ff;--el-color-primary-light-9: #e6f0ff;--el-color-primary-dark-2: #5a8de0}html.dark body{background:var(--bg-page);color:var(--text-primary)}@media print{body{background:#fff!important}.sidebar,.main-header,.mobile-overlay,.mobile-sidebar,.offline-banner,.cp-overlay,.filter-bar,.el-pagination,.table-card .top-scrollbar,.el-button{display:none!important}.main-content{padding:0!important;overflow:visible!important}.el-main{padding:0!important}.el-table{font-size:11px!important}.table-card{border:none!important;box-shadow:none!important}.el-card{box-shadow:none!important;border:1px solid #ddd!important}*{color:#000!important;background:transparent!important}}.el-overlay-dialog .el-dialog{animation:dialog-pop .22s cubic-bezier(.34,1.4,.6,1) both}@keyframes dialog-pop{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.el-button:active:not(.is-disabled){transform:scale(.97)}.el-button{transition:transform .08s ease,background-color .15s,border-color .15s,color .15s}.el-message{border-radius:var(--radius-pill)!important;padding:10px 18px!important;box-shadow:var(--shadow-md)!important;border:1px solid var(--border-color)!important;min-width:auto!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.el-message__content{font-size:var(--font-base)!important}.el-notification{border-radius:var(--radius-lg)!important;border:1px solid var(--border-color)!important;box-shadow:var(--shadow-lg)!important}.el-empty{padding:32px 0}.el-empty__image{opacity:.6}.el-empty__description p{color:var(--text-muted);font-size:var(--font-base);margin-top:8px}.profile-dialog{margin-top:5vh!important}.profile-dialog .el-dialog__body{height:min(420px,55vh);overflow-y:auto;padding-top:10px;padding-bottom:10px}.profile-dialog .el-tabs__header{margin-bottom:12px}.is-refreshing{position:relative}.is-refreshing:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--color-primary) 35%,var(--color-primary-dark) 50%,var(--color-primary) 65%,transparent 100%);background-size:200% 100%;animation:refresh-bar 1.2s linear infinite;z-index:10;border-radius:var(--radius-lg) var(--radius-lg) 0 0;pointer-events:none}@keyframes refresh-bar{0%{background-position:200% 0}to{background-position:-200% 0}}.el-table{--el-table-border-color: var(--border-light);--el-table-header-bg-color: transparent;--el-table-row-hover-bg-color: var(--color-primary-light);background:transparent!important}.el-table th.el-table__cell{background:transparent!important;font-weight:600!important;color:var(--text-secondary)!important;border-bottom:1px solid var(--border-color)!important;font-size:var(--font-sm)!important}.el-table td.el-table__cell{border-bottom:1px solid var(--border-light)!important;padding:6px 0!important;background:transparent!important}.el-table tr:hover>td{background:#4a90e212!important}.el-table__inner-wrapper:before{display:none}.el-dialog{border-radius:var(--radius-xl)!important;overflow:hidden;background:var(--bg-card)!important;backdrop-filter:var(--card-blur-heavy)!important;-webkit-backdrop-filter:var(--card-blur-heavy)!important;border:1px solid var(--border-color)!important;box-shadow:var(--shadow-lg)!important}.el-dialog__header{padding:16px 20px!important;border-bottom:1px solid var(--border-light);background:transparent!important}.el-dialog__title{font-weight:700;color:var(--text-primary)}.el-dialog__body{background:transparent!important}.el-dialog__footer{background:transparent!important;border-top:1px solid var(--border-light)}.el-drawer{background:var(--bg-card)!important;backdrop-filter:var(--card-blur-heavy)!important;-webkit-backdrop-filter:var(--card-blur-heavy)!important;border-left:1px solid var(--border-color)!important}.el-drawer__header{border-bottom:1px solid var(--border-light)!important;margin-bottom:0!important;padding:16px 20px!important}.el-drawer__body{background:transparent!important}.el-empty__description{color:var(--text-muted)}.kpi-card,.summary-card,.stat-card{transition:transform .2s ease,box-shadow .2s ease}.kpi-card:hover,.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}html.dark ::-webkit-scrollbar-thumb{background:var(--color-gray-700)}html.dark ::-webkit-scrollbar-thumb:hover{background:var(--color-gray-600)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}.nav-item:focus-visible,.icon-btn:focus-visible,.el-button:focus-visible,.summary-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}.filter-bar{display:flex;flex-wrap:nowrap;gap:var(--space-1) var(--space-2);margin-bottom:var(--space-2);align-items:center;overflow-x:auto}.filter-bar--wrap{flex-wrap:wrap;overflow-x:visible}.table-card{background:var(--bg-card);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm)}.dash-card{background:var(--bg-card);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:18px 20px;box-shadow:var(--shadow-sm)}.summary-card{background:var(--bg-card);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--space-4);box-shadow:var(--shadow-md)}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-lg);font-size:var(--font-xs);font-weight:600;line-height:1.6}.status-pending{background:var(--color-warning-light);color:var(--color-warning-dark)}.status-confirmed{background:var(--color-success-light);color:var(--color-success-dark)}.status-checked_in{background:var(--color-danger-light);color:var(--color-danger-dark)}.status-checked_out{background:var(--color-info-light);color:var(--color-info-dark)}.status-cancelled,.status-no_show{background:var(--color-gray-100);color:var(--color-gray-500)}.status-paid{background:var(--color-success-light);color:var(--color-success-dark)}.status-expired{background:var(--color-gray-100);color:var(--color-gray-500)}.status-approved{background:var(--color-success-light);color:var(--color-success-dark)}.status-rejected{background:var(--color-danger-light);color:var(--color-danger-dark)}.cp-overlay[data-v-936003ab]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3000;display:flex;justify-content:center;padding-top:12vh}.cp-panel[data-v-936003ab]{width:560px;max-width:90vw;max-height:70vh;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 30px 80px #0000004d;display:flex;flex-direction:column;overflow:hidden;animation:cp-pop-936003ab .18s cubic-bezier(.34,1.4,.6,1) both}@keyframes cp-pop-936003ab{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cp-input-wrap[data-v-936003ab]{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-light)}.cp-search-icon[data-v-936003ab]{color:var(--text-muted);font-size:18px}.cp-input[data-v-936003ab]{flex:1;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:var(--font-md)}.cp-hint[data-v-936003ab]{font-size:var(--font-xs);color:var(--text-muted);border:1px solid var(--border-color);border-radius:4px;padding:1px 6px}.cp-loading[data-v-936003ab],.cp-empty[data-v-936003ab]{padding:24px;text-align:center;color:var(--text-muted);font-size:var(--font-base)}.cp-list[data-v-936003ab]{overflow-y:auto;flex:1;padding:4px 0}.cp-group-label[data-v-936003ab]{font-size:var(--font-xs);color:var(--text-muted);padding:8px 16px 4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.cp-item[data-v-936003ab]{display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;transition:background .1s}.cp-item.active[data-v-936003ab],.cp-item[data-v-936003ab]:hover{background:var(--color-primary-light)}.cp-item-icon[data-v-936003ab]{font-size:18px;width:24px;text-align:center}.cp-item-body[data-v-936003ab]{flex:1;min-width:0}.cp-item-title[data-v-936003ab]{color:var(--text-primary);font-size:var(--font-base);font-weight:500}.cp-item-title[data-v-936003ab] mark{background:color-mix(in srgb,var(--color-warning) 30%,transparent);color:inherit;padding:0 2px;border-radius:2px}.cp-item-sub[data-v-936003ab]{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-item-kind[data-v-936003ab]{font-size:var(--font-xs);color:var(--text-muted);border:1px solid var(--border-color);border-radius:var(--radius-pill);padding:1px 8px;flex-shrink:0}.cp-footer[data-v-936003ab]{display:flex;gap:16px;padding:8px 16px;border-top:1px solid var(--border-light);background:var(--bg-page);font-size:var(--font-xs);color:var(--text-muted)}.cp-footer kbd[data-v-936003ab]{font-family:inherit;background:var(--bg-card);border:1px solid var(--border-color);border-radius:3px;padding:1px 5px;font-size:10px;margin-right:4px}.cp-fade-enter-active[data-v-936003ab],.cp-fade-leave-active[data-v-936003ab]{transition:opacity .18s ease}.cp-fade-enter-from[data-v-936003ab],.cp-fade-leave-to[data-v-936003ab]{opacity:0}.shinkai-bg[data-v-eff0367e]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.orb[data-v-eff0367e]{position:absolute;border-radius:50%;pointer-events:none}.orb-1[data-v-eff0367e]{width:700px;height:520px;top:-160px;right:-200px;background:radial-gradient(ellipse,rgba(200,228,255,.65) 0%,transparent 68%);filter:blur(55px);animation:shinkai-float-eff0367e 11s ease-in-out infinite alternate}.orb-2[data-v-eff0367e]{width:520px;height:380px;top:28%;left:-130px;background:radial-gradient(ellipse,rgba(255,255,255,.52) 0%,transparent 68%);filter:blur(48px);animation:shinkai-float-eff0367e 14s ease-in-out 2.5s infinite alternate}.orb-3[data-v-eff0367e]{width:420px;height:300px;bottom:6%;right:5%;background:radial-gradient(ellipse,rgba(180,215,255,.48) 0%,transparent 68%);filter:blur(42px);animation:shinkai-float-eff0367e 9s ease-in-out 5s infinite alternate}html.dark .orb-1[data-v-eff0367e]{background:radial-gradient(ellipse,rgba(74,144,226,.14) 0%,transparent 65%);filter:blur(95px);animation-duration:15s}html.dark .orb-2[data-v-eff0367e]{background:radial-gradient(ellipse,rgba(255,197,71,.09) 0%,transparent 65%);filter:blur(85px);animation-duration:18s}html.dark .orb-3[data-v-eff0367e]{background:radial-gradient(ellipse,rgba(139,92,246,.11) 0%,transparent 65%);filter:blur(75px);animation-duration:13s}.stars[data-v-eff0367e]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;pointer-events:none;background-image:radial-gradient(1px 1px at 8% 6%,rgba(255,255,255,.75) 0%,transparent 100%),radial-gradient(1px 1px at 22% 14%,rgba(255,255,255,.6) 0%,transparent 100%),radial-gradient(1px 1px at 38% 4%,rgba(255,255,255,.8) 0%,transparent 100%),radial-gradient(1px 1px at 55% 10%,rgba(255,255,255,.55) 0%,transparent 100%),radial-gradient(1px 1px at 72% 2%,rgba(255,255,255,.7) 0%,transparent 100%),radial-gradient(1px 1px at 86% 18%,rgba(255,255,255,.65) 0%,transparent 100%),radial-gradient(1px 1px at 12% 28%,rgba(255,255,255,.45) 0%,transparent 100%),radial-gradient(1px 1px at 48% 22%,rgba(255,255,255,.55) 0%,transparent 100%),radial-gradient(1px 1px at 68% 32%,rgba(255,255,255,.6) 0%,transparent 100%),radial-gradient(2px 2px at 92% 38%,rgba(255,230,150,.55) 0%,transparent 100%),radial-gradient(1px 1px at 3% 48%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 28% 52%,rgba(255,255,255,.6) 0%,transparent 100%),radial-gradient(1px 1px at 52% 43%,rgba(255,255,255,.45) 0%,transparent 100%),radial-gradient(2px 2px at 78% 50%,rgba(255,220,130,.5) 0%,transparent 100%),radial-gradient(1px 1px at 96% 58%,rgba(255,255,255,.35) 0%,transparent 100%),radial-gradient(1px 1px at 18% 68%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 42% 63%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(2px 2px at 62% 70%,rgba(255,255,255,.65) 0%,transparent 100%),radial-gradient(1px 1px at 83% 75%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 33% 82%,rgba(255,255,255,.35) 0%,transparent 100%),radial-gradient(1px 1px at 58% 88%,rgba(255,255,255,.45) 0%,transparent 100%),radial-gradient(2px 2px at 76% 90%,rgba(200,220,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 90% 85%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 15% 92%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 45% 96%,rgba(255,255,255,.35) 0%,transparent 100%);transition:opacity .4s ease}html.dark .stars[data-v-eff0367e]{opacity:1}@keyframes shinkai-float-eff0367e{0%{transform:translateY(0) translate(0)}to{transform:translateY(-18px) translate(8px)}}.weather[data-v-21334b3a]{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);background:var(--bg-page);font-size:var(--font-base);cursor:pointer;transition:background .15s;white-space:nowrap}.weather[data-v-21334b3a]:hover{background:var(--color-primary-light)}.w-icon[data-v-21334b3a]{font-size:14px}.w-temp[data-v-21334b3a]{font-weight:700;color:var(--text-primary)}.w-city[data-v-21334b3a]{color:var(--text-muted);font-size:var(--font-xs)}.notif-settings[data-v-825a1557]{font-size:13px}.type-row[data-v-825a1557]{padding:8px 4px;border-bottom:1px solid var(--border-color, #e9ecef)}.type-row[data-v-825a1557]:last-child{border-bottom:none}.type-head[data-v-825a1557]{display:flex;align-items:center;gap:10px}.type-label[data-v-825a1557]{font-weight:500}.type-hint[data-v-825a1557]{color:var(--text-secondary, #909399);font-size:12px}.type-body[data-v-825a1557]{padding:6px 0 4px 50px}.dim-row[data-v-825a1557]{display:flex;align-items:center;gap:8px;margin-top:6px}.dim-label[data-v-825a1557]{width:36px;color:var(--text-secondary, #909399);font-size:12px}.footer[data-v-825a1557]{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color, #e9ecef)}.sound-settings .hint[data-v-71740864]{margin-left:12px;color:var(--text-muted);font-size:12px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Segoe UI,sans-serif;background:linear-gradient(180deg,#c8e4ff,#deeeff 40%,#f0f8ff);background-attachment:fixed}html.dark body{background:#0a1628}:root{--primary: var(--color-primary);--border: var(--border-color)}.page-fade-enter-active,.page-fade-leave-active{transition:opacity .18s ease,transform .18s ease}.page-fade-enter-from{opacity:0;transform:translateY(8px)}.page-fade-leave-to{opacity:0;transform:translateY(-6px)}.sidebar{background:linear-gradient(180deg,#1a3360,#0f1e3d,#091428);display:flex;flex-direction:column;position:relative;box-shadow:4px 0 24px #0000004d;transition:width .25s ease;overflow:hidden;flex-shrink:0}html.dark .sidebar{background:linear-gradient(180deg,#0d1e3a,#081529,#050e1e)}.sidebar-logo{display:flex;align-items:center;gap:8px;padding:14px 10px;border-bottom:1px solid rgba(255,255,255,.07);min-height:52px;overflow:hidden}.logo-icon-wrap{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.logo-text{color:#fff;font-size:16px;font-weight:700;letter-spacing:.5px;white-space:nowrap}.sidebar-nav{flex:1;padding:8px 6px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;color:#fff9;text-decoration:none;font-size:13px;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;min-width:0}.nav-item:hover{background:var(--sidebar-hover);color:#ffffffe6}.nav-item.active{background:var(--primary);color:#fff;font-weight:600}.nav-label{overflow:hidden;white-space:nowrap;flex:1}.nav-icon-wrap{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.nav-badge-num{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;min-width:18px;height:18px;border-radius:9px;padding:0 4px;font-size:10px;font-weight:600;line-height:1;background:#ef4444;color:#fff}.nav-badge-mini{position:absolute;top:-6px;right:-8px;margin-left:0;min-width:14px;height:14px;border-radius:7px;padding:0 3px;font-size:9px;line-height:1;border:1.5px solid var(--sidebar-bg, #1e293b);box-sizing:content-box}@keyframes nav-badge-blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.92)}}.nav-badge-num.blink{animation:nav-badge-blink 1.2s ease-in-out infinite}.nav-divider-line{margin:4px 10px;height:1px;background:#ffffff14}.sidebar-footer{padding:10px 8px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:8px;overflow:hidden}.user-avatar{background:var(--primary)!important;font-size:14px!important;font-weight:700!important;flex-shrink:0}.user-info{overflow:hidden}.user-name{color:#fff;font-size:13px;font-weight:600;white-space:nowrap}.user-role{color:#ffffff73;font-size:11px;margin-top:1px}.logout-btn{background:none;border:none;cursor:pointer;color:#fff6;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0}.logout-btn:hover{color:#fff;background:#ffffff1a}.collapse-btn{position:absolute;bottom:80px;right:-1px;width:20px;height:40px;background:#1e2d47;border:1px solid rgba(255,255,255,.1);border-right:none;border-radius:6px 0 0 6px;color:#ffffff80;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s;z-index:10}.collapsed .collapse-btn{border-radius:0 6px 6px 0;border:1px solid rgba(255,255,255,.1);border-left:none}.collapse-btn:hover{color:#fff;background:var(--primary)}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-fade-enter-active,.overlay-fade-leave-active{transition:opacity .25s ease}.overlay-fade-enter-from,.overlay-fade-leave-to{opacity:0}.mobile-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;background:linear-gradient(180deg,#1a3360,#0f1e3d,#091428);z-index:1000;box-shadow:4px 0 24px #0006;display:flex;flex-direction:column;overflow:hidden}html.dark .mobile-sidebar{background:linear-gradient(180deg,#0d1e3a,#081529,#050e1e)}.drawer-slide-enter-active,.drawer-slide-leave-active{transition:transform .28s cubic-bezier(.4,0,.2,1)}.drawer-slide-enter-from,.drawer-slide-leave-to{transform:translate(-100%)}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;background:none;border:none;cursor:pointer;border-radius:6px;transition:background .15s;margin-right:10px}.hamburger-btn:hover{background:var(--bg-page)}.ham-line{display:block;width:20px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .25s,opacity .25s;transform-origin:center}.ham-line:nth-child(1).open{transform:translateY(7px) rotate(45deg)}.ham-line:nth-child(2).open{opacity:0}.ham-line:nth-child(3).open{transform:translateY(-7px) rotate(-45deg)}.main-header{background:#ffffffbf!important;backdrop-filter:blur(14px) saturate(1.5);-webkit-backdrop-filter:blur(14px) saturate(1.5);border-bottom:1px solid rgba(74,144,226,.15)!important;display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:48px!important;box-shadow:0 1px 12px #4a90e214;flex-shrink:0;transition:background .3s ease,border-color .3s ease}html.dark .main-header{background:#0a1628d1!important;border-bottom-color:#87b5ff1f!important;box-shadow:0 1px 12px #0000004d}.header-left{display:flex;align-items:center}.header-breadcrumb{font-size:16px;font-weight:600;color:var(--text-primary)}.staff-online-status{margin-left:10px;font-size:14px;cursor:pointer;padding:4px 8px;border-radius:4px}.staff-online-status:hover{background:#0000000a}.staff-online-status.status-online{color:#22c55e}.staff-online-status.status-offline{color:#94a3b8}.header-right{display:flex;align-items:center;gap:12px}.header-user{display:flex;align-items:center;font-size:13px;color:var(--text-muted);white-space:nowrap}.header-date{font-size:13px;color:var(--text-muted);white-space:nowrap}.header-divider{width:1px;height:18px;background:var(--border)}.icon-btn{border:1px solid var(--border)!important;color:var(--text-muted)!important}.header-action{position:relative;display:inline-flex;line-height:0;text-decoration:none}.header-badge{position:absolute;top:-5px;right:-6px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:600;line-height:16px;text-align:center;border:1.5px solid var(--bg-page);pointer-events:none;box-sizing:content-box}.header-badge.blink{animation:nav-badge-blink 1.2s ease-in-out infinite}.main-content{background:transparent!important;padding:16px 20px!important;overflow-y:auto;flex:1}.notif-popover{padding:0!important;border-radius:12px!important;overflow:hidden;box-shadow:0 8px 30px #0000001f!important}.notif-panel{display:flex;flex-direction:column;max-height:440px}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border-light)}.notif-tabs{display:flex;gap:16px}.notif-tab{font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;padding-bottom:4px;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.notif-tab.active{color:var(--text-primary);border-bottom-color:var(--primary)}.notif-tab:hover{color:var(--text-primary)}.notif-delete{display:flex;align-items:center}.notif-delete:hover{color:var(--color-danger)}.notif-empty{padding:20px 0}.notif-list{overflow-y:auto;flex:1}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-gray-50)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-hover)}.notif-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.dot-success{background:#22c55e}.dot-danger{background:#ef4444}.dot-warning{background:#f59e0b}.dot-primary{background:#2563eb}.dot-info{background:#06b6d4}.notif-body{flex:1;min-width:0}.notif-item-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.notif-item-title{font-size:13px;font-weight:600;color:var(--text-primary)}.notif-item-date{font-size:11px;color:var(--text-muted);white-space:nowrap;margin-left:8px}.notif-item-desc{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-close{font-size:18px;color:var(--text-muted);cursor:pointer;flex-shrink:0;line-height:1;padding:2px 4px;margin-top:2px;transition:color .15s}.notif-close:hover{color:var(--color-danger)}.notif-clear{margin-left:auto;font-size:12px;color:var(--text-muted);cursor:pointer;transition:color .15s}.notif-clear:hover{color:var(--color-danger)}.offline-banner{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--color-danger);color:#fff;padding:8px 16px;border-radius:var(--radius-pill);font-size:var(--font-base);font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-lg);z-index:4000}.offline-slide-enter-active,.offline-slide-leave-active{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .2s}.offline-slide-enter-from,.offline-slide-leave-to{transform:translate(-50%,-120%);opacity:0}@media (max-width: 767px){.main-content{padding:12px!important}.el-table{font-size:12px!important}.el-dialog{width:92vw!important;margin:0 auto}.el-dialog__body{padding:16px!important}.el-form-item__label{min-width:70px!important}.main-header{padding:0 10px}.header-breadcrumb{font-size:14px}.header-right{gap:6px}.filter-bar{flex-wrap:wrap!important;overflow-x:visible!important}.filter-bar>*{min-width:0}.kpi-card{padding:14px!important}.kpi-value{font-size:22px!important}.kpi-spark{display:none!important}.el-table th.el-table__cell{padding:4px 0!important;font-size:11px!important}.el-table td.el-table__cell{padding:4px 0!important}.cp-panel{width:100vw!important;max-width:100vw!important;border-radius:0!important}}.sparkline[data-v-bacacf52]{display:block;overflow:visible}.kpi-card[data-v-75ce0147]{background:var(--bg-card);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}.kpi-card[data-v-75ce0147]:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.kpi-card[data-v-75ce0147]:after{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--accent);border-radius:12px 0 0 12px}.kpi-icon-wrap[data-v-75ce0147]{width:50px;height:50px;border-radius:var(--radius-lg);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-value[data-v-75ce0147]{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}.kpi-label[data-v-75ce0147]{font-size:var(--font-base);color:var(--text-secondary);margin-top:5px}.kpi-body[data-v-75ce0147]{flex:1;min-width:0}.kpi-spark[data-v-75ce0147]{align-self:center;opacity:.85;flex-shrink:0;transition:opacity .2s}.kpi-card:hover .kpi-spark[data-v-75ce0147]{opacity:1}.chart-card[data-v-75ce0147]{background:var(--bg-card);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:18px 20px;height:100%}.chart-header[data-v-75ce0147]{display:flex;align-items:center;gap:10px;margin-bottom:14px}.chart-tabs[data-v-75ce0147]{display:flex;gap:0;background:var(--bg-page);border-radius:var(--radius-sm);padding:2px}.chart-tab[data-v-75ce0147]{font-size:var(--font-base);padding:4px 14px;border-radius:5px;cursor:pointer;color:var(--text-secondary);transition:all .2s;-webkit-user-select:none;user-select:none}.chart-tab.active[data-v-75ce0147]{background:var(--bg-card);color:var(--text-primary);font-weight:600;box-shadow:0 1px 3px #00000014}.chart-total[data-v-75ce0147]{font-size:20px;font-weight:700;color:var(--color-primary);margin-left:auto}.chart-body[data-v-75ce0147]{height:220px}.reg-tip[data-v-0b3972a3]{text-align:center;font-size:var(--font-sm);color:var(--text-muted);margin-top:10px}.login-page[data-v-25e80b01]{min-height:100vh;background:linear-gradient(150deg,#0a1628,#0f1e42 35%,#162850 60%,#1a3264);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-bg-blob[data-v-25e80b01]{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:blob-float-25e80b01 18s ease-in-out infinite}.blob-1[data-v-25e80b01]{width:500px;height:500px;background:radial-gradient(circle,rgba(74,144,226,.35) 0%,transparent 70%);top:-160px;left:-120px;opacity:1}.blob-2[data-v-25e80b01]{width:420px;height:420px;background:radial-gradient(circle,rgba(139,92,246,.25) 0%,transparent 70%);bottom:-160px;right:-100px;animation-delay:-6s}.blob-3[data-v-25e80b01]{width:320px;height:320px;background:radial-gradient(circle,rgba(255,197,71,.18) 0%,transparent 70%);top:35%;left:58%;opacity:1;filter:blur(60px);animation-delay:-12s}@keyframes blob-float-25e80b01{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.08)}66%{transform:translate(-25px,15px) scale(.95)}}.login-card[data-v-25e80b01]{position:relative;z-index:1;background:#ffffff17;backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1px solid rgba(135,181,255,.25);border-radius:24px;padding:40px 36px 32px;width:100%;max-width:400px;box-shadow:0 30px 80px #00000080,0 0 60px #4a90e21f}.login-logo[data-v-25e80b01]{text-align:center;margin-bottom:28px}.logo-icon[data-v-25e80b01]{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;margin-bottom:12px;font-size:32px;background:linear-gradient(135deg,#4a90e2,#2c6db5);border-radius:18px;box-shadow:0 8px 24px #4a90e273,0 0 30px #4a90e233}.login-title[data-v-25e80b01]{margin:0;font-size:24px;font-weight:700;color:#e8f0fe;letter-spacing:.5px;text-shadow:0 0 20px rgba(135,181,255,.4)}.login-sub[data-v-25e80b01]{margin:4px 0 0;color:#9bb9dccc;font-size:var(--font-base)}.login-tabs[data-v-25e80b01] .el-tabs__header{margin-bottom:20px}.login-tabs[data-v-25e80b01] .el-tabs__nav-wrap:after{height:1px;background:#87b5ff26}.login-tabs[data-v-25e80b01] .el-tabs__item{color:#9bb9dcb3!important}.login-tabs[data-v-25e80b01] .el-tabs__item.is-active{color:#87b5ff!important}.login-tabs[data-v-25e80b01] .el-tabs__active-bar{background:#87b5ff!important}.reg-tip[data-v-25e80b01]{text-align:center;font-size:var(--font-sm);color:#9bb9dc99;margin-top:10px}
