:root{
  --ink:#101113;--ink2:#181a1d;--panel:#1e2125;--accent:#caa257;
  --accent-soft:#e3c483;--accent-deep:#8f7035;--fg:#f0f1f3;--dim:#9ea4ac;
  --line:rgba(202,162,87,.22);--rad:3px;--maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--ink);color:var(--fg);font-family:'Jost',sans-serif;font-weight:400;line-height:1.65;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.head{font-family:'Cormorant Garamond',serif;600}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:22px}

.hdr{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--ink) 86%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--maxw);margin-inline:auto;padding-inline:18px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:38px;height:38px;border:2px solid var(--accent);display:grid;place-items:center;font-family:'Cormorant Garamond',serif;600;font-weight:600;font-size:1.4rem;color:var(--accent-soft);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.brand b{font-family:'Cormorant Garamond',serif;600;font-weight:600;font-size:1.28rem;letter-spacing:.03em;color:var(--fg);line-height:1;display:block}
.brand small{display:block;font-size:.54rem;letter-spacing:.32em;text-transform:uppercase;color:var(--dim);margin-top:3px}
.nav{display:none}
.nav a{font-family:'Cormorant Garamond',serif;600;font-size:.95rem;letter-spacing:.07em;text-transform:uppercase;color:var(--dim);padding:6px 2px;position:relative;transition:color .22s}
.nav a:hover,.nav a[aria-current=page]{color:var(--accent-soft)}
.nav a[aria-current=page]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}
.hdr-cta{font-family:'Cormorant Garamond',serif;600;font-size:.92rem;letter-spacing:.06em;text-transform:uppercase;background:var(--accent);color:var(--ink);font-weight:600;padding:9px 17px;border-radius:var(--rad);white-space:nowrap;transition:.2s}
.hdr-cta:hover{background:var(--accent-soft)}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--accent-soft);transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mnav{display:none;flex-direction:column;background:var(--ink2);border-bottom:1px solid var(--line)}
.mnav.open{display:flex}
.mnav a{padding:14px 26px;border-top:1px solid color-mix(in srgb,var(--line) 60%,transparent);font-family:'Cormorant Garamond',serif;600;font-size:1.05rem;letter-spacing:.05em;text-transform:uppercase;color:var(--dim)}
.mnav a[aria-current=page]{color:var(--accent-soft)}

.hero{position:relative;min-height:82vh;display:flex;align-items:flex-end;border-bottom:1px solid var(--line);overflow:hidden}
.hero .bg{position:absolute;inset:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,color-mix(in srgb,var(--ink) 45%,transparent),color-mix(in srgb,var(--ink) 82%,transparent) 60%,var(--ink))}
.hero-in{position:relative;padding:40px 22px 56px;width:100%;max-width:var(--maxw);margin-inline:auto}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-soft);border:1px solid var(--line);border-radius:999px;padding:7px 14px;background:color-mix(in srgb,var(--accent) 7%,transparent)}
.hero h1{font-family:'Cormorant Garamond',serif;600;font-weight:600;line-height:1;font-size:clamp(2.7rem,11vw,5.4rem);letter-spacing:.01em;margin-top:16px;text-transform:none;letter-spacing:.01em}
.hero h1 span{color:var(--accent-soft);display:block}
.hero .sub{color:var(--dim);max-width:46ch;margin-top:18px;font-size:1.04rem}
.phone-xl{display:inline-flex;align-items:baseline;gap:10px;margin-top:12px;font-family:'Cormorant Garamond',serif;600;font-size:2rem;color:var(--fg)}
.phone-xl small{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}

.btns{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:54px;padding:0 28px;font-family:'Cormorant Garamond',serif;600;font-size:1.02rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;border-radius:var(--rad);transition:.22s}
.btn-accent{background:var(--accent);color:var(--ink)}
.btn-accent:hover{background:var(--accent-soft);transform:translateY(-2px)}
.btn-line{border:1.5px solid var(--line);color:var(--fg)}
.btn-line:hover{border-color:var(--accent);color:var(--accent-soft)}

section{padding:64px 0}
.kicker{font-family:'Cormorant Garamond',serif;600;font-size:.92rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px}
.kicker::before{content:"";width:7px;height:7px;transform:rotate(45deg);background:var(--accent);flex:none}
.kicker.ctr{justify-content:center}
h2.sec{font-family:'Cormorant Garamond',serif;600;font-weight:600;line-height:1.05;font-size:clamp(2rem,7vw,3.3rem);margin-top:12px;text-transform:none}
.sec-head{max-width:62ch}
.sec-head.ctr{margin-inline:auto;text-align:center}
.sec-head.ctr .kicker{justify-content:center}
.lead{color:var(--dim);font-size:1.02rem;margin-top:14px;max-width:62ch}

