*{margin:0;padding:0;box-sizing:border-box}body{font-family:Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}html{scroll-behavior:smooth}h1,h2,h3,h4,h5,h6{margin-bottom:1rem;line-height:1.2}.App{width:100%;overflow-x:hidden}.btn{display:inline-block;padding:.8rem 2rem;border-radius:4px;font-weight:700;text-decoration:none;transition:all .3s;cursor:pointer;text-align:center}.btn-primary{background-color:#ff5722;color:#fff!important;border:none}.btn-primary:hover{background-color:#e64a19;transform:translateY(-2px)}.btn-secondary{background-color:transparent;color:#333!important;border:2px solid #333}.btn-secondary:hover{background-color:#333;color:#fff!important;transform:translateY(-2px)}.hero .btn-secondary{color:#fff!important;border-color:#fff}.hero .btn-secondary:hover{background-color:#fff;color:#333!important}.header{width:100%;background-color:#fff;z-index:1000}.top-bar{background-color:#333;color:#fff;padding:.5rem 0;font-size:.9rem}.top-bar-container{display:flex;justify-content:space-between;align-items:center}.top-bar-item{display:flex;align-items:center}.top-bar-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-weight:700;transition:all .3s}.top-bar-link:hover{color:#ff5722}.phone-icon{color:#ff5722;margin-right:2px}.contact-text{font-weight:400}.license-text{font-weight:600;color:#ccc}.header-brand{padding:1.5rem 0;background-color:#fff;border-bottom:1px solid #eee}.header-brand-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 1.5rem}.brand-left{flex:1;display:flex;justify-content:flex-start;align-items:center}.brand-center{flex:2;display:flex;justify-content:center;align-items:center}.brand-right{flex:1;display:flex;justify-content:flex-end;align-items:center}.brand-logo-img{height:auto;max-height:140px;max-width:100%;display:block}.cs-logo,.roofovers-logo{max-height:130px}.brand-partners{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.partners-label{font-size:.7rem;text-transform:uppercase;color:#888;font-weight:700;letter-spacing:.5px}.partners-logos-stack{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;gap:1rem}.partner-logo{height:auto;max-height:40px;display:block;opacity:.9;transition:opacity .3s}.partner-logo:hover{opacity:1}.duke-logo,.estar-logo,.gaf-logo{max-height:40px}@media(max-width:768px){.top-bar-container{flex-direction:column;gap:.5rem;padding:.2rem 0}.header-brand-container{flex-direction:row;justify-content:center;align-items:center;gap:1.5rem;padding:1rem}.brand-left,.brand-center{flex:none;width:auto}.brand-right{display:none}.brand-logo-img{max-height:75px;width:auto}.cs-logo{max-height:85px}.roofovers-logo{max-height:75px}.header-container{justify-content:space-between}.logo-text-mobile{display:block}.nav{position:absolute;top:100%;left:0;width:100%;background-color:#fff;height:0;overflow:hidden;transition:height .3s ease-in-out;box-shadow:0 5px 10px #0000001a}.nav-open{height:350px}.nav-list{flex-direction:column;padding:2rem 0;gap:1.5rem}.mobile-menu-toggle{display:block}}.header-nav-container{position:sticky;top:0;background-color:#fff;box-shadow:0 2px 10px #0000001a;padding:.8rem 0;z-index:1001}.header-container{display:flex;justify-content:center;align-items:center;max-width:1200px;margin:0 auto;padding:0 1.5rem}.logo-text-mobile{display:none;font-size:1.25rem;font-weight:800;color:#ff5722}.nav-list{display:flex;list-style:none;gap:2rem;align-items:center}.nav-list a{text-decoration:none;color:#333;font-weight:600;transition:color .3s}.nav-list a:hover{color:#ff5722}.contact-btn{background-color:#ff5722;color:#fff!important;padding:.6rem 1.2rem;border-radius:4px;transition:background-color .3s!important}.contact-btn:hover{background-color:#e64a19!important}.mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.hamburger{display:block;width:25px;height:3px;background-color:#333;position:relative;transition:background-color .3s}.hamburger:before,.hamburger:after{content:"";position:absolute;width:25px;height:3px;background-color:#333;left:0;transition:transform .3s}.hamburger:before{top:-8px}.hamburger:after{bottom:-8px}.hamburger-open{background-color:transparent}.hamburger-open:before{transform:rotate(45deg) translate(5px,6px)}.hamburger-open:after{transform:rotate(-45deg) translate(5px,-6px)}.hero{position:relative;height:30vh;min-height:250px;background-color:#333;background-image:linear-gradient(135deg,#333,#444);display:flex;align-items:center;color:#fff;text-align:center}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1}.hero-container{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.hero-content h1{font-size:3.5rem;margin-bottom:1rem;font-weight:800;text-transform:uppercase;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.slogan{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;font-style:italic}.sub-slogan{font-size:1.25rem;margin-bottom:1.5rem;opacity:.9}.hero-btns{display:flex;gap:1rem;justify-content:center}@media(max-width:768px){.hero-content h1{font-size:2.5rem}.slogan{font-size:1.1rem}.sub-slogan{font-size:1rem}.hero-btns{flex-direction:column;align-items:center}}.services{padding:5rem 0;background-color:#f9f9f9}.section-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:#333}.services-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem}.service-card{flex:0 1 350px;min-width:280px;background-color:#fff;padding:2.5rem;border-radius:8px;box-shadow:0 4px 15px #0000000d;transition:transform .3s;text-align:center}.service-card:hover{transform:translateY(-10px)}.icon-circle{width:60px;height:60px;background-color:#ff57221a;border-radius:50%;margin:0 auto 1.5rem;position:relative}.icon-circle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;background-color:#ff5722;border-radius:4px}.service-card h3{font-size:1.5rem;margin-bottom:1rem;color:#333}.service-card p{color:#666;line-height:1.6;margin-bottom:1.5rem}.service-link{color:#ff5722;text-decoration:none;font-weight:700;transition:opacity .3s}.service-link:hover{opacity:.8}.payment-logos{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:1.5rem;flex-wrap:nowrap}.payment-logo{height:42px;width:70px;object-fit:contain;background-color:#fff;border:1px solid #eee;border-radius:4px;padding:6px;box-shadow:0 2px 5px #0000000d;transition:transform .3s,box-shadow .3s}.payment-logo:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}@media(max-width:768px){.section-title{font-size:2rem}}.testimonials{padding:5rem 0;background-color:#fff}.testimonials .section-title{text-align:center;margin-bottom:3rem;font-size:2.5rem;color:#333}.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-flow:dense;gap:2rem;max-width:1200px;margin:0 auto}.testimonial-card{background-color:#fff;padding:3rem;border-radius:12px;border:1px solid #eee;box-shadow:0 10px 30px #00000008;transition:transform .3s,box-shadow .3s;position:relative;display:flex;flex-direction:column}.testimonial-card-long{grid-column:span 2;background-color:#f9f9f9;border-left:5px solid #ff5722}.testimonial-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000014}.quote-icon{font-family:Georgia,serif;font-size:5rem;color:#ff5722;line-height:1;position:absolute;top:1rem;left:1.5rem;opacity:.1;pointer-events:none}.testimonial-text{font-style:italic;color:#444;line-height:1.8;margin-bottom:2rem;flex-grow:1;font-size:1.1rem;position:relative;z-index:1}.testimonial-card-long .testimonial-text{font-size:1.2rem}.testimonial-author{font-weight:700;color:#333;text-align:right;border-top:1px solid #eee;padding-top:1.5rem;text-transform:uppercase;letter-spacing:1px}@media(max-width:768px){.testimonials{padding:3rem 0}.testimonials .section-title{font-size:2rem}.testimonials-grid{grid-template-columns:1fr}.testimonial-card{padding:2rem}.testimonial-card-long{grid-column:span 1}}.testimonials-footer{margin-top:4rem;display:flex;justify-content:center;gap:1.5rem;padding-top:3rem;border-top:1px solid #eee}@media(max-width:576px){.testimonials-footer{flex-direction:column;align-items:stretch}}.job-photos{padding:5rem 0;background-color:#f9f9f9}.job-photos .section-title{text-align:center;margin-bottom:1rem;font-size:2.5rem;color:#333}.job-photos .section-description{text-align:center;max-width:800px;margin:0 auto 4rem;color:#666;font-size:1.1rem}.jobs-grid{display:flex;flex-direction:column;gap:4rem}.job-category{display:grid;grid-template-columns:300px 1fr;gap:2rem;align-items:flex-start}.job-info h3{color:#ff5722;font-size:1.5rem;margin-bottom:1rem}.job-info p{color:#555;line-height:1.6}.job-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.job-image-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 15px #0000000d;transition:transform .3s}.job-image-card:hover{transform:translateY(-5px)}.image-wrapper{width:100%;height:250px;overflow:hidden}.image-wrapper img{width:100%;height:100%;object-fit:cover;display:block}.image-caption{padding:1rem;text-align:center;font-weight:600;color:#333;font-size:.95rem;border-top:1px solid #eee}@media(max-width:992px){.job-category{grid-template-columns:1fr;text-align:center}.job-info{margin-bottom:1rem}}@media(max-width:768px){.job-photos{padding:3rem 0}.job-photos .section-title{font-size:2rem}.image-wrapper{height:200px}}.job-photos-footer{margin-top:4rem;display:flex;justify-content:center;gap:1.5rem;padding-top:3rem;border-top:1px solid #eee}@media(max-width:576px){.job-photos-footer{flex-direction:column;align-items:stretch}}.brochures{padding:5rem 0;background-color:#f9f9f9}.brochures .section-title{text-align:center;margin-bottom:1rem;font-size:2.5rem;color:#333}.brochures .section-description{text-align:center;max-width:800px;margin:0 auto 4rem;color:#666;font-size:1.1rem}.brochures-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:3rem;margin-bottom:5rem}.brochure-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 15px #0000000d;transition:transform .3s;display:flex;flex-direction:column}.brochure-card:hover{transform:translateY(-5px)}.brochure-image-wrapper{width:100%;background:#f0f0f0}.brochure-image-wrapper img{width:100%;height:auto;display:block}.brochure-caption{padding:1.5rem;text-align:center;font-weight:700;color:#333;font-size:1.1rem;border-top:1px solid #eee;background:#fff}.brochures-info{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 20px #0000000d;margin-bottom:4rem}.brochures-info h3{color:#ff5722;font-size:1.8rem;margin-bottom:2rem;text-align:center}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.info-item strong{display:block;font-size:1.2rem;color:#333;margin-bottom:.5rem}.info-item p{color:#666;line-height:1.6}.brochures-footer{margin-top:4rem;display:flex;justify-content:center;gap:1.5rem;padding-top:3rem;border-top:1px solid #eee}@media(max-width:992px){.brochures-grid{grid-template-columns:1fr;max-width:600px;margin-left:auto;margin-right:auto}}@media(max-width:768px){.brochures{padding:3rem 0}.brochures .section-title{font-size:2rem}.brochures-grid{grid-template-columns:1fr;gap:2rem}}@media(max-width:576px){.brochures-footer{flex-direction:column;align-items:stretch}.brochures-info{padding:2rem 1.5rem}}.faq-section{padding:5rem 0;background-color:#f9f9f9}.faq-section .section-title{text-align:center;margin-bottom:1rem;font-size:2.5rem;color:#333}.faq-section .section-description{text-align:center;max-width:800px;margin:0 auto 4rem;color:#666;font-size:1.1rem}.faq-list{max-width:1000px;margin:0 auto;display:flex;flex-direction:column;gap:2.5rem}.faq-item{background-color:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 15px #0000000d;border-left:5px solid #ff5722}.faq-question{display:flex;gap:1rem;font-size:1.4rem;color:#333;margin-bottom:1.5rem;font-weight:700;line-height:1.4}.question-prefix{color:#ff5722;font-weight:800}.faq-answer{display:flex;gap:1rem;color:#555;line-height:1.8;font-size:1.1rem}.answer-prefix{color:#ff5722;font-weight:800;flex-shrink:0}.faq-answer p{margin:0}.faq-footer{margin-top:4rem;display:flex;justify-content:center;gap:1.5rem;padding-top:3rem;border-top:1px solid #eee}@media(max-width:768px){.faq-section{padding:3rem 0}.faq-section .section-title{font-size:2rem}.faq-item{padding:1.5rem}.faq-question{font-size:1.2rem}.faq-answer{font-size:1rem}}@media(max-width:576px){.faq-footer{flex-direction:column;align-items:stretch}}.contact{padding:5rem 0;background-color:#fff}.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;max-width:1200px;margin:0 auto;padding:0 1.5rem}.contact-info h2{font-size:2.5rem;margin-bottom:1.5rem;color:#333}.contact-info p{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.info-item{margin-bottom:1.5rem}.info-item p{margin-bottom:0}.info-item p a{color:#333;text-decoration:none;transition:color .3s}.info-item p a:hover{color:#ff5722}.info-item strong{display:block;font-size:1.1rem;color:#ff5722;margin-bottom:.3rem}.contact-form{background-color:#f9f9f9;padding:2.5rem;border-radius:8px;box-shadow:0 4px 20px #00000014}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}input,select,textarea{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s}input:focus,select:focus,textarea:focus{outline:none;border-color:#ff5722}.form-error{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1.5rem;font-size:.95rem;text-align:center;border:1px solid #ffcdd2}.btn-block{width:100%;padding:1rem;font-size:1.1rem}.btn-block:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.contact-success{text-align:center;padding:3rem;background-color:#f9f9f9;border-radius:8px;max-width:600px;margin:0 auto}.contact-success h2{color:#4caf50;margin-bottom:1rem}.contact-success p{margin-bottom:2rem;font-size:1.1rem}@media(max-width:992px){.contact-grid{grid-template-columns:1fr;gap:3rem}}@media(max-width:576px){.form-row{grid-template-columns:1fr;gap:0}}.footer{background-color:#333;color:#fff;padding:4rem 0 2rem}.footer-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.footer-content{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:3rem}.footer-brand-logos{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.footer-brand-logo{height:auto;max-height:80px;display:block;transition:transform .3s}.footer-brand-logo:hover{transform:translateY(-2px)}.footer-cs-logo,.footer-roof-logo{max-height:70px}.footer-brand p{color:#ccc;line-height:1.6}.footer-links h3,.footer-contact h3{font-size:1.2rem;margin-bottom:1.5rem;position:relative;padding-bottom:.5rem}.footer-links h3:after,.footer-contact h3:after{content:"";position:absolute;left:0;bottom:0;width:30px;height:2px;background-color:#ff5722}.footer-links ul{list-style:none}.footer-links ul li{margin-bottom:.8rem}.footer-links ul li a{color:#ccc;text-decoration:none;transition:color .3s}.footer-links ul li a:hover{color:#ff5722}.footer-contact p{color:#ccc;margin-bottom:.8rem}.footer-tel a,.footer-email a{color:#ff5722;text-decoration:none;font-weight:700}.footer-support{margin-top:1.5rem;border-top:1px solid #444;padding-top:1rem}.footer-support .support-label{font-size:.8rem;text-transform:uppercase;color:#888;margin-bottom:.5rem;font-weight:700}.footer-partners-wrapper{display:flex;align-items:center;gap:1rem;margin-top:.5rem;flex-wrap:wrap}.footer-partner-logo{height:auto;transition:transform .3s}.footer-duke-logo,.footer-estar-logo,.footer-gaf-logo{max-height:35px}.footer-partner-logo:hover{transform:translateY(-2px)}.footer-bottom{border-top:1px solid #444;padding-top:2rem;text-align:center}.footer-bottom p{color:#888;font-size:.9rem}.footer-license{margin-bottom:.8rem;font-weight:600;color:#bbb!important}@media(max-width:768px){.footer-content{grid-template-columns:1fr;gap:2.5rem}}
