:root{
  --bg:#f5f1ea;
  --bg-2:#ebe3d6;
  --ink:#2a2620;
  --ink-soft:#5a5147;
  --accent:#7d8c5c;
  --accent-deep:#566041;
  --clay:#c47a5a;
  --line:#d8cfbf;
  --card:#fffaf2;
  --shadow:0 8px 28px rgba(60,45,25,.08);
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-deep);text-decoration:none}
a:hover{color:var(--clay)}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.15;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.5vw,3rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:.6rem}
h3{font-size:1.15rem;margin-bottom:.4rem}
p{margin-bottom:.7rem;color:var(--ink-soft)}
.container{width:min(1140px,92%);margin-inline:auto}
section{padding:3rem 0}

.site-header{
  position:absolute;top:0;left:0;right:0;z-index:50;
  padding:1rem 0;
  transition:transform .35s ease,background .3s ease,box-shadow .3s ease;
}
.site-header.scrolled{
  position:fixed;background:rgba(245,241,234,.92);backdrop-filter:blur(10px);
  box-shadow:0 2px 14px rgba(0,0,0,.05);
}
.site-header.hidden{transform:translateY(-110%)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.5rem;font-family:'Fraunces',serif;font-weight:600;font-size:1.15rem;color:var(--ink)}
.brand i{color:var(--accent);font-size:1.5rem}
.nav-toggle{
  background:var(--ink);color:var(--bg);border:none;
  width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:transform .25s ease,background .25s ease;
  font-size:1.1rem;
}
.nav-toggle:hover{background:var(--accent-deep);transform:rotate(90deg)}
.nav-toggle[aria-expanded="true"]{background:var(--clay)}

.overlay-nav{
  position:fixed;inset:0;background:var(--ink);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .35s ease;z-index:60;
}
.overlay-nav.open{opacity:1;visibility:visible}
.overlay-nav .close{
  position:absolute;top:1.2rem;right:1.2rem;
  width:42px;height:42px;border-radius:50%;
  background:var(--clay);color:#fff;border:none;cursor:pointer;font-size:1.1rem;
}
.overlay-nav ul{list-style:none;text-align:center}
.overlay-nav li{margin:.6rem 0}
.overlay-nav a{
  font-family:'Fraunces',serif;color:var(--bg);
  font-size:clamp(1.4rem,3.5vw,2rem);
  display:inline-block;padding:.3rem .8rem;border-bottom:1px solid transparent;
  transition:border-color .25s ease,color .25s ease;
}
.overlay-nav a:hover,.overlay-nav a.active{color:var(--clay);border-color:var(--clay)}

.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  padding-top:5rem;overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:center}
.hero-copy .eyebrow{
  display:inline-block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-deep);background:var(--bg-2);padding:.35rem .7rem;border-radius:99px;margin-bottom:1rem;
}
.hero-copy h1 span{color:var(--clay);font-style:italic}
.hero-copy p.lead{font-size:1.05rem;margin:1rem 0 1.5rem;max-width:48ch}
.hero-figure{position:relative}
.hero-figure img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover}
.hero-figure::before{
  content:"";position:absolute;inset:-12px -12px auto auto;width:60%;height:60%;
  background:repeating-linear-gradient(45deg,var(--bg-2) 0 6px,transparent 6px 12px);
  border-radius:var(--radius);z-index:-1;
}

.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.7rem 1.2rem;border-radius:99px;font-weight:500;font-size:.92rem;
  border:1px solid transparent;cursor:pointer;transition:all .25s ease;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--accent-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}

.section-head{text-align:center;max-width:640px;margin:0 auto 2rem}
.section-head .kicker{
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);
  display:block;margin-bottom:.5rem;
}

.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.pillar{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.4rem;transition:transform .25s ease,box-shadow .25s ease;
}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pillar i{font-size:1.6rem;color:var(--accent);margin-bottom:.6rem;display:block}

.split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:5/4;object-fit:cover}
.checks{list-style:none;margin-top:1rem}
.checks li{display:flex;gap:.5rem;align-items:flex-start;margin-bottom:.5rem;color:var(--ink-soft)}
.checks i{color:var(--accent);margin-top:.15rem}

.stages{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;counter-reset:step}
.stage{
  background:var(--bg-2);border-radius:var(--radius);padding:1.3rem;position:relative;
}
.stage::before{
  counter-increment:step;content:"0" counter(step);
  position:absolute;top:.6rem;right:.9rem;font-family:'Fraunces',serif;
  font-size:1.6rem;color:var(--clay);opacity:.7;
}

.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.quote{
  background:var(--card);border-left:3px solid var(--accent);padding:1.2rem;border-radius:var(--radius);
  font-style:italic;color:var(--ink);
}
.quote footer{margin-top:.7rem;font-style:normal;font-size:.85rem;color:var(--ink-soft)}

