:root{--brand-primary:hsl(195,65%,38%);--brand-primary-dark:hsl(195,65%,28%);--brand-accent:hsl(25,90%,55%);--brand-accent-dark:hsl(25,90%,45%);--brand-dark:hsl(210,25%,15%);--brand-light:hsl(195,30%,96%);--brand-gray:hsl(210,10%,92%);--brand-text:hsl(210,20%,25%);--brand-muted:hsl(210,10%,55%);--brand-white:hsl(0,0%,100%);--brand-radius:0.625rem;--brand-shadow:0 0.25rem 1rem hsla(210,25%,15%,0.08);--brand-shadow-lg:0 0.5rem 2rem hsla(210,25%,15%,0.12);--brand-transition:all 0.3s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:100%;scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--brand-text);line-height:1.7;background:var(--brand-white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-primary);text-decoration:none;transition:var(--brand-transition)}
a:hover{color:var(--brand-primary-dark)}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:700;line-height:1.3;color:var(--brand-dark)}
h1{font-size:2.75rem}
h2{font-size:2.15rem}
h3{font-size:1.5rem}
h4{font-size:1.2rem}
p{margin-bottom:1rem}
.wrap{max-width:75rem;margin:0 auto;padding:0 1.5rem}
.section-pad{padding:5rem 0}
.section-title{text-align:center;margin-bottom:0.75rem}
.section-subtitle{text-align:center;color:var(--brand-muted);max-width:38rem;margin:0 auto 3rem;font-size:1.05rem}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:0.85rem 2rem;border-radius:var(--brand-radius);font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:var(--brand-transition);min-height:2.75rem;min-width:2.75rem;text-align:center;font-family:'Inter',sans-serif}
.btn-primary{background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-dark));color:var(--brand-white);box-shadow:0 0.25rem 0.75rem hsla(195,65%,38%,0.3)}
.btn-primary:hover{transform:translateY(-0.125rem);box-shadow:0 0.5rem 1.25rem hsla(195,65%,38%,0.4);color:var(--brand-white)}
.btn-accent{background:linear-gradient(135deg,var(--brand-accent),var(--brand-accent-dark));color:var(--brand-white);box-shadow:0 0.25rem 0.75rem hsla(25,90%,55%,0.3)}
.btn-accent:hover{transform:translateY(-0.125rem);box-shadow:0 0.5rem 1.25rem hsla(25,90%,55%,0.4);color:var(--brand-white)}
.btn-outline{background:transparent;color:var(--brand-primary);border:0.125rem solid var(--brand-primary)}
.btn-outline:hover{background:var(--brand-primary);color:var(--brand-white)}

.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--brand-white);box-shadow:var(--brand-shadow);transition:var(--brand-transition)}
.header-wrap{display:flex;align-items:center;justify-content:space-between;max-width:75rem;margin:0 auto;padding:0.75rem 1.5rem}
.brand-logo{display:flex;align-items:center;gap:0.4rem;font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--brand-dark)}
.brand-logo:hover{color:var(--brand-primary)}
.brand-icon{font-size:1.75rem;color:var(--brand-primary)}
.nav-toggle{display:none;flex-direction:column;gap:0.3rem;background:none;border:none;cursor:pointer;padding:0.5rem;min-height:2.75rem;min-width:2.75rem;justify-content:center;align-items:center}
.nav-toggle span{display:block;width:1.5rem;height:0.15rem;background:var(--brand-dark);border-radius:0.125rem;transition:var(--brand-transition)}
.main-nav{display:flex;align-items:center;gap:1.5rem}
.nav-list{display:flex;list-style:none;gap:0.25rem;align-items:center}
.nav-list a{padding:0.5rem 0.85rem;border-radius:var(--brand-radius);font-weight:500;color:var(--brand-text);font-size:0.95rem}
.nav-list a:hover,.nav-list a.active{color:var(--brand-primary);background:var(--brand-light)}
.has-dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:var(--brand-white);box-shadow:var(--brand-shadow-lg);border-radius:var(--brand-radius);padding:0.5rem 0;min-width:14rem;list-style:none;z-index:100}
.has-dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:0.5rem 1.25rem;white-space:nowrap}
.dropdown-menu a:hover{background:var(--brand-light)}
.header-cta{background:var(--brand-primary);color:var(--brand-white)!important;padding:0.5rem 1.25rem;border-radius:var(--brand-radius);font-weight:600;font-size:0.9rem;white-space:nowrap}
.header-cta:hover{background:var(--brand-primary-dark);color:var(--brand-white)!important}

