:root{
  --color-primary:#6B1F2E;
  --color-secondary:#F2E8D8;
  --color-accent:#3D5A47;
  --color-neutral-dark:#1A0F12;
  --color-neutral-light:#FBF5E8;
  --font-heading:'Cormorant Garamond', serif;
  --font-body:'Lato', sans-serif;
  --radius:16px;
  --radius-lg:24px;
  --shadow-card:0 30px 60px -30px rgba(26,15,18,0.25);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:17px;line-height:1.6;color:var(--color-neutral-dark);background:var(--color-secondary)}
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{font-family:var(--font-heading);font-weight:600;line-height:1.15;color:var(--color-neutral-dark);margin:0 0 .75rem}
h1{font-size:clamp(2.25rem,5vw,3.75rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem)}
h3{font-size:1.4rem}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--color-primary);font-weight:700;margin:0 0 1rem}
/* === Header === */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;background:var(--color-neutral-light);border-bottom:1px solid rgba(26,15,18,0.08)}
.logo img{height:72px;width:auto;display:block}
.primary-nav{position:relative}
.nav-toggle{display:inline-block;background:transparent;border:1px solid var(--color-primary);color:var(--color-primary);font-family:var(--font-body);font-weight:700;padding:.55rem 1rem;border-radius:999px;cursor:pointer}
.nav-list{display:none;list-style:none;margin:0;padding:0;position:absolute;right:0;top:calc(100% + .75rem);background:var(--color-neutral-light);border:1px solid rgba(26,15,18,0.08);border-radius:12px;padding:.5rem;min-width:200px;box-shadow:var(--shadow-card)}
.nav-list.open{display:block}
.nav-list li{margin:0}
.nav-list a{display:block;padding:.55rem .85rem;color:var(--color-neutral-dark);text-decoration:none;border-radius:8px;font-weight:700}
.nav-list a:hover,.nav-list a[aria-current="page"]{background:var(--color-secondary);color:var(--color-primary)}
@media (min-width:768px){
  .logo img{height:96px}
  .nav-toggle{display:none}
  .nav-list{display:flex;gap:.25rem;position:static;background:transparent;border:none;box-shadow:none;padding:0;min-width:0}
  .site-header{padding:1.5rem 3rem}
}
/* === Buttons === */
.btn{display:inline-block;font-family:var(--font-body);font-weight:700;letter-spacing:.03em;padding:.85rem 1.6rem;border-radius:999px;text-decoration:none;border:none;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.btn-primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn-primary:hover{color:var(--color-neutral-light);transform:translateY(-1px);box-shadow:0 12px 24px -12px rgba(107,31,46,0.6)}
.btn-light{background:var(--color-neutral-light);color:var(--color-primary)}
.btn-light:hover{transform:translateY(-1px)}
/* === Hero card === */
.hero{padding:3rem 1rem 4rem;background:linear-gradient(180deg,var(--color-secondary) 0%, var(--color-neutral-light) 100%)}
.hero-card__inner{max-width:880px;margin-inline:auto;padding:2.5rem 1.5rem;background:var(--color-neutral-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);text-align:center}
.hero-card__inner h1{margin-bottom:1.25rem}
.hero-sub{font-size:1.15rem;max-width:54ch;margin:0 auto 1.75rem;color:var(--color-neutral-dark)}
.hero-card__media{margin:2rem 0 0}
.hero-card__media img{border-radius:12px;aspect-ratio:16/10;object-fit:cover;width:100%}
@media (min-width:768px){
  .hero{padding:5rem 2rem 6rem}
  .hero-card__inner{padding:4rem 3.5rem}
}
/* === Generic section === */
main section{padding:3.5rem 1.25rem}
@media (min-width:768px){main section{padding:5rem 2rem}}
.intro{max-width:760px;margin-inline:auto;text-align:center}
.intro h2{margin-bottom:.75rem}
.section-sub{font-size:1.05rem;color:var(--color-neutral-dark);opacity:.78;max-width:60ch;margin:0 auto 1.5rem}
.intro-body{font-size:1.05rem;line-height:1.75;text-align:left;background:var(--color-neutral-light);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-card)}
/* === Highlights grid === */
.highlights{max-width:1180px;margin-inline:auto;text-align:center}
.grid{display:grid;gap:1.25rem;margin-top:2rem;text-align:left}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media (min-width:640px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:960px){.grid-3{grid-template-columns:repeat(3,1fr)} .grid-4{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--color-neutral-light);border-radius:var(--radius);padding:1.75rem;border:1px solid rgba(26,15,18,0.08);transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}
.card h3{color:var(--color-primary);margin-bottom:.5rem}
.card p{margin:0;font-size:.97rem}
.card-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:var(--color-secondary);color:var(--color-primary);font-size:1.25rem;margin-bottom:1rem}
/* === Gallery === */
.gallery{max-width:1180px;margin-inline:auto;text-align:center}
.gallery-grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:2rem}
@media (min-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gallery-grid figure{margin:0}
.gallery-grid img{border-radius:12px;aspect-ratio:4/3;object-fit:cover;width:100%}
/* === Testimonial === */
.testimonial-section{background:var(--color-neutral-light)}
.testimonial{max-width:780px;margin:0 auto;text-align:center;font-family:var(--font-heading);font-style:italic}
.testimonial p{font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.45;margin-bottom:1.25rem;color:var(--color-neutral-dark)}
.testimonial cite{display:block;font-family:var(--font-body);font-style:normal;font-size:.95rem;color:var(--color-primary);font-weight:700;letter-spacing:.04em}
/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);text-align:center}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{max-width:54ch;margin:0 auto 1.75rem;opacity:.92}
/* === Pricing === */
.pricing{max-width:1180px;margin-inline:auto;text-align:center}
.pricing-grid{display:grid;gap:1.5rem;margin-top:2.25rem;text-align:left}
.pricing-grid--3{grid-template-columns:1fr}
@media (min-width:960px){.pricing-grid--3{grid-template-columns:repeat(3,1fr);align-items:stretch}}
.pricing-card{position:relative;background:var(--color-neutral-light);border:1px solid rgba(26,15,18,0.12);border-radius:var(--radius);padding:2.25rem;display:flex;flex-direction:column}
.pricing-card--featured{border-color:var(--color-accent);border-width:2px;box-shadow:var(--shadow-card)}
.pricing-card__badge{position:absolute;top:1rem;right:1rem;background:var(--color-accent);color:var(--color-neutral-light);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.3rem .7rem;border-radius:999px}
.pricing-card__plan{color:var(--color-primary);margin-bottom:.25rem}
.pricing-card__price{font-family:var(--font-heading);font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--color-neutral-dark);margin:0 0 .75rem}
.pricing-card__lede{font-size:.97rem;color:var(--color-neutral-dark);opacity:.78;margin-bottom:1.25rem}
.pricing-card__features{list-style:none;margin:0 0 1.75rem;padding:0;display:flex;flex-direction:column;gap:.65rem;flex:1}
.pricing-card__features li{display:flex;gap:.6rem;align-items:flex-start;font-size:.97rem}
.pricing-card__features li span{color:var(--color-accent);font-weight:700;flex-shrink:0}
.pricing-card__cta{align-self:flex-start}
/* === FAQ === */
.faq{max-width:820px;margin-inline:auto;text-align:center}
.faq-list{margin-top:2rem;text-align:left;display:flex;flex-direction:column;gap:.75rem}
.faq-list details{background:var(--color-neutral-light);border:1px solid rgba(26,15,18,0.08);border-radius:12px;padding:1rem 1.25rem}
.faq-list summary{cursor:pointer;font-weight:700;color:var(--color-primary);font-family:var(--font-heading);font-size:1.2rem}
.faq-list details[open] summary{margin-bottom:.5rem}
.faq-list p{margin:0}
/* === Contact === */
.contact-block{max-width:1180px;margin-inline:auto}
.contact-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media (min-width:900px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info address{font-style:normal;line-height:1.7;margin-bottom:1.5rem}
.hours{width:100%;border-collapse:collapse;background:var(--color-neutral-light);border-radius:12px;overflow:hidden;margin-top:1rem}
.hours caption{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;text-align:left;padding:.75rem 1rem;color:var(--color-primary)}
.hours th,.hours td{padding:.6rem 1rem;text-align:left;border-top:1px solid rgba(26,15,18,0.08);font-size:.95rem}
.hours th{font-weight:600}
.contact-form{background:var(--color-neutral-light);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:700;font-size:.92rem;color:var(--color-neutral-dark)}
.field input,.field textarea{font-family:var(--font-body);font-size:1rem;padding:.7rem .85rem;border:1px solid rgba(26,15,18,0.18);border-radius:8px;background:#fff;color:var(--color-neutral-dark)}
.field input:focus,.field textarea:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:var(--color-primary)}
.contact-form .btn{align-self:flex-start}
/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3.5rem 1.5rem 2rem;margin-top:2rem}
.footer-grid{max-width:1180px;margin-inline:auto;display:grid;gap:2rem;grid-template-columns:1fr}
@media (min-width:768px){.footer-grid{grid-template-columns:1.2fr 1fr 1.4fr}}
.footer-col h2.footer-title{font-size:1.2rem;color:var(--color-neutral-light);margin-bottom:.85rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.footer-col a{color:var(--color-neutral-light);text-decoration:none;opacity:.85}
.footer-col a:hover{opacity:1;text-decoration:underline}
.footer-col address{font-style:normal;line-height:1.7;opacity:.9;margin-bottom:.75rem}
.legal-links{margin-top:.5rem;font-size:.9rem;opacity:.8}
.logo--footer img{height:64px;filter:brightness(0) invert(1)}
.tagline{font-family:var(--font-heading);font-style:italic;font-size:1.1rem;margin-top:.75rem;opacity:.9}
.copyright{max-width:1180px;margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(251,245,232,0.12);font-size:.85rem;opacity:.7;text-align:center}
/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:90;background:var(--color-neutral-dark);color:var(--color-neutral-light);border-radius:14px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 30px 60px -20px rgba(0,0,0,0.5)}
.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:none;font-weight:700;padding:.6rem 1.25rem;border-radius:999px;cursor:pointer;align-self:flex-start;font-family:var(--font-body)}
.cookie-banner button:hover{filter:brightness(1.1)}
@media (min-width:640px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between;left:auto;right:1.5rem;bottom:1.5rem;max-width:520px}}
body.cookies-accepted .cookie-banner{display:none}
