/* === Tokens === */
:root{
  --color-primary:#2C4A6E;
  --color-secondary:#F0E8D8;
  --color-accent:#B86B33;
  --color-neutral-dark:#162033;
  --color-neutral-light:#FBF8F0;
  --font-heading:'Lora',serif;
  --font-body:'Source Sans 3',sans-serif;
  --radius:12px;
  --maxw:1180px;
}

/* === Reset === */
*,*::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.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600;color:var(--color-neutral-dark);line-height:1.2;margin:0 0 .6em}
h1{font-size:clamp(2.25rem,5vw,4rem);letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}

/* === Header === */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;max-width:var(--maxw);margin-inline:auto;flex-wrap:wrap}
.logo{display:inline-block}
.logo img{height:72px;width:auto;vertical-align:middle}
.primary-nav{position:relative}
.nav-toggle{display:inline-block;background:transparent;border:1px solid var(--color-neutral-dark);color:var(--color-neutral-dark);padding:.45rem .9rem;border-radius:6px;font:600 .95rem var(--font-body);cursor:pointer}
.primary-nav ul{display:none;list-style:none;margin:0;padding:1rem 0 0;flex-direction:column;gap:.65rem;width:100%}
.primary-nav.is-open ul{display:flex}
.primary-nav a{color:var(--color-neutral-dark);font-weight:600;font-size:1rem}
.primary-nav a[aria-current="page"]{color:var(--color-accent)}

@media(min-width:768px){
  .nav-toggle{display:none}
  .primary-nav ul{display:flex!important;flex-direction:row;gap:1.75rem;padding:0;width:auto}
  .logo img{height:96px}
}

/* === Hero — centered === */
.hero{text-align:center;padding:3.5rem 1.5rem 2rem;max-width:var(--maxw);margin-inline:auto}
.eyebrow{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);font-weight:600;margin-bottom:1rem}
.hero h1{max-width:28ch;margin-inline:auto}
.hero__sub{max-width:52ch;margin:1rem auto 1.75rem;font-size:1.125rem;color:#3b4a63}
.hero__cta{margin-bottom:2.5rem}
.hero__image{margin:0;border-radius:var(--radius);overflow:hidden}
.hero__image img{width:100%;aspect-ratio:16/9;object-fit:cover}
@media(min-width:768px){
  .hero{padding:5.5rem 2rem 3rem}
  .hero__image img{aspect-ratio:21/9}
}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:8px;font-weight:600;font-family:var(--font-body);font-size:1rem;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 8px 18px -10px rgba(22,32,51,.4)}
.btn--primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn--accent{background:var(--color-accent);color:var(--color-neutral-light)}

/* === Section === */
.section{padding:3.5rem 1.5rem;max-width:var(--maxw);margin-inline:auto}
.section--narrow{max-width:760px;text-align:left}
.section--narrow h2{text-align:left;max-width:30ch}
.section--soft{background:var(--color-secondary);max-width:none}
.section--soft > *{max-width:var(--maxw);margin-inline:auto}
.section--soft h2{text-align:center}
.section__sub{text-align:center;max-width:60ch;margin:0 auto 2rem;color:#3b4a63}
.section__image{margin:0 0 1.75rem;border-radius:var(--radius);overflow:hidden}
.section__image img{width:100%;aspect-ratio:16/9;object-fit:cover}

@media(min-width:768px){
  .section{padding:5rem 2rem}
}

/* === Cards grid === */
.grid--cards{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:640px){.grid--cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.grid--cards{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--color-neutral-light);border:1px solid rgba(22,32,51,.08);border-radius:var(--radius);padding:1.75rem;box-shadow:0 1px 2px rgba(22,32,51,.04)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--color-secondary);color:var(--color-primary);font-size:1.25rem;margin-bottom:1rem}
.card h3{margin-bottom:.5rem;color:var(--color-primary)}
.card p{color:#33405a;font-size:.98rem;margin:0}

/* === Testimonial === */
.section--quote{text-align:center;max-width:820px;padding-block:4rem}
.section--quote blockquote{margin:0;font-family:var(--font-heading);font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.45;color:var(--color-neutral-dark)}
.section--quote blockquote p{margin-bottom:1.25rem;font-style:italic}
.section--quote cite{font-style:normal;font-family:var(--font-body);font-size:.95rem;color:var(--color-accent);letter-spacing:.05em;text-transform:uppercase}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);text-align:center;padding:4rem 1.5rem}
.cta-band h2{color:var(--color-neutral-light);max-width:30ch;margin-inline:auto}
.cta-band p{max-width:54ch;margin:1rem auto 1.5rem;color:#dde6f1}

/* === FAQ === */
.faq details{border-bottom:1px solid rgba(22,32,51,.12);padding:1.1rem 0}
.faq summary{cursor:pointer;font-weight:600;font-family:var(--font-heading);font-size:1.1rem;color:var(--color-primary);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';float:right;font-weight:400;font-size:1.4rem;color:var(--color-accent);transition:transform .2s ease}
.faq details[open] summary::after{content:'–'}
.faq details p{margin-top:.85rem;color:#33405a}

/* === Contact form === */
.contact-form{display:grid;gap:1.1rem;max-width:560px}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:600;font-size:.95rem}
.field input,.field textarea{font:inherit;padding:.7rem .85rem;border:1px solid rgba(22,32,51,.2);border-radius:8px;background:#fff;color:var(--color-neutral-dark)}
.field input:focus,.field textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:#cdd5e1;padding:3.5rem 1.5rem 1.5rem;margin-top:3rem}
.footer__cols{display:grid;gap:2.25rem;grid-template-columns:1fr;max-width:var(--maxw);margin-inline:auto}
@media(min-width:768px){.footer__cols{grid-template-columns:1.2fr 1fr 1.4fr}}
.site-footer h4{color:var(--color-neutral-light);font-size:1rem;margin-bottom:.85rem}
.site-footer a{color:#cdd5e1}
.site-footer a:hover{color:var(--color-neutral-light)}
.logo--footer img{height:56px;filter:brightness(0) invert(1)}
.footer__tagline{margin-top:1rem;color:#9aa6b9;font-style:italic;max-width:30ch}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}
.site-footer address{font-style:normal;line-height:1.7;margin-bottom:1rem}
.footer__legal{margin-top:1rem;font-size:.9rem}
.footer__copy{text-align:center;margin:2.5rem 0 0;font-size:.85rem;color:#7c8aa1;border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;max-width:var(--maxw);margin-inline:auto}

/* === 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;display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;box-shadow:0 20px 40px -20px rgba(0,0,0,.5);z-index:50;font-size:.92rem}
.cookie-banner p{margin:0;max-width:60ch;color:#dde6f1}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-light);border:none;padding:.6rem 1.2rem;border-radius:6px;font:600 .95rem var(--font-body);cursor:pointer}
.cookie-banner button:hover{filter:brightness(1.05)}
body.cookies-accepted .cookie-banner{display:none}
@media(min-width:768px){.cookie-banner{left:auto;right:1.5rem;bottom:1.5rem;max-width:520px}}
