:root{--bg: #f5f3ee;--surface: #ffffff;--surface-alt: #ece7de;--text: #1f2937;--muted: #5f6875;--border: #d8d2c8;--primary: #c66a12;--primary-dark: #a6560f;--navy: #1f2f46;--navy-dark: #0f1b2d;--white: #ffffff;--shadow: 0 10px 28px rgba(15, 23, 42, .08);--shadow-strong: 0 18px 40px rgba(15, 23, 42, .16);--radius: 8px;--radius-lg: 14px;--container: 1200px}*,*:before,*:after{box-sizing:border-box}html{font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}body{margin:0;line-height:1.5;background:var(--bg);color:var(--text)}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}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}.eyebrow{display:inline-block;margin-bottom:.85rem;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary)}.eyebrow-light{color:#f0c48e}h1,h2,h3{margin-top:0;color:var(--text);line-height:1.12}h1{font-size:clamp(2.3rem,4vw,4.5rem);margin-bottom:1rem}h2{font-size:clamp(1.9rem,3vw,2.8rem);margin-bottom:1rem}h3{font-size:1.15rem;margin-bottom:.7rem}p{margin:0 0 1rem;color:var(--muted);font-size:1rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.85rem 1.2rem;border:2px solid transparent;border-radius:6px;font-weight:700;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;cursor:pointer}.button:hover{transform:translateY(-1px)}.button-primary{background:var(--primary);color:var(--white)}.button-primary:hover{background:var(--primary-dark)}.button-secondary{background:#fffffffa;color:var(--navy-dark);border-color:#fffffffa}.topbar{background:var(--navy-dark);color:#ffffffe6;font-size:.92rem}.topbar-inner{min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.topbar-inner p{margin:0;color:#ffffffe6}.topbar-contact{display:flex;align-items:center;gap:.75rem}.topbar-contact a{color:var(--white);font-weight:500}.site-header{position:sticky;top:0;z-index:1000;background:var(--white);border-bottom:1px solid var(--border)}.header-inner{min-height:84px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;padding:0}.logo{display:inline-flex;align-items:center;min-width:0;flex-shrink:0}.logo-image{width:52px;height:52px;max-width:none;object-fit:contain}.nav{display:flex;justify-content:center;align-items:center;gap:1.75rem;min-width:0}.nav-link,.nav-parent{display:inline-flex;align-items:center;height:84px;font-weight:700;color:var(--text);font-size:.96rem;white-space:nowrap;position:relative}.nav-link:hover,.nav-parent:hover{color:var(--primary)}.nav-dropdown{position:relative;display:flex;align-items:center}.nav-parent:after{content:"";width:8px;height:8px;margin-left:.45rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-1px)}.dropdown-menu{position:absolute;top:calc(100% - 10px);left:0;min-width:240px;padding:.55rem 0;background:var(--white);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);box-shadow:var(--shadow-strong);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;z-index:50}.dropdown-menu a{display:block;padding:.8rem 1rem;color:var(--text);font-size:.95rem;font-weight:600;white-space:nowrap}.dropdown-menu a:hover{background:#c66a1214;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}.hero-contractor{position:relative;background:linear-gradient(#0f1b2d8f,#0f1b2d8f),url(/images/hero-roof-main.webp) center/cover no-repeat;color:#fff;min-height:calc(100vh - 130px);display:flex;align-items:center;padding:2.5rem 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}.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 .2s ease,color .2s ease}.service-row:hover{transform:translate(4px)}.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:12px;background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow);min-height:380px}.project-card img{width:100%;height:100%;object-fit:cover}.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:12px;padding:1.35rem;box-shadow:var(--shadow)}.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:12px;padding:1.4rem;min-height:220px;display:flex;flex-direction:column}.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.35rem;border-radius:8px}.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}.section-heading-narrow{max-width:760px}.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 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 1rem;border-radius:8px;background:var(--white);border:1px solid var(--border);font-weight:700;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.service-area-item:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow)}@media(max-width:1180px){.service-detail-grid,.service-areas-shell{grid-template-columns:1fr}.service-detail-grid-reverse>:first-child,.service-detail-grid-reverse>:last-child{order:initial}.service-detail-copy,.service-areas-copy,.service-detail-copy h2,.service-areas-copy h2{max-width:100%}}@media(max-width:860px){.detail-side-card{padding:1.15rem}}.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:2rem;border-radius:12px}.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.3fr 1fr 1fr;gap:2rem;padding-bottom:2rem}.footer-bottom{padding:1.25rem 0 2rem;border-top:1px solid rgba(255,255,255,.12)}@media(max-width:1180px){.header-inner{grid-template-columns:auto 1fr auto;gap:1.25rem}.nav{gap:1.1rem}.nav-link,.nav-parent{font-size:.92rem}.hero-contractor{min-height:auto;padding:3.5rem 0}.hero-content,.services-editorial,.why-shell,.service-areas-shell,.footer-grid{grid-template-columns:1fr}.steps-grid{grid-template-columns:1fr 1fr}.hero-main,.services-copy,.why-copy,.projects-copy,.testimonials-copy,.service-areas-copy,.hero-main h1,.services-copy h2,.why-copy h2,.projects-copy h2,.testimonials-copy h2,.service-areas-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{grid-template-columns:1fr 1fr}.service-areas-list{padding-top:0}.final-cta-box{flex-direction:column;align-items:flex-start}.testimonials-shell{grid-template-columns:1fr}.testimonials-copy,.testimonials-copy h2{max-width:100%}}@media(max-width:860px){.topbar-inner,.header-inner{display:flex;flex-direction:column;align-items:flex-start}.topbar-inner{padding:.6rem 0}.header-inner{padding:.9rem 0;gap:1rem}.logo-image{width:44px;height:44px}.nav,.hero-actions,.hero-trust,.final-cta-actions{width:100%}.nav{flex-direction:column;align-items:flex-start;gap:.25rem}.nav-link,.nav-parent{height:auto;padding:.45rem 0}.nav-dropdown{width:100%;display:block}.dropdown-menu{position:static;min-width:100%;margin-top:.2rem;padding:.25rem 0 .25rem .9rem;border:0;border-radius:0;box-shadow:none;opacity:1;visibility:visible;transform:none;background:transparent}.dropdown-menu a{padding:.45rem 0;font-size:.93rem}.steps-grid,.why-grid-cards,.testimonials-grid,.projects-grid{grid-template-columns:1fr}.hero-contractor{padding:3rem 0 3.25rem}.hero-content{grid-template-columns:1fr;gap:1.5rem}.hero-main h1{font-size:clamp(2.2rem,8vw,3.5rem)}.hero-side{justify-content:flex-start}.services-copy h2,.why-copy h2,.projects-copy h2,.testimonials-copy h2,.service-areas-copy h2{font-size:clamp(1.9rem,8vw,2.7rem)}.service-row{gap:.9rem;padding:1.1rem 0}.service-row-body p{max-width:100%}.project-card,.project-card-large{min-height:320px}.project-card-large{grid-column:auto}.button{width:100%}.testimonials-grid{grid-template-columns:1fr}.testimonial-card-wide{grid-column:auto}.testimonials-copy h2{font-size:clamp(1.9rem,8vw,2.7rem)}}@media(max-width:640px){.section,.final-cta{padding:3.75rem 0}.hero-contractor{padding:3.25rem 0 3.5rem}.hero-side-box,.why-card,.testimonial-card,.step,.final-cta-box{padding:1.25rem}.container{width:min(var(--container),calc(100% - 1.25rem))}}.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.4rem}.contact-info-card p:last-child{margin-bottom:0}.contact-form-card{padding:1.5rem}.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)}@media(max-width:860px){.contact-shell,.form-grid{grid-template-columns:1fr}}
