: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;
  --max:1160px;
  --radius:12px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
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;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--color-accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{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);letter-spacing:-.01em}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem);letter-spacing:-.005em}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--max);margin-inline:auto;padding-inline:1.25rem}
.narrow{max-width:780px}

/* === Header === */
.site-header{background:var(--color-neutral-light);border-bottom:1px solid rgba(15,19,32,.08);position:sticky;top:0;z-index:50}
.site-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}
@media(min-width:768px){.logo img{height:96px}}
.logo--footer img{height:64px}
.primary-nav{display:flex;align-items:center}
.nav-list{list-style:none;display:flex;gap:1.75rem;margin:0;padding:0}
.nav-list a{color:var(--color-primary);font-weight:500;font-size:.95rem}
.nav-list a[aria-current=page]{color:var(--color-accent)}
.nav-toggle{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--color-primary)}
@media(max-width:767px){
  .nav-toggle{display:flex}
  .nav-list{position:absolute;inset:auto 1rem 1rem 1rem;top:88px;background:var(--color-neutral-light);border:1px solid rgba(15,19,32,.08);border-radius:var(--radius);flex-direction:column;padding:1rem;display:none;box-shadow:0 20px 40px -20px rgba(0,0,0,.2)}
  .primary-nav[data-open=true] .nav-list{display:flex}
}

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

