:root{--color-primary: #007bff;--color-success: #10b981;--color-success-light: #f0fdf4;--color-success-bg: #e8f5e9;--color-success-border: #4caf50;--color-danger: #dc3545;--color-danger-light: #fee;--color-text: #333;--color-text-secondary: #666;--color-border: #ddd;--color-border-light: #e5e7eb;--color-bg-light: #f5f5f5;--color-white: white;--color-green: #10b981;--color-lime: #84cc16;--color-yellow: #eab308;--color-orange: #f97316;--color-red: #ef4444;--shadow-sm: 0 2px 8px rgba(0,0,0,.1);--shadow-md: 0 4px 12px rgba(0,0,0,.1)}.app-container{max-width:100%;margin:0 auto;padding:1rem;font-family:Inter}.app-container h2{margin-bottom:.5rem;text-align:center}.view-mode-toggle{margin-top:2rem;display:flex;justify-content:center;gap:0}.view-mode-button{padding:.75rem 1.5rem;font-size:1rem;border:1px solid var(--color-border);background-color:var(--color-bg-light);color:var(--color-text-secondary);cursor:pointer;font-weight:400;transition:all .2s ease}.view-mode-button:first-child{border-radius:8px 0 0 8px;border-right:none}.view-mode-button:last-child{border-radius:0 8px 8px 0}.view-mode-button.active{background-color:var(--color-white);color:var(--color-text);font-weight:500}.postcode-container{padding:2rem;max-width:800px;margin:0 auto;text-align:center}.postcode-container-intro{margin-bottom:1rem;font-weight:500}.postcode-error{color:red;margin-top:1rem}.selected-regions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem;justify-content:center}.region-card{padding:1rem;background-color:var(--color-success-bg);border-radius:8px;border:1px solid var(--color-success-border);flex:0 1 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem}.region-remove-button{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:1.2rem;padding:0 .5rem}.postcode-form{display:flex;gap:.5rem;align-items:flex-start;justify-content:center}.postcode-input-wrapper{flex:1;max-width:250px}.postcode-input{padding:.5rem;font-size:1rem;border:1px solid var(--color-border-light);border-radius:4px;width:100%;outline:none}.postcode-input.error{border-color:var(--color-danger);outline:1px solid var(--color-danger)}.postcode-input-error{color:var(--color-danger);font-size:.85rem;margin-top:.25rem;margin-bottom:0}.postcode-submit-button{padding:.5rem 1rem;font-size:1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap}.postcode-hint{font-size:.85rem;color:var(--color-text-secondary);margin-top:.5rem;font-style:italic}.forecast-container{width:100%;margin-top:2rem}.forecast-container-empty{padding:2rem;text-align:center;color:var(--color-text-secondary);font-style:italic}.forecast-iframe-wrapper{border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.forecast-iframe{width:100%;height:800px;border:none;display:block}.optimal-window-container{background-color:var(--color-success-light);padding:2rem;border-radius:8px;margin-top:2rem;border:2px solid var(--color-success)}.optimal-window-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.optimal-window-title{margin:0;font-size:1.25rem;color:var(--color-text)}.optimal-window-description{font-size:.875rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:.5rem}.optimal-window-toggle{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.optimal-window-toggle label{font-weight:600;font-size:.95rem;color:var(--color-text)}.optimal-postcode-select{padding:.5rem 1rem;border-radius:6px;border:2px solid var(--color-success);background-color:#fff;color:var(--color-text);font-size:.95rem;cursor:pointer;transition:all .2s}.optimal-postcode-select:hover{background-color:var(--color-success-light)}.optimal-postcode-select:focus{outline:none;border-color:var(--color-success);box-shadow:0 0 0 3px #10b98133}.optimal-window-loading,.optimal-window-error,.optimal-window-empty{padding:2rem;text-align:center;border-radius:8px;margin-top:2rem}.optimal-window-loading,.optimal-window-empty{background-color:var(--color-success-light);border:2px solid var(--color-success)}.optimal-window-loading p,.optimal-window-empty p{color:var(--color-text-secondary)}.optimal-window-error{background-color:var(--color-danger-light)}.optimal-window-error p{color:#c00}.optimal-window-list{display:flex;flex-direction:column;gap:1rem}.optimal-window-card{background-color:var(--color-white);padding:1.25rem;border-radius:8px;border:1px solid var(--color-border-light);display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s ease;cursor:default}.optimal-window-card:hover{box-shadow:var(--shadow-md)}.optimal-window-card-left{display:flex;align-items:center;gap:1rem;flex:1}.optimal-window-icon{background-color:var(--color-success-light);padding:.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;min-width:48px;height:48px}.optimal-window-icon span{font-size:1.5rem}.optimal-window-details{flex:1}.optimal-window-region{font-weight:600;font-size:1rem;color:#111;margin-bottom:.25rem}.optimal-window-time{font-size:.875rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:.5rem}.optimal-window-metrics{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.optimal-window-intensity{font-size:1.5rem;font-weight:700}.optimal-window-intensity-unit{font-size:.875rem;font-weight:400;color:var(--color-text-secondary);margin-left:.25rem}.optimal-window-intensity-label{font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:12px}.intensity-very-low{color:var(--color-green)}.intensity-low{color:var(--color-lime)}.intensity-moderate{color:var(--color-yellow)}.intensity-high{color:var(--color-orange)}.intensity-very-high{color:var(--color-red)}.intensity-very-low-bg{background-color:#10b98114}.intensity-low-bg{background-color:#84cc1614}.intensity-moderate-bg{background-color:#eab30814}.intensity-high-bg{background-color:#f9731614}.intensity-very-high-bg{background-color:#ef444414}.optimal-window-tip{margin-top:1.5rem;padding:1rem;background-color:var(--color-white);border-radius:8px;border:1px solid var(--color-border-light);font-size:.875rem;color:var(--color-text-secondary);line-height:1.6}.optimal-window-tip strong{color:var(--color-text)}.dynamic-routing-container{width:100%;margin-top:2rem;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.scope2-container{background-color:#fdf0f9;padding:2rem;border-radius:12px;margin-top:2rem;border:1px solid #B91048;color:#000;box-shadow:var(--shadow-md)}.scope2-header{text-align:center;margin-bottom:2rem}.scope2-header h3{margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.scope2-facility{font-size:1.125rem;opacity:.9;margin:0}.scope2-postcode-toggle{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.scope2-postcode-toggle label{font-weight:600;font-size:.95rem}.scope2-postcode-select{padding:.5rem 1rem;border-radius:6px;border:2px solid #B91048;background-color:#fff;color:#000;font-size:.95rem;cursor:pointer;transition:all .2s}.scope2-postcode-select:hover{background-color:#b910481a}.scope2-postcode-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b98133}.scope2-carbon-price-statement{text-align:center;padding:0 0 2rem}.scope2-loading,.scope2-error{text-align:center;padding:2rem;font-size:1rem}.scope2-error{background-color:#dc354533;border-radius:8px}.scope2-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.scope2-stat{background-color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:12px;text-align:center;border:1px solid rgba(255,255,255,.2)}.scope2-stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.scope2-stat-label{font-size:1rem;font-weight:600;margin-bottom:.25rem;opacity:.95}.scope2-stat-sublabel{font-size:.875rem;opacity:.75}.scope2-daily{background-color:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.2)}.scope2-daily h4{margin:0 0 1rem;font-size:1.25rem;font-weight:600}.scope2-daily-list{display:flex;flex-direction:column;gap:.75rem}.scope2-daily-item{background-color:#fff;padding:1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.scope2-daily-item:hover{background-color:#fff3}.scope2-daily-date{font-weight:600;font-size:.95rem;min-width:100px}.scope2-daily-values{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.875rem;margin-left:auto;margin-right:1rem}.scope2-daily-emissions{font-weight:600}.scope2-daily-usage,.scope2-daily-intensity{opacity:.85}.scope2-footer{text-align:center;opacity:.8;font-size:.875rem}.scope2-footer p{margin:.5rem 0}.scope2-methodology{font-style:italic;opacity:.7}
