:root{color:#19211d;font-synthesis:none;letter-spacing:0;text-rendering:optimizelegibility;background:#f5f7f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(#f0f6efeb,#faf8f3f5),#f5f7f3;min-width:320px;margin:0}button,input{font:inherit}button{cursor:pointer}.app-shell{width:min(1480px,100% - 32px);margin:0 auto;padding:28px 0 40px}.calculator-header{justify-content:space-between;align-items:flex-end;gap:24px;padding:12px 0 24px;display:flex}.eyebrow{color:#2c6c57;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:12px;font-size:.86rem;font-weight:800;display:inline-flex}h1,h2,p{margin:0}h1{color:#16231e;letter-spacing:0;max-width:780px;font-size:clamp(2rem,4vw,4.4rem);line-height:.98}.calculator-header p{color:#55635a;max-width:720px;margin-top:14px;font-size:1.04rem;line-height:1.5}.reset-button{color:#23332b;white-space:nowrap;background:#fff;border:1px solid #cad6cc;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-weight:800;transition:transform .16s,border-color .16s,box-shadow .16s;display:inline-flex}.reset-button:hover{border-color:#93b5a6;transform:translateY(-1px);box-shadow:0 10px 24px #2543361c}.site-home,.rep-home{align-items:center;min-height:100vh;display:grid}.site-panel,.rep-panel{background:#ffffffe6;border:1px solid #d7e0d8;border-radius:8px;width:min(860px,100%);padding:28px;box-shadow:0 16px 44px #293b3014}.site-panel h1,.rep-panel h1{max-width:680px;font-size:clamp(2.1rem,5vw,4rem)}.site-panel p,.rep-panel p{color:#5c6a62;max-width:560px;margin-top:14px;font-size:1rem;font-weight:700;line-height:1.5}.rep-link-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:26px;display:grid}.rep-link-grid a{color:#1d2b23;background:#fff;border:1px solid #d6dfd7;border-radius:8px;align-content:center;gap:8px;min-height:118px;padding:16px;text-decoration:none;transition:transform .16s,border-color .16s,box-shadow .16s;display:grid}.rep-link-grid a:hover{border-color:#83b89f;transform:translateY(-1px);box-shadow:0 12px 28px #2341341f}.rep-link-grid span{color:#66746d;text-transform:uppercase;font-size:.82rem;font-weight:900}.rep-link-grid strong{color:#1f7655;font-size:1.7rem;line-height:1}.input-grid,.summary-section,.table-grid{gap:16px;display:grid}.input-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.input-card,.summary-card,.projection-card{background:#ffffffe0;border:1px solid #d9dfd6;border-radius:8px;box-shadow:0 16px 44px #293b3014}.input-card{border-top:4px solid #c77844;gap:18px;padding:20px;display:grid}.input-card.utility-alt{border-top-color:#b78b31}.input-card.solar{border-top-color:#2f9b73}.card-title-row,.projection-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.card-title-row{justify-content:flex-start}.icon-badge{color:#9c542b;background:#f7eee4;border-radius:8px;flex:0 0 38px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.utility-alt .icon-badge{color:#8f6a13;background:#f7f1df}.solar .icon-badge{color:#247657;background:#e7f5ef}.input-card h2,.projection-card h2{color:#1b2922;font-size:1.04rem;line-height:1.2}label{color:#596760;gap:8px;font-size:.88rem;font-weight:800;display:grid}.input-wrapper{color:#52615a;background:#fff;border:1px solid #cdd8d0;border-radius:8px;grid-template-columns:20px 1fr auto;align-items:center;gap:8px;min-height:46px;padding:0 12px;display:grid}.input-wrapper:focus-within{border-color:#3b8d6e;box-shadow:0 0 0 3px #3b8d6e26}.input-wrapper.locked{color:#6b776f;background:#f1f6f2}input{color:#1f2e27;background:0 0;border:0;outline:0;width:100%;min-width:0;font-size:1.08rem;font-weight:850}input:disabled{color:#56645c;opacity:1}.suffix{color:#68756e;font-size:.95rem;font-weight:850}.scenario-results{border-top:1px solid #e3e9e2;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding-top:14px;display:grid}.scenario-results div{min-width:0}.scenario-results span{color:#69756d;text-transform:uppercase;font-size:.75rem;font-weight:850;display:block}.scenario-results strong{color:#1d2b23;overflow-wrap:anywhere;margin-top:4px;font-size:1.08rem;line-height:1.15;display:block}.summary-section{grid-template-columns:repeat(5,minmax(0,1fr));margin-top:16px}.summary-card{gap:8px;min-height:144px;padding:18px;display:grid}.summary-card span{color:#6a756f;text-transform:uppercase;font-size:.82rem;font-weight:850}.summary-card strong{color:#1a281f;overflow-wrap:anywhere;font-size:clamp(1.45rem,2.2vw,2.08rem);line-height:1.08}.summary-card p{color:#647069;align-self:end;font-size:.9rem;font-weight:750;line-height:1.35}.summary-card.utility-total{background:#faece7;border-color:#ddb4a6}.summary-card.utility-total strong{color:#8e3f2d}.summary-card.utility-total span,.summary-card.utility-total p{color:#76564f}.summary-card.featured{background:#edf8f2;border-color:#a9d8c5}.summary-card.savings{background:#e8f6ef;border-color:#8fc8ae}.summary-card.savings strong{color:#1e7b58}.summary-card.savings strong.negative{color:#b95533}.rate-section{background:#ffffffe6;border:1px solid #d5e0d7;border-radius:8px;margin-top:16px;overflow:hidden;box-shadow:0 16px 44px #293b3014}.rate-heading{background:0 0;border-bottom:1px solid #e2e8df;justify-content:space-between;align-items:flex-start;gap:18px;padding:18px;display:flex}.rate-heading h2{color:#1b2922;font-size:1.16rem;line-height:1.2}.rate-heading p{color:#617068;margin-top:6px;font-size:.92rem;font-weight:700}.rate-legend{background:0 0;flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.rate-legend span{color:#405047;white-space:nowrap;align-items:center;gap:7px;font-size:.82rem;font-weight:850;display:inline-flex}.rate-legend span:before{content:"";background:currentColor;border-radius:999px;width:24px;height:4px}.rate-legend .line-utility{color:#b56736}.rate-legend .line-utility-alt{color:#a77a1d}.rate-legend .line-solar{color:#2c936d}.rate-layout{grid-template-columns:minmax(0,1.6fr) minmax(360px,.75fr);gap:0;display:grid}.rate-chart{min-height:340px;padding:20px 18px 10px;position:relative}.rate-chart svg{cursor:crosshair;touch-action:none;width:100%;height:100%;min-height:300px;display:block}.axis-line{stroke:#aebbb3;stroke-width:1.5px}.grid-line{stroke:#e7ece7;stroke-width:1px}.axis-label{fill:#6b766f;text-anchor:end;font-size:.72rem;font-weight:800}.year-label{text-anchor:middle}.rate-line{stroke-width:4px;stroke-linecap:round;stroke-linejoin:round}.rate-line.line-utility{stroke:#b56736}.rate-line.line-utility-alt{stroke:#a77a1d}.rate-line.line-solar{stroke:#2c936d}.hover-year-line{stroke:#24322b;stroke-dasharray:5 5;stroke-width:1.5px}.hover-dot{stroke:#fff;stroke-width:3px}.hover-dot.line-utility{fill:#b56736}.hover-dot.line-utility-alt{fill:#a77a1d}.hover-dot.line-solar{fill:#2c936d}.chart-tooltip{z-index:3;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);text-shadow:0 1px 1px #ffffffb3,0 0 4px #ffffff94;background:#ffffff85;border:0;border-radius:8px;width:min(456px,100% - 132px);padding:7px 9px;position:absolute;top:18px;left:104px;box-shadow:0 8px 20px #1f31270f}.chart-tooltip.is-left{left:auto;right:24px}.tooltip-title{color:#1a281f;text-transform:uppercase;margin-bottom:4px;font-size:.76rem;font-weight:900;line-height:1.1}.tooltip-table{gap:0;display:grid}.tooltip-row{border-top:1px solid #21332a1a;grid-template-columns:78px 76px 76px 68px 86px;align-items:center;gap:5px;padding:3px 0 0;display:grid}.tooltip-row:first-child{border-top:0;padding-top:0}.tooltip-header{color:#6a756f;text-transform:uppercase;font-size:.56rem;font-weight:900;line-height:1}.tooltip-header span:not(:first-child){text-align:right}.tooltip-label{color:#405047;white-space:nowrap;align-items:center;gap:5px;font-size:.69rem;font-weight:900;line-height:1.05;display:inline-flex}.tooltip-label:before{content:"";background:currentColor;border-radius:999px;flex:0 0 16px;width:16px;height:3px}.tooltip-label.line-utility{color:#b56736}.tooltip-label.line-utility-alt{color:#a77a1d}.tooltip-label.line-solar{color:#2c936d}.tooltip-row strong{color:#1d2b23;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;font-size:.67rem;font-weight:900;line-height:1.05}.rate-table-wrap{border-left:1px solid #e2e8df;max-height:360px;overflow:auto}.rate-table th,.rate-table td{padding:11px 12px}.table-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start;margin-top:16px}.projection-card{overflow:hidden}.projection-heading{border-bottom:1px solid #e0e5de;padding:18px 18px 14px}.projection-card.utility .projection-heading{background:#fbf2ea}.projection-card.utility-alt .projection-heading{background:#faf4df}.projection-card.solar .projection-heading{background:#eaf7f1}.table-scroll{overflow-x:auto}table{border-collapse:collapse;table-layout:fixed;background:#fff;width:100%}th,td{text-align:right;border-bottom:1px solid #edf0eb;padding:12px 10px}th:first-child,td:first-child{text-align:left;width:48px}th{z-index:1;color:#667169;letter-spacing:0;text-transform:uppercase;background:#fff;font-size:.72rem;line-height:1.2;position:sticky;top:0}td{color:#2f3b34;white-space:nowrap;font-size:.9rem;font-weight:700}tbody tr:nth-child(2n) td{background:#fbfcfa}tbody tr:hover td{background:#f1f6f2}.preset-footer{justify-content:flex-end;margin-top:22px;padding-bottom:4px;display:flex}.preset-footer details{color:#65736b;background:#ffffffd1;border:1px solid #d8e0d8;border-radius:8px;max-width:520px;padding:10px 12px;font-size:.82rem;font-weight:800}.preset-footer summary{cursor:pointer;list-style-position:inside}.preset-link-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:10px;display:grid}.preset-link-grid a{color:#43534a;white-space:nowrap;background:#fff;border:1px solid #d5ded7;border-radius:8px;justify-content:center;align-items:center;min-height:36px;font-size:.8rem;font-weight:900;text-decoration:none;display:inline-flex}.preset-link-grid a:hover,.preset-link-grid a.active{color:#246b4e;background:#eef8f2;border-color:#83b89f}@media (width<=1180px){.summary-section{grid-template-columns:repeat(3,minmax(0,1fr))}.rate-layout{grid-template-columns:1fr}.rate-table-wrap{border-top:1px solid #e2e8df;border-left:0}.table-grid{grid-template-columns:1fr}}@media (width<=860px){.calculator-header{flex-direction:column;align-items:flex-start}.input-grid,.summary-section,.rep-link-grid{grid-template-columns:1fr}.reset-button{width:100%}.rate-heading{flex-direction:column}.rate-legend{justify-content:flex-start}.tooltip-header{display:none}.tooltip-row{grid-template-columns:repeat(2,minmax(0,1fr))}.tooltip-label{grid-column:1/-1}.tooltip-row strong{text-align:left;white-space:normal}}@media (width<=560px){.app-shell{width:min(100% - 20px,1480px);padding-top:18px}.input-card,.summary-card,.site-panel,.rep-panel{padding:16px}.scenario-results{grid-template-columns:1fr}h1{font-size:2.18rem}th,td{padding:10px 8px;font-size:.82rem}.rate-chart{min-height:260px;padding:14px 8px 0}.rate-chart svg{min-height:240px}.chart-tooltip{width:auto;left:12px;right:12px}.chart-tooltip.is-left{left:12px;right:12px}.preset-footer{justify-content:stretch}.preset-footer details{width:100%}.preset-link-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
