:root{
  --color-primary:#5C5A3D;
  --color-secondary:#E8DFC9;
  --color-accent:#A04A2E;
  --color-neutral-dark:#2A2818;
  --color-neutral-light:#F7F2E5;
  --font-heading:'Playfair Display', serif;
  --font-body:'Inter', sans-serif;
  --max-content:1100px;
}
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:var(--font-body);color:var(--color-neutral-dark);background:var(--color-neutral-light);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;height:auto;}
a{color:var(--color-accent);text-decoration:none;}
a:hover{text-decoration:underline;}
h1,h2,h3{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--color-neutral-dark);margin:0 0 1rem;}
p{margin:0 0 1rem;}

/* === Shell / sidebar layout === */
.shell{display:flex;flex-direction:column;min-height:100vh;}
.sidebar{background:var(--color-primary);color:var(--color-neutral-light);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;}
.sidebar .logo{display:inline-block;}
.sidebar .logo img{height:72px;width:auto;}
.sidebar-nav{display:flex;flex-direction:column;}
.nav-toggle{align-self:flex-start;background:transparent;border:1px solid var(--color-secondary);color:var(--color-neutral-light);padding:.5rem 1rem;border-radius:4px;font-family:var(--font-body);font-size:.95rem;cursor:pointer;}
.nav-list{list-style:none;margin:1rem 0 0;padding:0;display:none;flex-direction:column;gap:.5rem;}
.nav-list.open{display:flex;}
.nav-list a{color:var(--color-neutral-light);font-size:1.05rem;display:block;padding:.4rem 0;border-bottom:1px solid rgba(247,242,229,.15);}
.nav-list a[aria-current="page"]{color:var(--color-secondary);font-weight:500;}
.sidebar-foot{font-size:.8rem;color:rgba(247,242,229,.7);margin:auto 0 0;}
.content{flex:1;padding:0;}

@media (min-width:900px){
  .shell{flex-direction:row;}
  .sidebar{width:240px;min-height:100vh;position:sticky;top:0;height:100vh;padding:2rem 1.75rem;flex-shrink:0;}
  .sidebar .logo img{height:96px;}
  .nav-toggle{display:none;}
  .nav-list{display:flex;margin-top:2rem;}
  .content{flex:1;min-width:0;}
}

/* === Section wrapper === */
main > section{padding:3rem 1.25rem;max-width:var(--max-content);margin:0 auto;}
@media (min-width:768px){main > section{padding:5rem 2.5rem;}}

/* === Hero === */
.hero{text-align:left;}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.15em;font-size:.8rem;color:var(--color-primary);margin-bottom:1rem;}
.hero h1{font-size:clamp(2.25rem,5vw,3.75rem);max-width:18ch;}
.hero-sub{font-size:1.15rem;max-width:55ch;color:var(--color-neutral-dark);opacity:.85;margin-bottom:1.75rem;}
.hero-cta{margin-bottom:2.5rem;}
.hero-media img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:4px;font-weight:500;font-family:var(--font-body);font-size:1rem;border:1px solid transparent;cursor:pointer;text-decoration:none;}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light);}
.btn-primary:hover{background:var(--color-neutral-dark);text-decoration:none;}
.btn-accent{background:var(--color-accent);color:var(--color-neutral-light);}
.btn-accent:hover{background:var(--color-neutral-dark);text-decoration:none;}

/* === Intro paragraphs === */
.intro-text h2,.intro-grid h2{font-size:clamp(1.75rem,3.2vw,2.5rem);}
.intro-text{max-width:65ch;}
.intro-text.wide{max-width:70ch;margin:0 auto;}
.intro-text p{font-size:1.05rem;line-height:1.75;}
.intro-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;}
.intro-media img{aspect-ratio:4/3;object-fit:cover;border-radius:8px;}
@media (min-width:768px){
  .intro-grid{grid-template-columns:1.2fr 1fr;gap:4rem;}
}

/* === Section heading === */
.section-head{margin-bottom:2.5rem;max-width:60ch;}
.section-head h2{font-size:clamp(1.75rem,3.5vw,2.5rem);}
.section-sub{font-size:1.05rem;color:var(--color-primary);}

/* === Card grid === */
.card-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;}
@media (min-width:640px){.card-grid{grid-template-columns:repeat(2,1fr);}}
@media (min-width:1024px){.card-grid{grid-template-columns:repeat(4,1fr);}.card-grid.two{grid-template-columns:repeat(2,1fr);}.card-grid.three{grid-template-columns:repeat(3,1fr);}}
.card{background:var(--color-secondary);padding:1.75rem;border-radius:8px;border:1px solid rgba(42,40,24,.08);}
.card-icon{display:inline-block;font-size:1.5rem;color:var(--color-accent);margin-bottom:.75rem;}
.card h3{font-size:1.25rem;}
.card p{font-size:.95rem;line-height:1.65;margin:0;}

