:root{--bg:oklch(0.16 0.012 220);--bg-2:oklch(0.19 0.014 220);--surface:oklch(0.22 0.014 220);--surface-2:oklch(0.26 0.014 220);--line:oklch(0.32 0.014 220);--line-soft:oklch(0.26 0.012 220);--fg:oklch(0.96 0.006 80);--fg-dim:oklch(0.78 0.01 220);--muted:oklch(0.55 0.012 220);--accent:oklch(0.78 0.12 195);--accent-2:oklch(0.74 0.15 60);--accent-soft:oklch(0.78 0.12 195/0.12);--danger:oklch(0.65 0.18 25);--serif:"Instrument Serif","Times New Roman",serif;--sans:"Geist",system-ui,-apple-system,sans-serif;--mono:"JetBrains Mono",ui-monospace,monospace;--maxw:1320px;--gutter:clamp(20px,4vw,64px);--radius:4px}[data-palette=amber]{--accent:oklch(0.74 0.15 60);--accent-2:oklch(0.78 0.12 195);--accent-soft:oklch(0.74 0.15 60/0.12)}[data-palette=mono]{--accent:oklch(0.96 0.006 80);--accent-2:oklch(0.78 0.01 220);--accent-soft:oklch(0.96 0.006 80/0.08)}[data-mode=light]{--bg:oklch(0.97 0.005 80);--bg-2:oklch(0.94 0.006 80);--surface:oklch(0.99 0.004 80);--surface-2:oklch(0.92 0.006 80);--line:oklch(0.84 0.006 220);--line-soft:oklch(0.90 0.005 220);--fg:oklch(0.18 0.012 220);--fg-dim:oklch(0.36 0.012 220);--muted:oklch(0.50 0.012 220);--accent:oklch(0.55 0.13 195);--accent-2:oklch(0.60 0.16 50);--accent-soft:oklch(0.55 0.13 195/0.10)}[data-mode=light][data-palette=amber]{--accent:oklch(0.60 0.16 50);--accent-2:oklch(0.55 0.13 195)}[data-mode=light][data-palette=mono]{--accent:oklch(0.20 0.012 220);--accent-2:oklch(0.50 0.012 220)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:16px;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.mono{font-family:var(--mono);font-feature-settings:none;font-variant-ligatures:none}.serif{font-family:var(--serif);font-style:italic}.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}.eyebrow:before{content:"";width:18px;height:1px;background:var(--accent)}.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:50;backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);background:color-mix(in oklab,var(--bg) 75%,transparent);border-bottom:1px solid var(--line-soft)}.nav-inner{justify-content:space-between;padding:16px var(--gutter);max-width:var(--maxw);margin:0 auto}.nav-inner,.nav-logo{display:flex;align-items:center}.nav-logo{gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.nav-logo img{height:36px;width:36px;object-fit:cover;border-radius:50%;border:1px solid var(--line);background:#000}.nav-logo .ltd{color:var(--muted)}.nav-links{display:flex;gap:28px;font-family:var(--mono);font-size:12px;letter-spacing:.04em}.nav-links a{color:var(--fg-dim);transition:color .2s;position:relative}.nav-links a:hover{color:var(--fg)}.nav-cta{font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:10px 18px;background:var(--fg);color:var(--bg);border:none;border-radius:var(--radius);text-transform:uppercase;transition:transform .2s,background .2s}.nav-cta:hover{transform:translateY(-1px)}.nav-burger{display:none;background:transparent;border:1px solid var(--line);border-radius:var(--radius);width:44px;height:44px;padding:0;cursor:pointer;align-items:center;justify-content:center;color:var(--fg)}.nav-burger-icon{position:relative;width:20px;height:14px;display:inline-block}.nav-burger-icon span{position:absolute;left:0;width:100%;height:2px;background:currentColor;border-radius:2px;transition:transform .25s ease,opacity .2s ease,top .25s ease}.nav-burger-icon span:first-child{top:0}.nav-burger-icon span:nth-child(2){top:6px}.nav-burger-icon span:nth-child(3){top:12px}.nav-burger-icon.open span:first-child{top:6px;transform:rotate(45deg)}.nav-burger-icon.open span:nth-child(2){opacity:0}.nav-burger-icon.open span:nth-child(3){top:6px;transform:rotate(-45deg)}.nav-mobile-overlay{display:none;position:fixed;inset:0;z-index:49;background:color-mix(in oklab,var(--bg) 96%,transparent);backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);padding:88px var(--gutter) 40px;flex-direction:column;gap:8px;overflow-y:auto;transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .2s ease}.nav-mobile-overlay.open{transform:translateY(0);opacity:1;pointer-events:auto}.nav-mobile-links{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:18px;letter-spacing:.04em}.nav-mobile-links a{display:block;padding:16px 4px;color:var(--fg);border-bottom:1px solid var(--line-soft);text-decoration:none;text-transform:uppercase}.nav-mobile-links a[aria-current=page]{color:var(--accent)}.nav-mobile-cta{display:inline-block;margin-top:28px;width:100%;text-align:center;padding:16px 18px;font-size:13px}@media (max-width:820px){.nav-links{display:none}.nav-burger{display:inline-flex}.nav-mobile-overlay{display:flex}.nav-inner>.nav-cta{display:none}.nav-logo{font-size:11px}.nav-logo img{height:32px;width:32px}.nav-inner{padding:12px var(--gutter)}}.hero{min-height:92vh;padding:80px 0 100px;overflow:hidden;border-bottom:1px solid var(--line-soft)}.hero,.hero-grid{position:relative}.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:56px;gap:56px;align-items:center;z-index:2}@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:40px}}.hero-eyebrow{margin-bottom:32px}.hero h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(44px,5.6vw,84px);line-height:1.06;letter-spacing:-.025em;margin:0 0 32px;text-wrap:balance}.hero h1 .accent{color:var(--accent)}.hero h1 .normal{font-style:normal;font-family:var(--sans);font-weight:300}.hero-sub{font-size:18px;line-height:1.55;color:var(--fg-dim);max-width:480px;margin:0 0 36px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.btn{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:14px 22px;border-radius:var(--radius);transition:all .2s;display:inline-flex;align-items:center;gap:10px;border:1px solid transparent}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-primary:hover{background:color-mix(in oklab,var(--accent) 88%,var(--fg));transform:translateY(-1px)}.btn-ghost{color:var(--fg);border-color:var(--line)}.btn-ghost:hover{border-color:var(--fg)}.sun-stage{position:relative;aspect-ratio:1;width:100%;max-width:580px;margin:0 auto}.sun-core{position:absolute;inset:22%;border-radius:50%;background:radial-gradient(circle at 35% 30%,oklch(.95 .13 80),oklch(.78 .18 55) 40%,oklch(.55 .18 30) 75%,oklch(.3 .12 25));box-shadow:0 0 80px 10px oklch(.78 .18 55/.45),0 0 200px 30px oklch(.74 .15 60/.25),inset -20px -20px 60px oklch(.3 .1 25/.6);animation:sun-pulse 6s ease-in-out infinite}@keyframes sun-pulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.025);filter:brightness(1.08)}}[data-palette=mono] .sun-core{background:radial-gradient(circle at 35% 30%,oklch(.98 .005 80),oklch(.85 .005 80) 40%,oklch(.5 .008 220) 75%,oklch(.3 .008 220));box-shadow:0 0 80px 10px oklch(.85 .005 80/.3),0 0 200px 30px oklch(.7 .008 220/.2),inset -20px -20px 60px oklch(.2 .008 220/.6)}.sun-corona{pointer-events:none;background:radial-gradient(circle,transparent 38%,oklch(.78 .18 55/.1) 45%,transparent 70%);animation:sun-pulse 6s ease-in-out infinite reverse}.sun-corona,.sun-ring{position:absolute;inset:0;border-radius:50%}.sun-ring{border:1px dashed var(--line);animation:rotate 60s linear infinite}.sun-ring.r2{inset:8%;border-style:solid;border-color:var(--line-soft);animation-duration:90s;animation-direction:reverse}.sun-ring.r3{inset:-8%;border-color:oklch(.32 .014 220/.6);animation-duration:120s}@keyframes rotate{to{transform:rotate(1turn)}}.sun-tick{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--accent);top:50%;left:50%;transform-origin:0 0;box-shadow:0 0 12px var(--accent)}.sun-spec{position:absolute;font-family:var(--mono);font-size:11px;color:var(--fg-dim);background:color-mix(in oklab,var(--bg) 80%,transparent);border:1px solid var(--line);padding:8px 10px;border-radius:var(--radius);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);white-space:nowrap;display:flex;flex-direction:column;gap:2px;animation:spec-fade .6s ease-out backwards}.sun-spec .label{color:var(--muted);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.sun-spec .value{color:var(--fg);font-size:13px;font-weight:500}.sun-spec .value .unit{color:var(--accent);margin-left:4px;font-size:11px}@keyframes spec-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:32px;gap:32px;margin-top:48px;padding-top:40px;border-top:1px solid var(--line-soft)}@media (max-width:700px){.hero-stats{grid-template-columns:1fr 1fr;gap:24px}}.hero-stat .num{font-family:var(--serif);font-style:italic;font-size:clamp(36px,4vw,56px);line-height:1;color:var(--fg)}.hero-stat .num .unit{font-family:var(--mono);font-style:normal;font-size:14px;color:var(--accent);margin-left:6px;vertical-align:super}.hero-stat .label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:8px}.dash-stage,.house-stage,.sun-eclipse-stage,.sun-pixel-stage,.sun-radiant-stage{display:none}.hero[data-variant=sun] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:block}.hero[data-variant=sun-eclipse] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:none}.hero[data-variant=sun-eclipse] .sun-eclipse-stage{display:block}.hero[data-variant=sun-radiant] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:none}.hero[data-variant=sun-radiant] .sun-radiant-stage{display:block}.hero[data-variant=sun-pixel] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:none}.hero[data-variant=sun-pixel] .sun-pixel-stage{display:block}.hero[data-variant=house] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:none}.hero[data-variant=house] .house-stage{display:block}.hero[data-variant=dashboard] .sun-stage:not(.sun-eclipse-stage):not(.sun-radiant-stage):not(.sun-pixel-stage){display:none}.hero[data-variant=dashboard] .dash-stage{display:block}.house-stage{aspect-ratio:1}.dash-stage,.house-stage{position:relative;width:100%;max-width:580px;margin:0 auto}.dash-stage{border:1px solid var(--line);border-radius:6px;padding:20px;background:var(--surface);font-family:var(--mono);font-size:11px}.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(circle at 50% 30%,black 10%,transparent 70%);-webkit-mask-image:radial-gradient(circle at 50% 30%,black 10%,transparent 70%);opacity:.4;z-index:1;pointer-events:none}section[data-section]{padding:clamp(80px,10vw,140px) 0;border-bottom:1px solid var(--line-soft);position:relative}.section-head{display:grid;grid-template-columns:200px 1fr;grid-gap:40px;gap:40px;margin-bottom:60px;align-items:start}@media (max-width:820px){.section-head{grid-template-columns:1fr;gap:16px}}.section-num{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;padding-top:16px;border-top:1px solid var(--line)}.section-title{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-.02em;margin:0 0 16px;text-wrap:pretty}.section-title .normal{font-style:normal;font-family:var(--sans);font-weight:300}.section-desc{font-size:17px;line-height:1.55;color:var(--fg-dim);max-width:60ch}.services-list{display:grid;grid-template-columns:1fr}.service-row{display:grid;grid-template-columns:80px 1fr 2fr 200px;grid-gap:32px;gap:32px;padding:32px 0;border-top:1px solid var(--line);align-items:start;transition:padding .3s ease;cursor:default}.service-row:hover{padding-left:16px}.service-row:last-child{border-bottom:1px solid var(--line)}.service-num{font-family:var(--mono);font-size:12px;color:var(--muted);padding-top:4px}.service-name{font-family:var(--serif);font-style:italic;font-size:clamp(24px,2.4vw,32px);line-height:1.05;letter-spacing:-.01em}.service-desc{color:var(--fg-dim);font-size:15px;line-height:1.55}.service-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.service-tag{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border:1px solid var(--line);border-radius:2px;color:var(--fg-dim)}@media (max-width:820px){.service-row{grid-template-columns:40px 1fr;gap:16px}.service-desc,.service-tags{grid-column:1/-1}.service-tags{justify-content:flex-start}}.bio-card{margin-top:40px;padding:32px;border:1px solid var(--line);border-radius:6px;background:var(--surface)}.bio-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}.bio-grid{display:grid;grid-template-columns:1fr 1.4fr;grid-gap:32px;gap:32px;align-items:start}@media (max-width:820px){.bio-grid{grid-template-columns:1fr;gap:20px}.bio-card{padding:24px}}.bio-name{display:flex;flex-direction:column;gap:8px}.bio-name>span:first-child{font-family:var(--serif);font-style:italic;font-size:clamp(28px,3vw,38px);line-height:1;letter-spacing:-.01em;color:var(--fg)}.bio-role{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--accent)}.bio-creds{list-style:none;padding:0;margin:0;display:grid;grid-gap:12px;gap:12px;font-size:14px;line-height:1.5;color:var(--fg-dim)}.bio-creds li{display:flex;gap:12px;align-items:baseline}.bio-cred-num{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--accent);min-width:64px;padding:2px 8px;border:1px solid var(--line);border-radius:2px;text-align:center;flex-shrink:0}.bio-quote{grid-column:1/-1;font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.4vw,18px);line-height:1.55;color:var(--fg-dim);padding-top:24px;margin-top:8px;border-top:1px solid var(--line);max-width:720px}.bullet-list{list-style:none;padding:0;margin:0 0 8px;display:grid;grid-gap:12px;gap:12px}.bullet-list li{position:relative;padding:12px 0 12px 28px;font-size:15px;line-height:1.6;color:var(--fg-dim);border-bottom:1px solid var(--line-soft)}.bullet-list li:last-child{border-bottom:none}.bullet-list li:before{content:"/";position:absolute;left:0;top:12px;font-family:var(--mono);font-size:14px;color:var(--accent)}.bullet-list strong{color:var(--fg);font-weight:500}.bullet-list a{color:var(--accent);text-decoration:none}.bullet-list a:hover{text-decoration:underline}.article-byline{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:8px 0 24px;display:flex;gap:16px;flex-wrap:wrap}.article-byline a{color:var(--accent);text-decoration:none}.article-byline a:hover{text-decoration:underline}@media (max-width:640px){.article-byline{font-size:12px;gap:10px;letter-spacing:.08em}}.faq-list{display:grid;grid-template-columns:1fr}.faq-row{border-top:1px solid var(--line);padding:24px 0;transition:padding .3s ease}.faq-row:last-child{border-bottom:1px solid var(--line)}.faq-row[open]{padding-bottom:28px}.faq-q{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2vw,26px);line-height:1.2;letter-spacing:-.01em;color:var(--fg);cursor:pointer;list-style:none;position:relative;padding-right:40px}.faq-q::-webkit-details-marker{display:none}.faq-q:after{content:"+";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-style:normal;font-size:24px;color:var(--muted);transition:transform .2s ease,color .2s ease}.faq-row[open] .faq-q:after{content:"−";color:var(--accent)}.faq-q:hover{color:var(--accent)}.faq-a{font-size:15px;line-height:1.7;color:var(--fg-dim);margin-top:16px;max-width:760px}.tool-shell{background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden}.tool-titlebar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line);background:var(--bg-2);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim)}.tool-titlebar .lights{display:flex;gap:6px}.tool-titlebar .light{width:9px;height:9px;border-radius:50%;background:var(--line)}.tool-titlebar .light.on{background:var(--accent);box-shadow:0 0 8px var(--accent)}.tool-body{padding:24px}.roof-tool{display:grid;grid-template-columns:1fr 360px;min-height:560px}@media (max-width:980px){.roof-tool{grid-template-columns:1fr}}.roof-canvas-wrap{position:relative;background:var(--bg-2);border-right:1px solid var(--line);overflow:hidden;min-height:560px;height:560px}@media (max-width:980px){.roof-canvas-wrap{border-right:none;border-bottom:1px solid var(--line);min-height:420px;height:420px}}.roof-canvas{position:relative;cursor:crosshair}.roof-aerial-img,.roof-canvas{width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none}.roof-aerial-img{position:absolute;inset:0;object-fit:fill;-webkit-user-drag:none;pointer-events:none}.roof-canvas-hint-top{top:16px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;z-index:4;text-align:center;background:color-mix(in oklab,var(--bg) 60%,transparent);padding:10px 16px;border:1px solid var(--line);border-radius:100px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.roof-canvas-hint-top,.roof-svg{position:absolute;pointer-events:none}.roof-svg{inset:0;width:100%;height:100%}.roof-handle{position:absolute;width:16px;height:16px;border:2px solid var(--accent);background:var(--bg);border-radius:50%;transform:translate(-50%,-50%);cursor:-webkit-grab;cursor:grab;box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 20%,transparent);pointer-events:auto;z-index:3}.roof-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.roof-panel-grid{position:absolute;pointer-events:none;z-index:2}.pv-panel{background:linear-gradient(135deg,oklch(.4 .08 245),oklch(.28 .1 250));border:1px solid oklch(.18 .05 240);position:relative;overflow:hidden;transform-origin:top left;animation:panel-in .5s cubic-bezier(.2,.7,.3,1) backwards}.pv-panel:before{content:"";position:absolute;inset:2px;background-image:linear-gradient(oklch(.18 .05 240) 1px,transparent 0),linear-gradient(90deg,oklch(.18 .05 240) 1px,transparent 0);background-size:calc(100% / 3) calc(100% / 6);opacity:.7}.pv-panel:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 30%,oklch(.7 .1 240/.3) 50%,transparent 70%);mix-blend-mode:screen}@keyframes panel-in{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.roof-sidebar{display:flex;flex-direction:column}.roof-step-list{padding:24px;border-bottom:1px solid var(--line);flex:1 1}.roof-step{display:grid;grid-template-columns:28px 1fr;grid-gap:12px;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-soft);align-items:start}.roof-step:last-child{border-bottom:none}.roof-step-num{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--muted)}.roof-step.active .roof-step-num{background:var(--accent);border-color:var(--accent);color:var(--bg)}.roof-step.done .roof-step-num{background:transparent;border-color:var(--accent);color:var(--accent)}.roof-step-title{font-size:14px;font-weight:500;margin-bottom:4px}.roof-step-hint{font-family:var(--mono);font-size:11px;color:var(--muted)}.roof-step-input{display:flex;gap:8px;margin-top:10px;align-items:center}.roof-input{background:var(--bg-2);border:1px solid var(--line);color:var(--fg);padding:8px 10px;border-radius:var(--radius);font-family:var(--mono);font-size:13px;width:80px}.roof-input:focus{outline:none;border-color:var(--accent)}.roof-input-label{font-family:var(--mono);font-size:11px;color:var(--muted)}.roof-results{padding:20px 24px;background:var(--bg-2);display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.roof-result{border-left:2px solid var(--accent);padding-left:12px}.roof-result .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.roof-result .value{font-family:var(--serif);font-style:italic;font-size:26px;line-height:1.1}.roof-result .value .unit{font-family:var(--mono);font-style:normal;font-size:11px;color:var(--accent);margin-left:4px}.roof-actions{padding:16px 24px;border-top:1px solid var(--line);display:flex;gap:8px}.scaffold-tool{display:grid;grid-template-columns:360px 1fr}@media (max-width:980px){.scaffold-tool{grid-template-columns:1fr}}.scaffold-form{padding:28px;border-right:1px solid var(--line);background:var(--bg-2)}@media (max-width:980px){.scaffold-form{border-right:none;border-bottom:1px solid var(--line)}}.scaffold-stage{min-height:480px;grid-template-rows:1fr auto}.scaffold-stage,.scaffold-viz{position:relative;display:grid}.scaffold-viz{overflow:hidden;place-items:center;padding:32px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.field-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.field-row{display:flex;align-items:center;gap:10px}.range{flex:1 1;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--line);height:2px;border-radius:2px;outline:none}.range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg)}.range-val{font-family:var(--mono);font-size:13px;color:var(--fg);min-width:60px;text-align:right}.range-val .unit{color:var(--accent);margin-left:2px;font-size:11px}.radio-group{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px;gap:6px}.radio-opt{font-family:var(--mono);font-size:11px;letter-spacing:.05em;padding:10px 8px;border:1px solid var(--line);border-radius:var(--radius);text-align:center;cursor:pointer;background:transparent;color:var(--fg-dim);transition:all .15s}.radio-opt.on{background:var(--accent-soft);border-color:var(--accent);color:var(--fg)}.scaffold-svg{width:100%;max-width:460px;height:auto}.scaffold-quote{border-top:1px solid var(--line);background:var(--bg-2);padding:20px 28px;display:grid;grid-template-columns:1fr 1fr 1fr 1fr;grid-gap:18px;gap:18px}@media (max-width:700px){.scaffold-quote{grid-template-columns:1fr 1fr}}.scaffold-quote .roof-result{border-color:var(--accent-2)}[data-palette=amber] .scaffold-quote .roof-result{border-color:var(--accent)}.calc-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px}@media (max-width:980px){.calc-grid{grid-template-columns:1fr}}.calc-card{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:28px;display:flex;flex-direction:column}.calc-card h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:28px;margin:0 0 8px}.calc-card .calc-sub{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:24px}.calc-output{margin-top:auto;padding-top:24px;border-top:1px dashed var(--line);display:grid;grid-template-columns:1fr 1fr;grid-gap:18px;gap:18px}.calc-output .roof-result{border-color:var(--accent)}.grid-feed{background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden;font-feature-settings:"tnum" 1}.grid-feed-strip{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--bg-2);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.grid-feed-strip-left,.grid-feed-strip-right{display:flex;align-items:center;gap:12px}.grid-feed-label{color:var(--fg-dim)}.grid-feed-window{color:var(--muted)}.grid-live-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);position:relative}.grid-live-dot.live{background:var(--accent);box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 60%,transparent);animation:gridPulse 1.6s ease-out infinite}.grid-live-dot.loading{background:var(--accent-2);animation:gridFlicker .9s ease-in-out infinite}.grid-live-dot.error{background:var(--danger)}@keyframes gridPulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 60%,transparent)}to{box-shadow:0 0 0 8px color-mix(in oklab,var(--accent) 0%,transparent)}}@keyframes gridFlicker{0%,to{opacity:1}50%{opacity:.3}}.grid-refresh-btn{background:transparent;border:1px solid var(--line);color:var(--fg-dim);font-family:var(--mono);font-size:13px;width:24px;height:24px;border-radius:4px;cursor:pointer;display:grid;place-items:center;transition:all .15s ease}.grid-refresh-btn:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.grid-refresh-btn:disabled{opacity:.4;cursor:wait}.grid-error{padding:18px 24px;background:color-mix(in oklab,var(--danger) 8%,transparent);border-bottom:1px solid var(--line-soft)}.grid-error-msg{font-size:13px;color:var(--fg-dim);line-height:1.5}.grid-link{background:none;border:none;color:var(--accent);font-family:var(--mono);font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:0}.grid-headline{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;grid-gap:0;gap:0;border-bottom:1px solid var(--line-soft)}@media (max-width:880px){.grid-headline{grid-template-columns:1fr 1fr}}.grid-headline-stat{padding:24px;border-right:1px solid var(--line-soft)}.grid-headline-stat:last-child{border-right:none}@media (max-width:880px){.grid-headline-stat{border-bottom:1px solid var(--line-soft)}.grid-headline-stat:nth-child(2n){border-right:none}.grid-headline-stat:nth-last-child(-n+2){border-bottom:none}}.grid-headline-stat .label{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.grid-headline-stat .value{font-family:var(--serif);font-style:italic;font-size:38px;line-height:1;color:var(--fg);letter-spacing:-.02em}.grid-headline-stat .value .unit{font-family:var(--mono);font-style:normal;font-size:11px;color:var(--accent);margin-left:6px;letter-spacing:.04em;vertical-align:6px}.grid-headline-stat.is-primary .value{color:var(--accent)}.grid-headline-stat .sub{letter-spacing:.08em;color:var(--muted)}.grid-band,.grid-headline-stat .sub{font-size:10px;margin-top:10px;text-transform:uppercase}.grid-band{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 8px;border-radius:999px;font-family:var(--mono);letter-spacing:.1em;border:1px solid var(--line);background:var(--bg-2)}.grid-band-dot{width:6px;height:6px;border-radius:50%;background:var(--muted)}.grid-band.tone-good{color:var(--accent);border-color:color-mix(in oklab,var(--accent) 40%,var(--line))}.grid-band.tone-good .grid-band-dot{background:var(--accent)}.grid-band.tone-ok{color:var(--fg-dim)}.grid-band.tone-ok .grid-band-dot{background:var(--fg-dim)}.grid-band.tone-warn{color:var(--accent-2);border-color:color-mix(in oklab,var(--accent-2) 40%,var(--line))}.grid-band.tone-warn .grid-band-dot{background:var(--accent-2)}.grid-band.tone-alert{color:var(--danger);border-color:color-mix(in oklab,var(--danger) 50%,var(--line))}.grid-band.tone-alert .grid-band-dot{background:var(--danger)}.grid-section{padding:24px;border-bottom:1px solid var(--line-soft)}.grid-section:last-of-type{border-bottom:none}.grid-section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}.grid-section-title{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-dim)}.grid-section-sub{font-size:10px;color:var(--muted);letter-spacing:.06em}.grid-mixbar{display:flex;width:100%;height:14px;border-radius:3px;overflow:hidden;background:var(--bg-2);border:1px solid var(--line-soft);margin-bottom:18px}.grid-mixbar-seg{height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.grid-fuel-list{display:flex;flex-direction:column;gap:0}.grid-fuel-row{display:grid;grid-template-columns:14px 1fr 220px;align-items:center;grid-gap:14px;gap:14px;padding:10px 0;border-bottom:1px dashed var(--line-soft);font-size:13px}.grid-fuel-row:last-child{border-bottom:none}@media (max-width:700px){.grid-fuel-row{grid-template-columns:14px 1fr 130px;gap:10px}}.grid-fuel-swatch{width:12px;height:12px;border-radius:2px;border:1px solid color-mix(in oklab,var(--bg) 30%,transparent)}.grid-fuel-name{display:flex;align-items:center;gap:8px;color:var(--fg)}.grid-fuel-tag{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:3px;background:var(--accent-soft);color:var(--accent)}.grid-fuel-tag.muted{background:var(--bg-2);color:var(--muted)}.grid-fuel-tag.warn{background:color-mix(in oklab,var(--danger) 12%,transparent);color:var(--danger)}.grid-fuel-pct{display:grid;grid-template-columns:1fr 70px;align-items:center;grid-gap:12px;gap:12px}@media (max-width:700px){.grid-fuel-pct{grid-template-columns:1fr 56px}}.grid-fuel-pct-track{height:4px;background:var(--bg-2);border-radius:2px;overflow:hidden}.grid-fuel-pct-fill{height:100%;border-radius:2px;transition:width .5s cubic-bezier(.4,0,.2,1)}.grid-fuel-pct-num{font-family:var(--mono);font-size:13px;color:var(--fg);text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.grid-fuel-pct-num .unit{color:var(--muted);font-size:10px;margin-left:2px}.grid-skeleton{display:flex;flex-direction:column;gap:8px;padding:8px 0}.grid-skeleton-row{height:24px;background:linear-gradient(90deg,var(--bg-2),var(--surface-2),var(--bg-2));background-size:200% 100%;animation:gridShimmer 1.6s ease-in-out infinite;border-radius:3px}@keyframes gridShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.grid-spark-wrap{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;padding:14px}.grid-spark{width:100%;height:130px;display:block}.grid-spark-axis{font-family:var(--mono);margin-top:8px}.grid-feed-foot,.grid-spark-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--muted)}.grid-feed-foot{align-items:center;padding:12px 20px;background:var(--bg-2);border-top:1px solid var(--line);letter-spacing:.06em;text-transform:uppercase}.grid-feed-foot a{color:var(--fg-dim);text-decoration:none;border-bottom:1px dotted var(--muted)}.grid-feed-foot a:hover{color:var(--accent);border-color:var(--accent)}.grid-pulse{display:inline-block;width:6px;height:6px;margin-left:8px;background:var(--accent);border-radius:50%;vertical-align:middle;opacity:.4;transition:opacity .6s ease}.grid-pulse[data-tick="1"]{opacity:1}.cta-section{padding:clamp(80px,10vw,140px) 0;position:relative;overflow:hidden}.cta-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:60px;gap:60px;align-items:start}@media (max-width:900px){.cta-grid{grid-template-columns:1fr;gap:40px}}.cta-grid--solo{grid-template-columns:1fr;max-width:760px}.testimonial-track--solo{min-height:0}.testimonial-track--solo .testimonial-slide{position:relative}.cta-headline{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(40px,6vw,84px);line-height:.96;letter-spacing:-.025em;margin:0;text-wrap:pretty}.cta-headline .accent{color:var(--accent)}.cta-card{border:1px solid var(--line);padding:24px;border-radius:6px;background:var(--surface)}.cta-card .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.cta-card .value{font-family:var(--mono);font-size:18px;margin:4px 0 16px}.cta-sub{font-size:16px;color:var(--fg-dim);max-width:460px;line-height:1.55;margin:16px 0 28px}.cta-direct{display:grid;grid-gap:14px;gap:14px}.cta-direct-row{display:grid;grid-gap:4px;gap:4px}.cta-direct-row .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.email-cta,.email-mask,.phone-cta{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:18px;color:var(--fg);text-decoration:none;padding:8px 0;min-height:44px}.phone-cta{color:var(--accent)}.email-cta:hover,.phone-cta:hover{text-decoration:underline}.phone-cta-icon{font-size:20px;opacity:.8}.contact-form-wrap,.cta-form-wrap{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:24px}.contact-form{display:grid;grid-gap:14px;gap:14px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}@media (max-width:480px){.contact-form-row{grid-template-columns:1fr}}.contact-field{display:grid;grid-gap:6px;gap:6px}.contact-field>span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.contact-field input,.contact-field textarea{background:var(--bg);border:1px solid var(--line);border-radius:4px;color:var(--fg);padding:10px 12px;font:400 14px/1.4 var(--sans);min-height:44px;width:100%}.contact-field textarea{resize:vertical;min-height:120px;font-family:var(--sans)}.contact-field input:focus,.contact-field textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.contact-field-error{color:#ff7a7a;font:400 12px var(--mono)}.contact-honeypot{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.contact-turnstile{margin-top:6px;min-height:65px}.contact-form-error{background:rgba(255,122,122,.08);border:1px solid rgba(255,122,122,.4);color:#ffb4b4;padding:10px 12px;border-radius:4px;font-size:13px}.contact-form-submit{margin-top:4px;min-height:48px}.contact-form-success{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:28px}.contact-form-success h3{font-family:var(--serif);font-style:italic;font-size:26px;margin:0 0 8px}.contact-form-success p{color:var(--fg-dim);margin:0;line-height:1.5}.cta-intro{display:grid;grid-gap:0;gap:0;align-content:start}.footer{border-top:1px solid var(--line-soft);padding:40px 0;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}.footer-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.tag-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-dim);padding:6px 10px;border:1px solid var(--line);border-radius:100px;background:color-mix(in oklab,var(--surface) 50%,transparent)}.tag-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:blink 2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.under-accent{background-image:linear-gradient(var(--accent),var(--accent));background-size:100% 2px;background-repeat:no-repeat;background-position:0 100%;padding-bottom:2px}.tp-content{font-family:var(--sans)!important}.carbon-stat-row{display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;align-items:stretch;background:var(--surface);border:1px solid var(--line);border-radius:6px;margin-bottom:28px;overflow:hidden}@media (max-width:880px){.carbon-stat-row{grid-template-columns:1fr}.carbon-stat-divider{display:none}.carbon-stat{border-bottom:1px solid var(--line-soft)}.carbon-stat:last-child{border-bottom:none}}.carbon-stat-divider{background:var(--line-soft)}.carbon-stat{padding:36px 32px}.carbon-stat-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}.carbon-stat-value{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.carbon-stat-num{font-family:var(--serif);font-style:italic;font-size:clamp(56px,7vw,88px);line-height:.92;color:var(--accent);letter-spacing:-.03em;font-feature-settings:"tnum" 1}.carbon-stat-unit{font-family:var(--mono);font-size:13px;letter-spacing:.06em;color:var(--fg-dim);text-transform:uppercase}.carbon-stat-foot{font-size:11px;color:var(--muted);letter-spacing:.04em}.carbon-grid-intensity{color:var(--accent);border-bottom:1px dotted var(--accent);padding-bottom:1px}.carbon-grid-intensity.loading{color:var(--muted);border-color:var(--muted)}.carbon-row-aside{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:20px;gap:20px;margin-bottom:24px}@media (max-width:880px){.carbon-row-aside{grid-template-columns:1fr}}.carbon-pledge{display:grid;grid-template-columns:56px 1fr;grid-gap:20px;gap:20px;align-items:center;padding:24px 28px;background:var(--accent-soft);border:1px solid color-mix(in oklab,var(--accent) 30%,var(--line));border-radius:6px}.carbon-pledge-glyph{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--surface);color:var(--accent);border:1px solid color-mix(in oklab,var(--accent) 40%,var(--line))}.carbon-pledge-glyph svg{width:28px;height:28px}.carbon-pledge-title{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--fg);margin-bottom:4px}.carbon-pledge-sub{font-size:13px;color:var(--fg-dim);line-height:1.5}.carbon-cta{padding:24px 28px;background:var(--surface);border:1px solid var(--line);border-radius:6px;display:flex;flex-direction:column;justify-content:center}.carbon-cta-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.carbon-cta-link{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--fg);text-decoration:none;display:inline-flex;align-items:center;gap:12px;margin-bottom:8px;transition:color .2s ease}.carbon-cta-link:hover{color:var(--accent)}.carbon-cta-link:hover .carbon-cta-arrow{transform:translateX(4px);color:var(--accent)}.carbon-cta-arrow{color:var(--accent);transition:transform .2s ease}.carbon-cta-sub{font-size:11px;letter-spacing:.04em;color:var(--muted)}.carbon-foot{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line-soft);font-size:10px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}.carbon-foot strong{color:var(--fg-dim);font-weight:500}@media (max-width:700px){.carbon-foot{flex-direction:column;gap:8px;align-items:flex-start}}.testimonial-stage{position:relative;padding:60px clamp(20px,5vw,80px) 40px;background:var(--surface);border:1px solid var(--line);border-radius:6px;min-height:360px;overflow:hidden}.testimonial-quote-mark{position:absolute;top:-20px;left:30px;font-family:var(--serif);font-size:200px;line-height:1;color:var(--accent);opacity:.18;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.testimonial-track{position:relative;min-height:200px}.testimonial-slide{margin:0;position:absolute;inset:0;opacity:0;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease;pointer-events:none}.testimonial-slide.is-active{opacity:1;transform:translateY(0);pointer-events:auto;position:relative}.testimonial-quote{font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.4vw,30px);line-height:1.4;color:var(--fg);margin:0 0 28px;text-wrap:pretty}.testimonial-foot{display:flex;flex-direction:column;gap:4px;border-left:2px solid var(--accent);padding-left:14px}.testimonial-name{font-size:14px;font-weight:500;color:var(--fg)}.testimonial-meta{font-size:11px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}.testimonial-controls{display:flex;align-items:center;gap:20px;margin-top:28px;padding-top:24px;border-top:1px solid var(--line-soft)}.testimonial-arrow{background:transparent;border:1px solid var(--line);color:var(--fg-dim);width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:14px;display:grid;place-items:center;transition:all .2s ease}.testimonial-arrow:hover{border-color:var(--accent);color:var(--accent)}.testimonial-dots{display:flex;gap:8px;flex:1 1;justify-content:center}.testimonial-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--line);background:transparent;padding:0;cursor:pointer;transition:all .2s ease}.testimonial-dot:hover{border-color:var(--accent)}.testimonial-dot.is-active{background:var(--accent);border-color:var(--accent);width:24px;border-radius:4px}.testimonial-counter{position:absolute;top:20px;right:24px;font-size:11px;letter-spacing:.1em;color:var(--muted)}.case-featured{display:grid;grid-template-columns:1.3fr 1fr;grid-gap:0;gap:0;background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-bottom:24px}@media (max-width:880px){.case-featured{grid-template-columns:1fr}}.case-featured-image{position:relative;background:var(--bg-2);min-height:380px;border-right:1px solid var(--line)}@media (max-width:880px){.case-featured-image{border-right:none;border-bottom:1px solid var(--line);min-height:280px}}.case-featured-tag{position:absolute;top:16px;left:16px;z-index:2;padding:6px 10px;background:color-mix(in oklab,var(--bg) 80%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:3px;font-size:10px;letter-spacing:.14em;color:var(--accent)}.case-featured-body{padding:36px;display:flex;flex-direction:column;justify-content:center}.case-num{font-size:11px;letter-spacing:.14em;color:var(--muted);margin-bottom:8px}.case-title{font-family:var(--serif);font-size:30px;font-weight:400;line-height:1.15;margin:0 0 8px;color:var(--fg);letter-spacing:-.01em}.case-meta{font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-bottom:18px}.case-detail{font-size:14px;line-height:1.6;color:var(--fg-dim);margin:0 0 22px;text-wrap:pretty}.case-outcome{display:flex;align-items:baseline;gap:12px;padding-top:18px;border-top:1px solid var(--line-soft)}.case-outcome-label{font-size:10px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}.case-outcome-value{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent)}.case-grid{display:grid;grid-template-columns:1.4fr 1fr;grid-gap:24px;gap:24px}@media (max-width:980px){.case-grid{grid-template-columns:1fr}}.case-thumbs{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}@media (max-width:600px){.case-thumbs{grid-template-columns:1fr}}.case-thumb{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;cursor:pointer;text-align:left;padding:0;transition:border-color .2s ease,transform .2s ease}.case-thumb:hover{border-color:color-mix(in oklab,var(--accent) 50%,var(--line));transform:translateY(-2px)}.case-thumb.is-active{border-color:var(--accent)}.case-thumb-image{background:var(--bg-2);aspect-ratio:4/3;position:relative}.case-thumb-meta{padding:14px 16px}.case-thumb-num{font-size:10px;color:var(--muted);letter-spacing:.14em;margin-bottom:4px}.case-thumb-title{font-size:14px;color:var(--fg);margin-bottom:6px;font-weight:500}.case-thumb-tag{font-size:10px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}.case-detail-card{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:28px;position:-webkit-sticky;position:sticky;top:90px;align-self:start}.case-cta{display:inline-block;margin-top:18px;padding-top:18px;border-top:1px solid var(--line-soft);font-size:11px;letter-spacing:.1em;color:var(--accent);text-transform:uppercase;text-decoration:none;border-bottom:none;width:100%}.case-cta:hover{color:var(--fg)}image-slot{--is-bg:var(--bg-2);--is-fg:var(--muted);--is-border:var(--line)}.twk-fab{position:fixed;right:16px;bottom:16px;z-index:2147483646;padding:10px 16px;border-radius:999px;background:rgba(20,22,26,.86);color:#fff;border:.5px solid rgba(255,255,255,.2);box-shadow:0 8px 24px rgba(0,0,0,.3);font:500 12px/1 ui-sans-serif,system-ui,sans-serif;letter-spacing:.04em;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}@media (max-width:640px){.twk-fab{padding:8px 12px;font-size:11px;right:10px;bottom:10px;opacity:.85}}.twk-panel{position:fixed;right:16px;bottom:16px;z-index:2147483646;width:280px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;background:rgba(250,249,247,.78);color:#29261b;-webkit-backdrop-filter:blur(24px) saturate(160%);backdrop-filter:blur(24px) saturate(160%);border:.5px solid rgba(255,255,255,.6);border-radius:14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 12px 40px rgba(0,0,0,.18);font:11.5px/1.4 ui-sans-serif,system-ui,-apple-system,sans-serif;overflow:hidden}.twk-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 8px 10px 14px;cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none}.twk-hd b{font-size:12px;font-weight:600;letter-spacing:.01em}.twk-x{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:rgba(41,38,27,.55);width:22px;height:22px;border-radius:6px;cursor:default;font-size:13px;line-height:1}.twk-x:hover{background:rgba(0,0,0,.06);color:#29261b}.twk-body{padding:2px 14px 14px;gap:10px;overflow-y:auto;overflow-x:hidden;min-height:0}.twk-body,.twk-row{display:flex;flex-direction:column}.twk-row{gap:5px}.twk-lbl{display:flex;justify-content:space-between;align-items:baseline;color:rgba(41,38,27,.72)}.twk-lbl>span:first-child{font-weight:500}.twk-sect{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(41,38,27,.45);padding:10px 0 0}.twk-sect:first-child{padding-top:0}.twk-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:26px;padding:0 8px;border:.5px solid rgba(0,0,0,.1);border-radius:7px;background:rgba(255,255,255,.6);color:inherit;font:inherit;outline:none}select.twk-field{padding-right:22px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='rgba(0,0,0,.5)' d='M0 0h10L5 6z'/></svg>");background-repeat:no-repeat;background-position:right 8px center}.twk-seg{position:relative;display:flex;padding:2px;border-radius:8px;background:rgba(0,0,0,.06);-webkit-user-select:none;-moz-user-select:none;user-select:none}.twk-seg button{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1 1;border:0;background:transparent;color:inherit;font:inherit;font-weight:500;min-height:22px;border-radius:6px;cursor:default;padding:4px 6px;line-height:1.2;transition:background .15s}.twk-seg button[data-on="1"]{background:rgba(255,255,255,.9);box-shadow:0 1px 2px rgba(0,0,0,.12)}.articles-page{padding:80px 0 100px}.articles-head h1{font-family:var(--serif);font-style:italic;font-size:clamp(48px,6vw,80px);line-height:1;margin:0 0 16px;letter-spacing:-.03em}.articles-head h1 .normal{font-style:normal;font-family:var(--sans);font-weight:300}.articles-head .lede{font-size:18px;line-height:1.55;color:var(--fg-dim);max-width:720px;margin:0 0 64px}.articles-breadcrumb{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:28px}.articles-breadcrumb a{color:var(--muted);text-decoration:none}.articles-breadcrumb a:hover{color:var(--accent)}.articles-list{display:grid;grid-gap:0;gap:0;border-top:1px solid var(--line)}.article-row{display:grid;grid-template-columns:100px 1fr 220px;grid-gap:36px;gap:36px;padding:36px 0;border-bottom:1px solid var(--line-soft);align-items:start;transition:background .2s ease;text-decoration:none;color:inherit}@media (max-width:880px){.article-row{grid-template-columns:1fr;gap:12px}}.article-row:hover{background:color-mix(in oklab,var(--accent) 4%,transparent)}.article-row:hover .article-title{color:var(--accent)}.article-meta{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.article-meta .num{font-size:12px;color:var(--fg-dim);display:block;margin-bottom:4px}.article-body{max-width:700px}.article-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.article-tag{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--line);border-radius:3px;color:var(--fg-dim)}.article-tag.featured{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in oklab,var(--accent) 40%,var(--line))}.article-title{font-family:var(--serif);font-size:clamp(24px,2.4vw,32px);line-height:1.2;margin:0 0 10px;color:var(--fg);letter-spacing:-.01em;font-weight:400;transition:color .2s ease;text-wrap:pretty}.article-excerpt{font-size:14px;line-height:1.6;color:var(--fg-dim);margin:0;text-wrap:pretty}.article-aside{text-align:right;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}@media (max-width:880px){.article-aside{text-align:left}}.article-readtime{color:var(--fg-dim);margin-bottom:4px}.article-arrow{display:inline-block;margin-top:12px;color:var(--accent);font-size:14px;letter-spacing:0}.articles-empty{padding:36px 0;font-style:italic;color:var(--muted);font-family:var(--serif);border-bottom:1px solid var(--line-soft)}.carbon-page{padding:80px 0 100px}.carbon-page .breadcrumb{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:28px}.carbon-page .breadcrumb a{color:var(--muted);text-decoration:none}.carbon-page .breadcrumb a:hover{color:var(--accent)}.carbon-page h1{font-family:var(--serif);font-style:italic;font-size:clamp(40px,5vw,64px);line-height:1.05;margin:0 0 16px;text-wrap:balance;letter-spacing:-.02em}.carbon-page h1 .normal{font-style:normal;font-family:var(--sans);font-weight:300}.carbon-page .lede{font-size:18px;line-height:1.55;color:var(--fg-dim);max-width:720px;margin:0 0 56px;text-wrap:pretty}.carbon-page h2{font-family:var(--serif);font-size:clamp(28px,3vw,38px);font-weight:400;margin:0 0 12px;letter-spacing:-.01em}.carbon-page h2 .normal{font-family:var(--sans);font-weight:300}.carbon-section{margin-bottom:80px}.carbon-section-num{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:12px}.postcode-tool{background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden}.postcode-input-row{display:grid;grid-template-columns:1fr auto auto;grid-gap:12px;gap:12px;padding:28px;background:var(--bg-2);border-bottom:1px solid var(--line);align-items:end}@media (max-width:700px){.postcode-input-row{grid-template-columns:1fr}}.postcode-input-row .field-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:block}.postcode-input{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--fg);font-family:var(--mono);font-size:16px;padding:12px 14px;border-radius:4px;letter-spacing:.06em;text-transform:uppercase}.postcode-input:focus{outline:none;border-color:var(--accent)}.system-select{background:var(--surface);border:1px solid var(--line);color:var(--fg);font-size:14px;padding:12px 14px;border-radius:4px}.postcode-go,.system-select{font-family:var(--mono);cursor:pointer}.postcode-go{background:var(--accent);color:var(--bg);border:none;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:14px 22px;border-radius:4px;transition:transform .15s ease}.postcode-go:hover{transform:translateY(-1px)}.postcode-go:disabled{opacity:.5;cursor:wait}.postcode-result{padding:36px 28px}.postcode-result.empty{padding:64px 28px;text-align:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}.result-headline-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:0;gap:0;margin-bottom:32px}@media (max-width:700px){.result-headline-grid{grid-template-columns:1fr}}.result-stat{padding:8px 24px;border-right:1px solid var(--line-soft)}.result-stat:first-child{padding-left:0}.result-stat:last-child{border-right:none}@media (max-width:700px){.result-stat{border-right:none;border-bottom:1px solid var(--line-soft);padding:16px 0}.result-stat:last-child{border-bottom:none}}.result-stat-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.result-stat-value{font-family:var(--serif);font-style:italic;font-size:56px;line-height:1;color:var(--accent);letter-spacing:-.02em;font-feature-settings:"tnum" 1}.result-stat-value .unit{font-family:var(--mono);font-style:normal;font-size:11px;color:var(--fg-dim);margin-left:8px;letter-spacing:.06em;text-transform:uppercase;vertical-align:12px}.result-stat-sub{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;margin-top:8px}.result-detail-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;padding-top:24px;border-top:1px solid var(--line-soft)}@media (max-width:700px){.result-detail-grid{grid-template-columns:1fr}}.result-detail h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 14px;font-weight:500}.result-detail .row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line-soft);font-size:14px}.result-detail .row:last-child{border-bottom:none}.result-detail .row .label{color:var(--fg-dim)}.result-detail .row .val{font-family:var(--mono);color:var(--fg)}.result-detail .row .val.accent{color:var(--accent)}.payback-bar{margin-top:24px;padding:20px 24px;background:var(--bg-2);border-radius:4px;border:1px solid var(--line-soft)}.payback-bar-title{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.payback-track{height:18px;background:var(--surface);border-radius:3px;overflow:hidden;position:relative;border:1px solid var(--line-soft)}.payback-fill{height:100%;background:linear-gradient(90deg,color-mix(in oklab,var(--accent-2) 70%,var(--accent)),var(--accent));transition:width .6s cubic-bezier(.4,0,.2,1)}.payback-marks{display:flex;justify-content:space-between;margin-top:8px;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.06em}.payback-summary{margin-top:14px;font-size:13px;color:var(--fg-dim);line-height:1.5}.payback-summary strong{color:var(--accent);font-weight:500}.table-card{background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;background:var(--bg-2);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line);font-weight:500}.data-table td,.data-table th{padding:14px 20px;color:var(--fg-dim)}.data-table td{border-bottom:1px solid var(--line-soft);font-size:14px}.data-table tr:last-child td{border-bottom:none}.data-table td.mono{font-family:var(--mono);color:var(--fg)}.data-table td.accent{color:var(--accent);font-family:var(--mono)}.data-table tr.total td{background:var(--bg-2);font-weight:500;color:var(--fg)}.method-list{list-style:none;padding:0;margin:0}.method-list li{padding:16px 0;border-bottom:1px solid var(--line-soft);display:grid;grid-template-columns:30px 1fr;grid-gap:16px;gap:16px;font-size:14px;color:var(--fg-dim);line-height:1.55}.method-list li:last-child{border-bottom:none}.method-list .step{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.1em;padding-top:2px}.method-list .formula{font-family:var(--mono);font-size:12px;color:var(--fg);background:var(--bg-2);padding:2px 6px;border-radius:3px;border:1px solid var(--line-soft)}.source-note{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;margin-top:16px;line-height:1.6}.source-note a{color:var(--fg-dim);text-decoration:none;border-bottom:1px dotted var(--muted)}.source-note a:hover{color:var(--accent);border-color:var(--accent)}.nav-links a[aria-current=page]{color:var(--accent)}.nav-links a[aria-current=page]:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle}.roof-mode-toggle{display:inline-flex;gap:4px;margin-top:24px;padding:4px;background:var(--surface);border:1px solid var(--line);border-radius:8px}.roof-mode-tab{padding:8px 14px;border:0;border-radius:5px;background:transparent;color:var(--fg-dim);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .15s,color .15s}.roof-mode-tab:hover{color:var(--fg)}.roof-mode-tab.on{background:var(--accent-soft);color:var(--accent)}.roof-mode-tab-pill{font-size:9px;padding:2px 6px;border-radius:999px;background:var(--line);color:var(--muted);letter-spacing:.08em}.roof-shape-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin:32px 0 24px}@media (max-width:880px){.roof-shape-grid{grid-template-columns:repeat(2,1fr)}}.roof-shape-card{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:18px 18px 16px;background:var(--surface);border:1px solid var(--line);border-radius:8px;color:var(--fg);cursor:pointer;text-align:left;transition:border-color .2s,background .2s,transform .15s}.roof-shape-card:hover{border-color:var(--accent);transform:translateY(-1px)}.roof-shape-card.on{border-color:var(--accent);background:color-mix(in oklab,var(--accent) 8%,var(--surface))}.roof-shape-icon{width:64px;height:40px;color:var(--accent)}.roof-shape-name{font-family:var(--serif);font-size:18px;font-style:italic}.roof-shape-sub{font-size:12px;color:var(--fg-dim);line-height:1.4}.roof-shape-tool{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:24px}@media (max-width:880px){.roof-shape-tool{grid-template-columns:1fr}}.roof-shape-panel{display:flex;flex-direction:column;gap:10px;min-width:0}.roof-shape-panel-head{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.roof-dim-row{display:grid;grid-template-columns:1fr 110px;grid-gap:12px;gap:12px;align-items:center}.roof-dim-row label{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-dim)}.roof-dim-input{display:inline-flex;align-items:center;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:0 10px}.roof-dim-input input{width:64px;border:0;background:transparent;color:var(--fg);font:14px/1 var(--mono);padding:6px 4px 6px 0;outline:none;-moz-appearance:textfield}.roof-dim-input input::-webkit-inner-spin-button,.roof-dim-input input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.roof-dim-input .unit{color:var(--muted);font:11px/1 var(--mono);padding-left:6px}.compass-picker-label{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:8px}.compass-picker-value{color:var(--accent);margin-left:6px}.compass-picker-hint{color:var(--muted);margin-left:6px;text-transform:none;letter-spacing:0;font-size:10px}.compass-dial-wrap{margin-top:6px;max-width:220px}.compass-dial{display:block;width:100%;max-width:200px;margin:0 auto;touch-action:none;cursor:-webkit-grab;cursor:grab;outline:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.compass-dial:focus-visible .compass-dial-rim{stroke:var(--accent)}.compass-dial.dragging{cursor:-webkit-grabbing;cursor:grabbing}.compass-dial-rim{fill:var(--bg-2);stroke:var(--line);stroke-width:1.5;transition:stroke .15s}.compass-dial-inner{fill:none;stroke:var(--line);stroke-width:.6;stroke-dasharray:2 3;opacity:.5}.compass-tick{stroke:var(--fg-dim);stroke-width:1;opacity:.4}.compass-tick.major{stroke:var(--fg);stroke-width:1.5;opacity:.85}.compass-cardinal{fill:var(--fg-dim);font:600 12px var(--mono);letter-spacing:.04em}.compass-needle{fill:var(--accent);stroke:var(--accent);stroke-width:.5;stroke-linejoin:round}.compass-needle-stem{stroke:var(--accent);stroke-width:1.5;opacity:.5}.compass-needle-pivot{fill:var(--bg);stroke:var(--accent);stroke-width:1.5}.compass-presets{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:4px;gap:4px;margin-top:10px;max-width:220px}.compass-preset{padding:6px 0;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;color:var(--fg-dim);font:600 10px/1 var(--mono);letter-spacing:.06em;cursor:pointer;transition:background .15s,color .15s,border-color .15s;min-height:28px}.compass-preset:hover{color:var(--fg);border-color:var(--accent)}.compass-preset.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}@media (max-width:480px){.compass-dial-wrap{max-width:100%}.compass-dial{max-width:220px}.compass-presets{max-width:100%}.compass-preset{min-height:36px;font-size:11px}}.postcode-row{display:grid;grid-template-columns:1fr auto;grid-gap:8px;gap:8px;align-items:center}.postcode-input.small{height:34px;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:0 10px;color:var(--fg);font:14px/1 var(--mono);outline:none;text-transform:uppercase}.postcode-input.small:focus{border-color:var(--accent)}.btn-ghost{height:34px;padding:0 14px;background:transparent;border:1px solid var(--line);border-radius:4px;color:var(--fg-dim);font:11px/1 var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.roof-shape-warn{font-family:var(--mono);font-size:11px;color:var(--danger);margin-top:6px}.roof-shape-region-summary{font-size:11px;color:var(--fg-dim);margin-top:8px}.roof-shape-region-summary.muted{color:var(--muted)}.roof-faces{display:flex;flex-direction:column;gap:6px}.roof-face-row{display:grid;grid-template-columns:22px 1fr auto;grid-gap:12px;gap:12px;align-items:center;padding:10px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;cursor:pointer;transition:border-color .15s,background .15s}.roof-face-row.on,.roof-face-row:hover{border-color:var(--accent)}.roof-face-row.on{background:color-mix(in oklab,var(--accent) 6%,var(--bg-2))}.roof-face-row input[type=checkbox]{accent-color:var(--accent);transform:scale(1.1)}.roof-face-name{font-size:13px}.roof-face-meta{font-size:11px;color:var(--muted);letter-spacing:.04em}.roof-out-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.roof-out-stat{padding:12px 14px;background:var(--bg-2);border:1px solid var(--line);border-radius:4px}.roof-out-stat .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.roof-out-stat .value{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent)}.roof-out-stat .value .unit{font-family:var(--mono);font-style:normal;font-size:10px;color:var(--muted);letter-spacing:.06em;margin-left:6px}.roof-shape-disclaimer{margin-top:14px;padding-top:14px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--muted);line-height:1.6}.roof-tool-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:18px;gap:18px;margin-top:20px;align-items:start}@media (max-width:1100px){.roof-tool-grid{grid-template-columns:1fr}}.roof-side-panel{gap:10px;padding:18px}.roof-canvas-column,.roof-side-panel{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:8px;min-width:0}.roof-canvas-column{overflow:hidden}.roof-canvas-titlebar{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-2);font-size:11px;letter-spacing:.06em}.roof-plan-wrap{position:relative;width:100%;aspect-ratio:5/3;background:oklch(.2 .02 220)}.roof-plan-svg{width:100%;height:100%;display:block}.roof-plan-face:hover{stroke:var(--accent)!important}.roof-face-row.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;text-align:left;background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:10px 12px;display:grid;grid-template-columns:14px 1fr auto;grid-gap:10px;gap:10px;align-items:center;cursor:pointer;color:var(--fg);transition:border-color .15s,background .15s}.roof-face-row.btn.on,.roof-face-row.btn:hover{border-color:var(--accent)}.roof-face-row.btn.on{background:color-mix(in oklab,var(--accent) 8%,var(--bg-2))}.roof-face-dot{width:10px;height:10px;border-radius:50%;background:var(--line);border:2px solid var(--line);transition:background .15s,border-color .15s}.roof-face-dot.on{background:var(--accent);border-color:var(--accent)}.roof-advanced-toggle{margin-top:14px;padding:8px 0 0;background:transparent;border:0;border-top:1px solid var(--line-soft);color:var(--fg-dim);font:11px/1.4 var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-align:left;transition:color .15s}.roof-advanced-toggle.on,.roof-advanced-toggle:hover{color:var(--accent)}.roof-advanced-panel{gap:10px;margin-top:10px;padding:12px;border:1px solid var(--line-soft);border-radius:6px}.roof-advanced-panel,.roof-face-stepper{display:flex;flex-direction:column;background:var(--bg-2)}.roof-face-stepper{border:1px solid var(--line);border-radius:6px;padding:10px 12px 12px;gap:8px;transition:border-color .15s,background .15s}.roof-face-stepper.on{border-color:var(--accent);background:color-mix(in oklab,var(--accent) 6%,var(--bg-2))}.roof-face-stepper-row{display:flex;align-items:center;gap:10px}.roof-face-stepper-row:first-child{display:grid;grid-template-columns:12px 1fr auto;grid-gap:10px;gap:10px}.roof-stepper-btn{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--line);border-radius:4px;color:var(--fg);font:600 14px/1 var(--mono);cursor:pointer;transition:border-color .15s,color .15s}.roof-stepper-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.roof-stepper-btn:disabled{opacity:.35;cursor:not-allowed}.roof-stepper-slider{flex:1 1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--line);border-radius:999px;outline:none}.roof-stepper-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.3)}.roof-stepper-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);cursor:pointer}.roof-stepper-readout{min-width:48px;text-align:right;font-size:12px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:0}.roof-orient-badge{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;padding:3px 7px;border-radius:999px;border:1px solid var(--line);white-space:nowrap;display:inline-flex;align-items:center;gap:4px}.roof-orient-badge.q-best{color:var(--accent);border-color:color-mix(in oklab,var(--accent) 50%,var(--line));background:var(--accent-soft)}.roof-orient-badge.q-ok{color:var(--fg-dim);border-color:var(--line);background:var(--bg-2)}.roof-orient-badge.q-poor{color:var(--muted);border-color:var(--line-soft);background:var(--bg-2);opacity:.85}.roof-sun-controls{display:grid;grid-template-columns:auto 1fr;grid-gap:18px;gap:18px;padding:16px 18px;border-top:1px solid var(--line);background:var(--bg-2);align-items:center}@media (max-width:600px){.roof-sun-controls{grid-template-columns:1fr}}.roof-sun-left{display:flex;align-items:center;justify-content:center}.roof-sun-right{display:flex;flex-direction:column;gap:10px}.roof-sun-row{display:grid;grid-template-columns:70px 1fr 60px;grid-gap:10px;gap:10px;align-items:center}.roof-sun-row .field-label{letter-spacing:.08em}.roof-sun-readout{font-size:12px;color:var(--accent);text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.roof-sun-meta{font-size:11px;color:var(--muted);letter-spacing:.04em}.sun-path-wrap{position:relative;display:inline-block;background:radial-gradient(circle at 50% 50%,oklch(.16 .02 220) 30%,oklch(.2 .02 220) 100%);border:1px solid var(--line);border-radius:50%;overflow:hidden}.sun-path-svg{width:100%;height:100%;display:block}.roof-sun-live{display:flex;flex-direction:column;padding:8px 12px;margin-bottom:4px;background:color-mix(in oklab,var(--accent) 8%,var(--bg-2));border:1px solid color-mix(in oklab,var(--accent) 35%,var(--line));border-radius:6px}.roof-sun-live-value{font-family:var(--serif);font-style:italic;font-size:36px;color:var(--accent);line-height:1;letter-spacing:-.01em;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.roof-sun-live-unit{font-style:normal;font-size:14px;margin-left:6px;letter-spacing:.04em}.roof-sun-live-label,.roof-sun-live-unit{font-family:var(--mono);color:var(--muted)}.roof-sun-live-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}