:root{
  --color-primary:#1A1F2E;
  --color-secondary:#F5E8DD;
  --color-accent:#E07A5F;
  --color-neutral-dark:#0F1320;
  --color-neutral-light:#FAF0E8;
  --font-heading:'Lora', serif;
  --font-body:'Source Sans 3', sans-serif;
  --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:1rem;line-height:1.65;color:var(--color-neutral-dark);background:var(--color-neutral-light)}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--font-heading);font-weight:600;color:var(--color-primary);line-height:1.2;margin:0 0 .75rem}
h1{font-size:clamp(2.25rem,5vw,4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}

/* === Header === */
.site-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;padding:1rem 1.25rem;background:var(--color-neutral-light);border-bottom:1px solid rgba(26,31,46,.08);position:sticky;top:0;z-index:50}
.logo{display:inline-block;line-height:0}
.logo img{height:72px;width:auto}
.site-nav{display:none;gap:1.5rem;width:100%;margin-top:.75rem;flex-direction:column}
.site-nav.is-open{display:flex}
.site-nav a{color:var(--color-primary);font-weight:600;font-size:1rem}
.site-nav a[aria-current=page]{color:var(--color-accent)}
.nav-toggle{background:none;border:1px solid var(--color-primary);color:var(--color-primary);padding:.4rem .7rem;border-radius:6px;font-size:1.1rem;cursor:pointer}
@media (min-width:768px){
  .logo img{height:96px}
  .nav-toggle{display:none}
  .site-nav{display:flex;flex-direction:row;width:auto;margin:0;gap:2rem}
}

/* === Hero centered === */
.hero{padding:4rem 1.25rem 3rem;text-align:center;max-width:var(--maxw);margin:0 auto}
.hero .eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;color:var(--color-accent);margin-bottom:1rem;font-weight:600}
.hero h1{max-width:28ch;margin-inline:auto}
.hero__sub{max-width:48ch;margin:1rem auto 2rem;color:#3a3f4d;font-size:1.15rem}
.hero__media{margin:3rem auto 0;max-width:var(--maxw)}
.hero__media img{width:100%;border-radius:14px;aspect-ratio:16/9;object-fit:cover}
@media (min-width:768px){
  .hero{padding-block:6rem 4rem}
}

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

/* === Sections === */
.section{padding:4rem 1.25rem;max-width:var(--maxw);margin:0 auto}
.section--narrow{max-width:720px}
.section__title{text-align:center;margin-bottom:2rem}
.section--narrow .section__title{text-align:left}
.section--narrow p{font-size:1.1rem;line-height:1.75}

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

/* === Cards === */
.card{background:var(--color-secondary);padding:1.75rem;border-radius:12px;border:1px solid rgba(26,31,46,.06)}
.card__icon{display:inline-block;font-size:1.6rem;margin-bottom:.75rem;color:var(--color-accent)}
.card h3{margin-bottom:.5rem}
.card p{margin:0;color:#3a3f4d}
.card-link{display:block;color:inherit;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease}
.card-link:hover{transform:translateY(-2px);box-shadow:0 14px 28px -16px rgba(26,31,46,.35);text-decoration:none}
.card-link h3{color:var(--color-primary)}

/* === Testimonial === */
.testimonial-section{text-align:center}
.testimonial{max-width:780px;margin:0 auto;font-family:var(--font-heading);font-size:1.4rem;line-height:1.5;color:var(--color-primary);position:relative;padding:2rem 1rem}
.testimonial p{margin-bottom:1.25rem}
.testimonial cite{font-family:var(--font-body);font-style:normal;font-size:.95rem;color:var(--color-accent);font-weight:600}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);padding:4rem 1.25rem;text-align:center}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{max-width:50ch;margin:.5rem auto 1.5rem;color:#cdd1dc}

/* === Article === */
.article{max-width:65ch;margin-inline:auto;padding:3rem 1.25rem}
.article .eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--color-accent);font-weight:600;margin-bottom:.5rem}
.article h1{font-size:clamp(2rem,4vw,3rem);line-height:1.15;margin-bottom:1.25rem}
.article__sub{font-size:1.2rem;color:#3a3f4d;margin-bottom:1rem}
.article__hero{aspect-ratio:16/9;object-fit:cover;width:100%;border-radius:8px;margin-block:2rem}
.article p{font-size:1.125rem;line-height:1.75;margin-block:1.25rem}
.article h2{margin-top:2.5rem}
.back{margin-top:3rem}
.back-link{font-weight:600}

/* === Contact === */
.contact-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media (min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.hours{width:100%;border-collapse:collapse}
.hours th,.hours td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid rgba(26,31,46,.1)}
.hours th{font-weight:600;color:var(--color-primary);width:40%}
.contact-form{display:grid;gap:1rem;max-width:640px}
.contact-form label{display:flex;flex-direction:column;font-weight:600;color:var(--color-primary);font-size:.95rem;gap:.4rem}
.contact-form input,.contact-form textarea{font:inherit;padding:.7rem .9rem;border:1px solid rgba(26,31,46,.2);border-radius:6px;background:#fff;font-weight:400;color:var(--color-neutral-dark)}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}
.contact-form button{justify-self:start}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:#cdd1dc;padding:3rem 1.25rem 1.5rem;margin-top:4rem}
.footer-grid{display:grid;gap:2rem;max-width:var(--maxw);margin:0 auto;grid-template-columns:1fr}
.site-footer h3{color:var(--color-neutral-light);font-size:1.05rem;margin-bottom:.75rem}
.site-footer a{color:#cdd1dc;display:block;margin-bottom:.35rem}
.site-footer a:hover{color:var(--color-accent)}
.site-footer address{font-style:normal;line-height:1.7}
.legal-links{margin-top:1rem;font-size:.9rem}
.legal-links a{display:inline}
.logo--footer img{height:64px}
.copyright{text-align:center;font-size:.85rem;color:#8a8e99;margin-top:2rem;border-top:1px solid rgba(255,255,255,.08);padding-top:1.25rem}
@media (min-width:768px){.footer-grid{grid-template-columns:1.2fr 1fr 1.4fr}}

/* === 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:10px;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;box-shadow:0 20px 40px -15px rgba(0,0,0,.4);z-index:100;max-width:540px;margin-inline:auto}
.cookie-banner p{margin:0;font-size:.95rem}
.cookie-banner button{background:var(--color-accent);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:6px;font:inherit;font-weight:600;cursor:pointer}
.cookie-banner button:hover{filter:brightness(1.05)}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between;left:auto;right:1rem;bottom:1rem}}