/* === Testimonial === */
.testimonial{background:var(--color-secondary);}
.testimonial blockquote{margin:0 auto;max-width:60ch;text-align:center;}
.testimonial blockquote p{font-family:var(--font-heading);font-size:clamp(1.35rem,2.2vw,1.65rem);line-height:1.5;font-style:italic;color:var(--color-neutral-dark);}
.testimonial cite{display:block;margin-top:1.5rem;font-family:var(--font-body);font-style:normal;font-size:.95rem;color:var(--color-primary);letter-spacing:.05em;}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);text-align:center;border-radius:0;}
.cta-band h2{color:var(--color-neutral-light);font-size:clamp(1.75rem,3.5vw,2.5rem);max-width:24ch;margin-left:auto;margin-right:auto;}
.cta-band p{max-width:50ch;margin-left:auto;margin-right:auto;opacity:.9;}

/* === Service blocks === */
.service-block{}
.service-block.alt{background:var(--color-secondary);max-width:none;}
.service-block.alt > .service-grid{max-width:var(--max-content);margin:0 auto;}
.service-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;}
.service-grid h2{font-size:clamp(1.75rem,3.2vw,2.5rem);}
.service-sub{font-size:1.1rem;color:var(--color-primary);max-width:50ch;}
.service-grid figure{margin:0;}
.service-grid figure img{aspect-ratio:4/3;object-fit:cover;border-radius:8px;}
@media (min-width:768px){
  .service-grid{grid-template-columns:1.1fr 1fr;gap:4rem;}
  .service-grid.reverse > div{order:2;}
  .service-grid.reverse > figure{order:1;}
}

/* === FAQ === */
.faq details{border-bottom:1px solid rgba(42,40,24,.15);padding:1.25rem 0;}
.faq summary{font-family:var(--font-heading);font-size:1.2rem;cursor:pointer;list-style:none;color:var(--color-neutral-dark);padding-right:2rem;position:relative;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:'+';position:absolute;right:0;top:0;font-family:var(--font-body);color:var(--color-accent);font-size:1.5rem;line-height:1;}
.faq details[open] summary::after{content:'−';}
.faq details p{margin-top:1rem;font-size:1rem;line-height:1.7;color:var(--color-neutral-dark);}

/* === Contact card === */
.contact-card-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:2.5rem;}
@media (min-width:768px){.contact-card-grid{grid-template-columns:1fr 1fr;gap:4rem;}}
.contact-block address{font-style:normal;}
.hours-table{width:100%;border-collapse:collapse;}
.hours-table th,.hours-table td{text-align:left;padding:.55rem 0;border-bottom:1px solid rgba(42,40,24,.12);font-weight:400;}
.hours-table th{color:var(--color-primary);}
.map-block{background:var(--color-secondary);border-radius:8px;padding:3rem 1rem;text-align:center;color:var(--color-primary);}
.map-marker{display:block;font-size:2.5rem;color:var(--color-accent);margin-bottom:.5rem;}

/* === Enquiry form === */
.enquiry-form{max-width:560px;}
.form-row{display:flex;flex-direction:column;margin-bottom:1.25rem;}
.form-row label{font-size:.9rem;color:var(--color-primary);margin-bottom:.4rem;letter-spacing:.02em;}
.form-row input,.form-row textarea{font-family:var(--font-body);font-size:1rem;padding:.75rem .9rem;border:1px solid rgba(42,40,24,.25);border-radius:4px;background:var(--color-neutral-light);color:var(--color-neutral-dark);}
.form-row input:focus,.form-row textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3rem 1.25rem 2rem;}
.site-footer{max-width:none;}
.footer-grid{max-width:var(--max-content);margin:0 auto;display:grid;grid-template-columns:1fr;gap:2rem;}
@media (min-width:768px){.footer-grid{grid-template-columns:1.2fr 1fr 1.4fr;gap:3rem;padding:0 2.5rem;}}
.footer-brand{font-family:var(--font-heading);font-size:1.35rem;margin-bottom:.5rem;}
.footer-nav{list-style:none;padding:0;margin:0;}
.footer-nav li{margin-bottom:.5rem;}
.footer-nav a,.footer-contact a{color:var(--color-secondary);}
.footer-contact{font-style:normal;font-size:.95rem;}
.footer-contact p{margin-bottom:.5rem;}
.legal-links{margin-top:1rem;font-size:.85rem;}
.copyright{max-width:var(--max-content);margin:2rem auto 0;padding:1.5rem 0 0;border-top:1px solid rgba(247,242,229,.15);font-size:.85rem;color:rgba(247,242,229,.65);text-align:center;}
@media (min-width:768px){.copyright{padding:1.5rem 2.5rem 0;}}

/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:1rem 1.25rem;border-radius:8px;box-shadow:0 20px 40px -20px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:.75rem;z-index:1000;font-size:.9rem;}
.cookie-banner p{margin:0;}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-light);border:none;padding:.6rem 1.2rem;border-radius:4px;font-family:var(--font-body);font-size:.95rem;cursor:pointer;align-self:flex-start;}
.cookie-banner button:hover{background:var(--color-primary);}
body.cookies-accepted .cookie-banner{display:none;}
@media (min-width:640px){
  .cookie-banner{flex-direction:row;align-items:center;justify-content:space-between;left:auto;right:1.5rem;bottom:1.5rem;max-width:480px;}
  .cookie-banner button{align-self:auto;flex-shrink:0;}
}