.hero-section{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--brand-white);overflow:hidden;margin-top:3.75rem}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg picture,.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,hsla(210,25%,15%,0.65) 0%,hsla(210,25%,15%,0.45) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:48rem;padding:2rem 1.5rem}
.hero-content h1{color:var(--brand-white);font-size:3.25rem;margin-bottom:1rem;text-shadow:0 0.125rem 0.25rem hsla(0,0%,0%,0.3)}
.hero-content p{font-size:1.2rem;margin-bottom:2rem;opacity:0.95;max-width:36rem;margin-left:auto;margin-right:auto}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.service-card{background:var(--brand-white);border-radius:var(--brand-radius);overflow:hidden;box-shadow:var(--brand-shadow);transition:var(--brand-transition)}
.service-card:hover{transform:translateY(-0.35rem);box-shadow:var(--brand-shadow-lg)}
.service-card-img{height:14rem;overflow:hidden}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:var(--brand-transition)}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card-body{padding:1.5rem}
.service-card-body h3{margin-bottom:0.5rem}
.service-card-body p{color:var(--brand-muted);font-size:0.95rem;margin-bottom:1rem}
.service-card-body a{font-weight:600;display:inline-flex;align-items:center;gap:0.3rem}

.about-preview{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about-preview-img{border-radius:var(--brand-radius);overflow:hidden;box-shadow:var(--brand-shadow-lg)}
.about-preview-content h2{margin-bottom:1rem}
.about-preview-content p{color:var(--brand-muted)}
.about-stats{display:flex;gap:2rem;margin-top:2rem}
.stat-item{text-align:center}
.stat-num{font-family:'Playfair Display',serif;font-size:2.25rem;font-weight:700;color:var(--brand-primary);display:block}
.stat-label{font-size:0.85rem;color:var(--brand-muted);text-transform:uppercase;letter-spacing:0.05em}

.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gallery-item{border-radius:var(--brand-radius);overflow:hidden;position:relative;aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:var(--brand-transition)}
.gallery-item:hover img{transform:scale(1.08)}

.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.testimonial-card{background:var(--brand-white);padding:2rem;border-radius:var(--brand-radius);box-shadow:var(--brand-shadow);position:relative}
.testimonial-card::before{content:"\201C";font-size:4rem;font-family:'Playfair Display',serif;color:var(--brand-primary);opacity:0.2;position:absolute;top:0.5rem;left:1rem;line-height:1}
.testimonial-text{font-style:italic;color:var(--brand-muted);margin-bottom:1.25rem;padding-top:1.5rem}
.testimonial-author{font-weight:600;color:var(--brand-dark)}
.testimonial-role{font-size:0.85rem;color:var(--brand-muted)}
.stars{color:var(--brand-accent);margin-bottom:0.5rem;font-size:1.1rem}

.faq-list{max-width:48rem;margin:0 auto}
.faq-item{border-bottom:0.0625rem solid var(--brand-gray);padding:1.25rem 0}
.faq-question{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:1.05rem;color:var(--brand-dark);gap:1rem;min-height:2.75rem}
.faq-question::after{content:"+";font-size:1.5rem;color:var(--brand-primary);transition:var(--brand-transition);flex-shrink:0}
.faq-item.open .faq-question::after{content:"\2212"}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.35s ease;color:var(--brand-muted);line-height:1.7}
.faq-item.open .faq-answer{max-height:25rem;padding-top:0.75rem}

.areas-section{background:var(--brand-dark);color:var(--brand-white)}
.areas-section .section-title{color:var(--brand-white)}
.areas-section .section-subtitle{color:hsla(0,0%,100%,0.7)}
.areas-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:0.75rem}
.area-tag{background:hsla(0,0%,100%,0.1);color:var(--brand-white);padding:0.5rem 1.25rem;border-radius:2rem;font-size:0.9rem;transition:var(--brand-transition)}
.area-tag:hover{background:var(--brand-primary);color:var(--brand-white)}

.cta-banner{background:linear-gradient(135deg,var(--brand-primary),hsl(195,65%,30%));color:var(--brand-white);text-align:center;padding:4rem 1.5rem;border-radius:var(--brand-radius);margin:0 auto;max-width:72rem}
.cta-banner h2{color:var(--brand-white);margin-bottom:1rem}
.cta-banner p{opacity:0.9;margin-bottom:2rem;font-size:1.1rem}

