:root{
  --clay:#c4956a;
  --clay-dark:#a87d58;
  --dark:#2c2420;
  --muted:#5d534d;
  --cream:#f7f2ea;
  --white:#ffffff;
  --line:#ded2c4;
  --shadow:0 14px 36px rgba(44,36,32,.12);
  --radius:8px;
  --max:1100px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  font-family:"Jost",sans-serif;
  background:var(--cream);
  color:var(--dark);
  line-height:1.6;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
.container{width:min(var(--max),92%);margin-inline:auto}

.skip-link{
  position:absolute;
  top:-100px;
  left:1rem;
  background:var(--dark);
  color:var(--white);
  padding:.7rem 1rem;
  z-index:1000;
  text-decoration:none;
  border-radius:6px;
}
.skip-link:focus{top:1rem}

nav{
  position:fixed;
  inset:0 0 auto 0;
  z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border-bottom:1px solid transparent;
  transition:background .3s ease,border-color .3s ease;
}

.nav-wrap{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  position:relative;
}

.brand{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(2rem,3.4vw,2.5rem);
  letter-spacing:.01em;
  font-weight:800;
  color:#1f1915;
  line-height:1;
  white-space:nowrap;
  text-decoration:none;
}

.nav-links-wrap{display:flex}

.nav-links{
  display:flex;
  gap:1.25rem;
  align-items:center;
  list-style:none;
}

.nav-links a{
  text-decoration:none;
  color:var(--dark);
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:.35rem .25rem;
}

.nav-links a.active{
  color:#1f1915;
  border-bottom:2px solid var(--clay);
}

.nav-toggle{
  display:none;
  width:42px;
  height:42px;
  border:1px solid var(--line);
  border-radius:6px;
  background:var(--white);
  cursor:pointer;
  align-items:center;
  justify-content:center;
}

.nav-toggle-line{
  position:relative;
  width:20px;
  height:2px;
  background:var(--dark);
  transition:background .2s ease;
}

.nav-toggle-line::before,
.nav-toggle-line::after{
  content:"";
  position:absolute;
  left:0;
  width:20px;
  height:2px;
  background:var(--dark);
  transition:transform .2s ease, top .2s ease, opacity .2s ease;
}
.nav-toggle-line::before{top:-6px}
.nav-toggle-line::after{top:6px}

.nav-toggle[aria-expanded="true"] .nav-toggle-line{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle-line::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-line::after{top:0;transform:rotate(-45deg)}

.hero{
  min-height:100svh;
  padding-top:72px;
  display:grid;
  grid-template-columns:1.1fr 1fr;
}

.hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:1rem;
  padding:clamp(2rem,4vw,4rem);
}

h1{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(2.1rem,5vw,4rem);
  line-height:1.06;
  font-weight:500;
  letter-spacing:0;
}
h1 em{color:var(--clay);font-style:normal}

.lead{
  max-width:48ch;
  color:var(--muted);
  font-size:1.05rem;
}

.hero-media{
  min-height:420px;
  position:relative;
  background:url("https://images.unsplash.com/photo-1519710164239-da123dc03ef4?q=80&w=1600&auto=format&fit=crop") center/cover no-repeat;
}

.hero-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(44,36,32,.12),rgba(44,36,32,.34));
}

.page-hero{
  padding-top:112px;
  padding-bottom:1rem;
}

.eyebrow{
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#7a6f69;
  margin-bottom:.4rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  border-radius:6px;
  background:var(--clay);
  color:var(--white);
  text-decoration:none;
  padding:.95rem 1.5rem;
  font-size:.94rem;
  font-weight:500;
  letter-spacing:.02em;
  cursor:pointer;
  transition:transform .2s ease,background .2s ease;
  width:fit-content;
}
.btn:hover{transform:translateY(-2px);background:var(--clay-dark)}
.btn:focus-visible{outline:3px solid rgba(196,149,106,.35);outline-offset:2px}

.btn-secondary{
  background:#4e4641;
}
.btn-secondary:hover{
  background:#3f3833;
}

.hero-actions{
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
}

section{
  padding:4.5rem 0;
  scroll-margin-top:92px;
}