/* === Hero (centered) === */
.hero{padding-block:4rem 3rem;text-align:center;background:linear-gradient(180deg,var(--color-secondary) 0%,var(--color-neutral-light) 100%)}
@media(min-width:768px){.hero{padding-block:6rem 4rem}}
.hero h1{max-width:28ch;margin-inline:auto;font-weight:600}
.hero__sub{max-width:54ch;margin:1rem auto 1.75rem;font-size:1.125rem;color:#3a3f4f}
.hero__cta{margin-bottom:3rem}
.hero__media{margin:2.5rem auto 0;max-width:1000px}
.hero__media img{border-radius:var(--radius);box-shadow:0 30px 60px -30px rgba(0,0,0,.35);width:100%}

/* === Sections === */
.section{padding-block:4rem}
@media(min-width:768px){.section{padding-block:5.5rem}}
.section__head{text-align:center;max-width:680px;margin:0 auto 2.5rem}
.section__sub{font-size:1.1rem;color:#3a3f4f;margin-bottom:1.25rem}

.intro-grid{display:grid;gap:2.5rem;align-items:center}
@media(min-width:900px){.intro-grid{grid-template-columns:1.1fr .9fr;gap:4rem}}
.intro-grid--reverse .intro-grid__text{order:1}
@media(min-width:900px){.intro-grid--reverse{grid-template-columns:.9fr 1.1fr}.intro-grid--reverse .intro-grid__media{order:1}.intro-grid--reverse .intro-grid__text{order:2}}
.intro-grid__media img{border-radius:var(--radius);aspect-ratio:4/5;object-fit:cover}

/* === Cards grid === */
.cards-grid{list-style:none;margin:0;padding:0;display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:640px){.cards-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.cards-grid--services{grid-template-columns:repeat(3,1fr)}}
@media(min-width:960px){.cards-grid:not(.cards-grid--services){grid-template-columns:repeat(2,1fr)}}
.card{background:#fff;border:1px solid rgba(15,19,32,.08);border-radius:var(--radius);padding:1.75rem;height:100%;display:block;color:inherit;transition:transform .15s ease, box-shadow .15s ease}
a.card-link{text-decoration:none}
a.card-link:hover{transform:translateY(-2px);box-shadow:0 20px 40px -25px rgba(0,0,0,.25);text-decoration:none}
.card__icon{display:inline-block;color:var(--color-accent);font-size:1.5rem;margin-bottom:.75rem}
.card__step{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-accent);color:#fff;font-weight:700;margin-bottom:.75rem}
.card p{color:#3a3f4f;margin:0}
.steps-grid{list-style:none;margin:0;padding:0;display:grid;gap:1.5rem;grid-template-columns:1fr;counter-reset:step}
@media(min-width:900px){.steps-grid{grid-template-columns:repeat(3,1fr)}}

/* === Testimonial === */
.section--testimonial{background:var(--color-secondary)}
.testimonial{max-width:760px;margin:0 auto;text-align:center;font-family:var(--font-heading);font-size:1.35rem;line-height:1.5;color:var(--color-primary)}
.testimonial p{margin-bottom:1.25rem}
.testimonial cite{display:block;font-family:var(--font-body);font-style:normal;font-size:.95rem;color:#3a3f4f;font-weight:500}

/* === CTA band === */
.cta-band{background:var(--color-primary);color:var(--color-neutral-light);padding-block:4rem}
.cta-band__inner{text-align:center;max-width:680px}
.cta-band h2{color:var(--color-neutral-light)}
.cta-band p{color:rgba(250,240,232,.85);margin-bottom:1.5rem}

/* === FAQ === */
.faq details{background:#fff;border:1px solid rgba(15,19,32,.08);border-radius:var(--radius);padding:1.1rem 1.25rem;margin-bottom:.75rem}
.faq summary{font-family:var(--font-heading);font-weight:600;font-size:1.1rem;color:var(--color-primary);cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--color-accent);font-size:1.4rem;line-height:1;transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq details p{margin-top:.75rem;color:#3a3f4f}

/* === 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;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;background:#fff}
.pricing-card__badge{position:absolute;top:1rem;right:1rem;background:var(--color-accent);color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.35rem .75rem;border-radius:999px}
.pricing-card__plan{font-size:1.4rem;margin-bottom:.25rem}
.pricing-card__price{font-size:clamp(2rem,4vw,2.75rem);font-weight:700;font-family:var(--font-heading);color:var(--color-primary);margin:.25rem 0 1rem;line-height:1.1}
.pricing-card__lede{color:#3a3f4f;font-style:italic;margin-bottom:1.25rem}
.pricing-card__features{list-style:none;margin:0 0 1.75rem;padding:0;flex:1}
.pricing-card__features li{display:flex;gap:.5rem;padding:.4rem 0;color:#3a3f4f;font-size:.95rem;border-bottom:1px solid rgba(15,19,32,.06)}
.pricing-card__features li:last-child{border-bottom:0}
.pricing-card__features li span{color:var(--color-accent);font-weight:700}
.pricing-card__cta{margin:0}
.pricing-card__cta .btn{width:100%;text-align:center}

/* === Contact === */
.contact-grid{display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:900px){.contact-grid{grid-template-columns:1.2fr .8fr;gap:3rem}}
.contact-form{background:#fff;padding:2rem;border-radius:var(--radius);border:1px solid rgba(15,19,32,.08)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:500;margin-bottom:.4rem;color:var(--color-primary);font-size:.95rem}
.field input,.field textarea{width:100%;padding:.75rem .9rem;border:1px solid rgba(15,19,32,.18);border-radius:8px;font:inherit;background:var(--color-neutral-light)}
.field input:focus,.field textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}
.contact-details{list-style:none;margin:0;padding:0;display:grid;gap:1.25rem}
.contact-details li{display:flex;gap:.85rem;align-items:flex-start}
.contact-details__icon{font-size:1.25rem;color:var(--color-accent);flex-shrink:0;margin-top:.15rem}
.contact-details h3{font-size:1rem;margin-bottom:.15rem}
.contact-details p{margin:0;color:#3a3f4f;font-size:.95rem}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:rgba(250,240,232,.85);padding-block:3.5rem 1.5rem;margin-top:4rem}
.site-footer__grid{display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:768px){.site-footer__grid{grid-template-columns:1.3fr 1fr 1.2fr}}
.site-footer h4{color:var(--color-neutral-light);font-size:1rem;margin-bottom:1rem}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.site-footer a{color:rgba(250,240,232,.85)}
.site-footer a:hover{color:var(--color-accent)}
.tagline{color:rgba(250,240,232,.7);font-style:italic;margin-top:.5rem}
.legal-links{margin-top:1rem;display:flex;gap:1rem;flex-wrap:wrap}
.legal-links li{font-size:.85rem}
address{font-style:normal;font-size:.95rem;line-height:1.7}
.site-footer__base{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgba(250,240,232,.12);font-size:.85rem;color:rgba(250,240,232,.6)}

/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:560px;margin-inline:auto;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,.4);display:flex;gap:1rem;align-items:center;justify-content:space-between;z-index:100;font-size:.9rem}
.cookie-banner p{margin:0;flex:1}
.cookie-banner button{background:var(--color-accent);color:#fff;border:0;padding:.6rem 1.2rem;border-radius:999px;font-weight:600;cursor:pointer;font:inherit;font-size:.9rem}
body.cookies-accepted .cookie-banner{display:none}