.page-hero{background:var(--brand-dark);color:var(--brand-white);padding:7rem 0 3.5rem;text-align:center;margin-top:3.75rem}
.page-hero h1{color:var(--brand-white);margin-bottom:0.5rem}
.page-hero p{color:hsla(0,0%,100%,0.75);font-size:1.1rem}
.breadcrumb{display:flex;justify-content:center;gap:0.5rem;margin-top:1rem;font-size:0.9rem}
.breadcrumb a{color:var(--brand-accent)}
.breadcrumb span{color:hsla(0,0%,100%,0.5)}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.contact-form-wrap{background:var(--brand-white);padding:2.5rem;border-radius:var(--brand-radius);box-shadow:var(--brand-shadow-lg)}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;margin-bottom:0.35rem;font-weight:500;font-size:0.95rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:0.75rem 1rem;border:0.0625rem solid var(--brand-gray);border-radius:var(--brand-radius);font-size:1rem;font-family:'Inter',sans-serif;transition:var(--brand-transition);background:var(--brand-white);min-height:2.75rem}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 0.2rem hsla(195,65%,38%,0.15)}
.form-group textarea{resize:vertical;min-height:8rem}
.contact-info-card{background:var(--brand-light);padding:2rem;border-radius:var(--brand-radius);margin-bottom:1.5rem}
.contact-info-card h3{margin-bottom:1rem}
.contact-info-item{display:flex;gap:0.75rem;margin-bottom:1rem;align-items:flex-start}
.contact-info-item span:first-child{font-size:1.25rem;flex-shrink:0;width:2rem;text-align:center}

.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.service-detail-content h2{margin-bottom:1rem}
.service-detail-content ul{list-style:none;margin:1.5rem 0}
.service-detail-content ul li{padding:0.5rem 0;padding-left:1.5rem;position:relative;color:var(--brand-muted)}
.service-detail-content ul li::before{content:"\2713";position:absolute;left:0;color:var(--brand-primary);font-weight:700}
.service-detail-img{border-radius:var(--brand-radius);overflow:hidden;box-shadow:var(--brand-shadow-lg)}
.service-sidebar{background:var(--brand-light);padding:2rem;border-radius:var(--brand-radius)}
.service-sidebar h3{margin-bottom:1rem}
.service-sidebar ul{list-style:none}
.service-sidebar ul li{border-bottom:0.0625rem solid var(--brand-gray);padding:0.75rem 0}
.service-sidebar ul li a{color:var(--brand-text);font-weight:500}
.service-sidebar ul li a:hover{color:var(--brand-primary)}
.pricing-note{background:var(--brand-accent);color:var(--brand-white);padding:1.5rem;border-radius:var(--brand-radius);margin-top:1.5rem;text-align:center}
.pricing-note strong{display:block;font-size:1.2rem;margin-bottom:0.25rem}

.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.value-card{text-align:center;padding:2rem 1.5rem}
.value-icon{font-size:2.5rem;margin-bottom:1rem}
.value-card h3{margin-bottom:0.5rem}
.value-card p{color:var(--brand-muted);font-size:0.95rem}

.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.portfolio-card{border-radius:var(--brand-radius);overflow:hidden;box-shadow:var(--brand-shadow);transition:var(--brand-transition)}
.portfolio-card:hover{transform:translateY(-0.25rem);box-shadow:var(--brand-shadow-lg)}
.portfolio-card-img{aspect-ratio:16/10;overflow:hidden}
.portfolio-card-img img{width:100%;height:100%;object-fit:cover}
.portfolio-card-body{padding:1.25rem}
.portfolio-card-body h3{font-size:1.15rem;margin-bottom:0.35rem}
.portfolio-card-body p{color:var(--brand-muted);font-size:0.9rem;margin-bottom:0}

.policy-content{max-width:52rem;margin:0 auto;padding:3rem 1.5rem}
.policy-content h2{margin-top:2.5rem;margin-bottom:1rem;font-size:1.5rem}
.policy-content h3{margin-top:1.5rem;margin-bottom:0.75rem;font-size:1.2rem}
.policy-content p,.policy-content li{color:var(--brand-muted);line-height:1.8}
.policy-content ul{margin:1rem 0;padding-left:1.5rem}
.policy-content ul li{margin-bottom:0.5rem}

.thank-you-wrap{text-align:center;padding:8rem 1.5rem;max-width:36rem;margin:0 auto}
.thank-you-wrap h1{margin-bottom:1rem}
.thank-you-wrap p{color:var(--brand-muted);margin-bottom:2rem}
.thank-you-icon{font-size:4rem;color:var(--brand-primary);margin-bottom:1rem}

