:root{--text:#1a1a1a;--text-h:#0b1a0e;--bg:#fdfaf3;--border:#dfd7c2;--code-bg:#f4f3ec;--accent:#928359;--btn-cta:#1c5222;--btn-cta-text:#fff;--accent-bg:#9283591a;--accent-border:#92835980;--social-bg:#f4f3ec80;--background-hero:#d4ebd0c8;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#ece6d6;--text-h:#fff;--bg:#11200f;--border:#2c4f34;--code-bg:#0a531d;--accent:#c8b48a;--btn-cta:#c8b48a;--btn-cta-text:#000;--accent-bg:#c8b48a1a;--accent-border:#b96c0080;--social-bg:#91520480;--background-hero:#0e180c99;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}}html{scroll-behavior:smooth}body{margin:0}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}.hero{text-align:center;background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:center;align-items:center;min-height:80vh;display:flex}.hero-overlay{background-color:var(--background-hero);border-radius:15px;max-width:800px;margin:0 20px;padding:3rem}.hero h1{text-align:center;margin-bottom:1rem;font-size:3.5rem;line-height:1.1}@media (width<=768px){.hero h1{font-size:2.5rem}}.brand-link{align-items:center;gap:12px;text-decoration:none;display:flex}.nav-logo{object-fit:cover;border-radius:50%;width:65px;height:65px}.hero p{color:var(--text);margin-bottom:2rem;font-size:1.2rem}.services-section{background-color:var(--bg);text-align:center;padding:5rem 2rem}.services-header{margin-bottom:4rem}.services-header h2{color:var(--text-h);margin-bottom:.5rem;font-size:2.5rem}.services-header p{color:var(--accent);font-size:1.2rem;font-weight:500}.services-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto;display:grid}.service-card{background-color:var(--accent-bg);border:1px solid var(--border);border-radius:12px;padding:2.5rem 2rem;transition:transform .3s,box-shadow .3s,border-color .3s}.service-card:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-8px)}.service-icon{margin-bottom:1.5rem;font-size:3rem}.service-card h3{color:var(--text-h);margin-bottom:1rem;font-size:1.5rem}.service-card p{color:var(--text);line-height:1.6}.navbar{background-color:var(--bg);border-bottom:1px solid var(--border);z-index:1000;justify-content:space-between;align-items:center;padding:1.5rem 5%;display:flex;position:sticky;top:0}.navbar-brand .logo-text{color:var(--text-h);letter-spacing:1px;font-size:1.5rem;font-weight:700;text-decoration:none}.navbar-brand span{color:var(--accent);margin-left:5px;font-size:1rem;font-weight:500}.navbar-links{gap:2.5rem;display:flex}.nav-link{color:var(--text);font-size:1.1rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:var(--accent)}@media (width<=768px){.navbar-links{display:none}.navbar{padding:1rem}}.call-btn{background-color:var(--accent);color:#000;border:1px solid var(--accent);white-space:nowrap;border-radius:6px;flex-shrink:0;padding:.5rem 1.2rem;font-weight:600;text-decoration:none;transition:all .2s}.call-btn:hover{color:var(--accent);background-color:#0000}.service-area-section{background-color:var(--accent-bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;padding:5rem 2rem}.service-area-content{max-width:800px;margin:0 auto}.service-area-content h2{color:var(--text-h);margin-bottom:.5rem;font-size:2.5rem}.service-area-content p{color:var(--text);margin-bottom:3rem;font-size:1.2rem}.town-grid{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.town-pill{border:1px solid var(--accent);color:var(--text-h);background-color:var(--bg);border-radius:6px;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.town-pill:hover{background-color:var(--accent);color:#000;transform:translateY(-3px)}.footer-section{background-color:var(--bg);border-top:1px solid var(--border);color:var(--text);padding:4rem 2rem 1rem}.footer-container{grid-template-columns:2fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto 3rem;display:grid}.footer-brand span{color:var(--accent);font-size:1rem;font-weight:500}.footer-brand p{max-width:400px;line-height:1.6}.footer-links,.footer-contact{flex-direction:column;gap:.8rem;display:flex}.footer-links h4,.footer-contact h4{color:var(--text-h);margin-bottom:.5rem;font-size:1.2rem}.footer-links a{color:var(--text);width:fit-content;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-phone{color:var(--accent);font-size:1.2rem;font-weight:700;text-decoration:none}.footer-email{color:var(--text);text-decoration:none;transition:color .2s;display:block}.footer-email:hover{color:var(--accent)}.footer-bottom{text-align:center;border-top:1px solid var(--border);opacity:.8;padding-top:2rem;font-size:.9rem}.footer-logo-group{align-items:center;gap:15px;margin-bottom:1rem;display:flex}.footer-logo{object-fit:cover;border-radius:50%;width:55px;height:55px;box-shadow:0 2px 8px #0000004d}.footer-brand h3{color:var(--text-h);letter-spacing:1px;margin-bottom:0;font-size:1.5rem}@media (width<=768px){.footer-container{text-align:center;grid-template-columns:1fr;gap:2rem}.footer-links a{margin:0 auto}}.gallery-section{background-color:var(--bg);text-align:center;padding:5rem 2rem}.gallery-header{margin-bottom:4rem}.gallery-header h2{color:var(--text-h);margin-bottom:.5rem;font-size:2.5rem}.gallery-header p{color:var(--accent);font-size:1.2rem;font-weight:500}.gallery-grid{flex-direction:column;gap:4rem;max-width:1000px;margin:0 auto;display:flex}.project-card{background-color:var(--accent-bg);border:1px solid var(--border);border-radius:6px;padding:2rem}.project-title{color:var(--text-h);text-align:left;margin-bottom:1.5rem;font-size:1.8rem}.comparison-container{gap:1rem;display:flex}.image-wrapper{border:1px solid var(--border);border-radius:4px;flex:1;position:relative;overflow:hidden}.image-label{color:#fff;z-index:10;text-transform:uppercase;letter-spacing:1px;background-color:#000000b3;border-radius:4px;padding:.4rem 1rem;font-size:.9rem;font-weight:600;position:absolute;top:1rem;left:1rem}.after-label{background-color:var(--accent);color:#000}@media (width<=768px){.comparison-container{flex-direction:column}.image-wrapper img{height:250px}.project-title{text-align:center}}.compare-container{border:1px solid var(--border);-webkit-user-select:none;user-select:none;border-radius:6px;width:100%;height:400px;position:relative;overflow:hidden}.compare-img{object-fit:cover;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.slider-line{background-color:var(--accent);z-index:15;pointer-events:none;width:4px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.slider-button{background-color:var(--accent);color:#000;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 10px #00000080}.compare-label{color:#fff;z-index:10;text-transform:uppercase;letter-spacing:1px;background-color:#000000b3;border-radius:4px;padding:.4rem 1rem;font-size:.8rem;font-weight:600;position:absolute;top:1rem}.label-before{left:1rem}.label-after{background-color:var(--accent);color:#000;right:1rem}@media (width<=768px){.compare-container{height:300px}.call-btn{padding:8px 16px;font-size:.9rem}}
