body{margin:0;font-family:PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;background:#f8fafc;color:#1d2b45;font-size:13px}.layout{min-height:100vh;display:grid;grid-template-columns:220px 1fr}.sidebar{background:#1a1f2e;color:#e5e7eb;padding:0 0 24px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.brand-block{display:flex;align-items:center;gap:10px;padding:16px 14px 14px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:2px}.brand-icon{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar h2{margin:0;font-size:14px;font-weight:600;color:#f3f4f6;letter-spacing:.2px}.side-title{margin:10px 14px 4px;color:#4b5563;font-weight:500;font-size:10px;text-transform:uppercase;letter-spacing:.8px}.tree-toolbar{display:flex;flex-wrap:wrap;gap:4px;padding:0 10px;margin-bottom:6px}.toolbar-btn{border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#9ca3af;border-radius:5px;font-size:11px;padding:4px 8px;cursor:pointer;transition:all .15s;font-family:inherit}.toolbar-btn:hover{background:#ffffff1a;color:#e5e7eb}.toolbar-btn.edit-active{background:#3b82f640;border-color:#3b82f680;color:#93c5fd}.edit-toolbar{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:8px;margin:0 10px 8px;display:flex;flex-direction:column;gap:5px}.edit-toolbar-row{display:flex;gap:4px}.edit-btn{flex:1;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#d1d5db;border-radius:5px;font-size:11px;padding:5px 4px;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap;text-align:center}.edit-btn:hover:not(:disabled){background:#ffffff1a;color:#f3f4f6}.edit-btn:disabled{opacity:.25;cursor:not-allowed}.edit-btn.danger{color:#fca5a5;border-color:#ef44444d}.edit-btn.danger:hover:not(:disabled){background:#ef444433}.edit-btn.icon-btn{padding:5px 3px;font-size:13px}.edit-btn.save-btn{width:100%;flex:none;background:#3b82f64d;border-color:#3b82f680;color:#93c5fd;font-weight:600}.edit-btn.save-btn:hover{background:#3b82f673}.edit-saved-tip{font-size:10px;color:#6ee7b7;text-align:center;padding:2px 0}.selected-edit{outline:2px solid rgba(59,130,246,.6)!important}.dept-search{width:calc(100% - 28px);margin:0 14px 8px;border:1px solid rgba(255,255,255,.08);background:#ffffff0d;color:#e5e7eb;border-radius:7px;padding:7px 10px;font-size:12px;outline:none;transition:border-color .15s;box-sizing:border-box}.dept-search:focus{border-color:#3b82f680}.dept-search::placeholder{color:#fff3}.side-list{display:flex;flex-direction:column;gap:1px;padding:0 8px;flex:1}.side-group{display:flex;flex-direction:column}.side-item{border:none;background:transparent;color:#9ca3af;text-align:left;border-radius:7px;padding:8px 8px 8px 6px;cursor:pointer;transition:background .12s,color .12s;display:flex;align-items:center;gap:6px;width:100%;box-sizing:border-box;font-family:inherit;font-size:13px;font-weight:500}.side-item:hover{background:#ffffff0f;color:#f3f4f6}.side-item:hover .hide-toggle{opacity:1}.side-item.active{background:#2563eb;color:#fff}.side-item.active:hover{background:#2563eb}.side-item.active .hide-toggle{color:#ffffffa6;border-color:#ffffff40}.hidden-dept{opacity:.4}.nav-chevron{width:16px;height:16px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#4b5563;border-radius:3px;transition:color .12s;line-height:1}.nav-toggle{cursor:pointer}.nav-toggle:hover{color:#9ca3af;background:#ffffff14}.side-item.active .nav-chevron{color:#ffffffbf}.nav-overview{color:#60a5fa;font-size:11px}.nav-leaf{color:#374151;font-size:10px}.side-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hide-toggle{margin-left:auto;flex-shrink:0;font-size:10px;color:#6b7280;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:1px 6px;cursor:pointer;opacity:0;transition:opacity .15s,background .12s;white-space:nowrap}.hide-toggle:hover{background:#ffffff1a;color:#d1d5db}.child-item:hover .hide-toggle,.leaf-item:hover .hide-toggle{opacity:1}.child-list{margin-left:20px;border-left:1px solid rgba(255,255,255,.05);padding-left:4px;display:flex;flex-direction:column;gap:1px;padding-top:2px;padding-bottom:4px}.child-group{display:flex;flex-direction:column}.child-item{font-size:12px;color:#9ca3af;padding:6px 8px 6px 6px;border-radius:6px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;width:100%;text-align:left;font-family:inherit;transition:background .12s,color .12s}.child-item:hover{background:#ffffff0d;color:#e5e7eb}.child-item.selected{background:#2563eb40;color:#93c5fd}.child-chevron{width:12px;height:12px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:9px;color:#374151;cursor:pointer;border-radius:3px;transition:color .12s;opacity:.5}.child-chevron:hover{color:#9ca3af;opacity:.85}.child-chevron-placeholder{width:12px;flex-shrink:0;display:inline-block}.child-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dept-name-input{flex:1;min-width:0;background:#ffffff1a;border:1px solid #60a5fa;border-radius:3px;color:#f1f5f9;font-size:12px;padding:1px 4px;outline:none;width:100%}.leaf-list{margin-left:14px;border-left:1px solid rgba(255,255,255,.04);padding-left:4px;display:flex;flex-direction:column;gap:1px;padding-top:1px;padding-bottom:3px}.leaf-item{font-size:11px;color:#6b7280;padding:5px 8px 5px 6px;border-radius:5px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;width:100%;text-align:left;font-family:inherit;transition:background .12s,color .12s}.leaf-item:hover{background:#ffffff0a;color:#d1d5db}.leaf-item.selected{background:#2563eb33;color:#93c5fd}.leaf-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{padding:20px 22px;min-width:0;background:#fff}.top-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:14px 18px;background:#fff;border-radius:12px;border:1px solid #F1F5F9;box-shadow:0 1px 4px #0f172a0f;gap:12px}.top-title-wrap{display:flex;flex-direction:column;gap:4px;min-width:0}.top-title-row{display:flex;align-items:center;gap:10px}h1{margin:0;font-size:22px;font-weight:700;color:#0f172a;letter-spacing:-.3px}.aggregate-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:2px 8px;flex-shrink:0}.scope-link{border:none;background:transparent;color:#2563eb;text-decoration:underline;cursor:pointer;font-size:11px;font-family:inherit;padding:0}.scope-list{margin-top:4px;display:flex;flex-wrap:wrap;gap:4px}.scope-list span{font-size:11px;color:#2a4f86;background:#e9f1ff;border:1px solid #c9dcff;border-radius:10px;padding:1px 8px}.top-right-bar{display:flex;align-items:center;gap:8px;flex-shrink:0}.version-chip{display:flex;align-items:center;gap:5px;background:#f8fafc;border:1px solid #E2E8F0;border-radius:7px;padding:4px 9px}.version-label{font-size:10px;color:#94a3b8;font-weight:500}.version-value{font-size:11px;color:#334155;font-weight:600;font-variant-numeric:tabular-nums}.loading-dot{font-size:8px;color:#3b82f6;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.top-date-note{font-size:11px;color:#94a3b8;white-space:nowrap}.unit-badge{font-size:11px;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:5px;padding:3px 7px;font-weight:500}.period-box{display:flex;gap:4px;align-items:center}.period-box select{border:1px solid #E2E8F0;border-radius:7px;padding:5px 8px;background:#fff;color:#1e293b;font-size:12px;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s;font-weight:500}.period-box select:focus{border-color:#3b82f6}.data-mgmt-btn{border:1px solid #E2E8F0;background:#fff;color:#374151;border-radius:7px;padding:5px 12px;cursor:pointer;font-weight:600;font-size:12px;font-family:inherit;transition:all .14s;white-space:nowrap}.data-mgmt-btn:hover{background:#f8fafc;border-color:#cbd5e1}.data-panel{margin-bottom:16px}.upload-panel{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;background:#fff;border-radius:10px;padding:12px 14px;border:1px solid #F1F5F9;box-shadow:0 1px 4px #0f172a0d}.upload-panel label{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:600;color:#475569}.hidden-file{display:none}.upload-row{display:flex;align-items:center;gap:7px}.upload-row button{border:1px solid #E2E8F0;background:#f8fafc;border-radius:6px;padding:4px 10px;cursor:pointer;color:#1e3a5f;font-weight:600;font-size:11px;font-family:inherit;white-space:nowrap;transition:all .14s}.upload-row button:hover{background:#eff6ff;border-color:#93c5fd}.upload-row span{color:#94a3b8;font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hint{margin:0 0 12px;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:12px;font-weight:500}.err-toggle{background:none;border:none;color:#1e40af;font-size:11px;cursor:pointer;padding:0;margin-bottom:6px;text-decoration:underline}.upload-err-table{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:8px}.upload-err-table th,.upload-err-table td{border:1px solid #bfdbfe;padding:4px 8px;text-align:left}.upload-err-table th{background:#dbeafe;color:#1e3a8a;font-weight:600}.upload-err-table tr:nth-child(2n) td{background:#f0f7ff}.warn-banner{margin:0 0 12px;background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;border-radius:8px;padding:8px 12px;font-size:12px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.kpi-grid.three-cards{grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid #F1F5F9;box-shadow:0 2px 8px #0f28500f;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column;position:relative}.kpi-card:hover{box-shadow:0 8px 24px #0f28501a;transform:translateY(-2px)}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px}.kpi-card.card-blue:before{background:#3b82f6}.kpi-card.card-green:before{background:#10b981}.kpi-card.card-amber:before{background:#f59e0b}.kpi-card.card-warn:before{background:#f97316}.kpi-card.card-danger:before{background:#ef4444}.kpi-body{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 18px 0 22px;gap:12px}.kpi-texts{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.kpi-label{font-size:13px;font-weight:600;color:#475569;line-height:1.4}.kpi-period{font-size:11px;font-weight:400;color:#94a3b8;margin-left:2px}.kpi-big{font-size:34px;font-weight:700;line-height:1.15;letter-spacing:-.5px;font-variant-numeric:tabular-nums;margin:4px 0}.kpi-big-blue{color:#2563eb}.kpi-big-green{color:#059669}.kpi-big-amber{color:#d97706}.kpi-big-warn{color:#b45309}.kpi-big-danger{color:#dc2626}.kpi-delta{font-size:13px;font-weight:600;display:flex;align-items:center;gap:3px}.kpi-delta .delta-suffix{font-size:11px;font-weight:400;color:#94a3b8;margin-left:3px}.delta-up{color:#ef4444}.delta-down{color:#10b981}.delta-na{color:#94a3b8;font-weight:400;font-size:12px}.kpi-budget-sub{font-size:11px;color:#78716c;margin-top:2px;line-height:1.5;font-variant-numeric:tabular-nums}.kpi-icon-wrap{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.kpi-icon-blue{background:#3b82f61a;color:#2563eb}.kpi-icon-green{background:#0596691a;color:#059669}.kpi-icon-amber{background:#d977061a;color:#d97706}.kpi-icon-danger{background:#dc26261a;color:#dc2626}.kpi-sparkline{display:block;width:100%;height:46px;margin-top:auto}.kpi-progress-wrap{padding:10px 18px 16px 22px;margin-top:auto}.kpi-progress-track{position:relative;height:6px;background:#f1f5f9;border-radius:6px;overflow:visible}.kpi-progress-fill{height:100%;border-radius:6px;background:#f59e0b;transition:width .5s ease}.kpi-progress-fill.fill-warn{background:#f97316}.kpi-progress-fill.fill-danger{background:#ef4444}.kpi-progress-pace{position:absolute;top:-4px;width:2px;height:14px;background:#94a3b8;border-radius:2px;transform:translate(-50%)}.kpi-progress-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:10px;color:#94a3b8}.overview9-wrap{display:flex;flex-direction:row;gap:14px;margin-bottom:16px;align-items:stretch}.ov-group{flex:1;border-radius:14px;overflow:hidden;border:1px solid #E2E8F0;box-shadow:0 2px 10px #0f28500f;transition:box-shadow .18s,transform .18s;position:relative}.ov-group:hover{box-shadow:0 6px 20px #0f28501c;transform:translateY(-2px)}.ov-group:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px}.ovg-blue:before{background:#3b82f6}.ovg-green:before{background:#10b981}.ovg-yellow:before{background:#eab308}.ovg-blue{background:#eff6ff;border-color:#bfdbfe}.ovg-green{background:#f0fdf4;border-color:#a7f3d0}.ovg-yellow{background:#fefce8;border-color:#fde68a}.ov-group-header{padding:10px 16px 10px 22px;border-bottom:1px solid rgba(0,0,0,.05);display:flex;align-items:center}.ovg-blue .ov-group-header{background:#dbeafe}.ovg-green .ov-group-header{background:#d1fae5}.ovg-yellow .ov-group-header{background:#fef3c7}.ov-group-label{font-size:12px;font-weight:700;letter-spacing:.5px}.ovg-blue .ov-group-label{color:#1d4ed8}.ovg-green .ov-group-label{color:#065f46}.ovg-yellow .ov-group-label{color:#92400e}.ov-group-cards{display:flex;flex-direction:column}.ov-card{padding:12px 16px 10px 22px;border-bottom:1px solid rgba(0,0,0,.045)}.ov-card:last-child{border-bottom:none}.ov-sub-label{font-size:11px;font-weight:600;color:#64748b;margin-bottom:6px}.ov-card-main{display:flex;align-items:flex-end;justify-content:space-between;gap:8px}.ov-value{font-size:26px;font-weight:700;line-height:1.15;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.ovg-blue .ov-value{color:#2563eb}.ovg-green .ov-value{color:#059669}.ovg-yellow .ov-value{color:#a16207}.ov-neg{color:#dc2626!important}.ov-ly{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;padding-bottom:2px}.ov-ly-label{font-size:9.5px;color:#94a3b8;font-weight:500;line-height:1.3}.ov-ly-val{font-size:13px;font-weight:700;color:#94a3b8;font-variant-numeric:tabular-nums;line-height:1.3}.ov-foot{margin-top:5px}.ov-yoy{font-size:11px;font-weight:600}.ov-yoy.ov-up{color:#059669}.ov-yoy.ov-dn{color:#dc2626}.ov-yoy.ov-na{color:#94a3b8;font-weight:400}.panel{background:#fff;border-radius:12px;padding:14px 14px 6px;margin-bottom:14px;border:1px solid #F1F5F9;box-shadow:0 2px 8px #0f28500d}.panel h2{margin:0 0 12px;font-size:14px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.unit-inline{font-size:11px;color:#94a3b8;font-weight:500;margin-left:auto}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid #F1F5F9;padding:10px 14px;font-size:13px;white-space:nowrap}th{font-weight:600}.summary-table thead th{position:sticky;top:0;z-index:2;background:#1e293b;color:#fff;font-weight:600;border-bottom:2px solid #0F172A}.summary-table thead tr:first-child th{font-size:12px;text-align:center!important;background:#1e293b;color:#fff;border-bottom:1px solid rgba(255,255,255,.08);top:0}.summary-table thead tr:nth-child(2) th{background:#253348;color:#fff;font-size:11.5px;top:33px}.summary-table td{color:#374151;background:#fff;font-weight:400}.summary-table tbody tr:hover td{background:#eef4ff!important}.summary-table tbody tr:hover td:first-child{box-shadow:inset 3px 0 #93c5fd}.summary-table th:nth-child(n+2),.summary-table td:nth-child(n+2){text-align:right}.summary-table th:first-child,.summary-table td:first-child{text-align:left}.summary-table th:nth-child(2),.summary-table td:nth-child(2){text-align:left}.summary-table.company-summary-table th:nth-child(n+2),.summary-table.company-summary-table td:nth-child(n+2){text-align:right}.summary-table.company-summary-table td:first-child{text-align:left}.summary-table td:nth-child(3),.summary-table td:nth-child(6),.summary-table td:nth-child(7),.summary-table td:nth-child(9),.summary-table td:nth-child(10),.summary-table td:nth-child(11){font-variant-numeric:tabular-nums}.summary-table.company-summary-table td:nth-child(2),.summary-table.company-summary-table td:nth-child(5),.summary-table.company-summary-table td:nth-child(6),.summary-table.company-summary-table td:nth-child(8),.summary-table.company-summary-table td:nth-child(9),.summary-table.company-summary-table td:nth-child(10){font-variant-numeric:tabular-nums}.business-row td{background:#fff!important;color:#1e293b;font-weight:400}.business-row.income_total td,.business-row.cost_total td,.business-row.profit td{background:#eff6ff!important;color:#1e40af!important;font-weight:700!important}.subtotal-row td{background:#f1f5f9!important;color:#1e293b!important;font-weight:700!important;border-top:2px solid #CBD5E1!important;padding-top:10px!important;padding-bottom:10px!important}.sum-row td{background:#eff6ff!important;color:#1e40af;font-weight:700;border-top:2px solid #BFDBFE}.direct-item-row td:nth-child(1),.direct-item-row td:nth-child(2){font-weight:600;padding-left:4px!important}.summary-table.company-summary-table thead tr:first-child th:nth-child(2){border-left:2px solid #2563EB;border-right:2px solid #2563EB;border-top:2px solid #2563EB;color:#fff}.summary-table.company-summary-table thead tr:first-child th:nth-child(3){border-left:2px solid #475569;border-right:2px solid #475569;border-top:2px solid #475569;color:#fff}.summary-table.company-summary-table thead tr:nth-child(2) th:nth-child(2){border-left:2px solid #2563EB}.summary-table.company-summary-table thead tr:nth-child(2) th:nth-child(7){border-right:2px solid #2563EB}.summary-table.company-summary-table thead tr:nth-child(2) th:nth-child(8){border-left:2px solid #475569}.summary-table.company-summary-table thead tr:nth-child(2) th:nth-child(11){border-right:2px solid #475569}.summary-table.company-summary-table tbody td:nth-child(2){border-left:2px solid #2563EB}.summary-table.company-summary-table tbody td:nth-child(7){border-right:2px solid #2563EB}.summary-table.company-summary-table tbody td:nth-child(8){border-left:2px solid #475569}.summary-table.company-summary-table tbody td:nth-child(11){border-right:2px solid #475569}.summary-table.company-summary-table .subtotal-row td:nth-child(2){border-left:2px solid #2563EB!important}.summary-table.company-summary-table .subtotal-row td:nth-child(7){border-right:2px solid #2563EB!important}.summary-table.company-summary-table .subtotal-row td:nth-child(8){border-left:2px solid #475569!important}.summary-table.company-summary-table .subtotal-row td:nth-child(11){border-right:2px solid #475569!important}.summary-table:not(.company-summary-table) thead tr:first-child th:nth-child(2){border-left:2px solid #2563EB;border-right:2px solid #2563EB;border-top:2px solid #2563EB;color:#93c5fd}.summary-table:not(.company-summary-table) thead tr:first-child th:nth-child(3){border-left:2px solid #475569;border-right:2px solid #475569;border-top:2px solid #475569;color:#94a3b8}.summary-table:not(.company-summary-table) thead tr:nth-child(2) th:nth-child(3){border-left:2px solid #2563EB}.summary-table:not(.company-summary-table) thead tr:nth-child(2) th:nth-child(8){border-right:2px solid #2563EB}.summary-table:not(.company-summary-table) thead tr:nth-child(2) th:nth-child(9){border-left:2px solid #475569}.summary-table:not(.company-summary-table) thead tr:nth-child(2) th:nth-child(12){border-right:2px solid #475569}.summary-table:not(.company-summary-table) tbody tr:not(.subtotal-row):not(.sum-row) td:nth-child(3){border-left:2px solid #2563EB}.summary-table:not(.company-summary-table) tbody tr:not(.subtotal-row):not(.sum-row) td:nth-child(8){border-right:2px solid #2563EB}.summary-table:not(.company-summary-table) tbody tr:not(.subtotal-row):not(.sum-row) td:nth-child(9){border-left:2px solid #475569}.summary-table:not(.company-summary-table) tbody tr:not(.subtotal-row):not(.sum-row) td:nth-child(12){border-right:2px solid #475569}.summary-table:not(.company-summary-table) .subtotal-row td:nth-child(2){border-left:2px solid #2563EB!important}.summary-table:not(.company-summary-table) .subtotal-row td:nth-child(7){border-right:2px solid #2563EB!important}.summary-table:not(.company-summary-table) .subtotal-row td:nth-child(8){border-left:2px solid #475569!important}.summary-table:not(.company-summary-table) .subtotal-row td:nth-child(11){border-right:2px solid #475569!important}.link-num{color:#2563eb;cursor:pointer;text-decoration:underline;text-decoration-color:#2563eb4d}.link-num:hover{color:#1d4ed8}.drag-handle{color:transparent;margin-right:4px;cursor:grab;-webkit-user-select:none;user-select:none;font-size:11px;transition:color .15s}.draggable-row:hover .drag-handle{color:#94a3b8}.draggable-row:active{cursor:grabbing}.subtotal-row .drag-handle{font-size:13px}.restore-hidden-pill{display:inline-flex;align-items:center;gap:4px;margin-left:12px;padding:2px 10px;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;vertical-align:middle;transition:background .15s}.restore-hidden-pill:hover{background:#fde68a}.export-xlsx-btn{display:inline-flex;align-items:center;gap:5px;margin-left:12px;padding:3px 12px;background:#f0fdf4;color:#166534;border:1px solid #86efac;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;vertical-align:middle;transition:background .15s,border-color .15s;white-space:nowrap}.export-xlsx-btn:hover{background:#dcfce7;border-color:#4ade80}.export-xlsx-btn:active{background:#bbf7d0}.warn{color:#dc2626;font-weight:600}.ok{color:#059669}.note-th{min-width:160px;max-width:240px;text-align:left!important;border-left:1px dashed rgba(255,255,255,.2)!important;color:#ffffffbf!important;font-style:italic}.note-td{min-width:160px;max-width:240px;text-align:left!important;padding:6px 10px!important;vertical-align:top;border-left:1px dashed #E2E8F0!important;cursor:pointer;position:relative}.note-td:hover{background:#fafbff!important}.note-td.editing{padding:4px 6px!important;cursor:default}.note-text{font-size:11px;color:#475569;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;white-space:pre-wrap}.note-td.has-note:after{content:"✎";position:absolute;top:5px;right:6px;font-size:10px;color:#93c5fd;opacity:.7}.note-input{width:100%;box-sizing:border-box;border:1.5px solid #3B82F6;border-radius:6px;padding:6px 8px;font-size:11.5px;line-height:1.55;color:#1e293b;resize:none;outline:none;background:#f0f7ff;box-shadow:0 0 0 3px #3b82f624;font-family:inherit}.note-hint{margin-top:4px;font-size:10px;color:#94a3b8;display:flex;align-items:center;gap:2px;line-height:1.4}.note-hint kbd{display:inline-block;padding:1px 4px;background:#f1f5f9;border:1px solid #CBD5E1;border-radius:3px;font-size:9.5px;font-family:inherit;color:#475569;line-height:1.4}.note-td.saved-ok{background:#f0fdf4!important}.note-saved-badge{display:block;font-size:11px;font-weight:700;color:#16a34a;animation:note-fade-in .2s ease;margin-bottom:2px}.note-text-dim{opacity:.5}.note-td.saved-err{background:#fff1f2!important}.note-err-badge{display:block;font-size:11px;font-weight:600;color:#dc2626;animation:note-fade-in .2s ease}.note-add{font-size:11px;color:#94a3b8;display:block;text-align:center;line-height:28px;opacity:0;transition:opacity .15s}.note-td:hover .note-add{opacity:1}@keyframes note-fade-in{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.trend-modal{position:fixed;width:580px;max-width:calc(100vw - 24px);background:#fff;border-radius:14px;box-shadow:0 16px 48px #0f172a29,0 2px 10px #0f172a12;z-index:100;border:1px solid #e2e8f0;overflow:hidden}.trend-header{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;background:linear-gradient(90deg,#1e293b,#334155);color:#e2e8f0;cursor:move;font-size:12px;font-weight:500;gap:10px;letter-spacing:.01em}.trend-header span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trend-header button{border:none;background:#ffffff1f;color:#cbd5e1;font-size:12px;cursor:pointer;border-radius:6px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:background .12s;flex-shrink:0}.trend-header button:hover{background:#ffffff38;color:#fff}.chart-area{display:flex;gap:8px;align-items:stretch;height:230px;padding:14px 14px 6px;background:#fff;border-bottom:1px solid #f1f5f9;box-sizing:border-box}.y-axis{width:50px;display:flex;flex-direction:column;justify-content:space-between;font-size:10px;color:#94a3b8;text-align:right;padding-right:6px;font-variant-numeric:tabular-nums;padding-bottom:28px;flex-shrink:0}.bar-zone{flex:1;display:flex;gap:6px;align-items:stretch;border-left:1px solid #f1f5f9;padding-left:8px;overflow-x:auto}.bar-col{flex:1;min-width:32px;display:flex;flex-direction:column;align-items:center;padding-bottom:2px}.bar-val-space{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;min-height:0}.bar-top-val{font-size:8.5px;color:#94a3b8;font-weight:600;white-space:nowrap;padding-bottom:3px;font-variant-numeric:tabular-nums;line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis}.bar-top-val.val-current{color:#2563eb;font-size:9px;font-weight:700}.bar{width:72%;border-radius:4px 4px 0 0;background:#bfdbfe;transition:opacity .12s;flex-shrink:0}.bar:hover{opacity:.72}.bar.bar-current{background:linear-gradient(180deg,#60a5fa,#2563eb);box-shadow:0 4px 10px #2563eb38;border-radius:4px 4px 0 0}.bar-x-label{font-size:9px;color:#94a3b8;white-space:nowrap;margin-top:4px;transform:rotate(-30deg);transform-origin:center top;line-height:1;display:block;height:22px}.trend-stats{display:grid;grid-template-columns:repeat(4,1fr);background:#f8fafc}.trend-stats>div{padding:10px 12px;border-right:1px solid #f1f5f9;text-align:center}.trend-stats>div:last-child{border-right:none}.trend-stats strong{font-size:10px;color:#64748b;font-weight:600;display:block;letter-spacing:.01em}.trend-stats p{margin:4px 0 0;color:#1e40af;font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}.trend-stats small{display:block;margin-top:2px;font-size:10px}.view-tabs{display:flex;gap:4px;padding:8px 12px 4px;border-bottom:1px solid #1e3a5f33}.view-tab{flex:1;padding:6px 4px;border:none;background:transparent;color:#94a3b8;font-size:11.5px;font-weight:500;cursor:pointer;border-radius:7px;transition:all .15s}.view-tab:hover{background:#ffffff14;color:#cbd5e1}.view-tab.active{background:#ffffff24;color:#fff;font-weight:600}.proj-sidebar-hint{padding:14px 16px 4px;display:flex;flex-direction:column;gap:4px}.proj-sidebar-hint p{margin:0;font-size:11px;color:#94a3b8}.project-library{padding:28px 32px;min-height:100%;box-sizing:border-box}.proj-lib-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.proj-lib-header h1{margin:0 0 4px;font-size:22px;color:#0f172a;font-weight:700}.proj-lib-sub{margin:0;font-size:13px;color:#64748b}.proj-add-btn{padding:9px 20px;background:#1e40af;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.proj-add-btn:hover{background:#1d4ed8}.proj-msg{color:#dc2626;font-size:13px;margin:0 0 12px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.project-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px 20px;cursor:pointer;transition:box-shadow .15s,transform .1s}.project-card:hover{box-shadow:0 6px 20px #0f172a1a;transform:translateY(-1px)}.project-card.terminated{background:#f8fafc;border-color:#e2e8f0}.project-card.terminated:hover{box-shadow:0 4px 14px #0f172a12}.proj-card-top{display:flex;align-items:center;gap:8px;margin-bottom:10px}.proj-status-badge{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px}.proj-status-badge.active{background:#dcfce7;color:#15803d}.proj-status-badge.terminated{background:#f1f5f9;color:#64748b}.proj-term-date{font-size:10px;color:#94a3b8}.proj-card-name{margin:0 0 8px;font-size:16px;font-weight:700;color:#0f172a}.project-card.terminated .proj-card-name{color:#64748b}.proj-card-meta{display:flex;gap:12px;font-size:11.5px;color:#64748b;margin-bottom:10px}.proj-card-desc{margin:0 0 10px;font-size:12px;color:#475569;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.proj-card-snapshot{font-size:12px;color:#64748b;padding-top:10px;border-top:1px solid #f1f5f9}.proj-card-snapshot strong{color:#1e40af}.proj-empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:#94a3b8;font-size:14px}.proj-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.proj-modal{background:#fff;border-radius:16px;width:860px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #0f172a38;overflow:hidden}.proj-modal-form{width:480px}.proj-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;flex-shrink:0}.proj-modal-title{margin:6px 0 0;font-size:20px;font-weight:700;color:#0f172a}.proj-modal-name-input{display:block;margin:6px 0 0;font-size:20px;font-weight:700;color:#0f172a;border:none;border-bottom:2px solid #3b82f6;outline:none;background:transparent;width:300px}.proj-modal-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;margin-top:4px}.proj-modal-close{border:none;background:#f1f5f9;color:#64748b;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.proj-modal-close:hover{background:#e2e8f0}.proj-terminate-bar{display:flex;align-items:center;gap:8px;padding:10px 24px;background:#fef9ec;border-bottom:1px solid #fde68a;font-size:13px;color:#92400e}.proj-terminate-bar select{padding:3px 6px;border:1px solid #fcd34d;border-radius:6px;background:#fff;font-size:12px}.proj-modal-body{display:flex;gap:0;overflow-y:auto;flex:1}.proj-modal-info{flex:1;padding:20px 24px;display:flex;flex-direction:column;gap:16px;border-right:1px solid #f1f5f9;min-width:0}.proj-modal-snapshot{width:300px;flex-shrink:0;padding:20px;background:#f8fafc}.proj-modal-snapshot h4{margin:0 0 14px;font-size:13px;color:#475569;font-weight:600}.proj-field{display:flex;flex-direction:column;gap:5px}.proj-field label{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.proj-label-hint{font-size:10px;color:#94a3b8;font-weight:400;text-transform:none;letter-spacing:0}.proj-field input,.proj-field textarea,.proj-field select{border:1px solid #e2e8f0;border-radius:8px;padding:7px 10px;font-size:13px;color:#0f172a;outline:none;font-family:inherit;resize:vertical}.proj-field input:focus,.proj-field textarea:focus{border-color:#3b82f6}.proj-field span{font-size:13px;color:#1e293b}.proj-field-desc textarea{min-height:90px}.proj-field-row{display:flex;gap:8px;align-items:center}.proj-attachments{display:flex;flex-direction:column;gap:6px}.proj-att-item{display:flex;align-items:center;gap:8px;padding:5px 8px;background:#f8fafc;border-radius:7px;border:1px solid #e2e8f0}.proj-att-name{font-size:12px;color:#1e40af;text-decoration:none;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-att-name:hover{text-decoration:underline}.proj-att-size{font-size:11px;color:#94a3b8;flex-shrink:0}.proj-att-del{border:none;background:none;color:#94a3b8;cursor:pointer;font-size:12px;padding:0 2px}.proj-att-del:hover{color:#dc2626}.proj-att-empty{font-size:12px;color:#94a3b8}.proj-att-upload{display:inline-flex;align-items:center;font-size:12px;color:#3b82f6;cursor:pointer;padding:5px 0;font-weight:500}.proj-att-upload:hover{color:#1d4ed8}.snap-manual{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.snap-manual-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fff;border-radius:10px;border:1px solid #e2e8f0}.snap-manual-row.snap-profit{border-color:#dbeafe;background:#f0f7ff}.snap-manual-row label{font-size:12px;color:#64748b;font-weight:500}.snap-manual-row strong{font-size:15px;color:#1e40af;font-weight:700;font-variant-numeric:tabular-nums}.profit-pos{color:#15803d!important}.profit-neg{color:#dc2626!important}.snap-manual-input{width:100px;text-align:right;border:1px solid #cbd5e1;border-radius:7px;padding:4px 8px;font-size:14px;font-weight:600;color:#1e40af;outline:none;background:#f8fafc}.snap-manual-input:focus{border-color:#3b82f6;background:#fff}.snap-notes{display:flex;flex-direction:column;gap:6px}.snap-notes label{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.snap-notes textarea{border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;font-size:12.5px;color:#1e293b;outline:none;font-family:inherit;resize:vertical;line-height:1.6}.snap-notes textarea:focus{border-color:#3b82f6}.snap-notes-text{margin:0;font-size:12.5px;color:#475569;line-height:1.7;white-space:pre-wrap;background:#f8fafc;border-radius:8px;padding:8px 10px;min-height:40px}.proj-btn-edit{padding:6px 14px;border:1px solid #e2e8f0;background:#fff;color:#1e293b;border-radius:7px;font-size:12px;cursor:pointer}.proj-btn-edit:hover{background:#f8fafc}.proj-btn-save{padding:6px 14px;background:#1e40af;color:#fff;border:none;border-radius:7px;font-size:12px;cursor:pointer;font-weight:600}.proj-btn-save:hover{background:#1d4ed8}.proj-btn-cancel{padding:6px 14px;border:1px solid #e2e8f0;background:#fff;color:#64748b;border-radius:7px;font-size:12px;cursor:pointer}.proj-btn-terminate{padding:6px 14px;background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:7px;font-size:12px;cursor:pointer;font-weight:500}.proj-btn-terminate:hover{background:#fde68a}.proj-btn-delete{padding:6px 14px;background:#fff;color:#dc2626;border:1px solid #fecaca;border-radius:7px;font-size:12px;cursor:pointer}.proj-btn-delete:hover{background:#fef2f2}.proj-modal-footer{padding:12px 24px;border-top:1px solid #f1f5f9;text-align:right;flex-shrink:0}.proj-form-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.proj-form-footer{padding:14px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.context-menu{position:fixed;z-index:40;background:#fff;border:1px solid #E2E8F0;border-radius:9px;box-shadow:0 8px 24px #0f172a1f;padding:4px;min-width:140px}.context-menu button{border:none;background:transparent;cursor:pointer;padding:7px 12px;border-radius:6px;width:100%;text-align:left;font-size:12.5px;color:#374151;font-family:inherit;display:block;white-space:nowrap}.context-menu button:hover{background:#eff6ff;color:#2563eb}.context-menu button.ctx-danger:hover{background:#fff1f2;color:#dc2626}.context-menu button.ctx-restore{color:#6b7280;font-size:11.5px}.context-menu button.ctx-restore:hover{background:#f1f5f9;color:#374151}.ctx-sep{height:1px;background:#f1f5f9;margin:3px 8px}.col-hideable{cursor:context-menu}.col-hideable:hover{background:#1e3a5f!important}.preview-modal{position:fixed;right:20px;bottom:20px;width:min(980px,calc(100vw - 40px));max-height:65vh;background:#fff;border:1px solid #E2E8F0;border-radius:12px;box-shadow:0 20px 40px #0f172a26;z-index:50;display:flex;flex-direction:column}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #F1F5F9;font-size:13px;font-weight:600;color:#0f172a}.preview-header button{border:1px solid #E2E8F0;border-radius:6px;background:#f8fafc;padding:4px 10px;cursor:pointer;font-family:inherit;font-size:12px;color:#475569;transition:all .12s}.preview-header button:hover{background:#eff6ff;border-color:#93c5fd;color:#2563eb}.preview-body{overflow:auto;padding:8px 10px 12px}.preview-table{width:100%;border-collapse:collapse}.preview-table th,.preview-table td{border-bottom:1px solid #F1F5F9;padding:6px 10px;font-size:12px;white-space:nowrap}.preview-table th{background:#fafbfd;color:#475569;font-weight:600;position:sticky;top:0}.preview-table tbody tr:hover td{background:#f8fbff}.kpi-nav-item{border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;margin-bottom:4px;background:#faf5ff}.kpi-nav-item:hover{background:#ede9fe!important}.kpi-nav-item.active{background:#7c3aed!important;color:#fff!important}.kpi-nav-item.active .side-label{color:#fff!important}.kpi-nav-item .nav-kpi{color:#7c3aed;font-size:12px}.kpi-nav-item.active .nav-kpi{color:#fff}.kpi-full-section{padding:24px 28px!important}.kpi-panel-title{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 20px;display:flex;align-items:center;gap:10px}.kpi-loading{padding:20px;color:#94a3b8;font-size:13px}.kpi-dept-table{width:100%;table-layout:fixed}.kpi-dept-table .kpi-dept-col{width:108px}.kpi-dept-table .kpi-metric-col,.kpi-dept-table .note-th{width:140px}.kpi-dept-table thead tr th,.kpi-dept-table tbody tr td{border-left:none!important;border-right:none!important}.kpi-dept-cell{font-weight:700;font-size:13px;color:#1e293b;vertical-align:middle;text-align:center;background:#eff6ff;border-right:2px solid #2563EB!important;border-bottom:2px solid #1e293b!important;padding:6px 10px;white-space:normal;word-break:break-all}.kpi-metric-cell{color:#475569;padding-right:14px;text-align:right!important}.kpi-lastyear-first{border-left:2px solid #475569!important}.kpi-dept-table thead tr:first-child th:nth-child(3){border-left:2px solid #2563EB!important}.kpi-dept-table thead tr:first-child th:nth-child(4){border-left:2px solid #475569!important}.kpi-dept-table thead tr:last-child th.kpi-lastyear-th{border-left:2px solid #475569!important}.kpi-dept-last-row td{border-bottom:2px solid #1e293b!important}.kpi-bold-row td{font-weight:700!important;color:#1e293b!important}.kpi-bold-row .kpi-metric-cell{color:#1e293b}.kpi-computed-row:not(.kpi-dept-last-row) td{border-bottom:1px solid #cbd5e1!important}.kpi-num{text-align:right;font-variant-numeric:tabular-nums}.kpi-num-clickable{cursor:context-menu}.kpi-num-clickable:hover{background:#dbeafe!important;color:#1d4ed8}.kpi-valid{color:#16a34a;font-size:11px;margin-left:4px}.kpi-mismatch{color:#dc2626;font-size:11px;margin-left:4px}.kpi-overpace{color:#dc2626!important;font-weight:700!important;background:#fff1f1!important}.kpi-overpace-tag{display:inline-block;margin-left:4px;font-size:10px;font-weight:700;color:#fff;background:#dc2626;border-radius:3px;padding:0 3px;vertical-align:middle;line-height:14px}.kpi-breakdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:transparent}.kpi-breakdown-popup{position:fixed;z-index:2001;background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 30px #00000026;min-width:280px;max-width:400px;max-height:420px;overflow:hidden;display:flex;flex-direction:column}.kpi-breakdown-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#1e40af;color:#fff;font-size:13px;font-weight:600;flex-shrink:0}.kpi-breakdown-header button{background:transparent;border:none;color:#fff;cursor:pointer;font-size:14px;padding:0 2px;line-height:1;opacity:.8}.kpi-breakdown-header button:hover{opacity:1}.kpi-breakdown-table{width:100%;border-collapse:collapse;font-size:12px;overflow-y:auto;display:block;max-height:360px}.kpi-breakdown-table thead{position:sticky;top:0;z-index:1}.kpi-breakdown-table th{background:#f1f5f9;padding:6px 12px;text-align:right;color:#64748b;font-weight:600;border-bottom:1px solid #e2e8f0}.kpi-breakdown-table th:first-child{text-align:left}.kpi-breakdown-table td{padding:5px 12px;border-bottom:1px solid #f1f5f9;color:#334155}.kpi-breakdown-table tbody tr:last-child td{border-bottom:none}.kpi-breakdown-table tbody tr:hover td{background:#f0f9ff}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1f2e,#2d3748)}.login-card{background:#fff;border-radius:16px;padding:48px 40px;text-align:center;box-shadow:0 20px 60px #0000004d;max-width:360px;width:100%}.login-logo{font-size:32px;color:#2563eb;font-weight:900;margin-bottom:16px}.login-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 8px}.login-sub{font-size:14px;color:#64748b;margin:0 0 32px}.login-btn{display:inline-flex;align-items:center;gap:10px;background:#07c160;color:#fff;padding:12px 28px;border-radius:8px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s}.login-btn:hover{background:#06ad56}.login-hint{font-size:12px;color:#94a3b8;margin-top:20px}.user-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.08);font-size:12px;color:#94a3b8}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.user-actions{display:flex;gap:4px;flex-shrink:0}.user-action-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:14px;padding:2px 5px;border-radius:4px;transition:color .15s}.user-action-btn:hover{color:#e2e8f0}.user-logout-btn:hover{color:#f87171}.perm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:3000;display:flex;align-items:center;justify-content:center}.perm-modal{background:#fff;border-radius:12px;padding:24px;width:min(720px,95vw);max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.perm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.perm-header h3{margin:0;font-size:16px;color:#1e293b}.perm-header button{background:none;border:none;font-size:18px;cursor:pointer;color:#64748b}.perm-hint{font-size:12px;color:#64748b;margin:0 0 14px}.perm-hint code{background:#f1f5f9;padding:1px 4px;border-radius:3px}.perm-msg{font-size:13px;color:#059669;margin:0 0 10px}.perm-table{width:100%;border-collapse:collapse;font-size:13px}.perm-table th{background:#f8fafc;padding:8px 10px;text-align:left;border-bottom:2px solid #e2e8f0;color:#475569}.perm-table td{padding:7px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.perm-uid{font-family:monospace;color:#64748b;font-size:12px}.perm-input{width:100%;padding:4px 8px;border:1px solid #cbd5e1;border-radius:4px;font-size:12px;box-sizing:border-box}.perm-input:focus{outline:none;border-color:#2563eb}.perm-del-btn{padding:3px 10px;background:#fff;border:1px solid #fca5a5;color:#dc2626;border-radius:4px;cursor:pointer;font-size:12px}.perm-del-btn:hover{background:#fef2f2}
