:root{
  --color-primary:#4A5A60;
  --color-secondary:#DEE5DF;
  --color-accent:#6FA88A;
  --color-neutral-dark:#1A2024;
  --color-neutral-light:#F7FAF7;
  --font-heading:'Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --radius:12px;
  --shadow:0 18px 40px -24px rgba(26,32,36,.25);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--color-neutral-dark);background:var(--color-neutral-light);-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-heading);color:var(--color-neutral-dark);line-height:1.2;margin:0 0 .75rem}
h1{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3vw,2.25rem);font-weight:600;letter-spacing:-.01em}
h3{font-size:1.15rem;font-weight:600}
p{margin:0 0 1rem}
a{color:var(--color-primary)}
img{max-width:100%;height:auto;display:block}

/* === Layout (sidebar + content) === */
.layout{display:block;min-height:100vh}
.sidebar{background:var(--color-secondary);padding:1.25rem 1.25rem;display:flex;flex-direction:column;gap:1rem;border-bottom:1px solid rgba(26,32,36,.08)}
.logo{display:inline-block}
.logo img{height:72px;width:auto;display:block}
.sidebar-nav{display:flex;flex-direction:column}
.nav-toggle{display:inline-block;align-self:flex-start;background:var(--color-primary);color:var(--color-neutral-light);border:0;border-radius:8px;padding:.5rem 1rem;font:600 .95rem var(--font-body);cursor:pointer}
.sidebar-nav ul{list-style:none;padding:0;margin:1rem 0 0;display:none;flex-direction:column;gap:.25rem}
.sidebar-nav ul.open{display:flex}
.sidebar-nav a{display:block;padding:.65rem .75rem;border-radius:8px;text-decoration:none;color:var(--color-neutral-dark);font-weight:500}
.sidebar-nav a:hover,.sidebar-nav a[aria-current="page"]{background:var(--color-neutral-light);color:var(--color-primary)}
.sidebar-foot{font-size:.8rem;color:var(--color-primary);margin:0}
.content{padding:1.5rem 1.25rem 0}

@media (min-width:900px){
  .layout{display:grid;grid-template-columns:240px 1fr}
  .sidebar{position:sticky;top:0;height:100vh;padding:2rem 1.5rem;border-bottom:0;border-right:1px solid rgba(26,32,36,.08);justify-content:flex-start}
  .logo img{height:96px}
  .nav-toggle{display:none}
  .sidebar-nav ul{display:flex;margin-top:2rem}
  .sidebar-foot{margin-top:auto}
  .content{padding:3rem 3rem 0}
}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:8px;font-weight:600;text-decoration:none;border:0;cursor:pointer;font:600 1rem var(--font-body);transition:transform .15s ease,box-shadow .15s ease}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn-accent{background:var(--color-accent);color:var(--color-neutral-light)}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}

/* === Hero === */
.hero{padding:2rem 0 3rem;max-width:980px}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;font-weight:600;color:var(--color-accent);margin:0 0 1rem}
.hero-sub{font-size:clamp(1.05rem,1.4vw,1.25rem);color:var(--color-primary);max-width:55ch;margin:0 0 1.75rem}
.hero-cta{margin:0 0 2.5rem}
.hero-image{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}

/* === Sections === */
.section{padding:3rem 0;max-width:1100px}
.section.narrow{max-width:760px}
.section-sub{color:var(--color-primary);max-width:60ch;margin:0 0 2rem;font-size:1.05rem}

