:root{--bg-primary:hsl(222, 24%, 10%);--bg-secondary:hsl(222, 20%, 15%);--panel-bg:rgba(30, 41, 59, 0.45);--panel-border:rgba(255, 255, 255, 0.08);--panel-border-glow:rgba(99, 102, 241, 0.25);--primary:hsl(245, 80%, 65%);--primary-hover:hsl(245, 85%, 72%);--primary-glow:rgba(99, 102, 241, 0.15);--air-accent:hsl(190, 90%, 50%);--air-accent-glow:rgba(6, 182, 212, 0.15);--ocean-accent:hsl(215, 90%, 55%);--ocean-accent-glow:rgba(59, 130, 246, 0.15);--carrying-accent:hsl(35, 90%, 55%);--carrying-accent-glow:rgba(245, 158, 11, 0.15);--text-primary:hsl(210, 40%, 96%);--text-secondary:hsl(215, 20%, 75%);--text-muted:hsl(215, 16%, 50%);--treemap-text:#ffffff;--danger:hsl(0, 85%, 60%);--success:hsl(140, 70%, 50%);--warning:hsl(35, 90%, 55%);--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--shadow-sm:0 1px 2px 0 rgba(0, 0, 0, 0.05);--shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);--shadow-lg:0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 10px 10px -5px rgba(0, 0, 0, 0.3);--transition-speed:0.3s;--border-radius:12px;--color-optimal:#10b981;--color-suboptimal-low:#fbbf24;--color-suboptimal-high:#ef4444}html.light-theme{--bg-primary:hsl(210, 30%, 98%);--bg-secondary:hsl(210, 20%, 94%);--panel-bg:rgba(255, 255, 255, 0.75);--panel-border:rgba(0, 0, 0, 0.08);--panel-border-glow:rgba(99, 102, 241, 0.15);--primary:hsl(245, 75%, 55%);--primary-hover:hsl(245, 75%, 45%);--primary-glow:rgba(99, 102, 241, 0.08);--air-accent:hsl(190, 85%, 40%);--air-accent-glow:rgba(6, 182, 212, 0.1);--ocean-accent:hsl(215, 80%, 45%);--ocean-accent-glow:rgba(59, 130, 246, 0.1);--carrying-accent:hsl(30, 85%, 45%);--carrying-accent-glow:rgba(245, 158, 11, 0.1);--text-primary:hsl(222, 47%, 12%);--text-secondary:hsl(217, 19%, 30%);--text-muted:hsl(215, 16%, 50%);--treemap-text:var(--text-primary);--danger:hsl(0, 75%, 45%);--success:hsl(140, 75%, 35%);--warning:hsl(30, 85%, 45%);--shadow-lg:0 20px 25px -5px rgba(0, 0, 0, 0.06),
        0 10px 10px -5px rgba(0, 0, 0, 0.04);--color-optimal:#10b981;--color-suboptimal-low:#d97706;--color-suboptimal-high:#dc2626}html.light-theme .chargeable-weights-bar{background:rgba(0,0,0,3%)}html.light-theme .breakeven-gauge-bar{background:rgba(0,0,0,8%)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;line-height:1.5}@supports not (view-transition-name:root){body,.panel,.btn,.input-control,.preset-btn{transition:background-color .3s ease,border-color .3s ease,color .3s ease}}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}::view-transition-new(root){z-index:9999}::view-transition-old(root){z-index:1}.app-container{width:100%;max-width:1400px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;flex-grow:1}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--panel-bg);border:1px solid var(--panel-border);backdrop-filter:blur(12px);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.header-brand{display:flex;align-items:center;gap:.75rem}.brand-icon{font-size:1.75rem;background:var(--primary-glow);padding:.5rem;border-radius:8px;border:1px solid var(--panel-border-glow)}.brand-text h1{font-family:var(--font-heading);font-size:1.25rem;font-weight:800;letter-spacing:-.5px;line-height:1.1}.brand-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600}.header-actions{display:flex;align-items:center;gap:1rem}.theme-toggle-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--panel-border);background:var(--panel-bg);cursor:pointer;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.theme-toggle-btn span{position:absolute;font-size:1.25rem;transition:transform .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1)}.sun-icon{opacity:0;transform:rotate(90deg)scale(0)}.moon-icon{opacity:1;transform:rotate(0)scale(1)}.light-theme .sun-icon{opacity:1;transform:rotate(0)scale(1)}.light-theme .moon-icon{opacity:0;transform:rotate(-90deg)scale(0)}.main-grid{display:grid;grid-template-columns:1.1fr 1.3fr;gap:1.5rem;align-items:start}@media(max-width:968px){.main-grid{grid-template-columns:1fr}}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);backdrop-filter:blur(16px);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--panel-border)}.panel-header h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text-primary)}.panel-subtitle{font-size:.8rem;color:var(--text-muted)}.panel-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.preset-section{display:flex;flex-direction:column;gap:.5rem}.section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;font-weight:700;color:var(--text-muted)}.preset-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.preset-btn{background:rgba(255,255,255,2%);border:1px solid var(--panel-border);border-radius:8px;padding:.6rem .25rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;transition:all .25s ease}.preset-btn:hover{background:rgba(99,102,241,6%);border-color:var(--panel-border-glow)}.preset-btn.active{background:var(--primary-glow);border-color:var(--primary);box-shadow:inset 0 0 10px rgba(99,102,241,.15)}.preset-icon{font-size:1.1rem}.preset-name{font-size:.7rem;font-weight:600;color:var(--text-secondary)}.preset-btn.active .preset-name{color:var(--text-primary)}.form-group-section{border-top:1px solid var(--panel-border);padding-top:1.25rem}.form-group-section:first-of-type{border-top:none;padding-top:0}.group-title{font-family:var(--font-heading);font-size:.85rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group.full-width{grid-column:span 2}.form-group label{font-size:.75rem;font-weight:600;color:var(--text-secondary)}.input-control,.select-control{background:rgba(0,0,0,.2);border:1px solid var(--panel-border);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-body);font-size:.85rem;outline:none;transition:all .2s ease;width:100%}.light-theme .input-control,.light-theme .select-control{background:rgba(255,255,255,.8)}.input-control:focus,.select-control:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.input-prefix-container,.input-suffix-container{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:.75rem;font-size:.85rem;color:var(--text-muted);font-weight:600;pointer-events:none}.input-prefix-container .input-control{padding-left:1.5rem}.input-suffix{position:absolute;right:.75rem;font-size:.85rem;color:var(--text-muted);font-weight:600;pointer-events:none}.input-suffix-container .input-control{padding-right:1.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-body);font-size:.85rem;font-weight:600;padding:.6rem 1.25rem;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#4c3eea;transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,.35)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:rgba(255,255,255,5%);border-color:var(--panel-border);color:var(--text-primary)}.btn-secondary:hover{background:rgba(255,255,255,.1);border-color:var(--panel-border-glow)}.btn.full-width{width:100%}.btn-icon-only{background:0 0;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-icon-only:hover{background:rgba(255,255,255,8%);color:var(--text-primary)}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.metric-card{background:rgba(255,255,255,2%);border:1px solid var(--panel-border);border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:.25rem;position:relative;overflow:hidden}.metric-card.primary{border-left:3px solid var(--air-accent)}.metric-card.highlight{border-left:3px solid var(--success);background:linear-gradient( 135deg,rgba(34,197,94,2%) 0%,rgba(34,197,94,6%) 100% );box-shadow:inset 0 0 10px rgba(34,197,94,5%)}.metric-card.warning{border-left:3px solid var(--warning)}.metric-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600}.metric-value{font-family:var(--font-heading);font-size:1.25rem;font-weight:800;line-height:1.2}.metric-card.highlight .metric-value{color:var(--success)}.metric-card.warning .metric-value{color:var(--warning)}.metric-trend{font-size:.65rem;font-weight:500}.metric-trend.savings{color:var(--success)}.metric-trend.penalty{color:var(--danger)}.text-muted{color:var(--text-muted)}.chargeable-weights-bar{background:rgba(0,0,0,.15);border:1px solid var(--panel-border);border-radius:8px;padding:.75rem 1rem;font-size:.75rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.chargeable-weights-bar strong{color:var(--text-primary)}.calc-formula{color:var(--text-muted);font-style:italic;margin-left:.25rem}.chart-container{background:rgba(255,255,255,1%);border:1px solid var(--panel-border);border-radius:var(--border-radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1rem}.chart-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.chart-header h3{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.chart-legend{display:flex;gap:.75rem}.legend-item{display:flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.air-freight{background:var(--air-accent);box-shadow:0 0 6px var(--air-accent)}.legend-dot.ocean-freight{background:var(--ocean-accent);box-shadow:0 0 6px var(--ocean-accent)}.legend-dot.carrying{background:var(--carrying-accent);box-shadow:0 0 6px var(--carrying-accent)}.svg-wrapper{width:100%;padding-top:.5rem}.chart-grid-line{stroke:var(--panel-border);stroke-width:1;stroke-dasharray:4 4}.chart-grid-label{fill:var(--text-muted);font-size:.65rem;font-weight:600;text-anchor:end}.bar-segment{stroke:transparent;stroke-width:0;transition:height .6s cubic-bezier(.25,1,.5,1),y .6s cubic-bezier(.25,1,.5,1),opacity .2s ease;cursor:pointer}.bar-segment:hover{opacity:.85}.bar-segment.air-freight{fill:url(#air-freight-grad)}.bar-segment.ocean-freight{fill:url(#ocean-freight-grad)}.bar-segment.carrying{fill:url(#carrying-grad)}#air-freight-grad stop:first-child{stop-color:var(--air-accent)}#air-freight-grad stop:last-child{stop-color:var(--air-accent)}#ocean-freight-grad stop:first-child{stop-color:var(--ocean-accent)}#ocean-freight-grad stop:last-child{stop-color:var(--ocean-accent)}#carrying-grad stop:first-child{stop-color:var(--carrying-accent)}#carrying-grad stop:last-child{stop-color:var(--carrying-accent)}.bar-label{fill:var(--text-secondary);font-size:.75rem;font-weight:700;text-anchor:middle}.bar-value-label{fill:var(--text-primary);font-size:.75rem;font-weight:800;text-anchor:middle;transition:y .6s cubic-bezier(.25,1,.5,1)}.breakeven-section{background:rgba(255,255,255,2%);border:1px solid var(--panel-border);border-radius:var(--border-radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.breakeven-header{display:flex;justify-content:space-between;align-items:center}.breakeven-header h3{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.breakeven-badge{background:var(--warning);color:var(--bg-primary);font-size:.7rem;font-weight:800;padding:.15rem .5rem;border-radius:4px}.breakeven-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.breakeven-desc span{font-weight:700;color:var(--text-primary)}.breakeven-gauge-container{margin-top:.5rem;display:flex;flex-direction:column;gap:.35rem}.breakeven-gauge-bar{height:8px;background:rgba(255,255,255,5%);border-radius:4px;position:relative;overflow:visible}.breakeven-gauge-fill{height:100%;background:var(--success);border-radius:4px;width:0%;transition:width .6s ease}.breakeven-gauge-fill.violated{background:var(--danger)}.breakeven-gauge-marker{position:absolute;top:-4px;width:4px;height:16px;background:var(--text-primary);border-radius:2px;left:0%;transform:translateX(-50%);transition:left .6s ease;box-shadow:0 0 8px rgba(255,255,255,.5)}.breakeven-gauge-labels{display:flex;justify-content:space-between;font-size:.65rem;font-weight:600;color:var(--text-muted);position:relative}#lbl-ocean-actual-marker{color:var(--text-primary)}.agentic-section{background:linear-gradient( 135deg,rgba(99,102,241,1%) 0%,rgba(99,102,241,4%) 100% );border:1px solid var(--panel-border-glow);border-radius:var(--border-radius);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:inset 0 0 15px rgba(99,102,241,5%)}.agentic-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.agentic-title-row{display:flex;align-items:center;gap:.6rem}.agentic-icon{font-size:1.5rem;background:rgba(99,102,241,.1);padding:.35rem;border-radius:8px;border:1px solid rgba(99,102,241,.2)}.agentic-subtitle{font-size:.75rem;color:var(--text-muted)}.agentic-header h3{font-family:var(--font-heading);font-size:.95rem;font-weight:700;line-height:1.1}.agent-loader{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:rgba(255,255,255,2%);border:1px solid var(--panel-border);border-radius:6px;font-size:.75rem;color:var(--text-secondary)}.agent-loader.hidden{display:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert-message{padding:.75rem 1rem;background:rgba(239,68,68,8%);border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:.75rem;color:var(--danger);line-height:1.4}.alert-message.hidden{display:none}.alert-message a{color:var(--primary);text-decoration:underline;font-weight:600}#csv-status-text a{color:var(--primary);text-decoration:none;font-weight:600;transition:color .15s ease}#csv-status-text a:hover{color:var(--primary-hover)}.proposal-container{border:1px solid var(--panel-border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;background:rgba(0,0,0,.2)}.light-theme .proposal-container{background:rgba(255,255,255,.8)}.proposal-container.hidden{display:none}.proposal-header{background:rgba(255,255,255,2%);border-bottom:1px solid var(--panel-border);padding:.5rem .75rem;display:flex;justify-content:space-between;align-items:center}.proposal-badge{font-size:.65rem;font-weight:800;color:var(--primary);letter-spacing:.5px}.proposal-actions{display:flex;gap:.25rem}.proposal-textarea{background:0 0;border:none;width:100%;color:var(--text-primary);font-family:monospace;font-size:.75rem;line-height:1.4;padding:.75rem;resize:vertical;outline:none}.report-actions{margin-top:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.65);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-overlay:not(.hidden){opacity:1;pointer-events:all}.modal-card{background:var(--bg-secondary);border:1px solid var(--panel-border-glow);border-radius:var(--border-radius);width:480px;max-width:90%;box-shadow:var(--shadow-lg),0 0 30px rgba(99,102,241,.15);display:flex;flex-direction:column;transform:scale(.95);transition:transform .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.modal-overlay:not(.hidden) .modal-card{transform:scale(1)}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--panel-border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--text-primary)}.modal-close{background:0 0;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;outline:none;line-height:1;transition:color .2s ease}.modal-close:hover{color:var(--danger)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem;max-height:60vh;overflow-y:auto}.modal-info-text{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--panel-border);display:flex;justify-content:flex-end;gap:.75rem;background:rgba(0,0,0,.15)}.light-theme .modal-footer{background:rgba(0,0,0,2%)}.hidden{display:none!important}.print-only{display:none}@media print{body>.app-container{display:none!important}.modal-overlay{display:none!important}.print-only{display:block!important}html,body{background:#fff!important;color:#000!important;padding:0!important;margin:0!important;font-size:10pt!important;height:auto!important;overflow:visible!important;font-family:inter,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,sans-serif!important}#print-report-container{padding:2.5rem!important;max-width:100%!important;width:100%!important;height:auto!important;overflow:visible!important}.print-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.print-logo{font-size:1.25rem;font-weight:800;font-family:outfit,sans-serif!important;color:#1e293b!important}.print-title{font-size:.85rem;font-weight:700;letter-spacing:.5px;color:#64748b!important}.print-date{font-size:.8rem;color:#475569!important}.print-divider{height:2px;background:#e2e8f0;margin-bottom:1.5rem}.print-section{margin-bottom:1.5rem}.print-section h3{font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#0f172a!important;border-bottom:1px solid #e2e8f0;padding-bottom:.35rem;margin-bottom:.75rem}.print-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:9pt}.print-table th,.print-table td{border:1px solid #cbd5e1;padding:.6rem .75rem;text-align:left}.print-table th{background-color:#f8fafc!important;font-weight:700;color:#1e293b!important}.highlight-row{background-color:#f1f5f9!important;font-weight:700}.savings-text{color:#16a34a!important;font-weight:700}.penalty-text{color:#ea580c!important;font-weight:600}.print-bullet-point{margin-bottom:.5rem;font-size:9pt;line-height:1.4;color:#334155}.print-bullet-point strong{color:#0f172a}.print-proposal-text{font-family:monospace;font-size:8.5pt;background-color:#f8fafc!important;border:1px solid #e2e8f0;border-radius:6px;padding:1rem;white-space:pre-wrap;line-height:1.4;color:#334155}.print-footer{margin-top:3rem;border-top:1px solid #e2e8f0;padding-top:.5rem;font-size:7.5pt;color:#94a3b8;text-align:center}.print-avoid-break{page-break-inside:avoid}}.view-switcher{border-bottom:1px solid var(--panel-border)!important}.view-tab-btn{border-bottom:2px solid transparent!important}.view-tab-btn.active{color:var(--primary-hover)!important;border-bottom-color:var(--primary)!important}.view-tab-btn:hover:not(.active){color:var(--text-primary)!important;background:rgba(255,255,255,3%)!important}.light-theme .view-tab-btn:hover:not(.active){background:rgba(0,0,0,3%)!important}.treemap-item{position:relative;box-shadow:inset 0 0 12px rgba(255,255,255,1%);background:rgba(255,255,255,2%);border:1px solid var(--panel-border)}.light-theme .treemap-item{background:rgba(0,0,0,1%);border-color:rgba(0,0,0,6%)}.treemap-item.green{background:rgba(16,185,129,6%)!important;border-color:rgba(16,185,129,.25)!important}.treemap-item.green:hover{background:rgba(16,185,129,.12)!important;border-color:rgba(16,185,129,.5)!important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(16,185,129,.15)!important}.treemap-item.green .item-status-badge{background:rgba(16,185,129,.15)!important;color:#34d399!important}.treemap-item.red{background:rgba(245,158,11,6%)!important;border-color:rgba(245,158,11,.25)!important}.treemap-item.red:hover{background:rgba(245,158,11,.12)!important;border-color:rgba(245,158,11,.5)!important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,.15)!important}.treemap-item.red .item-status-badge{background:rgba(245,158,11,.15)!important;color:#fbbf24!important}.treemap-item.darkred{background:rgba(239,68,68,6%)!important;border-color:rgba(239,68,68,.3)!important;animation:pulse-border-converter 2s infinite alternate}.treemap-item.darkred:hover{background:rgba(239,68,68,.12)!important;border-color:rgba(239,68,68,.6)!important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(239,68,68,.2)!important}.treemap-item.darkred .item-status-badge{background:rgba(239,68,68,.15)!important;color:#f87171!important}@keyframes pulse-border-converter{0%{border-color:rgba(239,68,68,.25);box-shadow:0 0 4px rgba(239,68,68,5%)}100%{border-color:rgba(239,68,68,.5);box-shadow:0 0 14px rgba(239,68,68,.2)}}.treemap-cell{border:1px solid rgba(255,255,255,5%);display:inline-block}.treemap-cell.green{background:#10b981}.treemap-cell.green:hover{transform:scale(1.3);box-shadow:0 0 12px rgba(16,185,129,.7);z-index:10;outline:2px solid #fff}.treemap-cell.red{background:#fbbf24}.treemap-cell.red:hover{transform:scale(1.3);box-shadow:0 0 12px rgba(251,191,36,.7);z-index:10;outline:2px solid #fff}.treemap-cell.darkred{background:#ef4444;animation:pulse-cell 2s infinite alternate}.treemap-cell.darkred:hover{transform:scale(1.3);box-shadow:0 0 12px rgba(239,68,68,.9);z-index:10;outline:2px solid #fff}@keyframes pulse-cell{0%{box-shadow:0 0 2px rgba(239,68,68,.2)}100%{box-shadow:0 0 6px rgba(239,68,68,.6)}}.package{}.tile{cursor:pointer;transition:filter .16s ease,opacity .16s ease,stroke-width .16s ease}.tile:hover,.tile:focus-visible{filter:saturate(1.22)brightness(1.08);opacity:.95}.tile-ring{pointer-events:none;fill:none;stroke:var(--warning);stroke-width:3px;stroke-linejoin:round;opacity:0;transition:opacity .16s ease}.tile-ring.selected{opacity:1}.tile-label{pointer-events:none;fill:#fff;font-family:var(--font-heading);font-weight:700;letter-spacing:0}.tile-sub{pointer-events:none;fill:rgba(255,255,255,.72);font-family:var(--font-body)}.light-theme .package.optimal .tile-label,.light-theme .package.suboptimal-low .tile-label{fill:var(--text-primary)}.light-theme .package.optimal .tile-sub,.light-theme .package.suboptimal-low .tile-sub{fill:var(--text-secondary)}.item-status-badge{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;display:inline-block;transition:all .2s ease}.item-status-badge.status-optimal{background:rgba(16,185,129,.15);color:var(--success);border:1px solid rgba(16,185,129,.25)}.item-status-badge.status-suboptimal{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.25)}.light-theme .item-status-badge.status-optimal{background:rgba(16,185,129,.12);color:var(--success);border-color:rgba(16,185,129,.4)}.light-theme .item-status-badge.status-suboptimal{background:rgba(239,68,68,.1);color:var(--danger);border-color:rgba(239,68,68,.35)}#tooltip{position:fixed;z-index:9999;max-width:320px;border:1px solid var(--panel-border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-lg);padding:10px 12px;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .12s ease,transform .12s ease;font-family:var(--font-body)}#tooltip.show{opacity:1;transform:translateY(0)}#tooltip strong{display:block;margin-bottom:4px;font-family:var(--font-heading);font-size:.95rem;font-weight:700}#tooltip span{display:block;font-size:.8rem;color:var(--text-secondary)}#tooltip .tip-grid{display:grid;grid-template-columns:auto auto;gap:4px 12px;margin-top:8px;color:var(--text-secondary);font-size:.75rem;border-top:1px solid var(--panel-border);padding-top:6px}#tooltip .tip-grid b{color:var(--text-primary);text-align:right}