:root{--brand:hsl(220,65%,28%);--brand-light:hsl(220,55%,42%);--accent:hsl(38,90%,55%);--accent-hover:hsl(38,90%,48%);--surface:hsl(220,15%,97%);--surface-alt:hsl(220,12%,93%);--text-main:hsl(220,20%,18%);--text-light:hsl(220,10%,45%);--white:hsl(0,0%,100%);--radius:6px;--shadow:0 2px 12px hsla(220,30%,15%,.08);--shadow-lg:0 8px 32px hsla(220,30%,15%,.12);--transition:0.25s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:100%;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;color:var(--text-main);background:var(--white);line-height:1.65}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
ul{list-style:none}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:700;line-height:1.25}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
.wrap{max-width:1200px;margin:0 auto;padding:0 1.25rem}
.btn{display:inline-block;padding:.85rem 2rem;border-radius:var(--radius);font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:background var(--transition),transform var(--transition)}
.btn-primary{background:var(--accent);color:var(--text-main)}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);color:var(--text-main)}
.btn-outline{background:transparent;border:2px solid var(--brand);color:var(--brand)}.btn-outline:hover{background:var(--brand);color:var(--white)}
.section{padding:4.5rem 0}
.section-title{text-align:center;margin-bottom:.75rem;color:var(--brand)}
.section-subtitle{text-align:center;color:var(--text-light);max-width:640px;margin:0 auto 2.5rem;font-size:1.05rem}
.site-header{position:sticky;top:0;z-index:100;background:var(--white);box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:.75rem 1.25rem}
.logo-link{display:flex;align-items:center;gap:.5rem;font-weight:700;color:var(--brand);font-size:1.15rem}
.logo-mark{background:var(--brand);color:var(--white);padding:.25rem .6rem;border-radius:4px;font-family:'Playfair Display',serif;font-size:1.1rem}
.logo-text{font-family:'Playfair Display',serif}
.main-nav .nav-list{display:flex;gap:1.75rem;align-items:center}
.main-nav .nav-list a{color:var(--text-main);font-weight:500;font-size:.95rem;padding:.4rem 0;position:relative}
.main-nav .nav-list a:hover{color:var(--brand)}
.has-dropdown{position:relative}
.dropdown-list{display:none;position:absolute;top:100%;left:0;background:var(--white);box-shadow:var(--shadow-lg);border-radius:var(--radius);min-width:220px;padding:.5rem 0;z-index:50}
.has-dropdown:hover .dropdown-list{display:block}
.dropdown-list li a{display:block;padding:.55rem 1.2rem;font-size:.9rem}
.dropdown-list li a:hover{background:var(--surface)}
.header-cta{background:var(--accent);color:var(--text-main);padding:.55rem 1.4rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;transition:background var(--transition)}
.header-cta:hover{background:var(--accent-hover);color:var(--text-main)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;min-width:44px;min-height:44px;justify-content:center;align-items:center}
.menu-toggle .bar{display:block;width:24px;height:2px;background:var(--text-main);transition:transform var(--transition),opacity var(--transition)}
.menu-toggle.active .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active .bar:nth-child(2){opacity:0}
.menu-toggle.active .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.hero{position:relative;background:var(--brand);color:var(--white);padding:6rem 0 5rem;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.22}
.hero-content{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:0 1.25rem}
.hero h1{color:var(--white);margin-bottom:1rem}
.hero p{font-size:1.15rem;margin-bottom:2rem;opacity:.92;max-width:580px;margin-left:auto;margin-right:auto}
.hero .btn{min-width:200px}
.stats-bar{background:var(--surface);padding:2.5rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1200px;margin:0 auto;padding:0 1.25rem;text-align:center}
.stat-item h3{color:var(--brand);font-size:2rem;margin-bottom:.25rem}
.stat-item p{color:var(--text-light);font-size:.9rem}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.service-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.service-card picture,.service-card img{width:100%;height:200px;object-fit:cover}
.service-card-body{padding:1.25rem}
.service-card-body h3{margin-bottom:.5rem}
.service-card-body p{color:var(--text-light);font-size:.92rem;margin-bottom:1rem}
.service-card-body a{font-weight:600;color:var(--brand);font-size:.92rem}
.about-section{background:var(--surface)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.about-text h2{text-align:left;margin-bottom:1rem}
.about-text p{color:var(--text-light);margin-bottom:1rem}
.about-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.testimonials-section{background:var(--white)}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.testimonial-card{background:var(--surface);padding:1.75rem;border-radius:var(--radius);position:relative}
.testimonial-card p{font-style:italic;color:var(--text-light);margin-bottom:1rem;line-height:1.7}
.testimonial-card .author{font-weight:600;color:var(--text-main)}
.testimonial-card .role{font-size:.85rem;color:var(--text-light)}
.faq-section{background:var(--surface)}
.faq-list{max-width:800px;margin:0 auto;padding:0 1.25rem}
.faq-list details{background:var(--white);margin-bottom:.75rem;border-radius:var(--radius);box-shadow:var(--shadow)}
.faq-list summary{padding:1.15rem 1.5rem;cursor:pointer;font-weight:600;font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;min-height:44px}
.faq-list summary::after{content:'+';font-size:1.4rem;font-weight:400;color:var(--brand);transition:transform var(--transition)}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details div{padding:0 1.5rem 1.25rem;color:var(--text-light);line-height:1.7}
.cta-section{background:var(--brand);color:var(--white);text-align:center;padding:4rem 0}
.cta-section h2{color:var(--white);margin-bottom:.75rem}
.cta-section p{opacity:.88;margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}
.contact-form-section{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.contact-info h2{text-align:left;margin-bottom:1rem}
.contact-info p{color:var(--text-light);margin-bottom:.75rem}
.contact-info a{color:var(--brand)}
.contact-form{background:var(--surface);padding:2rem;border-radius:var(--radius)}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:500;margin-bottom:.35rem;font-size:.92rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid var(--surface-alt);border-radius:var(--radius);font-family:inherit;font-size:1rem;transition:border-color var(--transition);min-height:44px}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--brand)}
.form-group textarea{resize:vertical;min-height:120px}
.form-msg{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;display:none}
.form-msg.error{display:block;background:hsl(0,80%,95%);color:hsl(0,70%,40%)}
.form-msg.success{display:block;background:hsl(140,60%,93%);color:hsl(140,50%,30%)}
.page-hero{background:var(--brand);color:var(--white);text-align:center;padding:3.5rem 0 3rem}
.page-hero h1{color:var(--white);margin-bottom:.5rem}
.page-hero p{opacity:.85;max-width:600px;margin:0 auto}
.service-detail{max-width:1200px;margin:0 auto;padding:3rem 1.25rem}
.service-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start;margin-bottom:2.5rem}
.service-detail-grid picture,.service-detail-grid img{border-radius:var(--radius);width:100%}
.service-detail h2{margin-bottom:1rem;text-align:left}
.service-detail p{color:var(--text-light);margin-bottom:1rem;line-height:1.75}
.service-detail ul{margin:1rem 0 1.5rem 1.25rem;list-style:disc}
.service-detail ul li{color:var(--text-light);margin-bottom:.4rem}
.service-sidebar{background:var(--surface);padding:1.5rem;border-radius:var(--radius)}
.service-sidebar h3{margin-bottom:1rem;font-size:1.15rem}
.service-sidebar ul{display:flex;flex-direction:column;gap:.5rem}
.service-sidebar ul li a{display:block;padding:.6rem 1rem;border-radius:4px;font-size:.92rem;color:var(--text-main);transition:background var(--transition)}
.service-sidebar ul li a:hover,.service-sidebar ul li a.active{background:var(--brand);color:var(--white)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.blog-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform var(--transition)}
.blog-card:hover{transform:translateY(-3px)}
.blog-card picture,.blog-card img{width:100%;height:210px;object-fit:cover}
.blog-card-body{padding:1.25rem}
.blog-card-body .date{font-size:.8rem;color:var(--text-light);margin-bottom:.4rem}
.blog-card-body h3{margin-bottom:.5rem;font-size:1.15rem}
.blog-card-body h3 a{color:var(--text-main)}
.blog-card-body h3 a:hover{color:var(--brand)}
.blog-card-body p{color:var(--text-light);font-size:.9rem;margin-bottom:.75rem}
.blog-article{max-width:820px;margin:0 auto;padding:3rem 1.25rem}
.blog-article .meta{color:var(--text-light);font-size:.88rem;margin-bottom:1.5rem}
.blog-article h1{text-align:left;margin-bottom:.5rem}
.blog-article h2{text-align:left;margin-top:2rem;margin-bottom:.75rem;font-size:1.5rem}
.blog-article p{color:var(--text-light);margin-bottom:1rem;line-height:1.8}
.blog-article ul{margin:1rem 0 1.5rem 1.25rem;list-style:disc}
.blog-article ul li{color:var(--text-light);margin-bottom:.35rem;line-height:1.7}
.blog-article picture,.blog-article img{border-radius:var(--radius);margin-bottom:1.5rem;width:100%}
.blog-sidebar{background:var(--surface);padding:1.5rem;border-radius:var(--radius);margin-top:2rem}
.blog-sidebar h3{margin-bottom:1rem;font-size:1.1rem}
.blog-sidebar ul li{margin-bottom:.6rem}
.blog-sidebar ul li a{font-size:.92rem;color:var(--text-main)}
.blog-sidebar ul li a:hover{color:var(--brand)}
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;max-width:1200px;margin:0 auto;padding:3rem 1.25rem}
.policy-page{max-width:820px;margin:0 auto;padding:3rem 1.25rem}
.policy-page h1{text-align:left;margin-bottom:1.5rem}
.policy-page h2{text-align:left;margin-top:2rem;margin-bottom:.75rem;font-size:1.35rem}
.policy-page p{color:var(--text-light);margin-bottom:1rem;line-height:1.75}
.policy-page ul{margin:1rem 0 1.5rem 1.25rem;list-style:disc}
.policy-page ul li{color:var(--text-light);margin-bottom:.35rem}
.error-page{text-align:center;padding:6rem 1.25rem}
.error-page h1{font-size:5rem;color:var(--brand);margin-bottom:1rem}
.error-page p{color:var(--text-light);margin-bottom:2rem;font-size:1.15rem}
.thankyou-page{text-align:center;padding:6rem 1.25rem}
.thankyou-page h1{color:var(--brand);margin-bottom:1rem}
.thankyou-page p{color:var(--text-light);margin-bottom:2rem}
.site-footer{background:var(--text-main);color:hsl(220,10%,75%);padding:3.5rem 0 0}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--white);display:block;margin-bottom:.75rem}
.site-footer p{font-size:.88rem;line-height:1.65;margin-bottom:.5rem}
.footer-col h4{color:var(--white);font-family:'Inter',sans-serif;font-size:.95rem;font-weight:600;margin-bottom:1rem}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul li a{color:hsl(220,10%,70%);font-size:.88rem;transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--accent)}
.footer-contact a{color:hsl(220,10%,70%)}
.footer-contact a:hover{color:var(--accent)}
.footer-social{display:flex;gap:.75rem;margin-top:.75rem}
.footer-social a{color:hsl(220,10%,70%);font-size:.8rem;padding:.35rem .6rem;border:1px solid hsl(220,10%,35%);border-radius:4px;transition:all var(--transition)}
.footer-social a:hover{border-color:var(--accent);color:var(--accent)}
.footer-bottom{text-align:center;padding:1.5rem 0;margin-top:2.5rem;border-top:1px solid hsl(220,10%,28%);font-size:.82rem}
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--text-main);color:hsl(220,10%,80%);box-shadow:0 -2px 16px hsla(0,0%,0%,.2)}
.cookie-inner{max-width:1200px;margin:0 auto;padding:1.25rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.cookie-inner p{flex:1;font-size:.88rem;min-width:260px}
.cookie-actions{display:flex;gap:.75rem}
.cookie-btn{padding:.6rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.88rem;cursor:pointer;border:none;min-height:44px;min-width:44px}
.cookie-btn.accept{background:var(--accent);color:var(--text-main)}
.cookie-btn.reject{background:transparent;border:1px solid hsl(220,10%,50%);color:hsl(220,10%,80%)}
.cookie-settings-btn{position:fixed;bottom:1rem;left:1rem;z-index:150;background:var(--brand);color:var(--white);border:none;width:44px;height:44px;border-radius:50%;font-size:1.3rem;cursor:pointer;box-shadow:var(--shadow-lg);transition:transform var(--transition)}
.cookie-settings-btn:hover{transform:scale(1.1)}
@media(max-width:1039px){
.header-cta{display:none}
.main-nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--white);box-shadow:var(--shadow-lg);padding:4.5rem 1.5rem 2rem;transition:right var(--transition);z-index:90;overflow-y:auto}
.main-nav.open{right:0}
.main-nav .nav-list{flex-direction:column;gap:0}
.main-nav .nav-list li a{display:block;padding:.75rem 0;font-size:1.05rem}
.dropdown-list{position:static;box-shadow:none;padding-left:1rem;display:none}
.has-dropdown.open .dropdown-list{display:block}
.menu-toggle{display:flex}
.hero{padding:4rem 0 3.5rem}
.about-grid,.contact-grid,.service-detail-grid{grid-template-columns:1fr}
.stats-grid{grid-template-columns:repeat(2,1fr)}
.footer-inner{grid-template-columns:1fr 1fr}
.blog-layout{grid-template-columns:1fr}
}
@media(max-width:755px){
.stats-grid{grid-template-columns:1fr 1fr}
.footer-inner{grid-template-columns:1fr}
.services-grid{grid-template-columns:1fr}
.testimonials-grid{grid-template-columns:1fr}
.blog-grid{grid-template-columns:1fr}
h1{font-size:1.75rem}
h2{font-size:1.4rem}
.section{padding:3rem 0}
.hero{padding:3rem 0 2.5rem}
.hero p{font-size:1rem}
}