/* === Grids === */
.grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media (min-width:640px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

.card{background:#fff;border:1px solid rgba(26,32,36,.08);border-radius:var(--radius);padding:1.5rem;transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.card-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--color-secondary);color:var(--color-primary);font-size:1.25rem;margin-bottom:.75rem}
.card h3{margin-bottom:.5rem}
.card p{color:var(--color-primary);margin:0;font-size:.97rem}

/* === Pricing === */
.pricing-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media (min-width:900px){.pricing-grid{grid-template-columns:repeat(3,1fr);align-items:stretch}}
.pricing-card{position:relative;background:var(--color-neutral-light);border:1px solid rgba(26,32,36,.12);border-radius:16px;padding:2.25rem;display:flex;flex-direction:column}
.pricing-card--featured{border-color:var(--color-accent);border-width:2px;background:#fff}
.pricing-card__badge{position:absolute;top:1rem;right:1rem;background:var(--color-accent);color:var(--color-neutral-light);font-size:.75rem;font-weight:600;padding:.3rem .6rem;border-radius:999px;letter-spacing:.05em;text-transform:uppercase}
.pricing-card__plan{font-size:1.25rem;margin-bottom:.25rem}
.pricing-card__price{font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--color-neutral-dark);margin:0 0 1rem;line-height:1.1}
.pricing-card__lede{color:var(--color-primary);font-size:.95rem;margin:0 0 1.25rem}
.pricing-card__features{list-style:none;padding:0;margin:0 0 1.75rem;flex:1}
.pricing-card__features li{display:flex;gap:.5rem;align-items:flex-start;padding:.4rem 0;font-size:.95rem;color:var(--color-neutral-dark);border-bottom:1px solid rgba(26,32,36,.06)}
.pricing-card__features li span{color:var(--color-accent);font-weight:700}
.pricing-card__cta{align-self:stretch;text-align:center}

/* === Testimonial === */
.testimonial-section{display:flex;justify-content:center}
.testimonial{max-width:760px;margin:0;padding:2.5rem 1.5rem;text-align:center;border-top:1px solid rgba(26,32,36,.08);border-bottom:1px solid rgba(26,32,36,.08)}
.testimonial p{font-size:clamp(1.1rem,1.8vw,1.4rem);line-height:1.5;color:var(--color-neutral-dark);font-style:italic}
.testimonial cite{display:block;margin-top:1rem;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);border-radius:var(--radius);padding:3rem 1.75rem;text-align:center;margin:3rem 0}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{color:var(--color-secondary);max-width:55ch;margin-left:auto;margin-right:auto}
.cta-band .btn-accent{margin-top:1rem}

/* === FAQ === */
.faq{max-width:780px}
.faq details{border:1px solid rgba(26,32,36,.08);border-radius:10px;padding:1rem 1.25rem;margin-bottom:.75rem;background:#fff}
.faq summary{cursor:pointer;font-weight:600;color:var(--color-neutral-dark);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--color-accent);font-weight:700}
.faq details[open] summary::after{content:"−"}
.faq details p{margin:.75rem 0 0;color:var(--color-primary)}

/* === Contact === */
.contact-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media (min-width:800px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-card{background:#fff;border:1px solid rgba(26,32,36,.08);border-radius:var(--radius);padding:1.75rem}
.contact-card h3{margin-top:1rem}
.contact-card h3:first-child{margin-top:0}
.contact-card a{color:var(--color-primary);text-decoration:none}
.contact-card a:hover{color:var(--color-accent)}
.hours{width:100%;border-collapse:collapse;font-size:.95rem}
.hours th,.hours td{text-align:left;padding:.5rem 0;border-bottom:1px solid rgba(26,32,36,.06);font-weight:400;color:var(--color-primary)}
.hours th{font-weight:600;color:var(--color-neutral-dark)}

.contact-form{max-width:640px;display:flex;flex-direction:column;gap:1rem}
.form-row{display:flex;flex-direction:column;gap:.35rem}
.form-row label{font-weight:600;font-size:.9rem;color:var(--color-neutral-dark)}
.form-row input,.form-row textarea{padding:.75rem;border:1px solid rgba(26,32,36,.15);border-radius:8px;font:400 1rem var(--font-body);background:#fff;color:var(--color-neutral-dark)}
.form-row input:focus,.form-row textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}
.contact-form .btn{align-self:flex-start}

/* === Footer === */
.site-footer{margin-top:4rem;padding:3rem 0 1.5rem;border-top:1px solid rgba(26,32,36,.08)}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media (min-width:800px){.footer-grid{grid-template-columns:1.2fr 1fr 1.2fr}}
.footer-brand{font-family:var(--font-heading);font-weight:700;font-size:1.15rem;margin-bottom:.25rem}
.site-footer nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.site-footer nav a{color:var(--color-primary);text-decoration:none}
.site-footer nav a:hover{color:var(--color-accent)}
.site-footer p{margin:0 0 .3rem;color:var(--color-primary);font-size:.95rem}
.footer-legal{margin-top:.75rem!important;font-size:.85rem}
.footer-legal a{color:var(--color-primary);text-decoration:underline}
.copyright{text-align:center;font-size:.85rem;color:var(--color-primary);margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(26,32,36,.06)}

/* === 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:12px;box-shadow:0 18px 40px -10px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:.75rem;z-index:100;max-width:560px;margin-left:auto;margin-right:auto}
.cookie-banner p{margin:0;font-size:.92rem;line-height:1.5}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-light);border:0;border-radius:8px;padding:.6rem 1.25rem;font:600 .95rem var(--font-body);cursor:pointer;align-self:flex-start}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between}}
