:root{
  --color-primary:#A04A2E;
  --color-secondary:#F0E0C0;
  --color-accent:#3D5A47;
  --color-neutral-dark:#2A1F18;
  --color-neutral-light:#FBF5E8;
  --font-heading:'Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --radius:12px;
  --radius-lg:24px;
  --shadow-card:0 8px 24px -16px rgba(42,31,24,.25);
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box}
body,h1,h2,h3,p,ul,figure,blockquote{margin:0}
ul{padding:0;list-style:none}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}

/* === Base === */
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--color-neutral-dark);
  background:var(--color-neutral-light);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--color-neutral-dark)}
h1{font-size:clamp(2.25rem,5vw,3.75rem);letter-spacing:-.02em}
h2{font-size:clamp(1.625rem,3vw,2.25rem);letter-spacing:-.01em}
h3{font-size:1.25rem}
p{max-width:65ch}

/* === Layout (sidebar) === */
.layout{display:flex;flex-direction:column;min-height:100vh}
.sidebar{
  background:var(--color-secondary);
  padding:1.25rem 1.5rem;
  border-bottom:1px solid rgba(42,31,24,.08);
  display:flex;align-items:center;gap:1rem;justify-content:space-between;
  flex-wrap:wrap;
  position:sticky;top:0;z-index:30;
}
.logo img{height:72px;width:auto;display:block}
.sidebar-nav{flex:1 1 100%}
.nav-toggle{
  display:inline-block;padding:.5rem .9rem;background:var(--color-neutral-dark);
  color:var(--color-neutral-light);border-radius:999px;font-weight:500;font-size:.9rem;
}
.sidebar-nav ul{display:none;flex-direction:column;gap:.5rem;margin-top:1rem}
.sidebar-nav[data-open="true"] ul{display:flex}
.sidebar-nav a{
  display:block;padding:.65rem .85rem;border-radius:8px;font-weight:500;color:var(--color-neutral-dark);
}
.sidebar-nav a:hover,.sidebar-nav a[aria-current="page"]{
  background:var(--color-neutral-light);color:var(--color-primary);
}
.sidebar-foot{display:none;font-size:.85rem;color:var(--color-neutral-dark);opacity:.7}
.content{flex:1;padding:2rem 1.25rem 0}

/* === Hero === */
.hero{padding-block:2.5rem 3rem;max-width:1100px;margin-inline:auto}
.eyebrow{
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:600;
  color:var(--color-primary);margin-bottom:1rem;
}
.hero h1{max-width:18ch;margin-bottom:1.25rem}
.hero .sub{font-size:1.125rem;color:rgba(42,31,24,.78);max-width:52ch;margin-bottom:1.5rem}
.cta-row{margin-bottom:2.5rem}
.hero-img{width:100%;border-radius:var(--radius);aspect-ratio:16/9;object-fit:cover;box-shadow:var(--shadow-card)}

