:root{
  --color-primary:#1A1F2E;
  --color-secondary:#F5E8DD;
  --color-accent:#E07A5F;
  --color-neutral-dark:#0F1320;
  --color-neutral-light:#FAF0E8;
  --font-heading:'Lora',serif;
  --font-body:'Inter',sans-serif;
  --radius:12px;
  --radius-lg:24px;
  --maxw:1200px;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);color:var(--color-neutral-dark);background:var(--color-neutral-light);line-height:1.6;font-size:17px}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--color-accent)}
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-primary);font-weight:600;line-height:1.2;margin:0 0 .75em}
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}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:1.25rem}
.narrow{max-width:760px}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--color-accent);font-weight:600;margin-bottom:1.25rem}

/* === Header === */
.site-header{background:var(--color-neutral-light);border-bottom:1px solid rgba(15,19,32,.08);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding-block:1rem;gap:1rem}
.logo{display:inline-flex;align-items:center}
.logo img{height:72px;width:auto;display:block}
.primary-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:1.75rem}
.primary-nav a{text-decoration:none;font-weight:500;color:var(--color-primary)}
.primary-nav a[aria-current="page"]{color:var(--color-accent)}
.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:1px solid rgba(15,19,32,.2);padding:.6rem;border-radius:8px;cursor:pointer;width:44px;height:44px}
.nav-toggle span{width:20px;height:2px;background:var(--color-primary);display:block}
.primary-nav{display:none}
.primary-nav.open{display:block;position:absolute;left:0;right:0;top:100%;background:var(--color-neutral-light);border-bottom:1px solid rgba(15,19,32,.08);padding:1rem 1.25rem}
.primary-nav.open ul{flex-direction:column;gap:1rem}

@media (min-width:768px){
  .logo img{height:96px}
  .nav-toggle{display:none}
  .primary-nav{display:block;position:static;padding:0;background:transparent;border:0}
  .primary-nav ul{flex-direction:row}
}

