.header-right[data-v-231dd9d0]{align-items:center;display:flex}.user-dropdown-wrapper[data-v-231dd9d0]{position:relative}.user-trigger[data-v-231dd9d0]{cursor:pointer;border-radius:var(--radius);background:0 0;border:none;align-items:center;gap:9px;padding:5px 8px;font-family:inherit;transition:background .15s;display:flex}.user-trigger[data-v-231dd9d0]:hover,.user-trigger.is-open[data-v-231dd9d0]{background:#f3f4f6}.header-avatar[data-v-231dd9d0]{color:#fff;background:linear-gradient(135deg,#da5c3a,#e87c5e);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex;overflow:hidden}.header-avatar-img[data-v-231dd9d0]{object-fit:cover;width:100%;height:100%}.user-meta[data-v-231dd9d0]{text-align:left}.user-name[data-v-231dd9d0]{color:var(--color-text);font-size:13px;font-weight:600;line-height:1.3}.trigger-caret[data-v-231dd9d0]{color:var(--color-text-muted);flex-shrink:0;transition:transform .18s}.trigger-caret.rotated[data-v-231dd9d0]{transform:rotate(180deg)}.user-dropdown[data-v-231dd9d0]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);z-index:500;min-width:168px;padding:4px 0;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 6px 20px #0000001a}.dropdown-item[data-v-231dd9d0]{color:var(--color-text);white-space:nowrap;cursor:pointer;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:9px 14px;font-family:inherit;font-size:13px;text-decoration:none;transition:background .1s;display:flex}.dropdown-item[data-v-231dd9d0]:hover{background:#f3f4f6}.dropdown-item--danger[data-v-231dd9d0]{color:#dc2626}.dropdown-item--danger[data-v-231dd9d0]:hover{background:#fee2e2}.dropdown-divider[data-v-231dd9d0]{background:var(--color-border);height:1px;margin:4px 0}.dropdown-enter-active[data-v-231dd9d0],.dropdown-leave-active[data-v-231dd9d0]{transition:opacity .12s,transform .12s}.dropdown-enter-from[data-v-231dd9d0],.dropdown-leave-to[data-v-231dd9d0]{opacity:0;transform:translateY(-4px)}.fade-enter-active,.fade-leave-active{transition:opacity .2s}.fade-enter-from,.fade-leave-to{opacity:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#da5c3a;--brand-dark:#bf4827;--brand-light:#da5c3a1a;--color-bg:#f5f4f1;--color-surface:#fff;--color-text:#111827;--color-text-muted:#6b7280;--color-border:#e5e7eb;--color-primary:#da5c3a;--color-success:#10b981;--color-danger:#ef4444;--color-action:#111827;--sidebar-width:240px;--sidebar-collapsed:64px;--header-height:56px;--radius:8px;--shadow:0 1px 3px #00000012, 0 1px 2px #0000000a}html,body{height:100%;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,PingFang TC,Microsoft JhengHei,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#app{height:100%}.app-layout{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{flex:1;padding:24px;overflow-y:auto}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;flex-shrink:0;height:100vh;transition:width .22s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:0;overflow:hidden}.sidebar.is-collapsed{width:var(--sidebar-collapsed)}.sidebar-top{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;height:56px;padding:0 12px;display:flex;overflow:hidden}.sidebar-brand{flex:1;align-items:center;gap:9px;min-width:0;display:flex;overflow:hidden}.sidebar-logo-mark{flex-shrink:0;width:28px;height:28px}.sidebar-logo-text{color:var(--color-text);white-space:nowrap;letter-spacing:-.01em;font-size:15px;font-weight:700;overflow:hidden}.sidebar.is-collapsed .sidebar-logo-text{display:none}.sidebar-toggle{border:1px solid var(--color-border);cursor:pointer;width:26px;height:26px;color:var(--color-text-muted);background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.sidebar-toggle:hover{color:var(--color-text);background:#f3f4f6;border-color:#d1d5db}.sidebar-footer{border-top:1px solid var(--color-border);flex-shrink:0;justify-content:flex-end;padding:10px 8px;display:flex}.sidebar.is-collapsed .sidebar-footer{justify-content:center}.sidebar.is-collapsed .sidebar-top{justify-content:center;padding:0}.sidebar.is-collapsed .sidebar-brand{flex:none;justify-content:center;width:100%}.sidebar-close{cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:none}.sidebar-close:hover{background:#f3f4f6}.sidebar-nav{flex:1;padding:8px;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:999px}.nav-item{color:var(--color-text-muted);white-space:nowrap;border-radius:6px;align-items:center;gap:10px;margin-bottom:1px;padding:9px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;overflow:hidden}.nav-item:hover{color:var(--color-text);background:#f3f4f6}.nav-item.active{background:var(--brand-light);color:var(--brand)}.nav-icon{flex-shrink:0;width:17px;height:17px}.nav-label{white-space:nowrap;overflow:hidden}.sidebar.is-collapsed .nav-item{justify-content:center;padding:9px 0}.sidebar.is-collapsed .nav-label{display:none}.nav-group+.nav-group{margin-top:4px}.nav-group--not-first{padding-top:6px}.nav-group-label{letter-spacing:.04em;color:var(--color-text-muted);opacity:.55;white-space:nowrap;padding:4px 10px 3px;font-size:10px;font-weight:700;overflow:hidden}.nav-group-divider,.sidebar.is-collapsed .nav-group-label{display:none}.sidebar.is-collapsed .nav-group-divider{background:var(--color-border);height:1px;margin:4px 10px;display:block}.sidebar.is-collapsed .nav-group--not-first{padding-top:4px}@media (width<=767px){.sidebar{z-index:300;height:100dvh;transition:transform .22s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;transform:translate(-100%);width:260px!important}.sidebar.is-mobile-open{transform:translate(0);box-shadow:4px 0 24px #0000001f}.sidebar.is-mobile-open .sidebar-logo-text,.sidebar.is-mobile-open .nav-label{display:block}.sidebar.is-mobile-open .nav-item{justify-content:flex-start;padding:9px 10px}.sidebar.is-mobile-open .sidebar-top{justify-content:space-between}.sidebar-toggle{display:none}.sidebar-close{display:flex}.sidebar-footer{display:none}.mobile-overlay{z-index:299;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0006;position:fixed;inset:0}.page-content{padding:16px}}.app-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 20px 0 16px;display:flex}.header-left{align-items:center;gap:8px;display:flex}.header-menu-btn{cursor:pointer;width:36px;height:36px;color:var(--color-text-muted);border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s;display:none}.header-menu-btn:hover{background:#f3f4f6}@media (width<=767px){.header-menu-btn{display:flex}}.header-title{font-size:15px;font-weight:600}.user-switcher{align-items:center;gap:10px;display:flex}.user-info{text-align:right}.user-name{font-size:13px;font-weight:600}.user-role-label{margin-top:2px}.role-select{border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;color:var(--color-text);background:#fff;padding:5px 8px;font-family:inherit;font-size:12px}.role-select:focus{border-color:var(--brand);outline:none}.role-badge{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.role-badge--admin{color:#da5c3a;background:#fff0ec}.role-badge--accountant{color:#1e40af;background:#dbeafe}.role-badge--shareholder{color:#065f46;background:#d1fae5}.role-badge--staff{color:#374151;background:#f3f4f6}.card{background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.card-header h2{font-size:14px;font-weight:600}.card-body{padding:20px}.page-header{margin-bottom:20px}.page-header h1{margin-bottom:4px;font-size:20px;font-weight:700}.page-header p{color:var(--color-text-muted);font-size:13px}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:5px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.btn:hover:not(:disabled){opacity:.88}.btn:active:not(:disabled){opacity:.75}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--color-action);color:#fff}.btn--brand{background:var(--brand);color:#fff}.btn--success{background:var(--color-success);color:#fff}.btn--danger{background:var(--color-danger);color:#fff}.btn--dark{background:var(--color-action);color:#fff}.btn--ghost{color:var(--brand);border:1px solid var(--brand);background:0 0}.btn--ghost-dark{color:var(--color-text);border:1px solid var(--color-border);background:0 0}.btn--ghost-neutral{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.btn--sm{padding:4px 10px;font-size:12px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;background:#f9fafb;padding:10px 12px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:11px 12px;font-size:13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f9fafb}.status-badge{border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.status-badge--pending{color:#713f12;background:#fef9c3}.status-badge--approved{color:#065f46;background:#d1fae5}.status-badge--rejected{color:#991b1b;background:#fee2e2}.status-badge--active{color:#065f46;background:#d1fae5}.status-badge--completed{color:#1e40af;background:#dbeafe}.status-badge--planning{color:#374151;background:#f3f4f6}.status-badge--quoting{color:#da5c3a;background:#fff0ec}.status-badge--waiting{color:#1e40af;background:#dbeafe}.status-badge--notstarted{color:#64748b;background:#f1f5f9}.status-badge--inprogress{color:#065f46;background:#d1fae5}.status-badge--closed{color:#6b21a8;background:#e9d5ff}.tag{color:#475569;background:#f1f5f9;border-radius:999px;padding:2px 7px;font-size:11px;font-weight:500;display:inline-block}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:20px;display:grid}.stat-card{background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow);padding:16px 20px}.stat-label{color:var(--color-text-muted);margin-bottom:8px;font-size:12px}.stat-value{font-size:22px;font-weight:700;line-height:1}.progress-bar{vertical-align:middle;background:#e5e7eb;border-radius:999px;width:90px;height:5px;margin-right:6px;display:inline-block;overflow:hidden}.progress-fill{background:var(--brand);border-radius:999px;height:100%}.form-group{margin-bottom:14px}.form-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;color:var(--color-text);background:#fff;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #da5c3a1f}.form-input[readonly],.form-input:read-only{cursor:not-allowed;color:var(--color-text-muted);background:#f9fafb}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius);width:500px;max-width:100%;max-height:90vh;animation:.15s modal-in;overflow-y:auto;box-shadow:0 20px 60px #0003}@keyframes modal-in{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{font-size:15px;font-weight:600}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.tab-bar{border-bottom:2px solid var(--color-border);gap:4px;padding-bottom:0;display:flex}.tab-btn{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:12px}@media (width<=640px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.page-header h1{font-size:17px}.card-body{padding:14px}.modal{width:100%}}