.faq details{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1rem 1.1rem;margin-bottom:.6rem;
}
.faq summary{cursor:pointer;font-weight:500;font-family:'Fraunces',serif;font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";color:var(--clay);font-size:1.4rem}
.faq details[open] summary::after{content:"−"}
.faq p{margin-top:.6rem}

.cta-band{
  background:var(--ink);color:var(--bg);border-radius:var(--radius);
  padding:2rem;text-align:center;
}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.75)}
.cta-band .btn-primary{background:var(--clay)}
.cta-band .btn-primary:hover{background:#fff;color:var(--ink)}

.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.product{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.4rem;display:flex;flex-direction:column;
}
.product .price{
  font-family:'Fraunces',serif;font-size:1.6rem;color:var(--accent-deep);margin:.6rem 0;
}
.product ul{list-style:none;margin:.6rem 0 1rem}
.product ul li{padding:.25rem 0;color:var(--ink-soft);font-size:.9rem;display:flex;gap:.4rem}
.product ul i{color:var(--accent)}
.product.featured{border-color:var(--clay);position:relative}
.product.featured::after{
  content:"Most chosen";position:absolute;top:-10px;right:14px;
  background:var(--clay);color:#fff;font-size:.7rem;padding:.2rem .6rem;border-radius:99px;letter-spacing:.05em;
}

.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}

.contact-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start;
}
.contact-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;
}
.contact-info{
  background:linear-gradient(160deg,var(--accent-deep),var(--ink));color:var(--bg);
  border-radius:var(--radius);padding:1.6rem;
}
.contact-info h2{color:#fff}
.contact-info p{color:rgba(255,255,255,.8)}
.contact-info ul{list-style:none;margin-top:1rem}
.contact-info li{display:flex;gap:.7rem;align-items:center;padding:.5rem 0;border-bottom:1px dashed rgba(255,255,255,.15)}
.contact-info li:last-child{border:0}
.contact-info i{font-size:1.1rem;color:var(--clay)}
.contact-info a{color:#fff}

form .field{margin-bottom:1rem}
form label{display:block;font-size:.82rem;color:var(--ink-soft);margin-bottom:.3rem}
form input,form textarea{
  width:100%;padding:.75rem .9rem;border:1px solid var(--line);
  background:var(--bg);border-radius:10px;font:inherit;color:var(--ink);
  transition:border-color .2s ease;
}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent)}
form textarea{resize:vertical;min-height:120px}
.consent{display:flex;gap:.55rem;align-items:flex-start;font-size:.82rem;color:var(--ink-soft)}
.consent input{width:auto;margin-top:.25rem}

.map-frame{
  margin-top:1.5rem;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);height:320px;
}
.map-frame iframe{width:100%;height:100%;border:0}

.page-hero{
  padding:7rem 0 3rem;background:var(--bg-2);text-align:center;
}
.page-hero p{max-width:55ch;margin:.6rem auto 0}

.center-page{
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:2rem;
}
.center-page-inner{max-width:560px}
.center-page i.big{font-size:3.5rem;color:var(--clay);margin-bottom:1rem;display:block}

.policy{background:var(--card);padding:6rem 0 3rem}
.policy article{max-width:780px;margin:0 auto;background:var(--bg);padding:2rem;border-radius:var(--radius);border:1px solid var(--line)}
.policy h2{margin-top:1.6rem}
.policy ul,.policy ol{margin:.6rem 0 .8rem 1.2rem;color:var(--ink-soft)}
.policy li{margin-bottom:.3rem}

.site-footer{
  background:var(--ink);color:rgba(255,255,255,.75);padding:1.5rem 0;font-size:.85rem;
}
.footer-inner{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;align-items:center}
.footer-inner a{color:rgba(255,255,255,.85)}
.footer-inner a:hover{color:var(--clay)}
.footer-links{display:flex;flex-wrap:wrap;gap:.8rem}

.cookie-banner{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:80;
  background:var(--ink);color:var(--bg);padding:1rem 1.2rem;border-radius:var(--radius);
  display:none;gap:1rem;align-items:center;flex-wrap:wrap;justify-content:space-between;
  box-shadow:0 10px 30px rgba(0,0,0,.25);max-width:560px;margin:0 auto;
}
.cookie-banner.show{display:flex}
.cookie-banner p{color:rgba(255,255,255,.8);margin:0;font-size:.85rem;flex:1;min-width:200px}
.cookie-banner button{background:var(--clay);color:#fff;border:none;padding:.55rem 1rem;border-radius:99px;cursor:pointer}

@media(max-width:820px){
  .hero{min-height:auto;padding:6rem 0 2rem}
  .hero-grid{grid-template-columns:1fr;gap:1.5rem}
  .split{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr}
}
@media(max-width:480px){
  body{font-size:14px}
  section{padding:2.2rem 0}
  .pillar,.product,.contact-card,.contact-info{padding:1.1rem}
  .footer-inner{flex-direction:column;text-align:center}
}