/* === Hero (centered) === */
.hero{padding-block:3rem;text-align:center;background:linear-gradient(180deg,var(--color-secondary) 0%,var(--color-neutral-light) 100%)}
.hero h1{max-width:24ch;margin-inline:auto}
.hero-sub{max-width:54ch;margin:1rem auto 1.75rem;font-size:1.125rem;color:#2c3245}
.hero-cta{margin-bottom:2.5rem}
.hero-figure{margin:0 auto;max-width:1000px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 30px 60px -30px rgba(15,19,32,.35)}
.hero-figure img{width:100%;aspect-ratio:16/9;object-fit:cover}
@media (min-width:768px){.hero{padding-block:6rem}}

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

/* === Sections === */
.section{padding-block:3.5rem}
@media (min-width:768px){.section{padding-block:5rem}}
.section-head{text-align:center;max-width:680px;margin:0 auto 2.5rem}
.section-head p{color:#3a4055}
.section-intro h2{max-width:24ch}
.section-intro.alt{background:var(--color-secondary)}

.two-col{display:grid;gap:2rem;align-items:center}
@media (min-width:900px){.two-col{grid-template-columns:1fr 1fr;gap:4rem}}
.two-col-figure img{border-radius:var(--radius);aspect-ratio:4/5;object-fit:cover;width:100%}

/* === Grid === */
.grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media (min-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:980px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--color-neutral-light);border:1px solid rgba(15,19,32,.08);padding:1.75rem;border-radius:var(--radius);transition:transform .2s ease,box-shadow .2s ease}
.card h3{color:var(--color-primary)}
.card p{margin:0;color:#3a4055}

/* === Testimonial === */
.section-testimonial{background:var(--color-secondary)}
.section-testimonial blockquote{margin:0;text-align:center;font-family:var(--font-heading);font-size:clamp(1.2rem,2vw,1.6rem);line-height:1.45;color:var(--color-primary)}
.section-testimonial blockquote p{margin-bottom:1.25rem}
.section-testimonial cite{font-family:var(--font-body);font-style:normal;font-size:.95rem;color:#3a4055;letter-spacing:.02em}

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

/* === FAQ === */
.section-faq details{border-top:1px solid rgba(15,19,32,.12);padding:1.25rem 0}
.section-faq details:last-of-type{border-bottom:1px solid rgba(15,19,32,.12)}
.section-faq summary{cursor:pointer;font-weight:600;font-family:var(--font-heading);font-size:1.1rem;color:var(--color-primary);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.section-faq summary::after{content:"+";color:var(--color-accent);font-size:1.5rem;line-height:1;transition:transform .2s ease}
.section-faq details[open] summary::after{content:"−"}
.section-faq details p{margin-top:.85rem;color:#3a4055}

/* === Pricing === */
.pricing-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media (min-width:900px){.pricing-grid-3{grid-template-columns:repeat(3,1fr)}}
.pricing-card{position:relative;padding:2.25rem;border-radius:16px;border:1px solid rgba(15,19,32,.12);background:var(--color-neutral-light);display:flex;flex-direction:column}
.pricing-card--featured{border-color:var(--color-accent);border-width:2px}
.pricing-card__badge{position:absolute;top:1rem;right:1rem;background:var(--color-accent);color:var(--color-neutral-light);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .65rem;border-radius:999px}
.pricing-card__plan{font-family:var(--font-heading);margin:0 0 .5rem;font-size:1.5rem}
.pricing-card__price{font-family:var(--font-heading);font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--color-primary);margin:0 0 1rem;line-height:1.1}
.pricing-card__lede{font-size:.98rem;color:#3a4055;margin-bottom:1.25rem}
.pricing-card__features{list-style:none;padding:0;margin:0 0 1.75rem;display:flex;flex-direction:column;gap:.65rem}
.pricing-card__features li{display:flex;gap:.5rem;align-items:flex-start;font-size:.97rem;color:#2c3245}
.tick{color:var(--color-accent);font-weight:700}
.pricing-card__cta{margin-top:auto}
.pricing-card__cta .btn{width:100%;text-align:center}

/* === Contact === */
.contact-grid{display:grid;gap:2rem;margin-bottom:3rem}
@media (min-width:900px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info dl.contact-list{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;margin:1rem 0 1.5rem}
.contact-info dt{font-weight:600;color:var(--color-primary)}
.hours-table{width:100%;border-collapse:collapse;margin-top:1rem;background:var(--color-secondary);border-radius:var(--radius);overflow:hidden}
.hours-table caption{text-align:left;font-weight:600;color:var(--color-primary);margin-bottom:.5rem;caption-side:top}
.hours-table th,.hours-table td{padding:.6rem .9rem;text-align:left;border-bottom:1px solid rgba(15,19,32,.08);font-size:.95rem}
.hours-table tr:last-child th,.hours-table tr:last-child td{border-bottom:0}
.contact-map img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);aspect-ratio:4/3;background:#e9e0d6}
.contact-form{background:var(--color-neutral-light);border:1px solid rgba(15,19,32,.1);padding:2rem;border-radius:var(--radius-lg);max-width:680px;margin:0 auto}
.contact-form h3{margin-top:0}
.contact-form label{display:block;font-weight:600;margin-bottom:.35rem;color:var(--color-primary);font-size:.92rem}
.contact-form input,.contact-form textarea{width:100%;padding:.75rem .9rem;border:1px solid rgba(15,19,32,.2);border-radius:8px;font-family:var(--font-body);font-size:1rem;background:#fff;color:var(--color-neutral-dark)}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--color-accent);outline-offset:2px;border-color:var(--color-accent)}
.contact-form textarea{resize:vertical;min-height:140px}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:#d9d6ce;padding-block:3rem 1.5rem;margin-top:3rem}
.site-footer h2{color:var(--color-neutral-light);font-size:1rem;text-transform:uppercase;letter-spacing:.12em;font-family:var(--font-body);font-weight:600;margin-bottom:1rem}
.site-footer a{color:#d9d6ce;text-decoration:none}
.site-footer a:hover{color:var(--color-accent)}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media (min-width:760px){.footer-grid{grid-template-columns:1.2fr 1fr 1.3fr}}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer-col address{font-style:normal;margin-bottom:1rem;line-height:1.7}
.footer-legal{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin-top:.5rem;font-size:.9rem}
.logo-footer img{height:64px;width:auto;filter:brightness(0) invert(1)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;padding-top:1.25rem;font-size:.85rem;color:#9a978f}
.footer-bottom p{margin: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:var(--radius);box-shadow:0 20px 40px -15px rgba(0,0,0,.5);display:flex;flex-direction:column;gap:.75rem;z-index:100;max-width:560px}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;left:auto;right:1rem;bottom:1rem}}
.cookie-banner p{margin:0;font-size:.92rem;color:#d9d6ce}
.cookie-banner button{background:var(--color-accent);color:var(--color-neutral-light);border:0;padding:.65rem 1.2rem;border-radius:999px;font-weight:600;cursor:pointer;font-family:var(--font-body);font-size:.92rem;white-space:nowrap}
.cookie-banner button:hover{background:#c8624a}
body.cookies-accepted .cookie-banner{display:none}
