:root{--bg: #f4f7fb;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-dim: #eff6ff;--accent-hover: #1d4ed8;--green: #16a34a;--amber: #d97706;--red: #dc2626;--purple: #9333ea;--aks: #2563eb;--aro: #dc2626;--vm: #0284c7;--radius: 10px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06);--font: "DM Sans", system-ui, sans-serif;--mono: "JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.mobile-header,.sidebar-backdrop{display:none}.sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-close{display:none}.sidebar-footer{margin-top:auto;padding:.5rem;font-size:.75rem;color:var(--muted)}.sidebar{background:var(--surface);border-right:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.5rem 1rem;display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:0;height:100vh;overflow-y:auto}.logo{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;padding:0 .5rem;color:var(--text)}.logo span{color:var(--accent)}.nav-link{display:block;padding:.6rem .75rem;border-radius:var(--radius);color:var(--muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover,.nav-link.active{background:var(--accent-dim);color:var(--accent);text-decoration:none}.main{padding:2rem 2rem 3.5rem;max-width:1400px}.site-footnote{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:.65rem 1rem;font-size:.75rem;color:var(--muted);text-align:center;background:var(--surface);border-top:1px solid var(--border)}.site-footnote--app{left:260px}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;color:var(--text)}.page-header p{color:var(--muted);margin-top:.35rem}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.card-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.card-value{font-size:1.75rem;font-weight:700;margin-top:.25rem;font-variant-numeric:tabular-nums;color:var(--text)}.card-value small{font-size:.9rem;font-weight:500;color:var(--muted)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-aks{background:#dbeafe;color:#1d4ed8}.badge-aro{background:#fee2e2;color:#b91c1c}.badge-vm{background:#e0f2fe;color:#0369a1}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--surface-2);color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc}.mono{font-family:var(--mono);font-size:.85rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-family:var(--font);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 3px #2563eb4d}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.grid-2{grid-template-columns:1fr}}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.35rem;font-weight:500}.form-group input,.form-group select{width:100%;padding:.55rem .75rem;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-family:var(--font);font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb26}.section{margin-bottom:2rem}.section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}.driver-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.driver-card h3{font-size:1rem;margin-bottom:.35rem;color:var(--text)}.driver-card p{font-size:.85rem;color:var(--muted);margin-bottom:.75rem}.impact{color:var(--amber);font-size:.85rem;font-weight:500}.positive{color:var(--green)}.negative{color:var(--red)}.config-table td:first-child{font-family:var(--mono);color:var(--accent)}.loading,.error{padding:3rem;text-align:center;color:var(--muted)}.error{color:var(--red)}.chart-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-sm)}.chart-container h2{color:var(--text)}.app-link{color:var(--text);text-decoration:none;font-weight:500}.app-link:hover{color:var(--accent)}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:0}.tab{padding:.6rem 1rem;border:none;background:none;color:var(--muted);font-family:var(--font);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.line-items{font-size:.85rem}.line-items .row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--border)}.line-items .row:last-child{border-bottom:none;font-weight:600}.tshirt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.tshirt-card{text-align:left;padding:1.25rem;border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;font-family:var(--font);box-shadow:var(--shadow-sm)}.tshirt-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.tshirt-card.active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 3px #2563eb1f}.tshirt-size{font-size:1.75rem;font-weight:700;color:var(--accent);line-height:1}.tshirt-label{font-size:.85rem;font-weight:600;margin-top:.35rem;color:var(--text)}.tshirt-cost{font-size:1.25rem;font-weight:700;margin:.5rem 0;font-variant-numeric:tabular-nums;color:var(--text)}.tshirt-cost span{font-size:.75rem;font-weight:500;color:var(--muted)}.tshirt-desc{font-size:.75rem;color:var(--muted);line-height:1.4}.driver-projection{margin-top:1rem;padding:1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.cost-type-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.cost-type-azure{background:#e0f2fe;color:#0369a1}.cost-type-subscription{background:#fef3c7;color:#b45309}.cost-type-license{background:#ede9fe;color:#6d28d9}.cost-type-resource_license{background:#f3e8ff;color:#7c3aed}.cost-type-system{background:#fce7f3;color:#be185d}.cost-type-vm,.cost-type-aks_node,.cost-type-aro_node,.cost-type-storage{background:#e0f2fe;color:#0369a1}.sim-scenario-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:900px){.sim-scenario-tabs{grid-template-columns:1fr}}.sim-scenario-tab{text-align:left;padding:1rem 1.25rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-family:var(--font);transition:border-color .15s,background .15s;box-shadow:var(--shadow-sm)}.sim-scenario-tab strong{display:block;font-size:1rem;color:var(--text)}.sim-scenario-tab span{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.sim-scenario-tab:hover{border-color:var(--accent)}.sim-scenario-tab.active{border-color:var(--accent);background:var(--accent-dim)}.sim-input-card h2{font-size:1.1rem;margin-bottom:.35rem}.sim-input-row{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap}.sim-input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:1rem;align-items:end}.sim-input-with-unit{display:flex;gap:.5rem;align-items:center}.sim-input-with-unit input{flex:1;min-width:0}.sim-frequency-select{width:100%;padding:.55rem .75rem;font-size:.9rem;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.sim-frequency-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}.sim-run-btn{align-self:end;height:fit-content}.sim-unit{font-size:.9rem;font-weight:600;color:var(--muted);padding-bottom:.6rem;text-transform:uppercase;letter-spacing:.04em}.sim-unit-select{min-width:4.5rem;padding:.55rem .75rem;font-size:.9rem;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.sim-unit-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}.sim-results{display:flex;flex-direction:column;gap:1rem}.sim-result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.sim-result-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.sim-result-cost{display:flex;flex-direction:column;align-items:flex-end;font-weight:700;font-size:1.1rem}.sim-breakdown{display:flex;gap:1.25rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted);padding:.5rem 0}.sim-impacts{margin-top:.75rem;border-top:1px solid var(--border);padding-top:.75rem}.sim-impacts-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.5rem}.sim-impacts ul{list-style:none}.sim-impacts li{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;padding:.35rem 0;font-size:.85rem;border-bottom:1px solid var(--border)}.sim-impacts li:last-child{border-bottom:none}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.form-section-title{font-size:.9rem;font-weight:600;margin:1.25rem 0 .75rem;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--surface);border-radius:12px;border:1px solid var(--border);box-shadow:0 20px 50px #0f172a26;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:1.5rem}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.modal-header h2{font-size:1.25rem}.modal-close{border:none;background:none;font-size:1.5rem;line-height:1;color:var(--muted);cursor:pointer;padding:.25rem}.modal-close:hover{color:var(--text)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.btn-danger-ghost{border:none;background:none;color:var(--red);box-shadow:none;font-size:.8rem;padding:.35rem .5rem}.btn-danger-ghost:hover{background:#fef2f2}.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.region-card{text-align:left;padding:1.25rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-family:var(--font);transition:border-color .15s,background .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}.region-card:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--shadow-md)}.region-card.active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 3px #2563eb1f}.region-card:disabled{opacity:.6;cursor:wait}.region-card-label{font-size:1.25rem;font-weight:700;color:var(--accent)}.region-card-id{font-family:var(--mono);font-size:.75rem;color:var(--muted);margin:.25rem 0}.region-card-desc{font-size:.8rem;color:var(--muted);line-height:1.4}.form-group textarea{width:100%;padding:.55rem .75rem;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-family:var(--font);font-size:.9rem;resize:vertical;min-height:4rem;transition:border-color .15s,box-shadow .15s}.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb26}.version-banner{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.9rem}.version-banner.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.version-dirty{color:var(--amber);font-size:.85rem;font-weight:500}.version-actions-grid{align-items:start}.version-dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;cursor:pointer;background:var(--surface-2);transition:border-color .15s,background .15s}.version-dropzone:hover,.version-dropzone.drag-over{border-color:var(--accent);background:var(--accent-dim)}.version-dropzone.disabled{opacity:.6;pointer-events:none}.version-dropzone strong{display:block;margin-bottom:.35rem;color:var(--text)}.version-dropzone span{font-size:.8rem;color:var(--muted)}.version-dropzone-icon{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;margin:0 auto .75rem;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:.75rem;font-weight:700;color:var(--accent);letter-spacing:.04em}.version-dl{display:grid;gap:.65rem}.version-dl div{display:grid;grid-template-columns:8rem 1fr;gap:.75rem;font-size:.9rem}.version-dl dt{color:var(--muted);font-weight:600}.version-timeline{display:flex;flex-direction:column;gap:.75rem}.version-timeline-item{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:start}.version-timeline-marker{width:10px;height:10px;border-radius:999px;margin-top:1.1rem;background:var(--accent)}.version-timeline-marker[data-action=import]{background:var(--green)}.version-timeline-marker[data-action=export]{background:var(--purple)}.version-timeline-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.version-backup-list{list-style:none;font-size:.85rem;color:var(--muted)}.version-backup-list li{padding:.35rem 0;border-bottom:1px solid var(--border)}.version-backup-list li:last-child{border-bottom:none}.version-changelog{display:flex;flex-direction:column;gap:1rem}.version-changelog-header{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.75rem}.version-changelog-body{font-family:var(--font);font-size:.85rem;line-height:1.55;white-space:pre-wrap;color:var(--muted);margin:0;background:transparent;border:none}@media(max-width:768px){.app-layout{display:flex;flex-direction:column;min-height:100vh}.mobile-header{display:flex;align-items:center;gap:.75rem;position:sticky;top:0;z-index:200;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.mobile-header-title{flex:1;font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.mobile-header-title span{color:var(--accent)}.mobile-header-meta{font-size:.7rem;color:var(--muted);white-space:nowrap}.menu-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:2.5rem;height:2.5rem;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;flex-shrink:0}.menu-toggle span{display:block;height:2px;width:100%;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}.nav-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-open .menu-toggle span:nth-child(2){opacity:0}.nav-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;border:none;background:#0f172a73;cursor:pointer}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:300;width:min(280px,85vw);height:100vh;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.nav-open .sidebar{transform:translate(0);box-shadow:4px 0 24px #0f172a1f}.sidebar-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:none;font-size:1.5rem;line-height:1;color:var(--muted);cursor:pointer;border-radius:var(--radius)}.sidebar-close:hover{background:var(--surface-2);color:var(--text)}.main{padding:1rem 1rem 3.5rem;max-width:none;min-width:0;flex:1}.page-header{margin-bottom:1.25rem}.page-header h1{font-size:1.35rem}.page-header p{font-size:.875rem}.page-header-row{flex-direction:column;align-items:stretch}.page-header-row .btn{width:100%;justify-content:center}.cards{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.25rem}.card{padding:1rem}.card-value{font-size:1.35rem}.chart-container{padding:.75rem;min-height:260px}.chart-container h2{font-size:.95rem!important}.section{margin-bottom:1.5rem}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;padding-bottom:0;margin-bottom:1rem;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0;padding:.55rem .85rem;font-size:.85rem}.sim-scenario-tabs{grid-template-columns:1fr;gap:.75rem}.sim-input-row{flex-direction:column;align-items:stretch}.sim-input-row .btn,.sim-run-btn{width:100%;justify-content:center}.sim-input-grid{grid-template-columns:1fr}.sim-unit{padding-bottom:0}.sim-unit-select{width:100%}.sim-result-header{flex-direction:column}.sim-result-cost{align-items:flex-start}.sim-breakdown{flex-direction:column;gap:.35rem}.sim-impacts li{grid-template-columns:1fr;gap:.25rem}.tshirt-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.tshirt-card{padding:1rem}.modal{max-height:85vh;padding:1.25rem;border-radius:12px 12px 0 0;align-self:flex-end}.modal-overlay{align-items:flex-end;padding:0}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%;justify-content:center}.region-grid{grid-template-columns:1fr}.responsive-table thead{display:none}.responsive-table tbody tr{display:block;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.responsive-table tbody tr:last-child{border-bottom:none}.responsive-table tbody tr:hover td{background:transparent}.responsive-table td{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.4rem 0;border-bottom:none;text-align:right}.responsive-table td:before{content:attr(data-label);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);text-align:left;flex-shrink:0}.responsive-table td.actions-cell{justify-content:flex-end;padding-top:.5rem}.responsive-table td.actions-cell:before{display:none}.responsive-table td.hide-mobile{display:none}.line-items .row{flex-direction:column;align-items:flex-start;gap:.2rem}.driver-card .form-group{max-width:none!important}.version-dl div{grid-template-columns:1fr;gap:.15rem}.version-dropzone{padding:1.5rem 1rem}}@media(max-width:400px){.cards,.tshirt-grid{grid-template-columns:1fr}.mobile-header-meta{display:none}}.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.25rem 3.5rem;background:var(--bg)}.landing-card{width:100%;max-width:640px;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);box-shadow:var(--shadow-md);padding:2rem}.landing-header{text-align:center;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.landing-logo{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;color:var(--text)}.landing-logo span{color:var(--accent)}.landing-tagline{margin-top:.35rem;color:var(--muted);font-size:.95rem}.landing-section{margin-bottom:1.5rem}.landing-section h2{font-size:1rem;font-weight:700;margin-bottom:.65rem;color:var(--text)}.landing-section p{color:var(--muted);font-size:.9rem;margin-bottom:.75rem}.landing-section p:last-child{margin-bottom:0}.landing-disclaimer{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.landing-disclaimer ul{margin:0;padding-left:1.25rem;color:var(--muted);font-size:.875rem}.landing-disclaimer li{margin-bottom:.6rem}.landing-disclaimer li:last-child{margin-bottom:0}.landing-ack{display:flex;align-items:flex-start;gap:.65rem;margin:1.5rem 0 1rem;font-size:.9rem;color:var(--text);cursor:pointer}.landing-ack input{margin-top:.2rem;flex-shrink:0;accent-color:var(--accent)}.landing-enter{width:100%;justify-content:center}.landing-enter:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.site-footnote--app{left:0}.landing-card{padding:1.5rem 1.25rem}.landing-logo{font-size:1.5rem}}
