:root{
  --copper:#B06A3B;
  --cream:#F6EFE6;
  --espresso:#2A2018;
  --amber:#D8A24A;
  --copper-soft:#c98a5e;
  --cream-deep:#ece1d2;
  --ink:#34281e;
  --muted:#6f6155;
  --line:rgba(42,32,24,.12);
  --shadow:0 24px 60px -28px rgba(42,32,24,.45);
  --radius:18px;
  --maxw:1180px;
  --font-display:"Forum",serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
}

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

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.12;letter-spacing:.01em}
h1{font-size:clamp(2.4rem,6vw,4.3rem)}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:1.45rem}
em{font-style:italic;color:var(--copper)}

.eyebrow{
  font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--copper);font-weight:600;margin-bottom:1rem;
}

section{padding:clamp(4rem,9vw,7.5rem) clamp(1.25rem,5vw,4rem)}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1.25rem,5vw,4rem);
  background:rgba(246,239,230,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{
  display:grid;place-items:center;width:38px;height:38px;border-radius:12px;
  background:var(--espresso);color:var(--amber);
}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-display);font-size:1.4rem;color:var(--espresso)}
.brand-sub{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin-top:.25rem}

nav{display:flex;align-items:center}
.nav-links{list-style:none;display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.9rem;color:var(--ink);transition:color .2s}
.nav-links a:hover{color:var(--copper)}
.nav-cta{
  background:var(--espresso);color:var(--cream)!important;
  padding:.6rem 1.1rem;border-radius:999px;font-weight:500;
  transition:background .2s,transform .2s;
}
.nav-cta:hover{background:var(--copper);transform:translateY(-1px)}

.menu-toggle{
  display:none;flex-direction:column;gap:5px;
  background:none;border:0;cursor:pointer;padding:8px;
}
.menu-toggle span{width:24px;height:2px;background:var(--espresso);border-radius:2px;transition:.25s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;padding:.85rem 1.6rem;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  transition:transform .2s,box-shadow .2s,background .2s,color .2s;
}
.btn-primary{background:var(--copper);color:#fff;box-shadow:0 14px 30px -14px rgba(176,106,59,.7)}
.btn-primary:hover{background:var(--espresso);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--copper);color:var(--copper)}
.btn-ghost:hover{background:var(--copper);color:#fff;transform:translateY(-2px)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding-top:clamp(3rem,6vw,5rem)}
.hero-glow{
  position:absolute;inset:auto -10% -40% 30%;height:70%;
  background:radial-gradient(closest-side,rgba(216,162,74,.35),transparent 70%);
  filter:blur(20px);z-index:0;pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.hero-copy .lead{font-size:1.12rem;color:var(--muted);max-width:34ch;margin-top:1.4rem}
.hero h1{margin-top:.4rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}

.hero-frame{
  position:relative;border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow);background:var(--cream-deep);
  border:8px solid #fff;
}
.hero-frame img{width:100%;aspect-ratio:4/5;object-fit:cover}
.hero-frame figcaption{
  position:absolute;left:14px;bottom:14px;
  background:rgba(42,32,24,.78);color:var(--cream);
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.45rem .85rem;border-radius:999px;backdrop-filter:blur(4px);
}

/* ---------- about ---------- */
.about{background:var(--espresso);color:var(--cream)}
.about .eyebrow{color:var(--amber)}
.about-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.about h2{color:var(--cream);max-width:18ch}
.about-text p{color:rgba(246,239,230,.78);margin-top:1.1rem;max-width:48ch}
.about-meta{list-style:none;display:flex;flex-wrap:wrap;gap:2rem;margin-top:2.4rem}
.about-meta li{display:flex;flex-direction:column;font-size:1.02rem;color:var(--cream)}
.about-meta span{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:.35rem}
.about-frame{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:6px solid rgba(246,239,230,.12)}
.about-frame img{width:100%;aspect-ratio:4/5;object-fit:cover}

/* ---------- services ---------- */
.services{background:var(--cream)}
.services-head{max-width:var(--maxw);margin:0 auto 3rem;text-align:center}
.services-head h2{margin-top:.3rem}
.services-note{color:var(--muted);max-width:46ch;margin:1rem auto 0}
.service-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.service-card{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:2.4rem 1.8rem 2rem;
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s;
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.service-num{
  font-family:var(--font-display);font-size:2.2rem;color:var(--copper-soft);
  opacity:.55;line-height:1;margin-bottom:1rem;
}
.service-card h3{color:var(--espresso)}
.service-card p{color:var(--muted);margin-top:.7rem;font-size:.97rem;flex:1}
.service-price{
  margin-top:1.5rem;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--copper);font-weight:600;
}

/* ---------- gallery ---------- */
.gallery{background:var(--cream-deep)}
.gallery-head{max-width:var(--maxw);margin:0 auto 3rem;text-align:center}
.gallery-head h2{margin-top:.3rem}
.gallery-note{color:var(--muted);margin-top:.9rem}
.gallery-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.gallery-item{
  border:0;padding:0;cursor:pointer;background:none;
  border-radius:14px;overflow:hidden;position:relative;
  box-shadow:0 12px 28px -20px rgba(42,32,24,.6);
}
.gallery-item img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  transition:transform .4s ease;
}
.gallery-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(42,32,24,.25),transparent 55%);
  opacity:0;transition:opacity .3s;
}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item:hover::after{opacity:1}