h2{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.8rem,4vw,2.7rem);
  line-height:1.12;
  margin-bottom:.7rem;
  font-weight:500;
  letter-spacing:0;
}

h3{
  font-family:"Cormorant Garamond",serif;
  font-size:1.55rem;
  line-height:1.15;
  margin-bottom:.6rem;
  font-weight:500;
  letter-spacing:0;
}

p{color:var(--muted)}
.section-text{max-width:68ch}

.gallery{
  margin-top:1.4rem;
  display:grid;
  gap:1rem;
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.gallery img{
  width:100%;
  height:260px;
  object-fit:cover;
  border-radius:var(--radius);
  transition:transform .35s ease;
}

.gallery img:hover{transform:translateY(-3px)}

.reviews{
  margin-top:1.4rem;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
}

.review{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.2rem;
}

.review p:first-child{color:var(--dark);font-size:1rem}
.review p:last-child{margin-top:.55rem;font-size:.92rem;color:#6d625c}

.service-grid{
  margin-top:1.2rem;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
}

.service-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.2rem;
}

.service-card p{
  margin-bottom:1rem;
}

.form-shell{
  margin-top:1.2rem;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.3rem;
  max-width:760px;
}

form{display:grid;gap:.9rem}
.field{display:grid;gap:.38rem}

label{
  font-size:.92rem;
  color:var(--dark);
}

input,select,textarea{
  width:100%;
  border:1px solid #c8b8a6;
  border-radius:6px;
  padding:.8rem .85rem;
  font:inherit;
  background:#fffdfa;
  color:var(--dark);
}

textarea{
  min-height:130px;
  resize:vertical;
}

input:focus,select:focus,textarea:focus{
  outline:3px solid rgba(196,149,106,.28);
  border-color:var(--clay);
}

.helper{
  min-height:1.2rem;
  font-size:.86rem;
  color:#7a6f69;
}

.notice{
  display:none;
  margin-top:.5rem;
  padding:.65rem .8rem;
  border-radius:6px;
  font-size:.92rem;
  background:#f3ede6;
  color:#564b45;
  border:1px solid #d8cbbe;
}
.notice.show{display:block}

.cta-band{
  margin-top:1.2rem;
  padding:1.1rem;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fffaf4;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
}

.mobile-cta{
  display:none;
  position:fixed;
  inset:auto 0 0 0;
  z-index:90;
  background:var(--clay);
  border-top:1px solid rgba(255,255,255,.35);
  text-align:center;
  padding:.8rem 1rem calc(.8rem + env(safe-area-inset-bottom));
}
.mobile-cta a{
  color:var(--white);
  text-decoration:none;
  font-weight:500;
  letter-spacing:.02em;
}

body.menu-open{
  overflow:hidden;
}

footer{
  border-top:1px solid var(--line);
  margin-top:1rem;
  padding:1.5rem 0 2.2rem;
  font-size:.9rem;
  color:#766a64;
}

@media (max-width:920px){
  .hero{grid-template-columns:1fr}
  .hero-media{min-height:50vh;order:-1}
  .hero-copy{padding-top:2rem}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .service-grid{grid-template-columns:1fr}
}

@media (max-width:768px){
  .nav-wrap{min-height:66px}
  .brand{font-size:1.95rem}
  .nav-toggle{display:inline-flex}
  .nav-links-wrap{
    position:absolute;
    top:66px;
    left:0;
    right:0;
    background:rgba(255,255,255,.98);
    border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-links-wrap.open{display:block}
  .nav-links{
    flex-direction:column;
    align-items:flex-start;
    gap:.3rem;
    padding:.8rem 1rem 1rem;
  }
  .nav-links a{
    font-size:.78rem;
    letter-spacing:.06em;
    padding:.45rem 0;
  }
  section{padding:3.8rem 0}
  .reviews{grid-template-columns:1fr}
  .mobile-cta{display:block}
  body{padding-bottom:64px}
}

@media (max-width:560px){
  .gallery{grid-template-columns:1fr}
  .gallery img{height:230px}
  .hero-copy{padding-inline:1.1rem}
  .brand{font-size:1.78rem}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
}
