:root{
  --char:#15110F;
  --char-2:#1E1814;
  --char-3:#2A211C;
  --cream:#F5EEE6;
  --ink:#EDE4D8;
  --ink-soft:rgba(237,228,216,.72);
  --ink-faint:rgba(237,228,216,.46);
  --gold:#C8A24A;
  --gold-2:#E0C176;
  --blush:#D9A6A0;
  --line:rgba(200,162,74,.26);
  --gut:clamp(20px,5vw,84px);
  --disp:"Cormorant Garamond",Georgia,serif;
  --ui:"Jost",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--char);color:var(--ink);font-family:var(--ui);font-weight:400;font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.stars{color:var(--gold)}
.it{font-style:italic}
.eyebrow{display:inline-block;font-family:var(--ui);font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;color:var(--gold);margin-bottom:18px}
.eyebrow.gold{color:var(--gold-2)}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(21,17,15,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:18px;min-height:66px;padding:10px 0}
.brand{font-family:var(--disp);font-weight:600;font-size:26px;letter-spacing:.01em;display:flex;align-items:baseline;gap:8px}
.brand .brand-sub{font-family:var(--ui);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:500}
.nav-links{display:flex;gap:28px;margin-left:auto;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.nav-links a{padding:8px 2px}
.nav-links a:hover{color:var(--gold-2)}
.nav-cta{margin-left:22px;min-height:44px;display:inline-flex;align-items:center;padding:0 20px;border:1px solid var(--gold);color:var(--gold-2);font-size:13px;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;transition:.18s}
.nav-cta:hover{background:var(--gold);color:var(--char)}
.mini-tel{display:none;margin-left:auto;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:500;min-height:44px;align-items:center;padding:0 6px}
.burger{display:none;margin-left:auto;width:46px;height:46px;border:1px solid var(--line);background:none;border-radius:4px;cursor:pointer;position:relative}
.burger span,.burger span::before,.burger span::after{content:"";position:absolute;left:12px;width:22px;height:2px;background:var(--ink);transition:.2s}
.burger span{top:22px}.burger span::before{top:-7px}.burger span::after{top:7px}
.drawer{display:none;flex-direction:column;background:var(--char-2);padding:8px var(--gut) 22px}
.drawer.open{display:flex}
.drawer a{font-family:var(--disp);font-size:26px;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);min-height:44px;display:flex;align-items:center}

/* hero */
.hero{position:relative;overflow:hidden;padding-top:clamp(54px,9vw,120px);padding-bottom:clamp(54px,9vw,120px);background:radial-gradient(120% 90% at 80% -10%,rgba(200,162,74,.14),transparent 55%)}
.hero-orbs{position:absolute;inset:0;z-index:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}
.orb.o1{width:320px;height:320px;background:rgba(200,162,74,.5);top:-60px;right:-40px}
.orb.o2{width:260px;height:260px;background:rgba(217,166,160,.4);bottom:-80px;left:-60px}
.orb.o3{width:200px;height:200px;background:rgba(200,162,74,.3);top:40%;left:55%}
.hero-in{position:relative;z-index:2;max-width:780px}
.hero-head{font-family:var(--disp);font-weight:500;font-size:clamp(3rem,11vw,7.4rem);line-height:.96;letter-spacing:-.01em;margin:0 0 24px;text-wrap:balance}
.hero-head .it{font-style:italic;color:var(--gold-2)}
.hero-lede{font-size:clamp(15px,1.7vw,17.5px);color:var(--ink-soft);line-height:1.66;max-width:54ch;margin:0 0 28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}
.btn-gold{display:inline-flex;align-items:center;min-height:48px;padding:0 26px;background:var(--gold);color:var(--char);font-weight:600;font-size:13.5px;letter-spacing:.1em;text-transform:uppercase;border-radius:2px;transition:.18s}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-2px)}
.btn-line{display:inline-flex;align-items:center;min-height:48px;padding:0 24px;border:1px solid var(--line);color:var(--ink);font-weight:500;font-size:13.5px;letter-spacing:.1em;text-transform:uppercase;border-radius:2px;transition:.18s}
.btn-line:hover{border-color:var(--gold)}
.hero-rating{font-size:14px;color:var(--ink-soft);display:flex;align-items:center;gap:9px}
.hero-rating b{color:var(--ink)}
.hero-rating .stars{letter-spacing:.1em}

/* gallery */
.gallery{padding:clamp(56px,9vw,120px) 0;background:var(--char-2)}
.g-head{max-width:640px;margin:0 0 clamp(34px,5vw,54px)}
.g-kicker{font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);font-weight:500}
.g-title{font-family:var(--disp);font-weight:500;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.01em;margin:12px 0 16px;line-height:1.04}
.g-note{font-size:clamp(14.5px,1.6vw,16px);color:var(--ink-soft);max-width:50ch;line-height:1.6}
.g-grid{column-count:3;column-gap:clamp(14px,2vw,24px)}
.g-card{break-inside:avoid;margin:0 0 clamp(14px,2vw,24px);background:var(--char-3);border:1px solid var(--line);border-radius:4px;overflow:hidden;will-change:transform;transition:transform .5s ease,box-shadow .3s ease,opacity .7s ease}
.g-card:hover{box-shadow:0 18px 40px rgba(0,0,0,.45);transform:translateY(-4px)}
.g-card figcaption{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:14px 16px 16px}
.gc-name{font-family:var(--disp);font-size:1.32rem;font-weight:500;color:var(--cream)}
.gc-tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);white-space:nowrap}

