:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1f2430;--app-bg:#f6f8ff;--surface:#fff;--surface-soft:#f7f9ff;--surface-tint:#e6f4f4;--line:#dfe4f2;--line-strong:#cbd3e6;--text:#1f2430;--muted:#676f80;--primary:#2f6b7a;--primary-strong:#1d4f5a;--primary-soft:#e6f4f4;--accent:#00a0b8;--green:#00a66c;--yellow:#f2a600;--red:#e2445c;--gray:#697386;--shadow:0 8px 24px #1f243014;--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;--text-xs:12px;--text-sm:13px;--text-base:14px;--text-md:16px;--text-lg:20px;--text-xl:24px;--text-2xl:30px;--text-3xl:36px;--z-dropdown:100;--z-drawer:200;--z-modal:1100;--z-tooltip:1000;font-synthesis:none;text-rendering:optimizelegibility;background:#f6f8ff;font-family:Inter,Noto Sans TC,PingFang TC,Microsoft JhengHei,system-ui,sans-serif}*{box-sizing:border-box}body{background:var(--app-bg);min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}.boot{min-height:100vh;color:var(--muted);place-items:center;display:grid}.app-shell{grid-template-columns:280px 1fr;min-height:100vh;display:grid;overflow-x:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--line);flex-direction:column;display:flex}.sidebar-inner{height:100vh;color:var(--text);flex-direction:column;gap:28px;padding:24px 18px;display:flex;position:sticky;top:0;overflow:hidden;box-shadow:6px 0 24px #1f24300a}.sidebar h1{letter-spacing:0;margin:6px 0 0;font-size:24px;line-height:1.2}.eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:12px;font-weight:800}.sidebar .eyebrow{color:var(--primary)}.sidebar-scroll{scrollbar-width:thin;scrollbar-color:var(--line) transparent;flex:1;width:100%;min-height:0;overflow-y:auto}nav{gap:8px;display:grid}.nav{color:#4b5265;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;width:100%;padding:11px 12px;font-weight:800;transition:background .15s,border-color .15s,color .15s;display:flex}.nav svg{color:var(--primary)}.nav.active,.nav:hover{background:var(--primary-soft);color:var(--primary-strong);border-color:#bce1e1}.profile{border:1px solid var(--line);background:var(--surface-soft);border-radius:8px;justify-content:space-between;gap:10px;padding:14px;display:flex}.profile strong{color:var(--primary-strong)}.content{width:auto;min-width:0;max-width:1520px;padding:28px}.app-shell{transition:grid-template-columns .2s ease-in-out}.app-shell.collapsed{grid-template-columns:80px 1fr}.sidebar,.sidebar-inner{transition:all .2s ease-in-out}.sidebar.collapsed{align-items:center}.sidebar.collapsed .sidebar-inner{padding:24px 10px}.sidebar.collapsed .nav{border-radius:50%;justify-content:center;width:44px;height:44px;padding:11px 0}.sidebar.collapsed .nav span{display:none}.sidebar.collapsed .profile{background:0 0;border:none;padding:4px}.stack{gap:28px;display:grid}.page-head h2{letter-spacing:0;margin:5px 0 8px;font-size:30px}.page-head p:last-child{color:var(--muted);max-width:760px;margin:0}.notice{color:#007a52;background:#e9fff6;border:1px solid #b7f0dc;border-radius:8px;margin-bottom:18px;padding:12px 14px}.kpi-grid{grid-template-columns:repeat(6,minmax(130px,1fr));gap:20px;display:grid}.kpi,.panel{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.kpi{align-content:space-between;min-height:122px;padding:20px;display:grid}.kpi span{color:var(--primary)}.kpi small{color:var(--muted)}.kpi strong{letter-spacing:0;font-size:34px}.kpi.red span,.kpi.red strong{color:var(--red)}.kpi.yellow span,.kpi.yellow strong{color:var(--yellow)}.kpi.slate span,.kpi.slate strong{color:var(--gray)}.panel{min-width:0;padding:18px}.panel h3{align-items:center;gap:8px;margin:0 0 14px;font-size:17px;display:flex}.split{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:24px;display:grid}.wide-left{grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr)}.project-rows{gap:10px;display:grid}.project-row{border:1px solid var(--line);background:var(--surface);text-align:left;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;padding:12px;display:grid}.project-row:hover,.project-row.selected{background:var(--primary-soft);border-color:#a8d5d5}.project-row strong,.project-row small{overflow-wrap:anywhere;display:block}.project-row small{color:var(--muted);margin-top:4px;font-size:13px}.health{background:#fff;border:1px solid;border-radius:999px;justify-self:end;padding:3px 8px;font-size:12px;font-weight:800}.progress{background:#edf0fa;border-radius:999px;grid-column:1/-1;height:14px;position:relative;overflow:hidden}.progress span{background:var(--primary);height:100%;display:block}.progress em{color:var(--text);font-size:11px;font-style:normal;position:absolute;top:-1px;right:6px}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #edf0fa;padding:11px 8px}th{color:var(--muted);text-transform:uppercase;font-size:12px}.filters{grid-template-columns:minmax(220px,1fr) repeat(3,minmax(150px,180px));gap:10px;display:grid}input:not([type=checkbox]),select,textarea{border:1px solid var(--line-strong);width:100%;color:var(--text);background:#fff;border-radius:8px;padding:10px 12px}input:not([type=checkbox]):focus,select:focus,textarea:focus{border-color:var(--primary);outline:3px solid #bce1e1}textarea{resize:vertical;min-height:84px}.workspace-head{justify-content:space-between;align-items:end;gap:18px;display:flex}.workspace-summary{gap:10px;display:flex}.workspace-summary span{border:1px solid var(--line);text-align:right;background:#fff;border-radius:8px;min-width:86px;padding:10px 12px;font-size:24px;font-weight:900;box-shadow:0 4px 14px #1f24300d}.workspace-summary small{color:var(--muted);margin-top:2px;font-size:12px;font-weight:700;display:block}.view-tabs{border:1px solid var(--line);background:var(--surface);border-radius:8px;flex-wrap:wrap;gap:8px;width:fit-content;padding:6px;display:flex;box-shadow:0 4px 16px #1f24300d}.view-tab,.mini-toggle{color:#4b5265;background:0 0;border:1px solid #0000;border-radius:7px;align-items:center;gap:7px;padding:9px 11px;font-weight:800;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.view-tab svg,.mini-toggle svg{color:var(--primary)}.view-tab.active,.view-tab:hover,.mini-toggle.active,.mini-toggle:hover{background:var(--primary);color:#fff;border-color:#bce1e1}.view-tab.active svg,.view-tab:hover svg{color:#fff}.workspace-filters{flex-wrap:wrap;gap:10px;display:flex}.workspace-filters>*{flex:auto;min-width:120px;max-width:180px}.workspace-filters>input[type=text]{flex:2 220px;max-width:none}.workspace-filters>input[type=date]{max-width:160px}.kanban-toolbar{color:var(--muted);align-items:center;gap:8px;font-size:14px;display:flex}.workspace-surface{border:1px solid var(--line);background:var(--surface);min-width:0;box-shadow:var(--shadow);border-radius:8px;padding:14px}.table-scroll{width:100%;max-width:100%;display:block;overflow-x:auto}.project-table{min-width:980px}.project-table tbody tr{cursor:pointer}.project-table tbody tr:nth-child(2n){background:var(--surface-tint)}.project-table tbody tr:hover{background:var(--primary-soft)}.project-table td strong,.project-table td small{display:block}.project-table td small{color:var(--muted);margin-top:4px}.stage-pill{background:var(--primary-soft);color:var(--primary-strong);border-radius:999px;padding:4px 8px;font-size:12px;font-weight:800;display:inline-block}.ok-text{color:var(--green);font-weight:800}.risk-text{color:var(--red);font-weight:800}.muted{color:var(--muted)}.compact-progress{min-width:112px;height:12px}.kanban-board{grid-template-columns:repeat(5,minmax(230px,1fr));gap:12px;padding-bottom:4px;display:grid;overflow-x:auto}.kanban-column{border:1px solid var(--line);background:var(--surface-soft);border-radius:8px;min-width:230px;padding:10px}.kanban-column header{color:var(--text);justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.kanban-column header span{color:var(--primary-strong);background:#d5ecec;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:800}.kanban-cards{gap:10px;display:grid}.kanban-card{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;gap:9px;width:100%;padding:12px;display:grid}.kanban-card:hover{box-shadow:var(--shadow);border-color:#a8d5d5}.kanban-card-head{justify-content:space-between;align-items:start;gap:8px;display:flex}.kanban-card-head strong{overflow-wrap:anywhere}.kanban-card small{color:var(--muted)}.card-meta{color:var(--muted);justify-content:space-between;gap:8px;font-size:12px;display:flex}.milestone-chips{flex-wrap:wrap;gap:6px;display:flex}.milestone-chips span{color:var(--primary-strong);background:#d5ecec;border-radius:999px;padding:3px 7px;font-size:11px;font-weight:800}.calendar-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}.calendar-day{border:1px solid var(--line);background:var(--surface-soft);border-radius:8px;min-height:148px;padding:10px}.calendar-day time{color:var(--muted);margin-bottom:9px;font-weight:900;display:block}.calendar-events{gap:8px;display:grid}.calendar-events button{text-align:left;background:#fff;border:1px solid;border-left-width:5px;border-radius:8px;padding:9px}.calendar-events strong,.calendar-events small{overflow-wrap:anywhere;display:block}.calendar-events small{color:var(--muted);margin-top:3px}.timeline-surface,.gantt-surface{gap:10px;display:grid;overflow-x:auto}.project-timeline-row,.gantt-row{border:1px solid var(--line);background:var(--surface);text-align:left;border-radius:8px;grid-template-columns:240px 1fr;align-items:center;gap:14px;min-width:820px;padding:12px;display:grid}.project-timeline-row:hover,.gantt-row:hover{background:var(--primary-soft);border-color:#a8d5d5}.timeline-label strong,.timeline-label small,.gantt-label strong,.gantt-label small{overflow-wrap:anywhere;display:block}.timeline-label small,.gantt-label small{color:var(--muted);margin-top:4px}.timeline-track,.gantt-track{background:linear-gradient(90deg,#edf0fb 0 1px,#0000 1px 100%) 0 0/12.5% 100%;border-radius:999px;height:34px;position:relative}.timeline-bar{opacity:.85;border-radius:999px;height:12px;position:absolute;top:11px}.timeline-dot{background:#fff;border:4px solid;border-radius:999px;width:20px;height:20px;margin-left:-10px;position:absolute;top:7px}.gantt-scale{min-width:820px;color:var(--muted);justify-content:space-between;padding:0 8px;font-size:12px;font-weight:800;display:flex}.gantt-row.attention{border-left:5px solid var(--yellow)}.gantt-plan{background:#e1e5f2;border-radius:999px;height:18px;position:absolute;top:8px;overflow:hidden}.gantt-plan em{border-radius:inherit;height:100%;display:block}.gantt-milestone{border:3px solid #fff;width:20px;height:20px;margin-left:-10px;position:absolute;top:7px;transform:rotate(45deg);box-shadow:0 1px 4px #17202633}.gantt-milestone.delayed{outline:2px solid #ffd2d8}.workspace-empty{text-align:center;padding:24px}.detail-drawer{z-index:20;background:#1f243038;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer-panel{background:#fff;width:min(520px,100vw);height:100vh;padding:24px;overflow-y:auto;box-shadow:-16px 0 40px #1f24302e}.drawer-close{float:right;border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:8px;place-items:center;width:36px;height:36px;transition:background .15s,border-color .15s,color .15s;display:inline-grid}.drawer-loading{min-height:240px;color:var(--muted);place-items:center;display:grid}.report-form.compact textarea{min-height:70px}.report-form{gap:12px;display:grid}.two{grid-template-columns:1fr 1fr;gap:10px;display:grid}.checks label,.report-form label{color:#4b5265;font-size:14px}.checks{align-items:stretch}.checkbox-row{border:1px solid var(--line);background:var(--surface-soft);border-radius:10px;justify-content:flex-start;align-items:center;gap:10px;width:100%;min-height:48px;padding:12px 14px;line-height:1.35;transition:border-color .16s,background-color .16s,box-shadow .16s;display:flex}.checkbox-row:hover{background:var(--primary-soft);border-color:#a8d5d5}.checkbox-row:has(input[type=checkbox]:focus-visible){border-color:var(--primary);box-shadow:0 0 0 3px #bce1e1}.checkbox-row input[type=checkbox]{width:18px;min-width:18px;height:18px;accent-color:var(--primary);flex:0 0 18px;margin:0}.checkbox-row span{font-weight:700;display:inline-block}.range{gap:6px;display:grid}.primary{background:var(--primary);color:#fff;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:11px 14px;font-weight:800;display:inline-flex}.primary:hover{background:var(--primary-strong)}.detail-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.detail-head h3{margin-bottom:4px}.detail-head p{color:var(--muted);margin:0}.meta-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin:16px 0;display:grid}.meta-grid span{background:var(--surface-soft);color:var(--muted);border-radius:8px;padding:10px;font-size:12px}.meta-grid strong{color:var(--text);margin-top:4px;font-size:14px;display:block}h4{margin:18px 0 8px}.plain-list{color:#4b5265;margin:0;padding-left:18px}.report-card{background:var(--surface-soft);border-radius:8px;padding:12px}.report-card p{margin:8px 0 0}.report-card small{color:var(--red);margin-top:8px;display:block}.empty{color:var(--muted);margin:0}.pill{color:#007a52;background:#e9fff6;border-radius:999px;padding:3px 8px;font-weight:800;display:inline-block}.timeline{gap:10px;display:grid}.timeline-item{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;grid-template-columns:120px 18px 1fr;align-items:center;gap:12px;padding:12px;display:grid}.timeline-item span{border:3px solid;border-radius:999px;width:12px;height:12px}.timeline-item time{color:var(--muted)}.timeline-item small{color:var(--muted);margin-top:4px;display:block}@media (width<=1050px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:10;height:auto;padding:16px;position:sticky}.sidebar-inner{height:auto;box-shadow:none;gap:16px;padding:0;position:static;overflow:visible}nav{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-grid,.split,.wide-left,.filters{grid-template-columns:1fr 1fr}.workspace-head{flex-direction:column;align-items:start}.kanban-board{grid-template-columns:repeat(3,minmax(230px,1fr))}}@media (width<=680px){.app-shell{display:block}.sidebar{border-right:0;border-bottom:1px solid var(--line);top:0}.sidebar-inner{gap:12px;height:auto;padding:16px;position:static;overflow:visible;box-shadow:0 8px 24px #1f243014}.sidebar h1{font-size:19px}.sidebar .eyebrow{font-size:11px}.profile{display:none}nav{scroll-snap-type:x mandatory;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.nav{scroll-snap-align:start;white-space:nowrap;flex:none;justify-content:center;min-width:138px;padding:10px 12px}.content{padding:14px}.stack{gap:16px}nav,.kpi-grid,.split,.wide-left,.filters,.two,.meta-grid{grid-template-columns:1fr}.page-head h2{font-size:24px}.page-head p:last-child{font-size:14px}.kpi{min-height:94px}.kpi strong{font-size:28px}.panel{padding:14px}.workspace-head{gap:12px}.timeline-item{grid-template-columns:1fr}.view-tabs{width:100%}.view-tab{flex:112px;justify-content:center;padding:10px 8px}.workspace-summary{width:100%}.workspace-summary span{flex:1}.workspace-filters{gap:8px}.workspace-surface{padding:10px}.table-scroll,.timeline-surface,.gantt-surface{-webkit-overflow-scrolling:touch}.project-table{min-width:860px}.kanban-board{grid-template-columns:1fr;overflow-x:visible}.kanban-column{min-width:0}.calendar-grid{grid-template-columns:1fr}.project-timeline-row,.gantt-row{grid-template-columns:180px 1fr;min-width:620px}.gantt-scale{min-width:620px}.drawer-panel{padding:18px}.drawer-close{margin-left:auto;position:sticky;top:0}.detail-panel{width:100vw}.notif-panel{width:calc(100vw - 80px);left:auto;right:10px}.summary-grid{grid-template-columns:1fr}.modal-content{max-width:94vw;padding:20px}}.login-container{background:linear-gradient(135deg,#f5f6fa 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border:1px solid var(--line);box-sizing:border-box;text-align:center;background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px 32px;transition:transform .2s,box-shadow .2s;box-shadow:0 10px 30px #0000000d,0 1px 3px #00000005}.login-card:hover{transform:translateY(-2px);box-shadow:0 12px 35px #00000014}.login-logo{color:#fff;background:#2f6b7a;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;transition:transform .3s;display:flex;box-shadow:0 4px 12px #2f6b7a33}.login-logo:hover{transform:rotate(5deg)scale(1.05)}.login-title{color:#1e293b;margin:0 0 8px;font-size:22px;font-weight:700}.login-subtitle{color:#64748b;margin:0 0 32px;font-size:14px}.login-error{color:#be123c;text-align:left;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;margin-bottom:20px;padding:10px 14px;font-size:13px;animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{text-align:left;flex-direction:column;gap:6px;display:flex}.form-group label{color:#475569;font-size:12px;font-weight:700}.input-icon-wrapper{position:relative}.input-icon-wrapper span{color:#94a3b8;align-items:center;display:flex;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-icon-wrapper input{padding-left:38px!important}.login-btn{color:#fff;cursor:pointer;background:#2f6b7a;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:800;transition:all .2s;box-shadow:0 4px 12px #2f6b7a26}.login-btn:hover:not(:disabled){background:#24535e;transform:translateY(-1px);box-shadow:0 6px 16px #2f6b7a40}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{background:var(--line-strong);color:var(--muted);cursor:not-allowed;box-shadow:none}.login-hint{color:#94a3b8;white-space:pre-line;border-top:1px dashed #e2e8f0;margin-top:32px;padding-top:16px;font-size:11px;line-height:1.5}.default-pwd-banner{color:#664d03;box-sizing:border-box;background:#fff3cd;border-bottom:1px solid #ffecb5;justify-content:space-between;align-items:center;width:100%;padding:12px 28px;font-size:14px;animation:.3s ease-out fadeInDown;display:flex}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.default-pwd-banner button{color:#664d03;cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:800;text-decoration:underline;transition:color .2s}.default-pwd-banner button:hover{color:#493702}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-modal);background:#1f243066;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{border:1px solid var(--line);box-sizing:border-box;background:#fff;border-radius:12px;width:90%;max-width:480px;padding:24px;animation:.2s ease-out scaleIn;position:relative;box-shadow:0 20px 40px #1f243026}.modal-close{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:#fff;border-radius:8px;place-items:center;width:32px;height:32px;transition:background .15s,color .15s,border-color .15s;display:inline-grid;position:absolute;top:16px;right:16px}.modal-close:hover{background:var(--primary-soft);color:var(--primary-strong);border-color:var(--primary)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-content h3{color:var(--text);border-bottom:1px solid var(--line);margin:0 0 20px;padding-bottom:12px;font-size:18px}.modal-form{flex-direction:column;gap:16px;display:flex}.form-row-2{gap:12px;display:flex}.form-row-2>div{flex:1}.checkbox-group{gap:20px;margin-top:6px;display:flex}.checkbox-group label{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:13px;font-weight:700;display:flex}.checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);margin:0}.form-info-box{background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;gap:8px;margin-top:6px;padding:10px;display:flex}.form-info-box svg{color:var(--yellow);flex-shrink:0}.form-info-box div{color:var(--muted);font-size:12px;line-height:1.4}.btn-primary{color:#fff;cursor:pointer;background:#2f6b7a;border:0;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-weight:800;transition:all .2s;display:inline-flex}.btn-primary:hover:not(:disabled){background:#24535e;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{border:1px solid var(--line-strong);color:var(--text);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-weight:800;transition:all .2s;display:inline-flex}.btn-secondary:hover:not(:disabled){background:var(--surface-soft);border-color:var(--muted)}.btn-danger{background:var(--red);color:#fff;cursor:pointer;border:0;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-weight:800;transition:all .2s;display:inline-flex}.btn-danger:hover:not(:disabled){background:#c8324b}.modal-actions{border-top:1px solid var(--line);justify-content:flex-end;gap:10px;margin-top:14px;padding-top:14px;display:flex}.role-badge{border-radius:10px;padding:3px 8px;font-size:11px;font-weight:700}.role-badge.Admin{color:#842029;background:#f8d7da}.role-badge.Manager{color:#087990;background:#cff4fc}.role-badge.PM{color:#722ed1;background:#f9f0ff}.role-badge.Member{color:#595959;background:#f5f5f5}.action-buttons{justify-content:flex-end;gap:10px;display:flex}.action-btn-edit{color:#2f6b7a;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:2px;padding:4px;font-size:13px;font-weight:700;display:flex}.action-btn-edit:hover{background:var(--primary-soft)}.action-btn-delete{color:var(--red);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:2px;padding:4px;font-size:13px;font-weight:700;display:flex}.action-btn-delete:hover{background:#fff1f2}.expandable-table .expand-cell{text-align:center;cursor:pointer;width:28px;padding:0 4px}.expandable-table .expand-icon{color:var(--muted);margin:auto;display:block}.expandable-table tr.project-table-row{cursor:pointer;transition:background .15s}.expandable-table tr.project-table-row:nth-child(2n){background:var(--surface-tint)}.expandable-table tr.project-table-row:hover,.expandable-table tr.project-table-row.expanded>td{background:var(--primary-soft)}.sub-row-container td.sub-row-cell{border-bottom:2px solid var(--line);background:#f9faff;padding:0}.sub-row-content{flex-direction:column;gap:2px;padding:8px 16px 12px 52px;display:flex}.sub-row-empty{color:var(--muted);padding:6px 0;font-size:12px}.sub-milestone-row{border:1px solid var(--line);background:#fff;border-radius:6px;align-items:center;gap:10px;padding:5px 10px;font-size:12.5px;transition:background .1s;display:flex}.sub-milestone-row:hover{background:var(--surface-tint)}.sub-ms-icon{font-size:13px}.sub-ms-name{color:var(--text);flex:1;font-weight:600}.sub-ms-date{color:var(--muted);font-size:11.5px}.sub-ms-amount{color:#137333;background:#e6f4ea;border-radius:4px;padding:1px 6px;font-size:12px;font-weight:700}.sub-ms-status{color:#666;background:#e9ecef;border-radius:10px;padding:1px 7px;font-size:11px}.sub-ms-status.done{color:#198754;background:#e8f5e9}.sub-ms-status.delayed{color:#dc3545;background:#ffebee}.sub-ms-status.inprog{color:#0d47a1;background:#e3f2fd}.detail-panel{width:460px;z-index:var(--z-drawer);flex-direction:column;animation:.22s cubic-bezier(.4,0,.2,1) slideInRight;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.panel-inner{background:var(--surface);border-left:1px solid var(--line);flex-direction:column;gap:16px;height:100%;padding:28px 24px;display:flex;position:relative;overflow-y:auto;box-shadow:-8px 0 32px #1f24301f}.detail-tabs{border-bottom:2px solid var(--line);gap:4px;margin-bottom:4px;display:flex}.detail-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-2px;padding:8px 12px;font-size:13px;font-weight:600;transition:color .15s,border-color .15s}.detail-tab:hover{color:var(--primary)}.detail-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-soft)}.tab-content{flex-direction:column;gap:12px;display:flex}.tab-content h4{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:13.5px;font-weight:700}.section-header-row{justify-content:space-between;align-items:center;display:flex}.member-table{border-collapse:collapse;width:100%;font-size:13px}.member-table th{text-align:left;color:var(--muted);border-bottom:1px solid var(--line);text-transform:uppercase;padding:6px 8px;font-size:11px}.member-table td{border-bottom:1px solid var(--line);vertical-align:middle;padding:8px}.alloc-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.alloc-badge.alloc-低{color:#388e3c;background:#e8f5e9}.alloc-badge.alloc-中{color:#f57f17;background:#fff8e1}.alloc-badge.alloc-高{color:#e65100;background:#fff3e0}.alloc-badge.alloc-滿載{color:#c62828;background:#ffebee}.risk-list{flex-direction:column;gap:10px;display:flex}.risk-card{border:1px solid var(--line);background:#fff;border-radius:8px;flex-direction:column;gap:8px;padding:12px 14px;transition:box-shadow .15s;display:flex}.risk-card:hover{box-shadow:0 2px 8px #1f24301a}.risk-card.risk-sev-high{border-left:4px solid var(--red)}.risk-card.risk-sev-medium{border-left:4px solid var(--yellow)}.risk-card.risk-sev-low{border-left:4px solid var(--green)}.risk-card-head{justify-content:space-between;align-items:center;display:flex}.risk-type-badge{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.risk-type-badge.risk-type-risk{color:#e65100;background:#fff3e0}.risk-type-badge.risk-type-issue{color:#1565c0;background:#e3f2fd}.risk-type-badge.risk-type-help{color:#6a1b9a;background:#f3e5f5}.risk-sev-badge{text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700}.risk-sev-badge.sev-high{color:var(--red);background:#ffebee}.risk-sev-badge.sev-medium{color:var(--yellow);background:#fff8e1}.risk-sev-badge.sev-low{color:var(--green);background:#e8f5e9}.risk-status{border-radius:10px;padding:2px 8px;font-size:11px}.risk-status.open{color:#c62828;background:#ffebee}.risk-status.inprog{color:#1565c0;background:#e3f2fd}.risk-status.closed{color:#2e7d32;background:#e8f5e9}.risk-desc{color:var(--text);margin:0;font-size:13px;line-height:1.5}.risk-meta{color:var(--muted);gap:14px;font-size:11.5px;display:flex}.risk-form{border:1px solid var(--line);background:#f9faff;border-radius:8px;padding:14px}.form-row-2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-field{flex-direction:column;gap:4px;display:flex}.form-field label{color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:700}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--line-strong);background:#fff;border-radius:6px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--primary)}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.btn-primary-sm{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:700;transition:background .15s}.btn-primary-sm:hover{background:var(--primary-strong)}.btn-primary-sm:disabled{opacity:.5;cursor:not-allowed}.btn-secondary-sm{border:1px solid var(--line-strong);color:var(--text);cursor:pointer;background:#fff;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s}.btn-secondary-sm:hover{background:var(--surface-tint)}.text-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:12px;font-weight:700;transition:background .15s,color .15s}.text-btn:hover{background:var(--primary-soft)}.text-btn.danger{color:var(--red)}.text-btn.danger:hover{background:#ffebee}.muted-text{color:var(--muted);font-size:11.5px}.milestone-item-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.milestone-item-info{flex-direction:column;gap:3px;display:flex}.type-tag{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.amt-tag{color:#137333;font-size:12px;font-weight:700}.inline-form{border:1px solid var(--line);background:#f9faff;border-radius:8px;flex-direction:column;gap:10px;padding:14px;display:flex}.inline-form h5{margin:0 0 4px;font-size:13px;font-weight:700}.cross-timeline-surface{overflow:hidden;padding:0!important}.cross-timeline-controls{border-bottom:1px solid var(--line);background:var(--surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex}.ct-scale-toggle{gap:4px;display:flex}.ct-nav{align-items:center;gap:12px;display:flex}.ct-nav-btn{border:1px solid var(--line-strong);color:var(--primary);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700}.ct-nav-btn:hover{background:var(--primary-soft)}.ct-window-label{color:var(--text);text-align:center;min-width:200px;font-size:13px;font-weight:800}.cross-timeline-grid{max-height:calc(100vh - 300px);overflow:auto}.ct-row{border-bottom:1px solid var(--line);grid-template-columns:220px 1fr;min-height:52px;display:grid}.ct-row:not(.ct-ruler-row):hover{background:var(--surface-tint);cursor:pointer}.ct-ruler-row{background:var(--surface-soft);min-height:36px}.ct-label-cell{border-right:1px solid var(--line);background:var(--surface);z-index:10;align-items:center;padding:10px 14px;display:flex;position:sticky;left:0}.ct-project-label{align-items:center;gap:8px;display:flex}.ct-project-label>div{flex-direction:column;gap:2px;display:flex}.ct-project-label strong{color:var(--text);font-size:13px}.ct-project-label small{color:var(--muted);font-size:11px}.ct-track-cell{min-width:600px;position:relative}.ct-ruler{align-items:flex-end;padding-bottom:6px;display:flex}.ct-ruler-tick{color:var(--muted);white-space:nowrap;font-size:11px;font-weight:700;position:absolute;bottom:6px;transform:translate(-50%)}.ct-track{padding:8px 0}.ct-today-line{background:var(--red);opacity:.65;pointer-events:none;z-index:5;border-radius:1px;width:2px;position:absolute;top:0;bottom:0}.ct-bar{background:#f0f4ff;border:2px solid;border-radius:5px;align-items:center;min-width:16px;height:22px;display:flex;position:absolute;top:50%;overflow:hidden;transform:translateY(-50%)}.ct-bar-fill{opacity:.45;height:100%}.ct-bar-label{color:#333;font-size:10px;font-weight:800;position:absolute;right:5px}.ct-milestone-diamond{cursor:pointer;z-index:8;background:#fff;border:2px solid;width:12px;height:12px;position:absolute;top:50%;transform:translate(-50%,-50%)rotate(45deg)}.ct-milestone-diamond:hover{z-index:20;transform:translate(-50%,-50%)rotate(45deg)scale(1.6)}.ct-billing-dot{cursor:pointer;z-index:8;background:#e6f4ea;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:800;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.ct-billing-dot:hover{z-index:20;transform:translate(-50%,-50%)scale(1.3)}.ct-billing-icon{color:#137333}.ct-tooltip{color:#fff;white-space:nowrap;pointer-events:none;z-index:var(--z-tooltip);background:#1f2430;border-radius:7px;flex-direction:column;gap:3px;min-width:140px;padding:8px 12px;font-size:12px;display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%)rotate(-45deg);box-shadow:0 4px 16px #0003}.ct-billing-dot .ct-tooltip{transform:translate(-50%)}.ct-tooltip:after{content:"";border:6px solid #0000;border-top-color:#1f2430;position:absolute;top:100%;left:50%;transform:translate(-50%)}.ct-milestone-diamond:hover .ct-tooltip,.ct-billing-dot:hover .ct-tooltip{display:flex}.summary-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;display:grid}.summary-card{background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;padding:12px}.summary-card small{color:var(--muted);margin-bottom:4px;font-size:11px;display:block}.summary-card strong{color:var(--text);font-size:15px}.notif-bell{border:1px solid var(--line);width:36px;height:36px;color:var(--muted);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.notif-bell:hover{background:var(--primary-soft);color:var(--primary-strong);border-color:var(--primary)}.notif-badge{background:var(--red);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px}.notif-panel{background:var(--surface);border:1px solid var(--line);width:340px;max-height:420px;box-shadow:var(--shadow);z-index:var(--z-dropdown);border-radius:10px;flex-direction:column;display:flex;position:absolute;bottom:0;left:60px;overflow:hidden}.notif-panel-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.notif-panel-header strong{font-size:14px}.notif-panel-body{max-height:360px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--line);cursor:pointer;padding:10px 14px;transition:background .12s}.notif-item:hover{background:var(--surface-tint)}.notif-item--unread{background:var(--primary-soft);border-left:3px solid var(--primary)}.notif-item-title{color:var(--text);font-size:13px;font-weight:700}.notif-item-msg{color:var(--muted);margin:2px 0;font-size:12px}.notif-item small{color:var(--muted);font-size:11px}.ms-timeline{margin:16px 0;padding:20px 0 16px;overflow-x:auto}.ms-timeline-track{border-top:2px solid var(--line);min-width:400px;height:60px;margin:0 40px;position:relative}.ms-timeline-dot{position:absolute;top:-6px;transform:translate(-50%)}.ms-timeline-marker{cursor:pointer;border:2px solid #fff;border-radius:50%;width:12px;height:12px;transition:transform .15s;box-shadow:0 0 0 2px,0 2px 6px #0000001f}.ms-timeline-marker:hover{transform:scale(1.35)}.ms-timeline-label{white-space:nowrap;text-align:center;background:var(--surface);border:1px solid var(--line);z-index:var(--z-tooltip);border-radius:6px;padding:4px 8px;display:none;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #00000014}.ms-timeline-label strong{color:var(--text);font-size:11px;display:block}.ms-timeline-label small{color:var(--muted);font-size:10px;display:block}.ms-timeline-label .status-pill{font-weight:700}.ms-timeline-dot:hover .ms-timeline-label{display:block}.skeleton{background:linear-gradient(90deg, var(--surface-tint) 25%, var(--surface-soft) 50%, var(--surface-tint) 75%);background-size:200% 100%;border-radius:4px;line-height:1;animation:1.4s ease-in-out infinite skeleton-shimmer;display:inline-block}.skeleton--text{width:100%;height:14px;margin-bottom:8px}.skeleton--circle{border-radius:50%}.skeleton--rect{border-radius:6px}.skeleton-row{flex-direction:column;gap:10px;padding:16px 0;display:flex}.skeleton-row--table{flex-direction:column;display:flex}.skeleton-table-row{border-bottom:1px solid var(--line);grid-template-columns:2fr 1fr 1fr 80px;align-items:center;gap:12px;padding:12px 16px;display:grid}.skeleton-table-row .skeleton{margin-bottom:0}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.wbs-container{flex-direction:column;gap:12px;display:flex}.wbs-toolbar{justify-content:space-between;align-items:center;display:flex}.wbs-toolbar h4{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:13.5px;font-weight:700}.wbs-tree{border:1px solid var(--line);border-radius:8px;overflow:hidden}.wbs-row{border-bottom:1px solid var(--line);grid-template-columns:24px 24px 1fr 70px 90px 80px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .12s;display:grid}.wbs-row:last-child{border-bottom:none}.wbs-row:hover{background:var(--surface-tint)}.wbs-header{background:var(--surface-soft);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;cursor:default;font-size:11px;font-weight:700}.wbs-header:hover{background:var(--surface-soft)}.wbs-completed .wbs-name-text{opacity:.65;text-decoration:line-through}.wbs-depth-0{padding-left:12px}.wbs-depth-1{padding-left:36px}.wbs-depth-2{padding-left:60px}.wbs-depth-1 .wbs-level-badge{background:var(--surface-tint)}.wbs-depth-2 .wbs-level-badge{background:var(--surface-soft)}.wbs-cell-grip{cursor:grab;color:var(--muted);opacity:.35;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.wbs-row:hover .wbs-cell-grip{opacity:.7}.wbs-cell-grip:active{cursor:grabbing;opacity:1;color:var(--primary)}.wbs-row.wbs-dragging{opacity:.5}.wbs-row.wbs-drag-over{background:var(--surface-tint);outline:2px dashed var(--primary);outline-offset:-2px}.wbs-cell-toggle{justify-content:center;align-items:center;display:flex}.wbs-toggle-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:background .12s;display:flex}.wbs-toggle-btn:hover{background:var(--surface-tint)}.wbs-toggle-placeholder{width:14px}.wbs-cell-name{align-items:center;gap:6px;display:flex;overflow:hidden}.wbs-name-text{text-overflow:ellipsis;white-space:nowrap;cursor:default;overflow:hidden}.wbs-name-text:hover{color:var(--primary)}.wbs-level-badge{background:var(--surface-soft);color:var(--muted);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:1px 5px;font-size:10px}.wbs-assignee{color:var(--muted);flex-shrink:0;font-size:10px}.wbs-cell-code{color:var(--muted);font-size:11px}.wbs-cell-status{align-items:center;display:flex}.wbs-status-select{border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;border-radius:4px;max-width:72px;padding:2px 4px;font-size:11px}.wbs-cell-actions{justify-content:flex-end;align-items:center;gap:2px;display:flex}.wbs-delete-btn{opacity:.5}.wbs-delete-btn:hover{opacity:1;color:var(--red)}.wbs-edit-input{border:1px solid var(--primary);background:var(--surface);width:100%;color:var(--text);border-radius:4px;outline:none;padding:3px 6px;font-size:13px}.wbs-children .wbs-row:last-child{border-bottom:1px solid var(--line)}.wbs-row-group:last-child .wbs-row,.wbs-row-group:last-child .wbs-children .wbs-row:last-child{border-bottom:none}.editable-cell{cursor:pointer;transition:opacity .12s;display:inline-block}.editable-cell:hover{opacity:.7}.inline-edit-select{border:1px solid var(--primary);color:var(--text);background:#fff;border-radius:4px;outline:none;max-width:120px;padding:2px 4px;font-size:12px}.inline-edit-date{border:1px solid var(--primary);color:var(--text);background:#fff;border-radius:4px;outline:none;max-width:130px;padding:2px 4px;font-size:12px}.inline-edit-progress{align-items:center;gap:6px;display:inline-flex}.inline-edit-progress input[type=range]{cursor:pointer;width:80px;height:4px;accent-color:var(--primary)}.inline-edit-progress .progress-val{color:var(--primary-strong);min-width:30px;font-size:11px;font-weight:700}.sub-wbs-section{flex-direction:column;gap:6px;margin-top:14px;display:flex}.sub-wbs-title{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:700}.sub-wbs-tree{flex-direction:column;gap:2px;display:flex}.sub-wbs-row{border-radius:4px;align-items:center;gap:6px;padding:4px 8px;font-size:12.5px;transition:background .12s;display:flex}.sub-wbs-row:hover{background:var(--surface-tint)}.sub-wbs-row.depth-1{padding-left:24px}.sub-wbs-row.depth-2{padding-left:44px}.sub-wbs-indent{flex-shrink:0}.sub-wbs-status-dot{background:#adb5bd;border-radius:50%;flex-shrink:0;width:8px;height:8px}.sub-wbs-status-dot.in_progress{background:#f2a600}.sub-wbs-status-dot.completed{background:#00a66c}.sub-wbs-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.sub-wbs-name.done{opacity:.6;text-decoration:line-through}.sub-wbs-status select{border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;border-radius:4px;max-width:72px;padding:1px 4px;font-size:11px}
