:root{
  --color-primary:#1E3A5F;
  --color-secondary:#F2EDE3;
  --color-accent:#C97B3D;
  --color-neutral-dark:#0D1A2A;
  --color-neutral-light:#FAF6EE;
  --font-heading:'Cormorant Garamond', serif;
  --font-body:'Lato', sans-serif;
  --radius:12px;
  --shadow:0 20px 40px -28px rgba(13,26,42,.35);
}

/* === Base === */
*{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.6;font-size:16px;-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{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,3.75rem);letter-spacing:-.01em}
h2{font-size:clamp(1.75rem,3.4vw,2.5rem)}
h3{font-size:1.35rem}
p{margin:0 0 1em}

/* === Layout: sidebar + main === */
.layout{display:block}
.sidebar{background:var(--color-primary);color:var(--color-neutral-light);padding:1.25rem 1.25rem;position:relative}
.sidebar__head{display:flex;align-items:center;justify-content:space-between}
.logo{display:inline-block}
.logo img{height:72px;width:auto;display:block}
.sidebar__nav{display:none;flex-direction:column;gap:.25rem;margin-top:1rem}
.sidebar__nav a{color:var(--color-neutral-light);padding:.6rem .25rem;border-bottom:1px solid rgba(250,246,238,.12);font-weight:600;letter-spacing:.02em}
.sidebar__nav a:hover{text-decoration:none;color:var(--color-accent)}
.sidebar__nav a.is-current{color:var(--color-accent)}
.sidebar__foot{display:none;margin-top:2rem;font-size:.8rem;opacity:.7}
.nav-toggle{background:transparent;border:1px solid rgba(250,246,238,.4);color:var(--color-neutral-light);font-size:1.4rem;padding:.3rem .7rem;border-radius:6px;cursor:pointer}
.sidebar.is-open .sidebar__nav,.sidebar.is-open .sidebar__foot{display:flex}
.sidebar.is-open .sidebar__foot{display:block}

.main{padding:0}

@media (min-width:900px){
  .layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
  .sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:2rem 1.5rem}
  .sidebar__nav{display:flex;margin-top:2.5rem}
  .sidebar__foot{display:block;margin-top:auto}
  .nav-toggle{display:none}
  .logo img{height:96px}
}