/* placeholder */
.ph{position:relative;overflow:hidden;background:var(--char);aspect-ratio:4/3}
.ph.tall{aspect-ratio:3/4}
.ph::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(200,162,74,.12) 0 2px,transparent 2px 13px)}
.ph::after{content:"";position:absolute;inset:14px;border:1px dashed var(--line)}
.ph .ph-label{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1;text-align:center;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:500;padding:0 16px;line-height:1.5}
.ph img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover}

/* order */
.order{padding:clamp(56px,9vw,118px) 0}
.order-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,68px);align-items:center}
.order-h{font-family:var(--disp);font-weight:500;font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.01em;margin:0 0 18px;line-height:1.05}
.order-h.light{color:var(--cream)}
.order-copy p{font-size:clamp(15px,1.7vw,17px);color:var(--ink-soft);line-height:1.7;max-width:46ch;margin:0 0 26px}
.steps{list-style:none;margin:0 0 30px;padding:0;display:flex;flex-direction:column;gap:14px}
.steps li{display:flex;align-items:center;gap:16px;border-top:1px solid var(--line);padding-top:14px}
.s-n{font-family:var(--disp);font-size:1.5rem;color:var(--gold);font-weight:600;min-width:36px}
.s-t{font-size:15px;color:var(--ink)}
.order-fig .ph{aspect-ratio:3/4;max-width:440px;border:1px solid var(--line);border-radius:4px}

/* counter chips */
.counter{padding:clamp(54px,8vw,104px) 0;background:var(--char-2)}
.chips{display:flex;flex-wrap:wrap;gap:12px;margin:8px 0 18px}
.chip{font-size:14px;letter-spacing:.02em;color:var(--ink);border:1px solid var(--line);border-radius:30px;padding:9px 18px;background:var(--char-3);transition:.18s}
.chip:hover{border-color:var(--gold);color:var(--gold-2)}
.counter-note{font-size:13px;color:var(--ink-faint)}

/* visit */
.visit{padding:clamp(54px,8vw,104px) 0}
.visit-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:2px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.visit-info{background:var(--char-2);padding:clamp(26px,3.6vw,46px);display:flex;flex-direction:column;gap:20px}
.visit-info .order-h{margin-bottom:6px}
.vrow .vk{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:6px}
.vrow .vv{font-size:clamp(16px,1.9vw,19px);line-height:1.45;color:var(--ink)}
.map-cell{background:var(--char-3);min-height:370px;position:relative}
.map-cell iframe{width:100%;height:100%;min-height:370px;border:0;filter:grayscale(.4) invert(.9) contrast(.9) saturate(.6)}
.map-tag{position:absolute;top:14px;left:14px;z-index:2;font-size:11px;letter-spacing:.1em;color:var(--gold-2);font-weight:500;background:rgba(21,17,15,.88);padding:6px 10px;border:1px solid var(--line);pointer-events:none}

/* footer */
.foot{background:var(--char);border-top:1px solid var(--line);padding:42px 0}
.foot-row{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-end}
.foot-name{font-family:var(--disp);font-size:22px;font-weight:600;color:var(--cream)}
.foot-line{font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.7}
.foot-credit{font-size:12px;color:var(--ink-faint);line-height:1.7;text-align:right;max-width:40ch}
.foot-credit a{color:var(--gold-2)}

/* reveals */
.g-card,.steps li,.order-fig .ph,.order-copy>*{opacity:0;transform:translateY(22px)}
.js .reveal-in{opacity:1 !important;transform:none !important}
.no-js .g-card,.no-js .steps li,.no-js .order-fig .ph,.no-js .order-copy>*{opacity:1;transform:none}

@media (max-width:960px){
  .g-grid{column-count:2}
  .order-grid{grid-template-columns:1fr;gap:30px}
  .order-fig .ph{max-width:none}
}
@media (max-width:640px){
  body{font-size:16px}
  .nav-links,.nav-cta{display:none}
  .mini-tel{display:inline-flex}
  .burger{display:block}
  .nav-in{gap:10px}
  .g-grid{column-count:1}
  .visit-grid{grid-template-columns:1fr}
  .map-cell,.map-cell iframe{min-height:300px}
  .foot-credit{text-align:left}
  .foot-row{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .g-card,.steps li,.order-fig .ph,.order-copy>*{opacity:1 !important;transform:none !important}
  .g-card{transition:none}
}