.site-footer{background:var(--brand-dark);color:hsla(0,0%,100%,0.8);padding-top:4rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2rem;max-width:75rem;margin:0 auto;padding:0 1.5rem}
.footer-heading{color:var(--brand-white);font-size:1.15rem;margin-bottom:1.25rem}
.footer-text{font-size:0.9rem;line-height:1.7;opacity:0.8}
.footer-contact{font-size:0.85rem;margin-top:1rem;opacity:0.7}
.footer-links{list-style:none}
.footer-links li{margin-bottom:0.5rem}
.footer-links a{color:hsla(0,0%,100%,0.7);font-size:0.9rem}
.footer-links a:hover{color:var(--brand-accent)}
.footer-contact-list{list-style:none}
.footer-contact-list li{margin-bottom:0.75rem;font-size:0.9rem;display:flex;gap:0.5rem;align-items:flex-start}
.footer-contact-list a{color:hsla(0,0%,100%,0.8)}
.footer-contact-list a:hover{color:var(--brand-accent)}
.footer-bottom{border-top:0.0625rem solid hsla(0,0%,100%,0.1);margin-top:3rem;padding:1.5rem 0}
.footer-bottom-inner{max-width:75rem;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:0.85rem;opacity:0.6;margin:0}
.footer-legal{display:flex;list-style:none;gap:1.5rem}
.footer-legal a{color:hsla(0,0%,100%,0.5);font-size:0.8rem}
.footer-legal a:hover{color:var(--brand-accent)}

.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--brand-dark);color:var(--brand-white);z-index:9999;box-shadow:0 -0.25rem 1rem hsla(0,0%,0%,0.15)}
.cookie-inner{max-width:75rem;margin:0 auto;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cookie-inner p{margin:0;font-size:0.9rem;opacity:0.9;flex:1}
.cookie-actions{display:flex;gap:0.75rem;flex-shrink:0}
.cookie-btn{padding:0.5rem 1.5rem;border-radius:var(--brand-radius);cursor:pointer;font-weight:600;font-size:0.85rem;border:none;font-family:'Inter',sans-serif;min-height:2.75rem}
.cookie-btn-outline{background:transparent;color:var(--brand-white);border:0.0625rem solid hsla(0,0%,100%,0.4)}
.cookie-btn-outline:hover{background:hsla(0,0%,100%,0.1)}
.cookie-btn-filled{background:var(--brand-accent);color:var(--brand-white)}
.cookie-btn-filled:hover{background:var(--brand-accent-dark)}
.cookie-settings-btn{position:fixed;bottom:1.25rem;left:1.25rem;background:var(--brand-dark);color:var(--brand-white);border:none;width:2.75rem;height:2.75rem;border-radius:50%;font-size:1.25rem;cursor:pointer;box-shadow:var(--brand-shadow-lg);z-index:9998;display:flex;align-items:center;justify-content:center;transition:var(--brand-transition)}
.cookie-settings-btn:hover{background:var(--brand-primary)}

.form-error{color:hsl(0,70%,50%);font-size:0.85rem;margin-top:0.25rem;display:none}
.form-group.has-error input,.form-group.has-error textarea{border-color:hsl(0,70%,50%)}
.form-group.has-error .form-error{display:block}

@media(max-width:1008px){
h1{font-size:2.25rem}
h2{font-size:1.75rem}
.hero-content h1{font-size:2.5rem}
.services-grid,.testimonials-grid,.portfolio-grid{grid-template-columns:repeat(2,1fr)}
.about-preview,.service-detail,.contact-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(3,1fr)}
.footer-grid{grid-template-columns:repeat(2,1fr)}
.about-values{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:756px){
.nav-toggle{display:flex}
.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--brand-white);flex-direction:column;padding:1.5rem;box-shadow:var(--brand-shadow-lg);align-items:stretch}
.main-nav.open{display:flex}
.nav-list{flex-direction:column;width:100%}
.nav-list a{padding:0.75rem 1rem;display:block}
.has-dropdown .dropdown-menu{display:none;position:static;box-shadow:none;padding-left:1rem}
.has-dropdown.open .dropdown-menu{display:block}
.header-cta{text-align:center;margin-top:0.5rem}
.hero-section{min-height:75vh;margin-top:3.5rem}
.hero-content h1{font-size:2rem}
.hero-content p{font-size:1rem}
.services-grid,.testimonials-grid,.gallery-grid,.about-values,.portfolio-grid{grid-template-columns:1fr}
.about-stats{flex-direction:column;gap:1.25rem}
.footer-grid{grid-template-columns:1fr}
.footer-bottom-inner{flex-direction:column;text-align:center}
.footer-legal{flex-wrap:wrap;justify-content:center}
.section-pad{padding:3rem 0}
.cookie-inner{flex-direction:column;text-align:center}
.areas-tags{gap:0.5rem}
.area-tag{font-size:0.8rem;padding:0.4rem 1rem}
}
@media(max-width:374px){
.hero-content h1{font-size:1.65rem}
h1{font-size:1.75rem}
h2{font-size:1.5rem}
.wrap{padding:0 1rem}
}
