:root{--bg: #f7f5f0;--surface: #ffffff;--surface-alt: #eee9df;--text: #1a1f2b;--muted: #5a6274;--border: #ddd7cc;--primary: #c66a12;--primary-dark: #a85a0e;--primary-light: #fff6ed;--navy: #1f2f46;--navy-dark: #0f1b2d;--white: #ffffff;--shadow: 0 4px 24px rgba(15, 23, 42, .07);--shadow-strong: 0 12px 40px rgba(15, 23, 42, .13);--shadow-hover: 0 16px 48px rgba(15, 23, 42, .16);--radius: 10px;--radius-lg: 16px;--container: 1200px;--transition: .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;line-height:1.6;background:var(--bg);color:var(--text)}body.nav-is-open{overflow:hidden}img{display:block;max-width:100%}a{color:inherit;text-decoration:none;transition:color var(--transition)}main{min-height:100vh}.container{width:min(var(--container),calc(100% - 2rem));margin:0 auto}.section{padding:4.5rem 0}.section-dark{background:var(--navy);color:var(--white)}.section-dark h1,.section-dark h2,.section-dark h3,.section-dark p{color:var(--white)}.section-heading{max-width:760px;margin:0 auto 2rem;text-align:center}.section-heading-left{text-align:left;margin-left:0}.section-heading-narrow{max-width:760px}.eyebrow{display:inline-block;margin-bottom:.85rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary)}.eyebrow-light{color:#f0c48e}h1,h2,h3{margin-top:0;color:var(--text);line-height:1.1;letter-spacing:-.02em}h1{font-size:clamp(2.3rem,4vw,4.2rem);margin-bottom:1rem;font-weight:800}h2{font-size:clamp(1.85rem,3vw,2.7rem);margin-bottom:1rem;font-weight:800}h3{font-size:1.15rem;margin-bottom:.7rem;font-weight:700;letter-spacing:-.01em}p{margin:0 0 1rem;color:var(--muted);font-size:1rem;line-height:1.65}.button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.85rem 1.4rem;border:2px solid transparent;border-radius:var(--radius);font-weight:700;font-size:.95rem;letter-spacing:.01em;transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition);cursor:pointer}.button:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.button-primary{background:var(--primary);color:var(--white)}.button-primary:hover{background:var(--primary-dark);box-shadow:0 8px 24px #c66a124d}.button-secondary{background:var(--white);color:var(--navy-dark);border-color:var(--border)}.button-secondary:hover{border-color:var(--primary);color:var(--primary)}.hero-contractor .button-secondary,.section-dark .button-secondary,.final-cta-box .button-secondary{background:#ffffff1f;color:var(--white);border-color:#ffffff4d}.hero-contractor .button-secondary:hover,.section-dark .button-secondary:hover,.final-cta-box .button-secondary:hover{background:#fff3;border-color:#ffffff80;color:var(--white)}.topbar{background:var(--navy-dark);color:#ffffffe0;font-size:.85rem}.topbar-inner{min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.topbar-inner p{margin:0;color:#ffffffbf;font-size:.84rem}.topbar-contact{display:flex;align-items:center;gap:1.25rem}.topbar-contact a{color:var(--white);font-weight:600;display:inline-flex;align-items:center;font-size:.85rem}.topbar-contact a:hover{color:#f0c48e}.site-header{position:sticky;top:0;z-index:1000;background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.header-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:0}.logo{display:inline-flex;align-items:center;gap:.6rem;min-width:0;flex-shrink:0}.logo:hover .logo-text{color:var(--primary)}.logo-image{width:44px;height:44px;max-width:none;object-fit:contain}.logo-text{font-size:.95rem;font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--navy-dark);transition:color var(--transition)}.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;background:none;border:none;cursor:pointer;z-index:1001}.nav-toggle-bar{display:block;width:100%;height:2.5px;background:var(--text);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(1){transform:translateY(7.5px) rotate(45deg)}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}.nav{display:flex;justify-content:center;align-items:center;gap:.25rem;min-width:0;flex:1}.nav-link,.nav-parent{display:inline-flex;align-items:center;height:72px;font-weight:600;color:var(--text);font-size:.92rem;white-space:nowrap;position:relative;padding:0 .65rem;border-radius:6px;transition:color var(--transition),background var(--transition)}.nav-link:hover,.nav-parent:hover{color:var(--primary)}.nav-dropdown{position:relative;display:flex;align-items:center}.nav-parent:after{content:"";width:7px;height:7px;margin-left:.4rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform var(--transition)}.nav-dropdown:hover .nav-parent:after{transform:rotate(-135deg) translateY(-2px)}.dropdown-menu{position:absolute;top:calc(100% - 4px);left:-.5rem;min-width:240px;padding:.5rem;background:var(--white);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);box-shadow:var(--shadow-strong);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease;z-index:50}.dropdown-menu a{display:block;padding:.65rem .85rem;color:var(--text);font-size:.9rem;font-weight:600;white-space:nowrap;border-radius:8px;transition:background var(--transition),color var(--transition)}.dropdown-menu a:hover{background:var(--primary-light);color:var(--primary)}.nav-dropdown:hover .dropdown-menu,.nav-dropdown:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.header-cta{flex-shrink:0;white-space:nowrap;margin-left:auto}.dropdown-all-link{display:none}.nav-overlay{position:fixed;inset:0;background:#0000;z-index:998;pointer-events:none;transition:background .35s ease}.nav-overlay.active{background:#00000073;pointer-events:auto}.hero-contractor{position:relative;background:linear-gradient(160deg,#0f1b2db8,#0f1b2d85),url(/images/hero-roof-main.webp) center/cover no-repeat;color:#fff;min-height:calc(100vh - 130px);display:flex;align-items:center;padding:3rem 0}.hero-content{display:grid;grid-template-columns:minmax(0,2fr) minmax(420px,500px);gap:2rem;align-items:center}.hero-main{max-width:980px}.hero-main h1,.hero-main p{color:#fff}.hero-main h1{max-width:18ch;font-size:clamp(2.6rem,3.6vw,4.2rem);line-height:1.02;margin-bottom:.85rem;text-wrap:pretty}.hero-main p{max-width:70ch;font-size:1rem;line-height:1.55;color:#ffffffeb;margin-bottom:0}.hero-kicker{display:inline-block;margin-bottom:.75rem;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.08em;color:#f2c590}.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin:1.1rem 0 .9rem}.hero-trust{display:flex;flex-wrap:wrap;gap:.65rem}.hero-trust span{padding:.5rem .75rem;border:1px solid rgba(255,255,255,.18);background:#ffffff14;font-size:.84rem;font-weight:700;border-radius:4px}.trust-strip{background:var(--navy-dark);color:var(--white);padding:1rem 0;border-bottom:3px solid var(--primary)}.trust-strip-inner{display:flex;justify-content:center;align-items:center;gap:2.5rem;flex-wrap:wrap}.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:700;letter-spacing:.02em;color:#ffffffeb}.trust-item svg{color:var(--primary);flex-shrink:0}@media(max-width:640px){.trust-strip-inner{gap:1rem;justify-content:flex-start}.trust-item{font-size:.82rem;width:calc(50% - .5rem)}}.hero-side{display:flex;justify-content:flex-end;align-items:center}.hero-side-box{width:100%;max-width:500px;background:#fffffffa;color:var(--text);padding:2rem;border-radius:10px;box-shadow:var(--shadow-strong);text-align:left}.hero-side-box h2{color:var(--navy-dark);font-size:1.75rem;line-height:1.08;margin:0 0 1rem;max-width:none;text-align:center}.hero-side-box ul{margin:0 0 1rem;padding-left:1.2rem;max-width:none;text-align:left}.hero-side-box li{color:var(--text);margin-bottom:.85rem;line-height:1.45}.hero-side-link{display:inline-block;margin-top:.35rem;font-weight:700;color:var(--primary)}.hero-side-link:hover{color:var(--primary-dark)}.services-section{background:linear-gradient(180deg,#faf8f4,#f5f3ee);padding-top:4.5rem;border-top:4px solid var(--primary)}.services-editorial{display:grid;grid-template-columns:minmax(300px,.82fr) minmax(0,1.18fr);gap:2.25rem;align-items:start}.services-copy{max-width:500px}.services-copy h2{max-width:14ch;margin-bottom:1rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.services-copy p{max-width:46ch;font-size:1rem;line-height:1.65;margin-bottom:1.35rem}.services-tags{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:1.5rem}.services-tags span{display:inline-flex;align-items:center;min-height:36px;padding:0 .85rem;border-radius:999px;background:#fffc;border:1px solid var(--border);font-size:.88rem;font-weight:700;color:var(--text)}.services-list{display:grid;border-top:1px solid var(--border)}.service-row{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;padding:1.35rem 0;border-bottom:1px solid var(--border);transition:transform var(--transition),color var(--transition)}.service-row:hover{transform:translate(6px)}.service-row-number{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;border-radius:999px;border:1px solid #f0c796;background:#fff7ed;font-size:.78rem;font-weight:800;letter-spacing:.06em;color:var(--primary)}.service-row-body h3{margin-bottom:.4rem;font-size:1.18rem;line-height:1.2}.service-row-body p{margin-bottom:0;max-width:58ch;font-size:1rem;line-height:1.6}.projects-section{background:var(--surface);padding-top:4rem}.projects-header{max-width:760px;margin:0 auto 1.75rem;text-align:center}.projects-copy{max-width:760px;margin:0 auto}.projects-copy h2{max-width:100ch;margin:0 auto .85rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.projects-copy p{max-width:100ch;margin:0 auto 1.25rem;font-size:1rem;line-height:1.6}.projects-actions{display:flex;justify-content:center}.projects-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:1rem}.project-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow);min-height:380px;transition:transform var(--transition),box-shadow var(--transition)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.project-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover img{transform:scale(1.03)}.project-card-large{min-height:460px}.project-overlay{position:absolute;inset:auto 0 0;padding:1.5rem;background:linear-gradient(180deg,#0f1b2d00,#0f1b2de0)}.project-overlay h3{color:#fff;margin:0;max-width:20ch;font-size:1.35rem;line-height:1.15}.project-body{padding:1rem 1rem 1.15rem;background:var(--white)}.project-body h3{margin:0;font-size:1.05rem;line-height:1.35}.project-tag{display:inline-flex;align-items:center;min-height:30px;padding:0 .7rem;margin-bottom:.8rem;border-radius:999px;background:#ffffffe6;color:var(--navy-dark);font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.project-overlay .project-tag{background:#ffffffeb}.why-section{background:linear-gradient(180deg,#f5f3ee,#f0ebe2)}.why-shell{display:grid;grid-template-columns:minmax(300px,.82fr) minmax(0,1.18fr);gap:2.25rem;align-items:start}.why-copy{max-width:500px}.why-copy h2{max-width:14ch;margin-bottom:.9rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.why-copy p{max-width:48ch;line-height:1.65}.why-grid-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.why-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.35rem;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.why-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}.why-card-number{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;margin-bottom:.85rem;border-radius:999px;background:#fff5e9;border:1px solid #f2d2ab;font-size:.76rem;font-weight:800;letter-spacing:.06em;color:var(--primary)}.why-card h3{margin-bottom:.55rem;font-size:1.08rem;line-height:1.2}.why-card p{margin-bottom:0;line-height:1.55}.testimonials-section{background:var(--surface)}.testimonials-shell{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:2.25rem;align-items:start}.testimonials-copy{max-width:500px}.testimonials-copy h2{max-width:14ch;margin-bottom:.85rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.testimonials-copy p{max-width:46ch;line-height:1.6;margin-bottom:1.25rem}.testimonials-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.testimonial-card{background:#fbfaf7;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.4rem;min-height:220px;display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition)}.testimonial-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.testimonial-card-wide{grid-column:1 / -1}.testimonial-stars{margin-bottom:.85rem;color:var(--primary);font-size:1rem;letter-spacing:.08em}.testimonial-card p{line-height:1.65;margin-bottom:1.1rem}.testimonial-name{margin-top:auto;font-size:.92rem;font-weight:700;color:var(--text)}.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.step{background:var(--white);border:1px solid var(--border);padding:1.5rem;border-radius:var(--radius-lg);transition:transform var(--transition),box-shadow var(--transition)}.step:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.step-number{display:inline-block;margin-bottom:.8rem;font-weight:800;color:var(--primary)}.service-detail-section{background:var(--surface)}.service-detail-section-alt{background:linear-gradient(180deg,#faf8f4,#f1ece3);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.service-detail-grid{display:grid;grid-template-columns:minmax(320px,.88fr) minmax(0,1.12fr);gap:2.5rem;align-items:start}.service-detail-grid-reverse>:first-child{order:2}.service-detail-grid-reverse>:last-child{order:1}.service-detail-copy{max-width:560px}.service-detail-copy h2{max-width:14ch;margin-bottom:.9rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.service-detail-copy p{max-width:48ch;line-height:1.65}.detail-side-stack{display:grid;gap:1rem;align-content:start}.detail-side-card{background:#ffffffe0;border:1px solid var(--border);border-radius:12px;padding:1.3rem;box-shadow:var(--shadow)}.detail-side-card-image{padding:0;overflow:hidden}.detail-side-card h3{margin-bottom:.7rem;font-size:1.08rem;line-height:1.2}.detail-side-card p{margin-bottom:0;line-height:1.6}.detail-check-list{margin:0;padding-left:1.1rem}.detail-check-list li{margin-bottom:.65rem;color:var(--text);line-height:1.5}.detail-check-list li:last-child{margin-bottom:0}.service-detail-section-alt .services-tags{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.service-detail-section-alt .services-tags span{display:inline-flex;align-items:center;min-height:36px;padding:0 .85rem;border-radius:999px;background:#ffffffdb;border:1px solid var(--border);font-size:.88rem;font-weight:700;color:var(--text)}.service-areas-shell{display:grid;grid-template-columns:minmax(300px,.82fr) minmax(0,1.18fr);gap:2rem;align-items:start}.service-areas-copy{max-width:500px}.service-areas-copy h2{max-width:14ch;margin-bottom:.85rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.service-areas-copy p{max-width:46ch;line-height:1.6}.service-areas-list{display:flex;flex-wrap:wrap;gap:.85rem;align-content:start;padding-top:1rem}.service-area-item{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 1.1rem;border-radius:var(--radius);background:var(--white);border:1px solid var(--border);font-weight:700;font-size:.92rem;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition),background var(--transition),color var(--transition)}.service-area-item:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:var(--shadow);background:var(--primary-light);color:var(--primary)}.final-cta{background:var(--surface-alt);padding:4.5rem 0}.final-cta-box{display:flex;justify-content:space-between;align-items:center;gap:2rem;background:var(--navy-dark);color:var(--white);padding:2.5rem 3rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-strong)}.final-cta-box h2,.final-cta-box p{color:#fff}.final-cta-actions{display:flex;flex-wrap:wrap;gap:.85rem}.site-footer{background:var(--navy-dark);color:#fff;padding-top:3rem}.site-footer h3,.site-footer h4{margin-top:0;margin-bottom:.8rem;color:#fff}.site-footer p,.site-footer li,.site-footer a{color:#ffffffc2}.site-footer ul{list-style:none;padding:0;margin:0}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2rem}.footer-brand p{max-width:28ch}.footer-social{display:flex;gap:.75rem;margin-top:1rem}.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:#ffffff14;color:#ffffffb3;transition:background var(--transition),color var(--transition)}.footer-social a:hover{background:var(--primary);color:var(--white)}.site-footer a:hover{color:var(--white)}.site-footer li{margin-bottom:.5rem}.footer-bottom{padding:1.25rem 0 2rem;border-top:1px solid rgba(255,255,255,.12)}.contact-shell{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr);gap:1.5rem;align-items:start}.contact-info-card,.contact-form-card{background:var(--white);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.contact-info-card{padding:1.5rem}.contact-info-card h1{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.85rem}.contact-info-card p:last-of-type{margin-bottom:1.5rem}.contact-details{display:grid;gap:1rem}.contact-detail-item{display:flex;align-items:flex-start;gap:.75rem}.contact-detail-item svg{flex-shrink:0;margin-top:2px}.contact-detail-item strong{display:block;font-size:.85rem;color:var(--text);margin-bottom:.15rem}.contact-detail-item a,.contact-detail-item span{font-size:.92rem;color:var(--muted)}.contact-detail-item a:hover{color:var(--primary)}.contact-form-card{padding:1.75rem}.contact-form-card h2{font-size:1.35rem;margin-bottom:1.25rem}.contact-form{display:grid;gap:1rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-field{display:grid;gap:.45rem}.form-field label{font-size:.92rem;font-weight:700;color:var(--text)}.form-field input,.form-field select,.form-field textarea{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--white);color:var(--text);font:inherit;padding:.9rem .95rem}.form-field textarea{resize:vertical;min-height:150px}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:2px solid rgba(198,106,18,.18);border-color:var(--primary)}.contact-form-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.form-status{margin:0;min-height:1.5rem;font-size:.95rem;color:var(--muted)}.replacement-overview-section{background:linear-gradient(180deg,#faf8f4,#f5f1e9);border-top:1px solid var(--border);border-bottom:1px solid var(--border);color:#000}.replacement-overview-grid{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(0,1.1fr);gap:2.5rem;align-items:start;color:#000}.replacement-overview-copy{max-width:560px}.replacement-overview-copy h2{max-width:14ch;margin-bottom:.9rem;font-size:clamp(2rem,2.7vw,3rem);line-height:1.04}.replacement-overview-copy p{max-width:48ch;line-height:1.65;color:#000}.replacement-overview-media{display:grid;gap:1rem}.replacement-stat-grid,.replacement-reasons-grid,.replacement-material-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;color:#000}.replacement-stat-card,.replacement-reason-card,.replacement-material-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.35rem;box-shadow:var(--shadow);color:#000}.replacement-stat-label{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;margin-bottom:.85rem;border-radius:999px;background:#fff5e9;border:1px solid #f2d2ab;font-size:.76rem;font-weight:800;letter-spacing:.06em;color:var(--primary)}.replacement-stat-card h3,.replacement-reason-card h3,.replacement-material-card h3{margin-bottom:.55rem;font-size:1.08rem;line-height:1.2;color:#000}.replacement-stat-card p,.replacement-reason-card p,.replacement-material-card p{margin-bottom:0;line-height:1.55;color:#000}.replacement-materials-section{background:var(--surface)}.location-hub-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.location-hub-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.35rem;box-shadow:var(--shadow)}.location-hub-card h3{margin-bottom:.5rem}.location-hub-card p{margin-bottom:.9rem}.location-hub-links{display:flex;flex-wrap:wrap;gap:.65rem}.location-hub-links a{display:inline-flex;align-items:center;min-height:34px;padding:0 .8rem;border-radius:999px;background:#faf8f4;border:1px solid var(--border);font-size:.88rem;font-weight:700}.location-hub-links a:hover{border-color:var(--primary);color:var(--primary)}.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.blog-card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.blog-card-image-link{display:block}.blog-card-body{padding:1.25rem}.blog-card-meta,.blog-post-meta{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;font-size:.88rem;color:var(--muted);margin-bottom:.8rem}.blog-card-title{font-size:1.35rem;line-height:1.2;margin-bottom:.65rem}.blog-card-link{display:inline-block;margin-top:.35rem;font-weight:700;color:var(--primary)}.blog-card-link:hover{color:var(--primary-dark)}.blog-post-shell{max-width:860px}.blog-post-header{margin-bottom:2rem}.blog-post-description{max-width:70ch;font-size:1.05rem;line-height:1.65}.blog-prose{max-width:72ch}.blog-prose h2,.blog-prose h3{margin-top:2rem}.blog-prose ul,.blog-prose ol{padding-left:1.25rem;margin:0 0 1rem}.blog-prose li{margin-bottom:.55rem;color:var(--text)}.blog-prose a{color:var(--primary);text-decoration:underline}.blog-tags{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:2rem}.blog-tag{display:inline-flex;align-items:center;min-height:34px;padding:0 .8rem;border-radius:999px;background:#faf8f4;border:1px solid var(--border);font-size:.85rem;font-weight:700}.blog-empty-state{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow)}.blog-empty-state code{font-family:Consolas,Monaco,monospace;font-size:.92rem}.replacement-feature-image,.detail-feature-image,.blog-card-image,.blog-post-hero-image,.before-after-image,.services-hub-image,.service-area-map-image,.repair-photo-strip-image,.residential-gallery-image{display:block;width:100%;object-fit:cover}.residential-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.residential-gallery-card,.residential-gallery-card-large{margin:0;background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);min-height:280px}.residential-gallery-image{height:280px}.replacement-feature-image{height:320px;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow)}.detail-feature-image{height:260px}.blog-card-image{height:240px}.blog-post-hero-image{height:420px;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);margin-top:1.25rem}.before-after-image{height:340px}.services-hub-image{height:100%;min-height:180px}.service-area-map-image{height:340px}.repair-photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.repair-photo-strip-image{height:240px;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow)}@media(max-width:1180px){.header-inner{min-height:64px;gap:1rem}.logo-image{width:40px;height:40px}.nav{gap:.15rem}.nav-link,.nav-parent{height:64px;font-size:.88rem;padding:0 .5rem}.hero-contractor{min-height:auto;padding:3.5rem 0}.hero-content,.services-editorial,.why-shell,.service-areas-shell,.footer-grid,.service-detail-grid,.replacement-overview-grid,.contact-shell{grid-template-columns:1fr}.service-detail-grid-reverse>:first-child,.service-detail-grid-reverse>:last-child{order:initial}.steps-grid{grid-template-columns:1fr 1fr}.hero-main,.services-copy,.why-copy,.projects-copy,.testimonials-copy,.service-areas-copy,.service-detail-copy,.replacement-overview-copy,.hero-main h1,.services-copy h2,.why-copy h2,.projects-copy h2,.testimonials-copy h2,.service-areas-copy h2,.service-detail-copy h2,.replacement-overview-copy h2{max-width:100%}.hero-side{justify-content:flex-start}.projects-grid{grid-template-columns:1fr 1fr}.project-card-large{grid-column:1 / -1}.why-grid-cards,.testimonials-grid,.replacement-stat-grid,.replacement-reasons-grid,.replacement-material-grid{grid-template-columns:1fr 1fr}.service-areas-list{padding-top:0}.final-cta-box{flex-direction:column;align-items:flex-start;padding:2rem}.testimonials-shell{grid-template-columns:1fr}.testimonials-copy,.testimonials-copy h2{max-width:100%}}@media(max-width:860px){html{-webkit-text-size-adjust:100%}body{overflow-x:hidden}.container{width:min(var(--container),calc(100% - 1.25rem))}.section,.final-cta{padding:3.5rem 0}h1{font-size:clamp(2rem,8vw,3rem);line-height:1.05}h2{font-size:clamp(1.7rem,7vw,2.35rem);line-height:1.08}h3{font-size:1.05rem}p{font-size:.98rem;line-height:1.6}.site-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--white)}.topbar-inner{min-height:auto;padding:.5rem 0;gap:.35rem;flex-direction:column;text-align:center}.topbar-contact{flex-wrap:wrap;gap:.75rem;justify-content:center}.header-inner{min-height:60px;padding:.5rem 0}.logo-image{width:36px;height:36px}.logo-text{font-size:.85rem}.nav-toggle{display:flex}.nav{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);height:100vh;height:100dvh;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;padding:5rem 1.5rem 2rem;background:var(--white);box-shadow:-8px 0 32px #0000001f;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:999}.nav.nav-open{transform:translate(0)}.nav-link,.nav-parent{height:auto;min-height:48px;padding:.6rem 0;width:100%;justify-content:flex-start;font-size:1rem;border-bottom:1px solid var(--border)}.nav-dropdown{width:100%;display:block}.nav-parent:after{margin-left:auto;transition:transform .25s ease}.nav-dropdown.dropdown-open .nav-parent:after{transform:rotate(-135deg) translateY(-2px)}.dropdown-menu{position:static;min-width:100%;margin-top:0;padding:0 0 0 1rem;border:0;border-radius:0;box-shadow:none;opacity:1;visibility:visible;transform:none;background:transparent;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.nav-dropdown.dropdown-open .dropdown-menu{max-height:600px;padding:.25rem 0 .25rem 1rem}.dropdown-menu a{min-height:44px;display:flex;align-items:center;padding:.45rem 0;font-size:.95rem;white-space:normal;border-radius:0}.dropdown-all-link{display:flex;color:var(--primary);font-weight:700;border-top:1px solid var(--border);margin-top:.25rem;padding-top:.55rem}.header-cta{width:100%;margin-top:1rem;margin-left:0}.button{width:100%;min-height:48px;padding:.85rem 1rem}.hero-actions,.hero-trust,.final-cta-actions{width:100%}.hero-actions,.final-cta-actions{flex-direction:column;align-items:stretch}.hero-actions>*,.final-cta-actions>*{width:100%}.hero-trust{gap:.5rem}.hero-trust span{width:100%;text-align:center;justify-content:center}.hero-content,.projects-grid,.steps-grid,.why-grid-cards,.testimonials-grid,.form-grid,.replacement-stat-grid,.replacement-reasons-grid,.replacement-material-grid,.location-hub-grid,.blog-grid,.residential-gallery-grid,.repair-photo-strip{grid-template-columns:1fr}.hero-contractor{padding:3rem 0 3.2rem}.hero-main h1{max-width:100%;font-size:clamp(2.1rem,8vw,3.3rem)}.hero-main p{max-width:100%}.hero-side{justify-content:flex-start}.hero-side-box{max-width:100%;padding:1.35rem}.services-copy h2,.why-copy h2,.projects-copy h2,.testimonials-copy h2,.service-areas-copy h2,.service-detail-copy h2,.replacement-overview-copy h2{font-size:clamp(1.9rem,8vw,2.7rem)}.service-row{gap:.85rem;padding:1rem 0}.service-row-body p{max-width:100%}.project-card,.project-card-large{min-height:300px}.project-card-large,.testimonial-card-wide{grid-column:auto}.detail-side-card,.why-card,.testimonial-card,.step,.contact-info-card,.contact-form-card,.replacement-stat-card,.replacement-reason-card,.replacement-material-card,.location-hub-card,.blog-card-body{padding:1.1rem}.residential-gallery-image,.replacement-feature-image,.detail-feature-image,.blog-card-image,.before-after-image,.service-area-map-image,.repair-photo-strip-image,.services-hub-image{width:100%;height:220px;object-fit:cover}.blog-post-hero-image{width:100%;height:240px;object-fit:cover}.residential-gallery-card,.residential-gallery-card-large{min-height:220px}.form-field input,.form-field select,.form-field textarea{min-height:46px;font-size:16px}.form-field textarea{min-height:140px}.final-cta-box{flex-direction:column;align-items:stretch;gap:1.2rem;padding:1.35rem}.blog-post-shell,.blog-prose{max-width:100%}.footer-grid{grid-template-columns:1fr 1fr}}@media(max-width:640px){.section,.final-cta{padding:3rem 0}.hero-contractor{padding:2.75rem 0 3rem}.container{width:min(var(--container),calc(100% - 1rem))}.topbar-inner{padding:.4rem 0}.nav-link,.nav-parent{min-height:44px;font-size:.95rem;padding:.45rem 0}.dropdown-menu a{min-height:36px;font-size:.9rem;padding:.35rem 0}h1{font-size:clamp(1.85rem,9vw,2.45rem)}h2{font-size:clamp(1.5rem,8vw,2rem)}.hero-side-box,.why-card,.testimonial-card,.step,.final-cta-box,.detail-side-card,.contact-info-card,.contact-form-card,.replacement-stat-card,.replacement-reason-card,.replacement-material-card,.location-hub-card,.blog-card-body{padding:1rem}.residential-gallery-image,.replacement-feature-image,.detail-feature-image,.blog-card-image,.before-after-image,.service-area-map-image,.repair-photo-strip-image,.services-hub-image,.blog-post-hero-image{height:200px}.project-card,.project-card-large{min-height:240px}.project-overlay{padding:1rem}.project-overlay h3{font-size:1.1rem}.service-row{gap:.75rem;padding:.95rem 0}.service-row-number{min-width:36px;height:36px;font-size:.72rem}.replacement-stat-label,.why-card-number{min-width:34px;height:34px;font-size:.72rem}.footer-grid{grid-template-columns:1fr}}
