:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #fafafa;--bg-gradient: #f5f5f5;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-muted: #adb5bd;--border-color: #dddddd;--border-light: #eeeeee;--shadow-sm: rgba(0, 0, 0, .05);--shadow-md: rgba(0, 0, 0, .1);--shadow-lg: rgba(0, 0, 0, .15);--shadow-color: rgba(0, 0, 0, .1);--primary: #2196F3;--primary-dark: #1976D2;--primary-light: #64B5F6;--secondary: #95a5a6;--secondary-dark: #7f8c8d;--success: #4CAF50;--success-dark: #388E3C;--danger: #f44336;--danger-dark: #d32f2f;--warning: #FF9800;--warning-dark: #F57C00;--info: #17a2b8;--info-dark: #138496;--color-oh-bg: rgba(54, 162, 235, .1);--color-oh-border: rgba(54, 162, 235, .3);--color-oh-text: #1565c0;--color-nco-bg: rgba(255, 99, 132, .1);--color-nco-border: rgba(255, 99, 132, .3);--color-nco-text: #c62828;--color-additive-bg: rgba(152, 251, 152, .1);--color-additive-border: rgba(152, 251, 152, .3);--color-additive-text: #2e7d32;--color-custom-bg: rgba(128, 128, 128, .1);--color-custom-border: rgba(128, 128, 128, .3);--color-custom-text: #666666;--input-bg: #ffffff;--input-border: #dddddd;--input-focus-border: #2196F3;--input-text: #333333;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--font-family: Arial, sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #242424;--bg-gradient: #1a1a1a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #808080;--text-muted: #6c757d;--border-color: #404040;--border-light: #333333;--shadow-sm: rgba(0, 0, 0, .2);--shadow-md: rgba(0, 0, 0, .3);--shadow-lg: rgba(0, 0, 0, .4);--shadow-color: rgba(0, 0, 0, .3);--primary: #4dabf7;--primary-dark: #339af0;--primary-light: #74c0fc;--success: #66BB6A;--success-dark: #4caf50;--danger: #ef5350;--danger-dark: #f44336;--warning: #FFB74D;--warning-dark: #FF9800;--color-oh-bg: rgba(54, 162, 235, .15);--color-oh-border: rgba(54, 162, 235, .4);--color-nco-bg: rgba(255, 99, 132, .15);--color-nco-border: rgba(255, 99, 132, .4);--color-additive-bg: rgba(152, 251, 152, .15);--color-additive-border: rgba(152, 251, 152, .4);--color-custom-bg: rgba(128, 128, 128, .15);--color-custom-border: rgba(128, 128, 128, .4);--input-bg: #2d2d2d;--input-border: #404040;--input-focus-border: #4dabf7;--input-text: #ffffff}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark);text-decoration:underline}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);position:sticky;top:0;z-index:100;box-shadow:0 4px 6px var(--shadow-md)}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1600px;margin:0 auto}.header-left{display:flex;align-items:baseline;gap:var(--spacing-md)}.app-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--primary);display:flex;align-items:center;gap:var(--spacing-sm)}.app-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.app-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 var(--spacing-lg)}.nav-list{display:flex;list-style:none;padding:0;gap:var(--spacing-xs);max-width:1600px;margin:0 auto}.nav-item{margin:0}.nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border:none;background:transparent;color:var(--text-secondary);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-fast);border-bottom:3px solid transparent;font-weight:500}.nav-link:hover{color:var(--primary);background:var(--bg-tertiary)}.nav-link.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--bg-tertiary)}.nav-icon{font-size:1.2em}.nav-divider{width:1px;background:var(--border-color);margin:4px 8px;align-self:stretch}.nav-cross-tools{gap:0}.nav-cross-tools .nav-link{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-tertiary);border-bottom:none;text-decoration:none}.nav-cross-tools .nav-link:hover{color:var(--primary)}.app-main{flex:1;padding:var(--spacing-lg);max-width:1600px;margin:0 auto;width:100%}.app-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--spacing-md);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.theme-toggle-btn{width:44px;height:44px;border:2px solid var(--border-color);border-radius:50%;background:var(--bg-tertiary);cursor:pointer;font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:0 4px 6px var(--shadow-md)}.theme-toggle-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.1) rotate(15deg);box-shadow:0 4px 12px var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 4px var(--shadow-sm)}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow-md)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-success{background:linear-gradient(135deg,var(--success),var(--success-dark));color:#fff}.btn-danger{background:linear-gradient(135deg,var(--danger),var(--danger-dark));color:#fff}.btn-warning{background:linear-gradient(135deg,var(--warning),var(--warning-dark));color:#fff}.btn-info{background:linear-gradient(135deg,var(--info),var(--info-dark));color:#fff}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg)}.btn-icon{background:transparent;border:none;padding:var(--spacing-xs);cursor:pointer;font-size:1rem;color:var(--text-secondary);transition:all var(--transition-fast);border-radius:var(--radius-sm);box-shadow:none}.btn-icon:hover{color:var(--primary);background:var(--bg-tertiary);transform:scale(1.1)}.input-group{margin-bottom:var(--spacing-md)}.input-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-primary);font-size:var(--font-size-sm)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--input-border);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--input-bg);color:var(--input-text);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--input-focus-border);box-shadow:0 0 0 3px #2196f326}.input-error .input{border-color:var(--danger)}.input-error-text{color:var(--danger);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.filter-select{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--input-border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--input-text);font-size:var(--font-size-md);cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-container{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:0 20px 60px var(--shadow-lg);max-height:90vh;overflow:auto;width:100%;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1000px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.modal-title{margin:0;font-size:var(--font-size-lg);font-weight:600}.modal-close-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:var(--spacing-xs);border-radius:var(--radius-sm)}.modal-close-btn:hover{color:var(--danger);background:var(--color-nco-bg)}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-sm);background:var(--bg-tertiary)}.table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;box-shadow:0 4px 6px var(--shadow-md)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.data-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table .empty-message{text-align:center;color:var(--text-muted);padding:var(--spacing-xl)}.type-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.type-NCO{background:var(--color-nco-bg);color:var(--color-nco-text);border:1px solid var(--color-nco-border)}.type-OH{background:var(--color-oh-bg);color:var(--color-oh-text);border:1px solid var(--color-oh-border)}.type-additive{background:var(--color-additive-bg);color:var(--color-additive-text);border:1px solid var(--color-additive-border)}.type-custom{background:var(--color-custom-bg);color:var(--color-custom-text);border:1px solid var(--color-custom-border)}.status-badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:500}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;border:1px solid var(--border-color);box-shadow:0 4px 6px var(--shadow-md);transition:all var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-md)}.stat-value{display:block;font-size:var(--font-size-3xl);font-weight:700;color:var(--primary)}.stat-label{display:block;font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.result-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);margin-bottom:var(--spacing-md);box-shadow:0 4px 6px var(--shadow-md)}.result-card h4{margin:0 0 var(--spacing-md);color:var(--text-primary)}.result-card dd.highlight{color:var(--primary);font-weight:700;font-size:var(--font-size-xl)}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.recipe-card{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;box-shadow:0 4px 6px var(--shadow-md);transition:all var(--transition-fast)}.recipe-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-md)}.recipe-card-header{padding:var(--spacing-md);background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.recipe-card-header h3{margin:0;font-size:var(--font-size-lg)}.recipe-date{font-size:var(--font-size-xs);color:var(--text-muted)}.recipe-card-body{padding:var(--spacing-md)}.recipe-card-footer{padding:var(--spacing-md);border-top:1px solid var(--border-light);display:flex;gap:var(--spacing-sm);background:var(--bg-tertiary)}.page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:var(--spacing-lg)}.page-header h2{margin:0 0 var(--spacing-xs);font-size:var(--font-size-2xl);color:var(--text-primary)}.page-header p{margin:0;color:var(--text-secondary)}.page-actions{margin-top:var(--spacing-lg);display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.filter-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;align-items:center;background:var(--bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.filter-bar .input-group{margin-bottom:0;flex:1;min-width:200px}.empty-state{text-align:center;padding:40px var(--spacing-lg);color:var(--text-muted);background:var(--bg-secondary);border-radius:var(--radius-md);border:2px dashed var(--border-color);font-style:italic}.empty-state .empty-icon{display:block;font-size:28px;margin-bottom:10px}.empty-state p{margin:0}.empty-message{text-align:center;padding:40px 20px;color:var(--text-muted);font-style:italic}.calculator-layout{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-lg)}.calculator-table-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);box-shadow:0 4px 6px var(--shadow-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-light)}.section-header h3{margin:0;color:var(--text-primary)}.calculator-results-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-sections{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);box-shadow:0 4px 6px var(--shadow-md)}.settings-section h3{margin:0 0 var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-light)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-light)}.setting-item:last-child{border-bottom:none}.setting-item label{font-weight:500}.setting-control{display:flex;gap:var(--spacing-sm)}.theme-btn{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-color);background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;font-weight:500}.theme-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.danger-zone{flex-direction:column;align-items:flex-start;gap:var(--spacing-md);border-color:var(--danger);background:var(--color-nco-bg)}.danger-zone h4{margin:0;color:var(--danger)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-large{width:48px;height:48px;border-width:4px}.page-loader,.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:var(--text-secondary);min-height:200px}.app-error{background:var(--color-nco-bg);color:var(--danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border:1px solid var(--color-nco-border)}.message{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.message-success{background:var(--color-additive-bg);color:var(--success);border:1px solid var(--color-additive-border)}.message-error{background:var(--color-nco-bg);color:var(--danger);border:1px solid var(--color-nco-border)}.message button{background:transparent;border:none;cursor:pointer;font-size:1.2rem;opacity:.7}.migration-step{min-height:200px}.migration-info h3{margin-top:0}.migration-stats{background:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0;border:1px solid var(--border-light)}.migration-warning{background:#fff3e0;padding:var(--spacing-md);border-radius:var(--radius-md);color:#e65100;border:1px solid #ffcc80}.migration-error{background:var(--color-nco-bg);padding:var(--spacing-md);border-radius:var(--radius-md);color:var(--danger);border:1px solid var(--color-nco-border)}.migration-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.migration-loading{text-align:center;padding:var(--spacing-xl)}.formula-charts-panel{margin-top:var(--spacing-lg)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.chart-card{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-md);box-shadow:0 4px 6px var(--shadow-md)}.chart-card:hover{box-shadow:0 4px 16px var(--shadow-md)}.chart-card h4{margin:0 0 var(--spacing-md);font-size:var(--font-size-md);color:var(--text-primary)}.chart-container{position:relative;height:250px;width:100%}.gauge-chart{display:flex;flex-direction:column;align-items:center;justify-content:center}.gauge-value{position:absolute;bottom:20px;left:50%;transform:translate(-50%);text-align:center}.gauge-value .value{display:block;font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.gauge-value .status{display:block;font-size:var(--font-size-sm);color:var(--text-secondary)}.functional-chart{display:flex;flex-direction:column;align-items:center;justify-content:center}.functional-ratio{position:absolute;bottom:50px;left:50%;transform:translate(-50%);text-align:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.functional-ratio .ratio-label{display:block;font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:2px}.functional-ratio .ratio-value{display:block;font-size:var(--font-size-lg);font-weight:700;color:var(--primary)}.calculator-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.status-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md);border:2px solid var(--border-color);box-shadow:0 4px 6px var(--shadow-md)}.status-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-md)}.status-card.ratio-status.optimal{border-color:var(--success);background:linear-gradient(135deg,var(--color-additive-bg),var(--bg-secondary))}.status-card.ratio-status.acceptable{border-color:var(--warning);background:linear-gradient(135deg,rgba(255,152,0,.1),var(--bg-secondary))}.status-card.ratio-status.warning{border-color:var(--danger);background:linear-gradient(135deg,var(--color-nco-bg),var(--bg-secondary))}.status-icon{font-size:2rem}.status-content{display:flex;flex-direction:column}.status-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.status-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.smart-proportion-row{display:flex;justify-content:space-between;align-items:center;width:100%}.toggle-label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-weight:400;color:var(--text-primary)}.toggle-label input[type=checkbox]{width:auto;margin:0}.mode-indicator{font-size:var(--font-size-sm);color:var(--text-secondary)}.formula-editor{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-lg);box-shadow:0 4px 6px var(--shadow-md)}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-light)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.target-weight-group{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-tertiary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md)}.target-weight-group label{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap;font-weight:500}.target-input{width:100px;padding:var(--spacing-sm);border:2px solid var(--input-border);border-radius:var(--radius-sm);font-size:var(--font-size-md);background:var(--input-bg);color:var(--input-text);text-align:right;font-weight:600}.undo-redo-group{display:flex;align-items:center;gap:var(--spacing-xs);margin-left:var(--spacing-sm);padding-left:var(--spacing-sm);border-left:1px solid var(--border-light)}.undo-redo-group button{min-width:auto;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.undo-redo-group button:disabled{opacity:.4;cursor:not-allowed}.formula-table-container{overflow-x:auto;margin-bottom:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border-light)}.formula-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.formula-table th,.formula-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.formula-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;font-size:var(--font-size-xs)}.formula-table tbody tr:hover{background:var(--bg-tertiary)}.formula-table .row-NCO{border-left:4px solid var(--danger);background:var(--color-nco-bg)}.formula-table .row-OH{border-left:4px solid var(--primary);background:var(--color-oh-bg)}.formula-table .row-additive{border-left:4px solid var(--success);background:var(--color-additive-bg)}.formula-table .row-custom{border-left:4px solid var(--secondary);background:var(--color-custom-bg)}.formula-table .cell-input{width:100px;padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--input-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--input-bg);color:var(--input-text);text-align:right;font-weight:500}.formula-table .cell-input:focus{outline:none;border-color:var(--input-focus-border);box-shadow:0 0 0 3px #2196f326}.formula-table .cell-percentage{font-family:Consolas,Monaco,monospace;color:var(--text-secondary)}.formula-table .cell-value{font-family:Consolas,Monaco,monospace;font-weight:500}.formula-table .total-row{background:var(--bg-tertiary);font-weight:700}.formula-table .total-row td{border-top:3px solid var(--primary)}.stat-mini{font-size:var(--font-size-sm);color:var(--text-secondary)}.calculation-results{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);border:1px solid var(--border-light)}.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.result-item{display:flex;flex-direction:column}.result-item.highlight{padding:var(--spacing-sm);background:var(--color-oh-bg);border-radius:var(--radius-sm);border:1px solid var(--color-oh-border)}.result-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.result-value{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);font-family:Consolas,Monaco,monospace}.adjustment-message{margin-top:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.adjustment-message.success{background:var(--color-additive-bg);color:var(--success);border:1px solid var(--color-additive-border)}.adjustment-message.warning{background:#ff98001a;color:var(--warning);border:1px solid rgba(255,152,0,.3)}.editor-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.material-selector{max-height:60vh;display:flex;flex-direction:column}.selector-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.selector-filters input{flex:1}.material-list{overflow-y:auto;flex:1;max-height:400px}.material-item{padding:var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-secondary)}.material-item:hover{background:var(--bg-tertiary);border-color:var(--primary);transform:translate(4px)}.material-item.type-NCO{border-left:4px solid var(--danger)}.material-item.type-OH{border-left:4px solid var(--primary)}.material-item.type-additive{border-left:4px solid var(--success)}.material-info{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.material-name{font-weight:600;color:var(--text-primary)}.material-details{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.save-recipe-form{padding:var(--spacing-md)}.recipe-preview{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md);margin:var(--spacing-md) 0;border:1px solid var(--border-light)}.recipe-preview h4{margin:0 0 var(--spacing-sm);font-size:var(--font-size-md);color:var(--text-secondary)}.preview-stats{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.preview-stats span{font-family:Consolas,Monaco,monospace;font-size:var(--font-size-sm);background:var(--bg-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}.comparison-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.comparison-card{background:var(--bg-secondary);border-radius:var(--radius-md);border:2px solid var(--border-color);overflow:hidden;box-shadow:0 4px 6px var(--shadow-md)}.comparison-card.selected{border-color:var(--primary);box-shadow:0 4px 16px #2196f333}.comparison-header{padding:var(--spacing-md);background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-bottom:1px solid var(--border-light)}.comparison-body{padding:var(--spacing-md)}.comparison-diff{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.diff-positive{color:var(--success)}.diff-negative{color:var(--danger)}.tooltip-container{position:relative;display:inline-block}.tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:0 4px 16px var(--shadow-md);z-index:100;min-width:200px;opacity:0;visibility:hidden;transition:all var(--transition-fast)}.tooltip-container:hover .tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.tooltip-title{font-weight:600;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.tooltip-content{font-size:var(--font-size-sm);color:var(--text-secondary)}.qr-container{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg)}.qr-code{background:#fff;padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:0 4px 6px var(--shadow-md);margin-bottom:var(--spacing-md)}.qr-mode-toggle{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);padding:var(--spacing-xs);background:var(--bg-tertiary);border-radius:var(--radius-md)}.mode-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.mode-btn.active{background:var(--bg-secondary);color:var(--primary);box-shadow:0 2px 4px var(--shadow-sm)}.mode-btn:hover:not(.active){color:var(--text-primary)}.qr-error{background:var(--color-nco-bg);color:var(--danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--color-nco-border)}.qr-generate-section{text-align:center}.qr-recipe-info{margin-bottom:var(--spacing-md)}.qr-recipe-info h4{margin:0 0 var(--spacing-xs)}.qr-recipe-info p{margin:0;color:var(--text-secondary);font-size:var(--font-size-sm)}.qr-code-display{display:inline-block;background:#fff;padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:0 4px 16px var(--shadow-md);margin-bottom:var(--spacing-lg)}.qr-code-display img{display:block;width:300px;height:300px}.qr-actions{display:flex;gap:var(--spacing-sm);justify-content:center;margin-bottom:var(--spacing-md)}.qr-tips{background:var(--color-oh-bg);color:var(--color-oh-text);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);border:1px solid var(--color-oh-border)}.qr-tips p{margin:0}.qr-paste-area{margin-bottom:var(--spacing-lg)}.qr-paste-area p{margin:0 0 var(--spacing-sm);color:var(--text-secondary)}.qr-input{width:100%;margin-bottom:var(--spacing-sm);resize:vertical;font-family:monospace;font-size:var(--font-size-sm)}.qr-preview{background:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.qr-preview h4{margin:0 0 var(--spacing-sm);color:var(--primary)}.qr-preview p{margin:0 0 var(--spacing-xs);font-size:var(--font-size-sm);color:var(--text-secondary)}.qr-preview ul{margin:var(--spacing-sm) 0 0;padding-left:var(--spacing-lg);font-size:var(--font-size-sm)}.qr-preview li{margin-bottom:var(--spacing-xs)}.smart-adjustment{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color);margin-top:var(--spacing-md)}.adjustment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.adjustment-header h4{margin:0;font-size:var(--font-size-md)}.adjustment-status{font-weight:600;font-size:var(--font-size-sm)}.adjustment-info{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.info-row{display:flex;flex-direction:column;text-align:center}.info-label{font-size:var(--font-size-xs);color:var(--text-secondary)}.info-value{font-size:var(--font-size-md);font-weight:600;font-family:monospace}.suggestions-list h5{margin:0 0 var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.suggestion-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.suggestion-card:hover{border-color:var(--primary);box-shadow:0 4px 6px var(--shadow-md)}.suggestion-card.selected{border-color:var(--primary);background:var(--color-oh-bg)}.suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.suggestion-type{font-size:var(--font-size-sm);font-weight:600;padding:2px 8px;border-radius:var(--radius-sm)}.suggestion-type.add{background:var(--color-additive-bg);color:var(--success)}.suggestion-type.reduce{background:var(--color-nco-bg);color:var(--danger)}.suggestion-material{font-weight:500;color:var(--text-primary)}.suggestion-details{display:flex;justify-content:space-between;align-items:center}.weight-change{display:flex;align-items:center;gap:var(--spacing-sm);font-family:monospace}.weight-change .current{color:var(--text-secondary)}.weight-change .arrow{color:var(--text-muted)}.weight-change .suggested{font-weight:600;color:var(--primary)}.change-amount{font-size:var(--font-size-sm);font-family:monospace}.change-amount.positive{color:var(--success)}.change-amount.negative{color:var(--danger)}.suggestion-actions{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed var(--border-light);text-align:right}.no-suggestions{text-align:center;padding:var(--spacing-md);color:var(--text-secondary)}.no-suggestions p{margin:0}@media(max-width:1024px){.calculator-layout{grid-template-columns:1fr}}@media(max-width:768px){.header-content{flex-direction:column;gap:var(--spacing-sm)}.header-left{flex-direction:column;align-items:center;text-align:center}.nav-list{overflow-x:auto}.nav-label{display:none}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .input-group{width:100%}.recipes-grid{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.calculator-status{grid-template-columns:repeat(2,1fr)}.editor-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{justify-content:center;flex-wrap:wrap}.result-grid{grid-template-columns:repeat(2,1fr)}.selector-filters{flex-direction:column}.comparison-container{grid-template-columns:1fr}}@media(max-width:480px){body{font-size:var(--font-size-sm)}.app-main{padding:var(--spacing-md)}.stats-row,.calculator-status{grid-template-columns:1fr}.page-header h2{font-size:var(--font-size-lg)}}.tooltip-trigger{display:inline-block;cursor:help}.tooltip-trigger:hover{text-decoration:underline dashed;text-decoration-color:var(--primary);text-underline-offset:2px}.material-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px var(--shadow-lg),0 2px 8px var(--shadow-sm);min-width:280px;max-width:360px;animation:tooltipFadeIn .15s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tooltip-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-light);border-radius:var(--radius-md) var(--radius-md) 0 0}.tooltip-type{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase}.tooltip-title{font-weight:600;color:var(--text-primary);font-size:var(--font-size-md)}.tooltip-content{padding:var(--spacing-sm)}.tooltip-section{padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.tooltip-section:last-child{margin-bottom:0}.tooltip-section h5{margin:0 0 var(--spacing-xs);font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.tooltip-row{display:flex;justify-content:space-between;align-items:center;padding:2px 0;font-size:var(--font-size-sm)}.tooltip-label{color:var(--text-secondary)}.tooltip-value{font-family:Consolas,Monaco,monospace;font-weight:500;color:var(--text-primary)}.tooltip-value.highlight-nco{color:var(--color-nco-text);background:var(--color-nco-bg);padding:2px 6px;border-radius:var(--radius-sm)}.tooltip-value.highlight-oh{color:var(--color-oh-text);background:var(--color-oh-bg);padding:2px 6px;border-radius:var(--radius-sm)}.advanced-filter-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.filter-panel-header h4{margin:0;font-size:var(--font-size-md);color:var(--text-primary)}.filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.filter-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.range-inputs{display:flex;align-items:center;gap:var(--spacing-xs)}.range-input{flex:1;padding:var(--spacing-sm);border:2px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--input-text);font-size:var(--font-size-sm);text-align:center}.range-input:focus{outline:none;border-color:var(--input-focus-border)}.range-separator{color:var(--text-secondary);font-weight:500}.active-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.filter-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-oh-bg);border:1px solid var(--color-oh-border);border-radius:var(--radius-lg);font-size:var(--font-size-sm);color:var(--color-oh-text)}.filter-tag button{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;border:none;background:transparent;color:inherit;font-size:14px;cursor:pointer;opacity:.7;transition:opacity var(--transition-fast)}.filter-tag button:hover{opacity:1}@media print{.app-header,.app-nav,.app-footer,.theme-toggle-btn,.editor-actions,.btn{display:none!important}body{background:#fff;color:#000}.page{padding:0}.chart-card,.result-card,.calculator-table-section{box-shadow:none;border:1px solid #ddd}}.form-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md) 0}.form-section+.form-section{border-top:1px solid var(--border-light);margin-top:var(--spacing-sm)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-row.cols-1{grid-template-columns:1fr}.form-row.cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:640px){.form-row,.form-row.cols-3{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:0}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.form-label .required-mark{color:var(--danger);font-weight:700}.form-hint{font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.4}.form-hint.variant-error{color:var(--danger)}.form-hint.variant-success{color:var(--success)}.form-hint.variant-warn{color:var(--warning)}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .75s linear infinite;vertical-align:middle;margin-right:var(--spacing-xs)}.btn-text{display:inline-block;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{display:block;background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--border-light) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-full{max-width:calc(100vw - var(--spacing-lg));width:100%;max-height:calc(100vh - var(--spacing-lg));height:100%}.spinner{display:inline-block;border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-md{width:24px;height:24px;border-width:3px}.spinner-lg{width:40px;height:40px;border-width:4px}.spinner-wrap{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-sm)}.toast-container{position:fixed;top:var(--spacing-md);right:var(--spacing-md);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none;max-width:calc(100vw - var(--spacing-lg))}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--info);border-radius:var(--radius-md);box-shadow:0 4px 12px var(--shadow-md);font-size:var(--font-size-sm);color:var(--text-primary);min-width:260px;max-width:420px;animation:toast-in .2s ease-out}.toast.variant-success{border-left-color:var(--success)}.toast.variant-warn{border-left-color:var(--warning)}.toast.variant-error{border-left-color:var(--danger)}.toast.variant-info{border-left-color:var(--info)}.toast-icon{flex-shrink:0;font-size:var(--font-size-lg)}.toast-body{flex:1;line-height:1.4;word-break:break-word}.toast-close{flex-shrink:0;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;font-size:var(--font-size-lg);line-height:1;padding:0 var(--spacing-xs);transition:color var(--transition-fast)}.toast-close:hover{color:var(--text-primary)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.tabs{display:flex;flex-direction:column;gap:var(--spacing-md)}.tabs-list{display:flex;gap:var(--spacing-xs);border-bottom:2px solid var(--border-light);overflow-x:auto;scrollbar-width:none}.tabs-list::-webkit-scrollbar{display:none}.tab-button{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-secondary);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab-button:disabled{color:var(--text-muted);cursor:not-allowed}.tab-panel{flex:1;min-height:0}.status-planned{background:var(--color-additive-bg);color:var(--warning-dark)}.status-progress{background:var(--color-oh-bg);color:var(--color-oh-text)}.status-completed{background:var(--color-additive-bg);color:var(--color-additive-text)}[data-theme=dark] .status-planned{background:#ff980033;color:var(--warning)}[data-theme=dark] .status-progress{background:#36a2eb33;color:var(--primary-light)}[data-theme=dark] .status-completed{background:#4caf5033;color:var(--success)}.hero-ratio-card{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-md);border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-secondary);box-shadow:0 4px 16px var(--shadow-md);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.hero-ratio-card.optimal{background:linear-gradient(135deg,var(--color-additive-bg),var(--bg-secondary));border-color:var(--success)}.hero-ratio-card.acceptable{background:linear-gradient(135deg,rgba(255,152,0,.12),var(--bg-secondary));border-color:var(--warning)}.hero-ratio-card.warning{background:linear-gradient(135deg,var(--color-nco-bg),var(--bg-secondary));border-color:var(--danger)}.hero-ratio-card.neutral{background:linear-gradient(135deg,var(--color-oh-bg),var(--bg-secondary));border-color:var(--primary)}.hero-ratio-left{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.hero-ratio-icon{font-size:3rem;line-height:1;flex-shrink:0}.hero-ratio-meta{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:0}.hero-ratio-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.hero-ratio-hint{font-size:var(--font-size-md);color:var(--text-primary);font-weight:500}.hero-ratio-value-group{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);flex-shrink:0}.hero-ratio-value{font-size:var(--font-size-3xl);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;color:var(--text-primary);line-height:1}.hero-ratio-target{font-size:var(--font-size-sm);color:var(--text-secondary);font-variant-numeric:tabular-nums}@media(max-width:640px){.hero-ratio-card{flex-direction:column;align-items:flex-start;padding:var(--spacing-md)}.hero-ratio-value-group{align-self:stretch;align-items:flex-start}.hero-ratio-icon{font-size:2.2rem}.hero-ratio-value{font-size:var(--font-size-2xl)}}.formula-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.formula-table th.sortable:hover{background:var(--color-oh-bg)}.formula-table th .sort-icon{display:inline-block;margin-left:2px;font-size:var(--font-size-xs);color:var(--text-tertiary);transition:color .15s ease}.formula-table th.sortable:hover .sort-icon{color:var(--primary)}.formula-table tbody tr:nth-child(2n){background:var(--bg-tertiary)}.formula-table tbody tr{transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.formula-table tbody tr:hover{background:var(--color-oh-bg);box-shadow:0 4px 6px var(--shadow-md)}.formula-table tbody tr.row-NCO{background:var(--color-nco-bg)}.formula-table tbody tr.row-OH{background:var(--color-oh-bg)}.formula-table tbody tr.row-additive{background:var(--color-additive-bg)}.formula-table tbody tr.row-custom{background:var(--color-custom-bg)}.formula-table tbody tr.row-NCO:hover{background:var(--color-nco-border)}.formula-table tbody tr.row-OH:hover{background:var(--color-oh-border)}.formula-table tbody tr.row-additive:hover{background:var(--color-additive-border)}.formula-table tbody tr.row-custom:hover{background:var(--color-custom-border)}.formula-table td.empty-cell{padding:0!important;background:transparent!important}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;color:var(--text-secondary);background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:var(--radius-md);margin:var(--spacing-md)}.empty-state-icon{font-size:4rem;line-height:1;opacity:.85;filter:grayscale(20%)}.empty-state-title{margin:0;font-size:var(--font-size-xl);color:var(--text-primary);font-weight:600}.empty-state-text{margin:0;font-size:var(--font-size-md);line-height:1.7;max-width:420px}