.cards{display:grid;gap:16px;margin-top:32px}
.svc{position:relative;border:1px solid var(--line);background:var(--panel);overflow:hidden;display:flex;flex-direction:column}
.svc .ph{aspect-ratio:16/10;overflow:hidden}
.svc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.svc:hover .ph img{transform:scale(1.06)}
.svc .bd{padding:20px 20px 24px;flex:1;display:flex;flex-direction:column}
.svc .n{font-family:'Cormorant Garamond',serif;600;font-size:.78rem;letter-spacing:.2em;color:var(--accent)}
.svc h3{font-family:'Cormorant Garamond',serif;600;font-weight:600;font-size:1.55rem;margin-top:4px;color:var(--fg);}
.svc p{color:var(--dim);font-size:.92rem;margin-top:8px}
.svc .go{margin-top:auto;padding-top:14px;font-family:'Cormorant Garamond',serif;600;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-soft)}

.prest{display:grid;gap:11px;margin-top:28px;list-style:none}
.prest li{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);background:var(--panel);padding:15px 18px}
.prest li .chk{flex:none;width:22px;height:22px;border:1.5px solid var(--accent);border-radius:50%;display:grid;place-items:center;margin-top:1px}
.prest li .chk::after{content:"";width:8px;height:4px;border-left:2px solid var(--accent-soft);border-bottom:2px solid var(--accent-soft);transform:rotate(-45deg) translateY(-1px)}
.prest li b{font-weight:500;color:var(--fg)}
.prest li .d{color:var(--dim);font-size:.92rem}

.pricelist{display:grid;gap:0;margin-top:28px;list-style:none;border:1px solid var(--line)}
.pricelist li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line);background:var(--panel)}
.pricelist li:last-child{border-bottom:0}
.pricelist .pl{color:var(--fg)}
.pricelist .pp{font-family:'Cormorant Garamond',serif;600;font-size:1.3rem;color:var(--accent-soft);white-space:nowrap}

.split{display:grid;gap:26px;align-items:center}
.split .ph{border:1px solid var(--line);overflow:hidden}
.split .ph img{width:100%;aspect-ratio:4/3;object-fit:cover}
.split h2{font-family:'Cormorant Garamond',serif;600;font-weight:600;font-size:clamp(2rem,7vw,3rem);line-height:1.04;text-transform:none}

.band{background:var(--ink2);border-block:1px solid var(--line)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.stats .s{background:var(--ink);padding:26px 18px;text-align:center}
.stats .s b{display:block;font-family:'Cormorant Garamond',serif;600;font-weight:600;font-size:2.5rem;color:var(--accent-soft);line-height:1}
.stats .s span{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--dim);margin-top:6px;display:block}

.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.chips span{font-size:.82rem;color:var(--fg);border:1px solid var(--line);border-radius:var(--rad);padding:7px 13px;background:var(--panel)}

.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:26px}
.gal a{display:block;overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.gal a:hover img{transform:scale(1.07)}

.info-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:26px}
.info-grid .cell{background:var(--ink2);padding:22px}
.info-grid .k{font-family:'Cormorant Garamond',serif;600;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.info-grid .v{font-size:1.12rem;color:var(--fg);margin-top:6px;font-weight:500}
.info-grid .v a:hover{color:var(--accent-soft)}
.hours{display:grid;gap:8px;margin-top:18px;list-style:none}
.hours li{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:9px 0;color:var(--dim)}
.hours li b{color:var(--fg);font-weight:500}

.ft{border-top:1px solid var(--line);background:var(--ink2);padding:46px 0 30px}
.ft-in{display:grid;gap:26px}
.ft p{color:var(--dim);font-size:.88rem;max-width:36ch;margin-top:14px}
.ft h5{font-family:'Cormorant Garamond',serif;600;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.ft a.fl{display:block;color:var(--dim);font-size:.92rem;padding:3px 0}
.ft a.fl:hover{color:var(--accent-soft)}
.ft .legal{border-top:1px solid var(--line);margin-top:28px;padding-top:16px;font-size:.72rem;color:color-mix(in srgb,var(--dim) 60%,transparent);display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between}

/* animation pass (reveal, gated behind .js-anim for safe progressive enhancement) */
.js-anim .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js-anim .reveal{opacity:1!important;transform:none!important;transition:none!important}}

@media(min-width:760px){
  section{padding:88px 0}
  .nav{display:flex;gap:22px}
  .burger,.mnav{display:none!important}
  .hero{align-items:center}
  .btns{flex-direction:row}
  .cards{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr;gap:48px}
  .split.rev .ph{order:2}
  .stats{grid-template-columns:repeat(4,1fr)}
  .gal{grid-template-columns:repeat(4,1fr);gap:12px}
  .gal .wide{grid-column:span 2}
  .gal .tall{grid-row:span 2;aspect-ratio:auto}
  .info-grid{grid-template-columns:repeat(3,1fr)}
  .ft-in{grid-template-columns:1.7fr 1fr 1fr;gap:38px}
}