/* === Buttons === */
.btn{
  display:inline-block;padding:.85rem 1.5rem;border-radius:999px;
  font-weight:600;font-size:1rem;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn-primary:hover{background:#8a3e26;transform:translateY(-1px);box-shadow:0 10px 24px -14px rgba(160,74,46,.6)}
.btn-light{background:var(--color-neutral-light);color:var(--color-neutral-dark)}
.btn-light:hover{background:#fff}

/* === Intro === */
.intro{
  display:grid;grid-template-columns:1fr;gap:2rem;
  padding-block:3rem;max-width:1100px;margin-inline:auto;align-items:center;
}
.intro-text h2{margin-bottom:1rem}
.intro-img{border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-card)}

/* === Section head === */
.section-head{text-align:center;max-width:62ch;margin:0 auto 2.5rem}
.section-head h2{margin-bottom:.75rem}
.section-head p{margin-inline:auto;color:rgba(42,31,24,.72)}

/* === Highlights / cards === */
.highlights{padding-block:3rem;max-width:1200px;margin-inline:auto}
.grid{display:grid;gap:1.25rem}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
.card{
  background:var(--color-neutral-light);
  border:1px solid rgba(42,31,24,.08);
  border-radius:var(--radius);padding:1.75rem;
  box-shadow:var(--shadow-card);
  transition:transform .15s ease,box-shadow .15s ease;
}
.card:hover{transform:translateY(-2px)}
.card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:2.5rem;height:2.5rem;border-radius:10px;
  background:var(--color-secondary);color:var(--color-primary);
  font-size:1.25rem;margin-bottom:1rem;
}
.card h3{margin-bottom:.5rem}
.card p{font-size:.97rem;color:rgba(42,31,24,.8)}

/* === Testimonial === */
.testimonial{
  padding-block:3.5rem;max-width:820px;margin-inline:auto;text-align:center;
}
.testimonial blockquote{position:relative;padding:0 1rem}
.testimonial p{
  font-size:1.25rem;line-height:1.55;font-style:italic;
  color:var(--color-neutral-dark);margin-inline:auto;
}
.testimonial cite{
  display:block;margin-top:1.25rem;font-style:normal;font-weight:600;
  color:var(--color-primary);font-size:.95rem;
}

/* === CTA band === */
.cta-band{
  background:var(--color-primary);color:var(--color-neutral-light);
  text-align:center;padding:3rem 1.5rem;border-radius:var(--radius-lg);
  max-width:1100px;margin:3rem auto;
}
.cta-band h2{color:var(--color-neutral-light);margin-bottom:.75rem}
.cta-band p{margin:0 auto 1.5rem;color:rgba(251,245,232,.9)}

/* === Stats === */
.stats{padding-block:3rem;max-width:1100px;margin-inline:auto}
.stats-grid{text-align:center}
.stat{padding:1.5rem}
.stat-num{
  display:block;font-family:var(--font-heading);font-weight:700;
  font-size:clamp(2rem,4vw,2.75rem);color:var(--color-accent);margin-bottom:.5rem;
  letter-spacing:-.02em;
}
.stat p{color:rgba(42,31,24,.78);margin-inline:auto;max-width:32ch}

/* === FAQ === */
.faq{padding-block:3rem;max-width:820px;margin-inline:auto}
.faq details{
  border:1px solid rgba(42,31,24,.12);
  border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:.75rem;
  background:var(--color-neutral-light);
}
.faq summary{font-weight:600;cursor:pointer;padding:.25rem 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--color-primary);font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:.75rem;color:rgba(42,31,24,.8)}

/* === Pricing === */
.pricing{padding-block:3rem;max-width:1200px;margin-inline:auto}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.pricing-card{
  position:relative;background:var(--color-neutral-light);
  border:1px solid rgba(42,31,24,.12);border-radius:16px;padding:2.25rem;
  display:flex;flex-direction:column;
}
.pricing-card--featured{border-color:var(--color-accent);border-width:2px;box-shadow:0 20px 50px -28px rgba(61,90,71,.5)}
.pricing-card__badge{
  position:absolute;top:-.75rem;right:1.5rem;
  background:var(--color-accent);color:var(--color-neutral-light);
  padding:.35rem .8rem;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:.04em;
}
.pricing-card__plan{font-size:1.1rem;color:var(--color-primary);margin-bottom:.5rem}
.pricing-card__price{font-size:clamp(2rem,4vw,2.75rem);font-weight:700;line-height:1.1;margin-bottom:.75rem}
.pricing-card__lede{color:rgba(42,31,24,.75);margin-bottom:1.25rem;font-size:.97rem}
.pricing-card__features{margin-bottom:1.75rem;flex:1}
.pricing-card__features li{display:flex;gap:.5rem;align-items:flex-start;padding:.4rem 0;font-size:.95rem;border-bottom:1px solid rgba(42,31,24,.06)}
.pricing-card__features li:last-child{border-bottom:0}
.pricing-card__features span{color:var(--color-accent);font-weight:700;flex-shrink:0}
.pricing-card__cta{align-self:stretch;text-align:center}

