@import "https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;600;700&display=swap";.tour-progress-bar[data-v-d81f961d]{background:#e5e7eb;border-radius:99px;height:3px;overflow:hidden}.tour-progress-fill[data-v-d81f961d]{background:var(--primary,#ea580c);border-radius:99px;height:100%;transition:width .4s}.tour-step-count[data-v-d81f961d]{color:#9ca3af;text-align:center;margin-top:6px;font-size:12px}.tour-btn-next[data-v-d81f961d]{background:var(--primary,#ea580c);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:700;transition:opacity .15s}.tour-btn-next[data-v-d81f961d]:hover{opacity:.85}.tour-btn-skip[data-v-d81f961d]{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:8px;padding:8px 14px;font-size:13px;transition:background .15s}.tour-btn-skip[data-v-d81f961d]:hover{background:#f3f4f6}.tour-btn-prev[data-v-d81f961d]{color:#374151;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:8px;padding:7px 12px;font-size:13px}.tour-btn-prev[data-v-d81f961d]:hover{background:#f3f4f6}.tour-backdrop[data-v-d81f961d]{z-index:10000;background:#000000a6;justify-content:center;align-items:center;animation:.25s tour-fade-in-d81f961d;display:flex;position:fixed;inset:0}.tour-modal[data-v-d81f961d]{text-align:center;background:#fff;border-radius:20px;width:calc(100vw - 40px);max-width:440px;padding:40px 36px 32px;animation:.3s cubic-bezier(.34,1.56,.64,1) tour-slide-up-d81f961d;box-shadow:0 24px 60px #00000040}.tour-modal-emoji[data-v-d81f961d]{margin-bottom:12px;font-size:48px}.tour-modal-title[data-v-d81f961d]{color:#111827;margin-bottom:12px;font-size:22px;font-weight:900}.tour-modal-desc[data-v-d81f961d]{color:#6b7280;margin-bottom:24px;font-size:15px;line-height:1.7}.tour-modal-actions[data-v-d81f961d]{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:20px;display:flex}.tour-btn-cta[data-v-d81f961d]{color:#fff;cursor:pointer;background:#06c755;border-radius:10px;margin:0 auto 12px;padding:12px 24px;font-size:15px;font-weight:700;text-decoration:none;transition:opacity .15s;display:block}.tour-btn-cta[data-v-d81f961d]:hover{opacity:.88}.tour-spotlight[data-v-d81f961d]{z-index:9998;pointer-events:none;border-radius:10px;transition:all .35s cubic-bezier(.4,0,.2,1);position:fixed;box-shadow:0 0 0 9999px #0000009e}.tour-tooltip[data-v-d81f961d]{z-index:9999;background:#fff;border-radius:14px;padding:16px 18px 14px;transition:all .35s cubic-bezier(.4,0,.2,1);animation:.2s tour-fade-in-d81f961d;position:fixed;box-shadow:0 12px 40px #00000038}.tour-tooltip-header[data-v-d81f961d]{align-items:center;gap:8px;margin-bottom:8px;display:flex}.tour-tooltip-emoji[data-v-d81f961d]{font-size:20px}.tour-tooltip-title[data-v-d81f961d]{color:#111827;flex:1;font-size:15px;font-weight:800}.tour-tooltip-close[data-v-d81f961d]{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.tour-tooltip-close[data-v-d81f961d]:hover{color:#374151}.tour-tooltip-desc[data-v-d81f961d]{color:#6b7280;margin-bottom:8px;font-size:13px;line-height:1.65}.tour-tooltip-footer[data-v-d81f961d]{justify-content:space-between;align-items:center;margin-top:10px;display:flex}@keyframes tour-fade-in-d81f961d{0%{opacity:0}to{opacity:1}}@keyframes tour-slide-up-d81f961d{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}:root{--primary:#ea580c;--primary-dark:#c2410c;--primary-light:#f97316;--primary-bg:#fff7ed;--secondary:#f58220;--secondary-light:#fff0e6;--accent:#ffc107;--success:#28a745;--success-bg:#eaf7ee;--warning:#f58220;--warning-bg:#fff4ec;--danger:#e63946;--danger-bg:#fdecea;--info:#00a7af;--info-bg:#e6f7f8;--bg:#f2f4f7;--bg-card:#fff;--bg-card-hover:#f8fafc;--bg-sidebar:#fff;--bg-input:#fff;--bg-header:#fff;--text-primary:#1a2332;--text-secondary:#4a5568;--text-muted:#8a97a8;--text-light:#b8c4ce;--border:#e2e8f0;--border-light:#eef2f7;--border-strong:#cbd5e0;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 4px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--sidebar-width:220px;--topbar-height:58px;--sidebar-border:#e2e8f0;--sidebar-muted:#8a97a8;--shift1-bg:#e8f4fd;--shift1-text:#1565c0;--shift1-border:#90caf9;--shift2-bg:#ede7f6;--shift2-text:#4527a0;--shift2-border:#ce93d8;--shift3-bg:#fff8e1;--shift3-text:#e65100;--shift3-border:#ffcc02;--off-bg:#f5f5f5;--off-text:#757575;--off-border:#bdbdbd;--leave-bg:#fce4ec;--leave-text:#ad1457;--leave-border:#f48fb1;--holiday-color:#e63946;--restday-color:#f58220;--today-color:#ea580c}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:15px}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--border-light)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-dark)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;height:100vh;box-shadow:var(--shadow-sm);flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-header);border-bottom:1px solid var(--border);z-index:90;box-shadow:var(--shadow-xs);align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.page-content{flex:1;padding:24px}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 18px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--primary), var(--primary-dark));border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-logo-title{color:var(--text-primary);font-size:15px;font-weight:700}.sidebar-logo-sub{color:var(--text-muted);font-size:10px}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.sidebar-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:10px 18px 4px;font-size:10px;font-weight:700}.nav-item{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:calc(100% - 16px);margin:1px 8px;padding:9px 18px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-item:hover{background:var(--primary-bg);color:var(--primary)}.nav-item.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.nav-item.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:-8px;transform:translateY(-50%)}.nav-item .nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;display:flex}.sidebar-user{border-top:1px solid var(--border);align-items:center;gap:10px;padding:14px 18px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);font-size:11px}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px;font-size:14px;transition:color .2s}.logout-btn:hover{color:var(--danger)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.card-title{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:600}.card-subtitle{color:var(--text-muted);font-size:12px}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #ea580c4d}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 3px 10px #ea580c66}.btn-secondary{color:var(--text-secondary);border-color:var(--border-strong);background:#fff}.btn-secondary:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.btn-danger{color:var(--danger);border-color:var(--danger);background:#fff}.btn-danger:hover{background:var(--danger-bg)}.btn-success{background:var(--success);color:#fff;border-color:var(--success);box-shadow:0 2px 6px #28a7454d}.btn-success:hover{background:#218838}.btn-outline{color:var(--primary);border-color:var(--primary);background:#fff}.btn-outline:hover{background:var(--primary-bg)}.btn-sm{padding:5px 12px;font-size:12px}.btn-lg{padding:11px 24px;font-size:15px}.btn-icon{padding:7px}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-control{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .2s,box-shadow .2s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ea580c1f}.form-control::placeholder{color:var(--text-light)}select.form-control{cursor:pointer}.badge{border:1px solid;border-radius:4px;justify-content:center;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-shift1{background:var(--shift1-bg);color:var(--shift1-text);border-color:var(--shift1-border);min-width:22px;font-size:13px;font-weight:700}.badge-shift2{background:var(--shift2-bg);color:var(--shift2-text);border-color:var(--shift2-border);min-width:22px;font-size:13px;font-weight:700}.badge-shift3{background:var(--shift3-bg);color:var(--shift3-text);border-color:var(--shift3-border);min-width:22px;font-size:13px;font-weight:700}.badge-off{background:var(--off-bg);color:var(--off-text);border-color:var(--off-border)}.badge-leave{background:var(--leave-bg);color:var(--leave-text);border-color:var(--leave-border)}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#1a233280;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-lg);background:#fff;padding:28px;animation:.2s modalIn}.modal-lg{max-width:700px}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{color:var(--text-primary);font-size:16px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px}.modal-close:hover{background:var(--bg);color:var(--text-primary)}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;display:flex}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:13px}.table th{color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:#f8fafc;padding:10px 14px;font-size:12px;font-weight:600}.table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);padding:11px 14px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:#f8fafc}.toast-container{z-index:999;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-md);max-width:320px;box-shadow:var(--shadow-md);background:#fff;border:1px solid;align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:500;animation:.3s toastIn;display:flex}.toast-success{color:#155724;border-color:#c3e6cb}.toast-error{color:#721c24;border-color:#f5c6cb}.toast-warning{color:#856404;border-color:#ffeeba}.toast-info{color:#0c5460;border-color:#bee5eb}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{color:var(--text-muted);justify-content:center;align-items:center;gap:12px;padding:48px;display:flex}.alert{border-radius:var(--radius-md);border:1px solid;align-items:flex-start;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:13px;display:flex}.alert-warning{background:var(--warning-bg);color:#e65100;border-color:#ffcc80}.alert-danger{background:var(--danger-bg);color:var(--danger);border-color:#ffcdd2}.alert-info{background:var(--info-bg);color:var(--info);border-color:#b2ebf2}.alert-success{background:var(--success-bg);color:#2e7d32;border-color:#c8e6c9}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-title{color:var(--text-primary);font-size:20px;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:20px;display:grid}.stat-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);background:#fff;align-items:center;gap:14px;padding:16px 20px;transition:box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.stat-value{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:3px;font-size:12px}.sidebar-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);background:#00000073;position:fixed;inset:0}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-content{padding:12px}.stats-grid{grid-template-columns:1fr 1fr}.page-title{font-size:17px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;-webkit-overflow-scrolling:touch;max-width:100%;max-height:92vh;animation:.25s modalSlideUp;overflow-y:auto}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.table-wrapper{-webkit-overflow-scrolling:touch}.form-control{padding:10px 12px;font-size:16px}select.form-control{font-size:16px}.toast-container{bottom:16px;left:12px;right:12px}.toast{max-width:100%}.btn{min-height:38px}.btn-sm{min-height:32px}}.fade-enter-active,.fade-leave-active{transition:opacity .18s}.fade-enter-from,.fade-leave-to{opacity:0}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.chip{background:var(--primary-bg);color:var(--primary);border:1px solid #ea580c40;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.shift-pill{letter-spacing:.01em;border:1px solid;border-radius:4px;justify-content:center;align-items:center;width:34px;height:24px;font-size:12px;font-weight:700;display:inline-flex}.shift-pill.shift1{background:var(--shift1-bg);color:var(--shift1-text);border-color:var(--shift1-border)}.shift-pill.shift2{background:var(--shift2-bg);color:var(--shift2-text);border-color:var(--shift2-border)}.shift-pill.shift3{background:var(--shift3-bg);color:var(--shift3-text);border-color:var(--shift3-border)}.shift-pill.off{background:var(--off-bg);color:var(--off-text);border-color:var(--off-border)}.shift-pill.leave{background:var(--leave-bg);color:var(--leave-text);border-color:var(--leave-border)}@media print{@page{size:A4 landscape;margin:8mm}.sidebar,.topbar,.tabs,.leave-panel,.paint-toolbar,.no-print,.btn-quickfill,.btn-quickfill-all,.col-fill-trigger,.col-fill-popover,.day-understaffed-dot{display:none!important}body{background:#fff!important}.app-layout{display:block!important}.main-content{width:100%!important;max-width:100%!important;margin-left:0!important;padding:0!important}.page-content{padding:4px 0 0!important}.card{box-shadow:none!important;border:1px solid #ddd!important;margin-bottom:6px!important;padding:8px!important}.schedule-grid-container{width:100%!important;overflow:visible!important}.schedule-table{table-layout:fixed!important;width:100%!important;min-width:0!important;font-size:9px!important}.schedule-table th,.schedule-table td{padding:1px!important}.col-name,.col-stat{position:static!important}.col-name{width:52px!important;min-width:0!important}.col-day{width:auto!important;min-width:0!important}.col-stat{width:26px!important;min-width:0!important}.shift-pill{border-radius:2px!important;min-width:0!important;padding:1px 2px!important;font-size:8px!important;display:inline-block!important}.day-num{padding:1px 1px 0!important;font-size:9px!important}.day-week,.day-holiday-hint{font-size:7px!important}.stat-num{font-size:10px!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.feature-gate{min-height:60vh;color:var(--text-muted,#999);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.feature-gate-icon{font-size:48px}.feature-gate-title{color:var(--text-primary,#333);font-size:18px;font-weight:600}.feature-gate-desc{font-size:14px}
