*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: var(--primaryColor, #92400E);--primary-dark: var(--primaryDark, #78350F);--primary-light: #FEF3C7;--wood: #A16207;--wood-light: #D4A574;--stone: #78716C;--sand: #F5F0EB;--dark: #1C1917;--text: #44403C;--text-light: #78716C;--text-white: #FAFAF9;--bg: #FAFAF9;--bg-alt: #F5F0EB;--bg-dark: #1C1917;--border: #D6D3D1;--radius: 6px;--shadow: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 12px 32px rgba(0,0,0,.1);--transition: .3s ease;--max-width: 1200px}html{scroll-behavior:smooth}body{font-family:Work Sans,-apple-system,sans-serif;color:var(--text);line-height:1.7;background:var(--bg);-webkit-font-smoothing:antialiased}img{max-width:100%;height:auto;display:block}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}h1,h2,h3,h4{font-family:"DM Serif Display",Georgia,serif;font-weight:400;color:var(--dark);line-height:1.2}h1{font-size:clamp(2.5rem,6vw,4rem)}h2{font-size:clamp(1.75rem,4vw,2.5rem)}h3{font-size:clamp(1.125rem,2vw,1.4rem);font-family:Work Sans,sans-serif;font-weight:600}.section-title{text-align:center;margin-bottom:3rem}.section-title h2{margin-bottom:.5rem}.section-title p{color:var(--text-light);font-size:1rem}.section-label{display:inline-block;background:var(--primary-light);color:var(--primary);padding:.25rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}section{padding:5rem 0}.site-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:2px solid var(--primary)}.site-header .container{display:flex;justify-content:space-between;align-items:center;height:72px}.site-header .logo{font-family:"DM Serif Display",serif;font-size:1.4rem;font-weight:400;color:var(--dark)}.site-header nav{display:flex;gap:1.75rem;align-items:center}.site-header nav a{color:var(--text);font-size:.9rem;font-weight:500;transition:color var(--transition)}.site-header nav a:hover{color:var(--primary)}.nav-cta{background:var(--primary)!important;color:var(--text-white)!important;padding:.55rem 1.5rem;border-radius:var(--radius);font-weight:600!important;font-size:.9rem!important}.nav-cta:hover{background:var(--primary-dark)!important}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.menu-toggle span{display:block;width:24px;height:2px;background:var(--dark);margin:5px 0;transition:var(--transition)}@media(max-width:768px){.menu-toggle{display:block}.site-header nav{display:none;position:absolute;top:72px;left:0;right:0;background:var(--bg);flex-direction:column;padding:1.5rem;border-bottom:2px solid var(--primary);gap:1rem}.site-header nav.open{display:flex}}.hero{position:relative;min-height:85vh;display:flex;align-items:center;overflow:hidden}.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--sand),#E7DDD2);z-index:0}.hero-bg.with-image{background-size:cover;background-position:center}.hero-bg.with-image:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,25,23,.8) 0%,rgba(28,25,23,.3) 60%,transparent 100%)}.hero-content{position:relative;z-index:1;max-width:600px;padding:2rem 1.5rem}.hero-content h1{color:var(--dark);margin-bottom:1.5rem}.hero-bg.with-image+.hero-content h1{color:var(--text-white)}.hero-content p{font-size:1.1rem;color:var(--text-light);margin-bottom:2rem}.hero-cta{display:inline-block;background:var(--primary);color:var(--text-white);padding:.875rem 2rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:all var(--transition)}.hero-cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg);color:var(--text-white)}.promo-banner{background:var(--primary);color:var(--text-white);text-align:center;padding:.75rem;font-weight:600;font-size:.95rem}.closure-banner{background:#fef2f2;border-bottom:2px solid #FECACA;color:#dc2626;text-align:center;padding:1rem;font-weight:600}.process-section{background:var(--bg)}.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1000px;margin:0 auto;position:relative}.process-step{text-align:center;padding:2rem 1.5rem;position:relative}.step-number{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--primary);color:var(--text-white);font-family:"DM Serif Display",serif;font-size:1.5rem;margin-bottom:1.25rem}.process-step h3{margin-bottom:.75rem}.process-step p{color:var(--text-light);font-size:.9rem}.portfolio-section{background:var(--bg-alt)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.portfolio-card{background:var(--bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.portfolio-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.portfolio-image{aspect-ratio:16/10;overflow:hidden;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:3rem}.portfolio-image img{width:100%;height:100%;object-fit:cover}.portfolio-body{padding:1.5rem}.portfolio-body h3{margin-bottom:.5rem}.portfolio-body .project-type{color:var(--primary);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.portfolio-body p{color:var(--text-light);font-size:.9rem}.certifications{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;padding:2rem 0;margin-top:2rem;border-top:1px solid var(--border)}.cert-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-light);border-radius:var(--radius);font-size:.85rem;font-weight:600;color:var(--primary)}.quote-section{background:var(--dark);color:var(--text-white);text-align:center;padding:5rem 0}.quote-section h2{color:var(--text-white);margin-bottom:1rem}.quote-section p{color:var(--stone);font-size:1.05rem;margin-bottom:2rem}.quote-section .cta-button{display:inline-block;background:var(--primary);color:var(--text-white);padding:1rem 2.5rem;border-radius:var(--radius);font-weight:600;font-size:1rem;transition:all var(--transition)}.quote-section .cta-button:hover{background:var(--wood);transform:translateY(-2px)}.quote-phone{margin-top:1.5rem;font-family:"DM Serif Display",serif;font-size:1.5rem}.quote-phone a{color:var(--wood-light)}.about-section .content-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.about-section .text-content h2{margin-bottom:1.5rem}.about-section .text-content p{color:var(--text-light);font-size:1.05rem;margin-bottom:1rem}.about-section .image-content{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:4rem}@media(max-width:768px){.about-section .content-grid{grid-template-columns:1fr;gap:2rem}}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.service-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;border-left:4px solid var(--primary);transition:transform var(--transition),box-shadow var(--transition)}.service-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.service-card .icon{font-size:2rem;margin-bottom:.75rem}.service-card h3{margin-bottom:.5rem}.service-card p{color:var(--text-light);font-size:.9rem}.gallery-section{background:var(--bg-alt)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.gallery-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;transition:transform var(--transition)}.gallery-item:hover{transform:scale(1.02)}.gallery-item img{width:100%;height:100%;object-fit:cover}.gallery-placeholder{width:100%;height:100%;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:3rem}.hours-section{background:var(--bg)}.hours-card{background:var(--bg-alt);border-radius:var(--radius);padding:2.5rem;max-width:500px;margin:0 auto;text-align:center;border:1px solid var(--border)}.hours-card h3{color:var(--primary);margin-bottom:1.5rem}.hours-text{white-space:pre-line;font-size:1rem;line-height:2;color:var(--text-light)}.contact-section .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.contact-info-list{list-style:none;display:flex;flex-direction:column;gap:1.5rem}.contact-info-list li{display:flex;align-items:flex-start;gap:1rem}.contact-info-list .icon{font-size:1.5rem;flex-shrink:0}.contact-info-list .label{font-weight:600;display:block;margin-bottom:.25rem}.contact-info-list .value{color:var(--text-light)}.contact-map{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;border:1px solid var(--border)}@media(max-width:768px){.contact-section .contact-grid{grid-template-columns:1fr}}.site-footer{background:var(--bg-dark);color:#a8a29e;padding:3rem 0 2rem}.footer-content{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;margin-bottom:2rem}.footer-brand .logo{font-family:"DM Serif Display",serif;color:var(--text-white);font-size:1.25rem;margin-bottom:.5rem}.footer-brand p{font-size:.9rem;max-width:300px}.footer-links h4{color:var(--text-white);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}.footer-links a{color:#a8a29e;font-size:.9rem}.footer-links a:hover{color:var(--text-white)}.footer-bottom{border-top:1px solid #292524;padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.85rem}.social-links{display:flex;gap:1rem}.social-links a{color:#a8a29e;font-size:1.25rem}.social-links a:hover{color:var(--text-white)}