/* === Contact === */
.contact-card{
  display:grid;grid-template-columns:1fr;gap:2rem;
  padding-block:3rem;max-width:1000px;margin-inline:auto;
}
.contact-info address,.contact-hours table{font-style:normal;line-height:1.8}
.contact-info h2,.contact-hours h2{margin-bottom:1rem}
.contact-hours table{width:100%;border-collapse:collapse}
.contact-hours th{text-align:left;font-weight:500;padding:.5rem 0;color:var(--color-neutral-dark)}
.contact-hours td{text-align:right;padding:.5rem 0;color:rgba(42,31,24,.78)}
.contact-hours tr{border-bottom:1px solid rgba(42,31,24,.08)}
.contact-form-section{padding-block:3rem;max-width:680px;margin-inline:auto}
.contact-form label{display:block;font-weight:500;margin-bottom:.35rem;font-size:.92rem}
.contact-form input,.contact-form textarea{
  width:100%;padding:.75rem .9rem;border:1px solid rgba(42,31,24,.18);
  border-radius:8px;background:var(--color-neutral-light);font:inherit;color:var(--color-neutral-dark);
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:2px solid var(--color-primary);outline-offset:1px;border-color:var(--color-primary);
}
.contact-form p{margin-bottom:1.25rem;max-width:none}

/* === Footer === */
.site-footer{
  background:var(--color-neutral-dark);color:var(--color-neutral-light);
  margin-top:4rem;padding:3rem 1.5rem 2rem;
}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:2rem;
  max-width:1100px;margin-inline:auto;
}
.site-footer h2{font-size:1rem;color:var(--color-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.08em}
.site-footer a{color:var(--color-neutral-light)}
.site-footer a:hover{color:var(--color-secondary)}
.site-footer address{font-style:normal;line-height:1.7;margin-bottom:1rem;color:rgba(251,245,232,.85)}
.site-footer .legal li{padding:.2rem 0;font-size:.9rem}
.logo-footer img{height:56px;filter:brightness(0) invert(1)}
.copy{
  text-align:center;margin-top:2.5rem;padding-top:1.5rem;
  border-top:1px solid rgba(251,245,232,.15);font-size:.85rem;color:rgba(251,245,232,.7);
}

/* === Cookie banner === */
.cookie-banner{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:50;
  background:var(--color-neutral-dark);color:var(--color-neutral-light);
  padding:1rem 1.25rem;border-radius:var(--radius);
  display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.4);
  max-width:560px;
}
.cookie-banner p{font-size:.9rem;margin:0;color:rgba(251,245,232,.9)}
.cookie-banner button{
  background:var(--color-accent);color:var(--color-neutral-light);
  padding:.55rem 1.1rem;border-radius:999px;font-weight:600;font-size:.9rem;
}
.cookie-banner button:hover{background:#2f4737}
body.cookies-accepted .cookie-banner{display:none}

/* === Desktop === */
@media (min-width:768px){
  .logo img{height:96px}
  .grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem}
  .grid-4{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .intro{grid-template-columns:1.1fr 1fr;gap:3rem;padding-block:4rem}
  .intro-reverse .intro-text{order:2}
  .intro-reverse .intro-img{order:1}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1.4fr 1fr 1.2fr;gap:3rem}
  .contact-card{grid-template-columns:1fr 1fr;gap:3rem}
  .cookie-banner{flex-direction:row;align-items:center;left:auto;right:1.5rem;bottom:1.5rem}
}

@media (min-width:900px){
  .layout{flex-direction:row}
  .sidebar{
    position:sticky;top:0;height:100vh;
    width:240px;flex-direction:column;justify-content:flex-start;align-items:stretch;
    padding:2rem 1.5rem;border-bottom:0;border-right:1px solid rgba(42,31,24,.08);
    flex-shrink:0;
  }
  .sidebar-nav{flex:1 1 auto;width:100%;margin-top:2rem}
  .nav-toggle{display:none}
  .sidebar-nav ul{display:flex;margin-top:0}
  .sidebar-foot{display:block;margin-top:auto;padding-top:2rem}
  .content{padding:3rem 3rem 0;flex:1;min-width:0}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .pricing-grid{grid-template-columns:repeat(3,1fr)}
  .hero{padding-block:4rem 4rem}
}

@media (min-width:1100px){
  .content{padding:4rem 4rem 0}
}