/* === Hero === */
.hero{padding:3rem 1.25rem 2rem;background:var(--color-secondary)}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--color-primary);font-weight:700;margin-bottom:1rem}
.hero h1{max-width:22ch}
.hero__sub{max-width:54ch;font-size:1.15rem;color:#3a4858;margin-bottom:1.5rem}
.hero__img{margin-top:2.5rem;width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
@media (min-width:900px){.hero{padding:5rem 3rem 3.5rem}}

/* === Buttons === */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-weight:700;letter-spacing:.02em;font-size:.95rem;transition:transform .15s ease,background .15s ease;border:none;cursor:pointer}
.btn--primary{background:var(--color-primary);color:var(--color-neutral-light)}
.btn--primary:hover{background:var(--color-neutral-dark);text-decoration:none;transform:translateY(-1px)}
.btn--accent{background:var(--color-accent);color:var(--color-neutral-light)}
.btn--accent:hover{background:#a86530;text-decoration:none;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}
.btn--ghost:hover{background:var(--color-primary);color:var(--color-neutral-light);text-decoration:none}

/* === Section === */
.section{padding:3rem 1.25rem}
.section--alt{background:var(--color-secondary)}
.section__head{max-width:60ch;margin:0 auto 2rem;text-align:center}
.section__body{max-width:65ch;margin:0 auto 1em}
.lead{font-size:1.1rem;color:#4a5566}
@media (min-width:900px){.section{padding:4.5rem 3rem}}

/* === Two-column === */
.two-col{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;max-width:1100px;margin:0 auto}
.two-col figure{margin:0}
.two-col img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
@media (min-width:900px){.two-col{grid-template-columns:1fr 1fr;gap:4rem}.two-col--reverse>div{order:2}.two-col--reverse>figure{order:1}}

/* === Grid of cards === */
.grid{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:1200px;margin:0 auto}
@media (min-width:700px){.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1100px){.grid--4{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--color-neutral-light);padding:1.75rem;border-radius:var(--radius);border:1px solid rgba(13,26,42,.08);box-shadow:0 6px 20px -16px rgba(13,26,42,.3)}
.section--alt .card{background:#fff}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--color-primary);color:var(--color-neutral-light);font-size:1.2rem;margin-bottom:.9rem}
.card h3{margin-bottom:.5rem}

/* === Before/After === */
.before-after{display:grid;grid-template-columns:1fr;gap:1rem;max-width:1100px;margin:0 auto 2rem}
@media (min-width:700px){.before-after{grid-template-columns:1fr 1fr;gap:1.5rem}}
.before-after figure{margin:0;position:relative}
.before-after img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.before-after figcaption{position:absolute;top:.75rem;left:.75rem;background:var(--color-primary);color:var(--color-neutral-light);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .75rem;border-radius:999px}

/* === Testimonial === */
.testimonial{background:var(--color-primary);color:var(--color-neutral-light);padding:4rem 1.5rem}
.testimonial blockquote{max-width:65ch;margin:0 auto;text-align:center;font-family:var(--font-heading);font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.5;font-style:italic}
.testimonial blockquote p{margin-bottom:1.25rem}
.testimonial cite{display:block;font-family:var(--font-body);font-size:.9rem;font-style:normal;letter-spacing:.06em;color:var(--color-accent);text-transform:uppercase}

/* === CTA band === */
.cta-band{background:var(--color-accent);color:var(--color-neutral-light);text-align:center;padding:3.5rem 1.5rem}
.cta-band h2{color:var(--color-neutral-light);max-width:24ch;margin:0 auto .75rem}
.cta-band p{max-width:50ch;margin:0 auto 1.5rem}
.cta-band .btn{background:var(--color-neutral-light);color:var(--color-primary)}
.cta-band .btn:hover{background:var(--color-neutral-dark);color:var(--color-neutral-light)}

/* === Contact === */
.contact-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:1000px;margin:2rem auto}
@media (min-width:700px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-card{background:#fff;padding:1.75rem;border-radius:var(--radius);border:1px solid rgba(13,26,42,.08)}
.hours{width:100%;border-collapse:collapse}
.hours th,.hours td{text-align:left;padding:.45rem .25rem;border-bottom:1px solid rgba(13,26,42,.08);font-weight:400}
.hours th{font-weight:600;color:var(--color-primary)}

/* === Form === */
.form{max-width:680px;margin:2.5rem auto 0;background:#fff;padding:2rem;border-radius:var(--radius);border:1px solid rgba(13,26,42,.08)}
.form__row{margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.4rem}
.form label{font-weight:600;font-size:.92rem;color:var(--color-primary)}
.form input,.form textarea{font-family:inherit;font-size:1rem;padding:.7rem .85rem;border:1px solid rgba(13,26,42,.18);border-radius:8px;background:var(--color-neutral-light)}
.form input:focus,.form textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}

/* === Footer === */
.footer{background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:3rem 1.5rem 1.5rem}
.footer a{color:var(--color-neutral-light)}
.footer__cols{display:grid;grid-template-columns:1fr;gap:2rem;max-width:1200px;margin:0 auto}
@media (min-width:700px){.footer__cols{grid-template-columns:2fr 1fr 1.5fr}}
.footer__brand{font-family:var(--font-heading);font-size:1.6rem;font-weight:600;margin-bottom:.3rem;color:var(--color-secondary)}
.footer nav{display:flex;flex-direction:column;gap:.5rem}
.footer address{font-style:normal;line-height:1.7}
.footer__legal{font-size:.85rem;opacity:.8;margin-top:.6rem}
.footer__legal a{margin-right:.4rem}
.footer__copy{text-align:center;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(250,246,238,.12);font-size:.85rem;opacity:.7}

/* === 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 50px -20px rgba(0,0,0,.5);display:flex;flex-direction:column;gap:.75rem;z-index:50;max-width:520px;margin-left:auto;margin-right:auto}
.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;padding:.6rem 1.2rem;border-radius:999px;font-weight:700;cursor:pointer;align-self:flex-start}
.cookie-banner button:hover{background:#a86530}
body.cookies-accepted .cookie-banner{display:none}
@media (min-width:600px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between}.cookie-banner button{align-self:auto;white-space:nowrap}}