/* ---------- contact ---------- */
.contact{background:var(--cream)}
.contact-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
  background:linear-gradient(135deg,#fff,var(--cream-deep));
  border:1px solid var(--line);border-radius:24px;
  padding:clamp(2.2rem,5vw,3.6rem);box-shadow:var(--shadow);
}
.contact h2{color:var(--espresso);margin-top:.3rem}
.contact-copy p{color:var(--muted);margin-top:1rem;max-width:44ch}
.contact-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.contact-details{list-style:none;display:flex;flex-direction:column;gap:1.4rem}
.contact-details li{display:flex;flex-direction:column;border-left:2px solid var(--copper);padding-left:1rem}
.ct-label{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin-bottom:.3rem;font-weight:600}
.ct-value{color:var(--ink);font-size:1.02rem}
.ct-value a:hover{color:var(--copper)}

/* ---------- footer ---------- */
footer{background:var(--espresso);color:var(--cream);padding:2.6rem clamp(1.25rem,5vw,4rem)}
.footer-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;
}
.footer-brand{font-family:var(--font-display);font-size:1.5rem;color:var(--amber)}
.footer-meta{color:rgba(246,239,230,.6);font-size:.88rem}
.footer-copy{color:rgba(246,239,230,.6);font-size:.85rem}

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  background:rgba(20,15,10,.9);padding:5vw;
}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px -20px #000}
.lightbox-close{
  position:absolute;top:18px;right:24px;
  background:none;border:0;color:var(--cream);font-size:2.6rem;line-height:1;cursor:pointer;
}

/* ---------- mobile cta ---------- */
.mobile-cta{
  display:none;position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:60;background:var(--copper);color:#fff;font-weight:600;
  padding:.85rem 2rem;border-radius:999px;
  box-shadow:0 16px 34px -14px rgba(176,106,59,.85);
}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .menu-toggle{display:flex}
  .nav-links{
    position:absolute;top:100%;right:0;left:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid var(--line);
    padding:.5rem 1.25rem 1.25rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto;box-shadow:var(--shadow)}
  .nav-links li{padding:.45rem 0;border-bottom:1px solid var(--line)}
  .nav-links li:last-child{border-bottom:0;padding-top:.9rem}
  .nav-cta{display:inline-block;text-align:center}
  .hero-inner,.about-inner,.contact-inner{grid-template-columns:1fr}
  .hero-copy{order:2}
  .hero-frame{order:1}
  .about-frame{order:-1}
  .service-grid{grid-template-columns:1fr;max-width:30rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .mobile-cta{display:inline-block}
}
@media(max-width:480px){
  .gallery-grid{gap:.6rem}
  .footer-inner{flex-direction:column;align-items:flex-start;text-align:left}
}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
