.outsourcing-manager{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;padding:var(--spacing-xl);background:var(--color-bg);min-height:100vh;color:var(--color-text);width:100%;min-width:0}.outsourcing-manager .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md);flex-wrap:wrap}.outsourcing-manager .page-header h1{color:var(--color-text);margin:0;font-size:32px;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--color-text) 0%,var(--color-text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.year-selector{min-width:160px}.outsourcing-manager .actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.outsourcing-manager .import-section{background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.outsourcing-manager .import-section h2{margin:0 0 var(--spacing-md);font-size:18px;font-weight:600;color:var(--color-text)}.outsourcing-manager .import-section form{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.outsourcing-manager .file-drop-zone{flex:1;min-width:250px}.outsourcing-manager .file-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.outsourcing-manager .file-drop-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-lg);border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:center}.outsourcing-manager .file-drop-label:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.outsourcing-manager .file-drop-zone.drag-over .file-drop-label{border-color:var(--color-primary);background:var(--color-primary-light);transform:scale(1.01)}.outsourcing-manager .file-drop-zone.has-files .file-drop-label{border-color:var(--color-success);background:var(--color-success-light)}.outsourcing-manager .file-drop-icon{font-size:32px;line-height:1}.outsourcing-manager .file-drop-text{font-size:15px;font-weight:500;color:var(--color-text)}.outsourcing-manager .file-drop-hint{font-size:13px;color:var(--color-text-muted)}.outsourcing-manager .file-names{font-size:14px;font-weight:500;color:var(--color-text);word-break:break-all}.charts-row{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.charts-row>.monthly-chart-section,.charts-row>.company-chart-section{flex:1;min-width:0;margin-bottom:0}@media(max-width:1200px){.charts-row{flex-direction:column}.charts-row>.monthly-chart-section,.charts-row>.company-chart-section{margin-bottom:var(--spacing-lg)}}.monthly-chart-section{margin-bottom:var(--spacing-xl)}.monthly-chart-container{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.monthly-chart-header{margin-bottom:var(--spacing-sm)}.monthly-chart-title{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin:0}.monthly-chart-content{display:flex;gap:var(--spacing-lg);align-items:stretch}.monthly-chart-area{flex:1;min-width:0;height:220px}.monthly-chart-area .recharts-responsive-container{min-height:200px}.monthly-summary-list{flex-shrink:0;width:160px;display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-xs)}.monthly-summary-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid var(--color-border-light)}.monthly-summary-row:last-of-type{border-bottom:none}.monthly-summary-label{font-size:12px;color:var(--color-text-secondary)}.monthly-summary-amount{font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px}.monthly-summary-amount.positive{color:var(--color-success)}.monthly-summary-amount.negative{color:var(--color-danger)}.monthly-summary-total{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border)}.monthly-summary-total .monthly-summary-label{font-weight:600;color:var(--color-text)}.monthly-summary-total .monthly-summary-amount{font-size:14px}.monthly-summary-rate{font-size:11px;color:var(--color-text-muted);text-align:right}.monthly-summary-amount .planned-dot{width:6px;height:6px;border-radius:50%;background:#26afd9}.outsourcing-manager .chart-tooltip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-md);min-width:220px}.outsourcing-manager .chart-tooltip-header{font-weight:600;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border-light);font-size:13px}.outsourcing-manager .chart-tooltip-section{margin-bottom:var(--spacing-sm)}.outsourcing-manager .chart-tooltip-section-title{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--spacing-xs)}.outsourcing-manager .chart-tooltip-row{display:flex;align-items:center;gap:var(--spacing-sm);font-size:12px;padding:2px 0}.outsourcing-manager .chart-tooltip-indicator{display:inline-block;width:10px;height:10px;border-radius:2px;flex-shrink:0}.outsourcing-manager .chart-tooltip-label{flex:1;color:var(--color-text-secondary)}.outsourcing-manager .chart-tooltip-value{font-weight:600;font-variant-numeric:tabular-nums}.outsourcing-manager .chart-tooltip-value.positive{color:var(--color-success)}.outsourcing-manager .chart-tooltip-value.negative{color:var(--color-danger)}.outsourcing-manager .chart-tooltip-profit{margin-top:var(--spacing-sm);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border-light);display:flex;justify-content:space-between;font-weight:600;font-size:13px}.outsourcing-manager .chart-tooltip-profit .positive{color:var(--color-success)}.outsourcing-manager .chart-tooltip-profit .negative{color:var(--color-danger)}.outsourcing-manager .chart-tooltip-profit.cumulative{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:none;color:#a73cdd}.outsourcing-manager .chart-tooltip-profit.cumulative span:first-child{color:var(--color-text-secondary)}.outsourcing-manager .recharts-legend-wrapper{padding-top:var(--spacing-sm)}@media(max-width:768px){.monthly-chart-content{flex-direction:column}.monthly-chart-area{width:100%;min-width:auto}.monthly-summary-list{width:100%;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-md)}.monthly-summary-row{flex:1;min-width:120px;flex-direction:column;align-items:flex-start;gap:2px}.monthly-summary-total{border-top:none;margin-top:0;padding-top:0}.monthly-summary-rate{text-align:left}}.company-chart-section{margin-bottom:var(--spacing-xl)}.company-chart-container{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);height:100%;display:flex;flex-direction:column}.company-chart-header{margin-bottom:var(--spacing-sm)}.company-chart-title{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin:0}.company-chart-content{display:flex;gap:var(--spacing-lg);align-items:stretch;flex:1}.company-chart-area{flex:1;min-width:0;display:flex;align-items:center}.company-chart-list{flex-shrink:0;width:180px;display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-xs)}.company-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:4px 0;border-bottom:1px solid var(--color-border-light)}.company-row:last-of-type{border-bottom:none}.company-indicator{display:inline-block;width:10px;height:10px;border-radius:2px;flex-shrink:0}.company-label{flex:1;font-size:12px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-amount{font-size:13px;font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums;text-align:right;min-width:75px}.company-total{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border);border-bottom:none}.company-total .company-label{font-weight:600;color:var(--color-text)}@media(max-width:768px){.company-chart-content{flex-direction:column}.company-chart-area,.company-chart-list{width:100%}}.outsourcing-manager .summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.outsourcing-manager .summary-card{background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);display:flex;align-items:flex-start;gap:var(--spacing-md);transition:all .2s ease;position:relative;overflow:hidden}.outsourcing-manager .summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-border);opacity:.5}.outsourcing-manager .summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.outsourcing-manager .summary-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-surface-elevated);color:var(--color-text-secondary)}.outsourcing-manager .summary-card-icon svg{stroke-width:1.5}.outsourcing-manager .summary-card-content{flex:1;min-width:0}.outsourcing-manager .summary-card h3{margin:0 0 var(--spacing-xs);font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.outsourcing-manager .summary-card .amount{font-size:26px;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums;line-height:1.2}.outsourcing-manager .summary-card .amount.positive{color:var(--color-success)}.outsourcing-manager .summary-card .amount.negative{color:var(--color-danger)}.outsourcing-manager .summary-card-subtitle{font-size:11px;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.outsourcing-manager .summary-card-count:before{background:linear-gradient(135deg,#4254f0,#8994f5)}.outsourcing-manager .summary-card-count .summary-card-icon{background:#4254f01a;color:#4254f0}.outsourcing-manager .summary-card-planned:before{background:linear-gradient(135deg,#26afd9,#67c7e4)}.outsourcing-manager .summary-card-planned .summary-card-icon{background:#26afd91a;color:#26afd9}.outsourcing-manager .summary-card-actual:before{background:linear-gradient(135deg,#22c35d,#52e086)}.outsourcing-manager .summary-card-actual .summary-card-icon{background:#22c35d1a;color:#22c35d}.outsourcing-manager .summary-card-diff:before{background:linear-gradient(135deg,#a73cdd,#c47de8)}.outsourcing-manager .summary-card-diff .summary-card-icon{background:#a73cdd1a;color:#a73cdd}.outsourcing-manager .summary-card-diff.positive:before{background:linear-gradient(135deg,var(--color-success) 0%,hsl(142,70%,60%) 100%)}.outsourcing-manager .summary-card-diff.negative:before{background:linear-gradient(135deg,var(--color-danger) 0%,hsl(0,70%,60%) 100%)}.outsourcing-manager .summary-card-progress:before{background:linear-gradient(135deg,#f49d25,#f7be6e)}.outsourcing-manager .summary-card-progress .summary-card-icon{background:#f49d251a;color:#f49d25}.progress-bar-container{width:100%;height:6px;background:var(--color-surface-elevated);border-radius:3px;margin-top:var(--spacing-sm);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#f49d25,#f6b355);border-radius:3px;transition:width .5s ease}.outsourcing-manager .table-container{background:var(--color-surface);border-radius:var(--radius-lg);overflow-x:auto;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);max-width:100%;height:auto;margin-bottom:var(--spacing-xl)}.outsourcing-table{width:100%;border-collapse:collapse;min-width:1000px;background:var(--color-surface)}.outsourcing-table th,.outsourcing-table td{padding:4px 6px;text-align:left}.outsourcing-table th{background:var(--color-surface-secondary, var(--color-surface-elevated));font-weight:600;border-bottom:1px solid var(--color-border);font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em;position:sticky;top:0;z-index:10}.outsourcing-table tbody tr{transition:background var(--transition-fast, .15s ease)}.outsourcing-table tbody tr:hover{background:#00000005}.outsourcing-table .sticky-left{position:sticky;left:0;background:var(--color-surface);z-index:2;border-right:1px solid var(--color-border);min-width:140px}.outsourcing-table th.sticky-left{background:var(--color-surface-secondary, var(--color-surface-elevated));z-index:11}.outsourcing-table tbody tr:hover .sticky-left{background:#00000005}.outsourcing-table .sticky-right{position:sticky;right:0;background:var(--color-surface);z-index:2;border-left:1px solid var(--color-border)}.outsourcing-table th.sticky-right{background:var(--color-surface-secondary, var(--color-surface-elevated));z-index:11}.outsourcing-table tbody tr:hover .sticky-right{background:#00000005}.outsourcing-table .amount-cell{text-align:right;font-size:14px;font-variant-numeric:tabular-nums;font-family:SF Mono,SFMono-Regular,Consolas,monospace;white-space:nowrap}.row-type-label{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:var(--radius-sm);min-width:40px}.row-type-label:has(+.amount-cell){background:var(--color-surface-elevated);color:var(--color-text-secondary)}tr[class*=-planned] .row-type-label{background:#4254f01a;color:#2b3eee}tr[class*=-actual] .row-type-label{background:#22c35d1a;color:#1fad53}tr[class*=-diff] .row-type-label{background:#a73cdd1a;color:#9d26d9}.row-type-outsourcing{background:#f47b251a;color:#da620b}.row-type-sales{background:#22c35d1a;color:#1fad53}.row-type-profit{background:#a73cdd1a;color:#9d26d9}.combined-table tbody tr.row-profit td,.combined-table tbody tr.row-sales-only td,.combined-table tbody tr.row-outsourcing-only td{box-shadow:inset 0 -2px 0 var(--color-border-light)}.combined-table tbody tr:last-child td{box-shadow:none}.planned-indicator-inline{display:inline-flex;align-items:center;margin-left:4px;color:#26afd9;vertical-align:middle}.amount-cell.is-planned{color:#26afd9}.amount-cell.has-planned{position:relative}.amount-cell.has-planned:after{content:"";position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:50%;background:#26afd9}.amount-cell.no-data{color:var(--color-text-muted);opacity:.5}.amount-cell.positive{color:var(--color-success)}.amount-cell.negative{color:var(--color-danger)}.company-type-cell{min-width:200px;width:100%;display:flex;align-items:flex-start;gap:8px}.company-type-cell .row-type-label{flex-shrink:0;margin-top:2px}.company-name-wrapper{display:flex;flex-direction:column;min-width:0;flex:1;gap:1px}.company-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-name.no-data{color:var(--color-text-muted);opacity:.5}.company-name-sub{font-size:10px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-name-cell{font-size:13px;min-width:100px;max-width:200px}.company-name-cell.no-data{color:var(--color-text-muted);opacity:.5}.outsourcing-manager .summary-card-outsourcing:before{background:linear-gradient(135deg,#f47b25,#f7a76e)}.outsourcing-manager .summary-card-outsourcing .summary-card-icon{background:#f47b251a;color:#f47b25}.outsourcing-manager .summary-card-sales:before{background:linear-gradient(135deg,#22c35d,#52e086)}.outsourcing-manager .summary-card-sales .summary-card-icon{background:#22c35d1a;color:#22c35d}.outsourcing-manager .summary-card-profit:before{background:linear-gradient(135deg,#a73cdd,#c47de8)}.outsourcing-manager .summary-card-profit .summary-card-icon{background:#a73cdd1a;color:#a73cdd}.outsourcing-manager .summary-card-profit.positive:before{background:linear-gradient(135deg,var(--color-success) 0%,hsl(142,70%,60%) 100%)}.outsourcing-manager .summary-card-profit.positive .summary-card-icon{background:#22c35d1a;color:var(--color-success)}.outsourcing-manager .summary-card-profit.negative:before{background:linear-gradient(135deg,var(--color-danger) 0%,hsl(0,70%,60%) 100%)}.outsourcing-manager .summary-card-profit.negative .summary-card-icon{background:#d926261a;color:var(--color-danger)}.outsourcing-table .month-header{text-align:center;min-width:60px;width:60px}.actions-inline{display:flex;align-items:center;gap:2px;margin-left:auto}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;margin:0 2px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.icon-button:hover{background:var(--color-surface-secondary, var(--color-surface-elevated));color:var(--color-primary)}.icon-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.icon-button-secondary:hover{background:var(--color-primary-light, hsla(234, 85%, 60%, .1));color:var(--color-primary)}.icon-button-danger:hover{background:var(--color-danger-light, hsla(0, 70%, 50%, .1));color:var(--color-danger)}.monthly-input-container{margin:var(--spacing-xs) 0}.bulk-input-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.bulk-input-toggle{font-size:12px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.bulk-input-toggle:hover{background:var(--color-surface-hover);color:var(--color-text)}.bulk-input-form{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border-light);flex-wrap:wrap}.bulk-input-amount{width:120px;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;text-align:right;background:var(--color-surface);color:var(--color-text)}.bulk-input-amount:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha)}.bulk-input-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;background:var(--color-surface);color:var(--color-text);cursor:pointer}.bulk-input-select:focus{outline:none;border-color:var(--color-primary)}.bulk-input-apply{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.bulk-input-apply:hover{background:var(--color-primary-hover)}.monthly-input-grid{display:grid;grid-template-columns:80px repeat(12,1fr) 100px;gap:1px;margin:var(--spacing-xs) 0;background:var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.monthly-input-grid .header{padding:var(--spacing-sm) var(--spacing-xs);text-align:center;font-weight:700;font-size:11px;color:var(--color-text-secondary);background:var(--color-surface-elevated);text-transform:uppercase;letter-spacing:.03em}.monthly-input-grid .row-label{padding:var(--spacing-sm) var(--spacing-md);font-weight:600;font-size:12px;display:flex;align-items:center;gap:var(--spacing-xs);background:var(--color-surface);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.monthly-input-grid .row-label-text{line-height:16px}.row-clear-button{flex-shrink:0;width:16px;height:16px;padding:0;margin:0;border:none;background:transparent;color:var(--color-text-muted);font-size:14px;line-height:16px;cursor:pointer;opacity:.5;transition:all var(--transition-fast);border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center}.row-clear-button:hover{opacity:1;color:var(--color-danger);background:var(--color-danger-light, hsla(0, 70%, 50%, .1))}.monthly-input-grid input{width:100%;padding:var(--spacing-sm);border:none;background:var(--color-surface);color:var(--color-text);text-align:right;font-size:13px;font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace;transition:background .15s ease}.monthly-input-grid input:focus{outline:none;background:var(--color-primary-alpha)}.monthly-input-grid input:hover:not(:focus){background:var(--color-surface-hover)}.monthly-input-grid input::placeholder{color:var(--color-text-muted);opacity:.5}.monthly-input-grid input:disabled{background:var(--color-surface-elevated);color:var(--color-text-muted);cursor:not-allowed}.monthly-input-grid .total-cell{padding:var(--spacing-sm);text-align:right;font-weight:700;font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace;background:var(--color-surface-elevated);display:flex;align-items:center;justify-content:flex-end;color:var(--color-text)}.outsourcing-manager .form-dialog-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:#00000080;backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-dialog{position:relative;z-index:1;background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:1300px;max-height:95vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-dialog h2{margin:0 0 var(--spacing-md);font-size:20px;font-weight:800;color:var(--color-text);letter-spacing:-.02em}.form-dialog h3{margin:var(--spacing-md) 0 var(--spacing-sm);font-size:14px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border-light)}.form-group{margin-bottom:var(--spacing-xs)}.form-group label{display:block;margin-bottom:2px;font-size:13px;font-weight:600;color:var(--color-text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:14px;transition:all .15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha)}.form-group input:hover:not(:focus),.form-group select:hover:not(:focus),.form-group textarea:hover:not(:focus){border-color:var(--color-text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-sm)}.form-actions{display:flex;gap:var(--spacing-md);justify-content:space-between;margin-top:var(--spacing-sm);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border-light)}.form-actions-left{display:flex;gap:var(--spacing-sm)}.form-actions-right{display:flex;gap:var(--spacing-md)}.form-actions button,.form-actions .btn{min-width:100px;padding:var(--spacing-sm) var(--spacing-lg);justify-content:center}.integrated-form{width:1400px;padding:var(--spacing-md)}.form-row-vertical{display:flex;gap:var(--spacing-sm)}.form-row-vertical .form-group{flex:1;min-width:0}.TabsRoot{display:flex;flex-direction:column}.TabsList{display:flex;gap:2px;background:var(--color-surface-elevated);padding:4px;border-radius:var(--radius-md);position:relative;margin-bottom:var(--spacing-md)}.TabsTab{flex:1;padding:var(--spacing-sm) var(--spacing-lg);border:none;background:transparent;color:var(--color-text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;border-radius:var(--radius-sm);z-index:1}.TabsTab:hover:not([data-selected]):not([data-active]){color:var(--color-text);background:var(--color-surface-hover, rgba(128, 128, 128, .1))}.TabsTab[data-selected],.TabsTab[data-active]{color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.2);font-weight:700}.TabsIndicator{position:absolute;top:4px;bottom:4px;left:var(--active-tab-left);width:var(--active-tab-width);border-radius:var(--radius-sm);background:var(--color-primary);box-shadow:0 2px 4px #00000026,0 1px 2px #0000001a;transition:left .2s ease,width .2s ease;z-index:0}.TabsPanel{outline:none;padding-top:var(--spacing-xs)}.TabsPanel[hidden]{display:none}.form-section{margin-bottom:var(--spacing-sm)}.form-section h3{margin:0 0 var(--spacing-xs);font-size:15px;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:var(--spacing-sm)}.form-section h4.monthly-section-title{margin:var(--spacing-xs) 0 2px;font-size:12px;font-weight:600;color:var(--color-text-secondary)}.optional-label{font-size:12px;font-weight:400;color:var(--color-text-muted)}.outsourcing-manager .empty-state{text-align:center;padding:var(--spacing-xxl) var(--spacing-xl);color:var(--color-text-muted);background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.outsourcing-manager .empty-state:before{content:"";display:block;width:64px;height:64px;margin:0 auto var(--spacing-lg);background:var(--color-surface-elevated);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'%3E%3C/path%3E%3Cpolyline points='14 2 14 8 20 8'%3E%3C/polyline%3E%3Cline x1='12' y1='18' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='9' y1='15' x2='15' y2='15'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.outsourcing-manager .empty-state p{margin:0;font-size:15px;line-height:1.6}.linked-sales-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px 10px;background:#22c35d1a;color:#1b9849;border-radius:var(--radius-full);font-size:11px;font-weight:600;margin-top:var(--spacing-xs)}.linked-sales-badge:before{content:"";width:6px;height:6px;background:currentColor;border-radius:50%}.no-linked-sales{display:inline-block;color:var(--color-text-muted);font-size:11px;margin-top:var(--spacing-xs);opacity:.7}.mobile-card-list{display:none}@media(max-width:768px){.outsourcing-manager{padding:var(--spacing-md)}.outsourcing-manager .page-header h1{font-size:24px}.outsourcing-manager .summary-cards{grid-template-columns:1fr;gap:var(--spacing-md)}.outsourcing-manager .summary-card{padding:var(--spacing-md)}.form-row{grid-template-columns:1fr;gap:var(--spacing-md)}.form-dialog{padding:var(--spacing-lg)}.monthly-input-grid{grid-template-columns:60px repeat(12,80px) 80px;overflow-x:auto}.outsourcing-manager .desktop-table{display:none}.outsourcing-manager .mobile-card-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.mobile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.mobile-card-header{display:flex;flex-direction:column;gap:var(--spacing-xs);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.mobile-card-title{font-size:16px;font-weight:700;color:var(--color-text)}.mobile-card-content{font-size:13px;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);line-height:1.5}.mobile-card-amounts{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm) 0}.mobile-card-amount-row{display:flex;justify-content:space-between;align-items:center}.mobile-card-label{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.mobile-card-value{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums;font-family:SF Mono,SFMono-Regular,Consolas,monospace}.mobile-card-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding-top:var(--spacing-sm);margin-top:var(--spacing-sm);border-top:1px solid var(--color-border-light)}.mobile-card-actions .icon-button{width:32px;height:32px}}@media(max-width:480px){.outsourcing-manager .actions{flex-direction:column}.outsourcing-manager .actions button,.outsourcing-manager .actions .btn{width:100%;justify-content:center}.form-actions{flex-direction:column}.form-actions button,.form-actions .btn{width:100%}.outsourcing-manager .page-header{flex-direction:column;align-items:stretch}.year-selector{width:100%}}.form-mode-selector{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.form-mode-selector label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:14px;color:var(--color-text)}.form-mode-selector input[type=radio]{accent-color:var(--color-primary)}.form-error{padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:#fff0f0;border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);font-size:14px}.outsourcing-select{margin-bottom:var(--spacing-md)}.outsourcing-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:200px;overflow-y:auto;padding:var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md)}.outsourcing-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:13px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.outsourcing-checkbox-label:hover{background:var(--color-surface-hover)}.outsourcing-checkbox-label input[type=checkbox]{accent-color:var(--color-primary)}.row-sales-detail{background:var(--color-bg);font-size:12px}.row-sales-detail .company-name{font-size:12px;color:var(--color-text-secondary)}.row-type-sales-detail{color:var(--color-text-tertiary);font-family:monospace;font-weight:400;margin-right:var(--spacing-xs)}.row-outsourcing-detail{background:var(--color-bg);font-size:12px}.row-outsourcing-detail .company-name{font-size:12px;color:var(--color-text-secondary)}.row-type-outsourcing-detail{color:var(--color-text-tertiary);font-family:monospace;font-weight:400;margin-right:var(--spacing-xs)}.mobile-card-sales-only{border-left:3px solid var(--color-primary)}.mobile-card-sales-only .mobile-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.mobile-card-sub{font-size:11px;color:var(--color-text-tertiary);margin-left:var(--spacing-xs)}.PopoverTrigger{display:inline-flex}.PopoverPositioner{outline:none;z-index:150;user-select:none}.PopoverPopup{box-sizing:border-box;border-radius:var(--radius-md);background-color:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border);min-width:160px;padding:var(--spacing-xs) 0;outline:none;transform-origin:var(--transform-origin);transition:transform .15s,opacity .15s}.PopoverPopup[data-starting-style],.PopoverPopup[data-ending-style]{opacity:0;transform:scale(.95)}.PopoverMenuItem{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--color-text);font-size:13px;text-align:left;cursor:pointer;transition:background-color var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.PopoverMenuItem:hover{background:var(--color-surface-hover, var(--color-surface-elevated))}.PopoverMenuItem:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}@media(max-width:768px){.PopoverPopup{min-width:200px}.PopoverMenuItem{padding:var(--spacing-md);font-size:15px}}
