@import"https://fonts.googleapis.com/css2?family=Archivo+Black&family=Noto+Sans+TC:wght@300;400;500;700;900&family=DM+Mono:wght@400;500&display=swap";@font-face{font-family:Taipei Sans TC Beta;src:url(/fonts/TaipeiSansTCBeta-Light.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Taipei Sans TC Beta;src:url(/fonts/TaipeiSansTCBeta-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Taipei Sans TC Beta;src:url(/fonts/TaipeiSansTCBeta-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--brand-yellow: #F9B91B;--brand-yellow-strong: #D49C12;--brand-yellow-soft: #FEF9EF;--brand-black: #1C1B1B;--warning-stripe: repeating-linear-gradient(45deg, #F9B91B 0 12px, #1C1B1B 12px 24px);--font-display: "Archivo Black", "Taipei Sans TC Beta", "Noto Sans TC", sans-serif;--font-body: "Taipei Sans TC Beta", "Noto Sans TC", "Microsoft JhengHei", sans-serif;--font-sans: var(--font-body);--font-mono: "DM Mono", "JetBrains Mono", "Consolas", monospace;--sidebar-w: 240px;--sidebar-w-collapsed: 64px;--header-h: 56px;--container-max: 1440px;--row-h-standard: 48px;--row-h-dense: 40px;--r-sharp: 2px;--rxs: 6px;--r-sm: 6px;--r: 10px;--r-md: 10px;--r-lg: 16px;--r-full: 9999px}:root,:root[data-theme=light]{--bg: #FCF9F8;--surface: #FFFFFF;--surface2: #F3F0EE;--surface3: #E8E4DE;--border: #E5E2E1;--border-strong: #D4D0CB;--text: #1C1B1B;--text2: #4C616C;--text3: #9E9A94;--accent: #F9B91B;--accent-hover: #D49C12;--accent-soft: #FEF9EF;--accent-ring: rgba(249,185,27,.25);--on-accent: #1C1B1B;--danger: #BA1A1A;--danger-bg: #FEF2F2;--danger-border: #FCA5A5;--warn: #B45309;--warn-bg: #FEF3C7;--success: #2E7D32;--success-bg: #D1FAE5;--success-border:#6EE7B7;--info: #1565C0;--info-bg: #E0F2FE;--table-zebra: #F8F6F4;--row-hover: #F0E9D9;--row-active: #FEF6E0;--sh-soft: 0 1px 3px rgba(28,27,27,.06), 0 4px 12px rgba(28,27,27,.04);--sh-card: 0 1px 3px rgba(28,27,27,.07), 0 6px 18px rgba(28,27,27,.05);--sh-hover: 0 4px 12px rgba(249,185,27,.2), 0 14px 32px rgba(28,27,27,.08);--sh-cta: 0 1px 0 rgba(212,156,18,.45), 0 4px 14px rgba(249,185,27,.25);--c-surface: var(--bg);--c-surface-bright: var(--surface);--c-surface-container-low: var(--surface2);--c-surface-container: var(--surface2);--c-surface-container-high: var(--surface3);--c-on-surface: var(--text);--c-on-surface-variant: var(--text2);--c-outline: var(--border-strong);--c-outline-variant: var(--border);--c-border-subtle: var(--border);--c-border-strong: var(--border-strong);--c-primary: var(--brand-black);--c-primary-hover: var(--brand-black);--c-on-primary: var(--surface);--c-accent: var(--accent);--c-accent-hover: var(--accent-hover);--c-on-accent: var(--on-accent);--c-status-draft: var(--text3);--c-status-sent: var(--info);--c-status-success: var(--success);--c-status-fail: var(--danger);--c-table-zebra: var(--table-zebra);--c-row-hover: var(--row-hover);--c-row-active: var(--row-active);--c-error: var(--danger);--c-error-bg: var(--danger-bg)}:root[data-theme=dark]{--bg: #1C1B1B;--surface: #2D2B2B;--surface2: #3A3838;--surface3: #454241;--border: #3A3838;--border-strong: #4C4847;--text: #FCF9F8;--text2: #D4C4AC;--text3: #6B6760;--accent: #F9B91B;--accent-hover: #FFCA3F;--accent-soft: rgba(249,185,27,.12);--accent-ring: rgba(249,185,27,.35);--on-accent: #1C1B1B;--danger: #FF6B6B;--danger-bg: rgba(255,107,107,.12);--danger-border: rgba(255,107,107,.5);--warn: #FBBF24;--warn-bg: rgba(251,191,36,.12);--success: #6EE7B7;--success-bg: rgba(110,231,183,.12);--success-border:rgba(110,231,183,.5);--info: #60A5FA;--info-bg: rgba(96,165,250,.12);--table-zebra: #2D2B2B;--row-hover: #3A3838;--row-active: rgba(249,185,27,.1);--sh-soft: 0 1px 3px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.3);--sh-card: 0 1px 3px rgba(0,0,0,.5), 0 8px 24px rgba(0,0,0,.4);--sh-hover: 0 4px 12px rgba(249,185,27,.3), 0 14px 32px rgba(0,0,0,.5);--sh-cta: 0 1px 0 rgba(123,89,0,.8), 0 6px 20px rgba(249,185,27,.4)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text);background:var(--bg);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color .25s ease,color .25s ease}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}input,select,textarea{font-family:inherit;font-size:14px;color:var(--text)}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700}.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--brand-yellow);color:var(--brand-black);border-radius:var(--rxs);font-family:var(--font-body);font-weight:900;font-size:16px;flex-shrink:0;-webkit-user-select:none;user-select:none;box-shadow:0 2px 6px #f9b91b40}.logo-mark.lg{width:42px;height:42px;font-size:21px}.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}.muted{color:var(--text2)}.muted-2{color:var(--text3)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.center{display:flex;align-items:center;justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:500;font-size:14px;white-space:nowrap;transition:background-color .15s ease,border-color .15s ease,transform .1s,box-shadow .15s}.btn:hover{background:var(--surface2);border-color:var(--border-strong)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--brand-black);color:#fff;border-color:var(--brand-black)}.btn-primary:hover{background:#2a2828;border-color:#2a2828}.btn-primary:active{transform:translateY(1px)}:root[data-theme=dark] .btn-primary{background:var(--surface3);color:var(--text);border-color:var(--border-strong)}:root[data-theme=dark] .btn-primary:hover{background:#545150;border-color:var(--accent)}.btn-accent{background:var(--accent);color:var(--on-accent);border-color:var(--brand-yellow-strong);box-shadow:var(--sh-cta)}.btn-accent:hover{background:var(--accent-hover)}.btn-accent:active{transform:translateY(2px);box-shadow:0 0 #d49c1266}.btn-accent:focus-visible{outline:none;box-shadow:0 0 0 4px var(--accent-ring),var(--sh-cta)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#9f1414}.btn-sm{height:28px;padding:4px 10px;font-size:13px}.btn-lg{height:44px;padding:12px 18px;font-size:15px;font-weight:700}.btn-icon{padding:0;width:32px;height:32px}.btn-link{background:transparent;border:none;color:var(--accent-hover);padding:0;height:auto}.btn-link:hover{background:transparent;text-decoration:underline;color:var(--accent)}.input,input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],textarea,select{font-family:var(--font-body);padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus,input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}input::placeholder,textarea::placeholder{color:var(--text3)}.input[disabled],input[disabled],textarea[disabled],select[disabled]{background:var(--surface2);color:var(--text3)}.badge{display:inline-block;padding:2px 8px;border-radius:var(--r-sm);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;line-height:1.5}.chip-group{display:inline-flex;gap:6px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;height:32px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .15s,color .15s,border-color .15s}.chip:hover{background:var(--surface2);color:var(--text)}.chip.active{background:var(--accent);color:var(--on-accent);border-color:var(--brand-yellow-strong);font-weight:700}.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;color:var(--text)}.toggle-track{width:32px;height:18px;border-radius:var(--r-full);background:var(--border-strong);position:relative;transition:background .15s ease}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .15s ease;box-shadow:0 1px 2px #0003}.toggle input{display:none}.toggle input:checked+.toggle-track{background:var(--accent)}.toggle input:checked+.toggle-track:after{transform:translate(14px)}.counter-circle{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--r-full);background:var(--accent);color:var(--on-accent);font-family:var(--font-mono);font-size:11px;font-weight:700}.counter-circle.muted{background:var(--surface3);color:var(--text)}table.tb-table{width:100%;border-collapse:collapse;font-size:14px}table.tb-table thead th{background:var(--surface2);text-align:left;padding:10px 12px;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);border-bottom:1px solid var(--border)}table.tb-table tbody td{padding:12px;border-bottom:1px solid var(--border)}table.tb-table tbody tr:nth-child(2n){background:var(--table-zebra)}table.tb-table tbody tr:hover{background:var(--row-hover)}table.tb-table tbody tr.active-row{background:var(--row-active)}table.tb-table tbody tr.dim-row td{color:var(--text3)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--sh-soft)}.card.flat{box-shadow:none}.card.raised{box-shadow:var(--sh-card)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 16px;display:flex;flex-direction:column;gap:2px;min-width:140px}.stat-card .stat-label{font-size:11px;font-weight:600;color:var(--text2);letter-spacing:.08em;text-transform:uppercase}.stat-card .stat-value{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--text)}.stat-card .stat-delta{font-size:11px;font-family:var(--font-mono)}.stat-card .stat-delta.up{color:var(--success)}.stat-card .stat-delta.down{color:var(--danger)}.app-layout{display:flex;min-height:100vh;background:var(--bg)}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;position:relative}.main{flex:1;min-width:0;display:flex;flex-direction:column}.main-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.main-content{flex:1;padding:24px;overflow-y:auto;max-width:var(--container-max)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);background:var(--surface);padding:0 4px;overflow-x:auto}.tab{padding:10px 16px;border:1px solid transparent;border-bottom:none;background:transparent;color:var(--text2);font-weight:500;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:14px}.tab:hover{color:var(--text);background:var(--surface2)}.tab.active{color:var(--text);background:var(--surface);border-color:var(--border);border-bottom:2px solid var(--accent);font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 12px 40px #00000040}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);font-weight:700;font-size:16px;font-family:var(--font-display)}.modal-body{padding:20px}.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.alert{padding:10px 14px;border-radius:var(--r-sm);font-size:13px;border:1px solid transparent}.alert-info{background:var(--info-bg);color:var(--info);border-color:var(--info)}.alert-warn{background:var(--warn-bg);color:var(--warn);border-color:var(--warn)}.alert-error{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.alert-success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.empty{padding:60px 20px;text-align:center;color:var(--text2)}.toast{position:fixed;top:80px;right:24px;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 16px;box-shadow:var(--sh-card);font-size:13px;display:flex;align-items:center;gap:8px;animation:toast-in .2s ease-out;max-width:480px}@keyframes toast-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--info)}.search-wrap{position:relative}.search-wrap input{padding-left:32px!important}.search-wrap:before{content:"🔍";position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none;opacity:.6}.theme-toggle{width:34px;height:34px;background:transparent;border:1px solid var(--border);border-radius:var(--rxs);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s,color .15s,border-color .15s;flex-shrink:0;padding:0}.theme-toggle:hover{background:var(--surface2);color:var(--text);border-color:var(--border-strong)}.theme-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}.warning-stripe{background:var(--warning-stripe);height:6px;width:100%}@media print{.no-print{display:none!important}}
