:root{
  --bg:#2a1c25; --bg2:#34232e; --ink:#f4e9ec; --mute:#c2a4ae;
  --blush:#e9b9c4; --blush-d:#d68b9c; --gold:#cda85f; --gold-d:#b3893f;
  --line:rgba(244,233,236,.14); --card:#3a2733;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font-family:"Jost",system-ui,sans-serif;font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:1180px;margin:0 auto;padding:0 30px}
h1,h2,h3,.disp{font-family:"Cormorant Garamond",Georgia,serif;font-weight:500;letter-spacing:.005em;margin:0;line-height:1.06}
.eyebrow{font-family:"Jost",sans-serif;text-transform:uppercase;letter-spacing:.34em;font-size:11px;color:var(--gold)}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(42,28,37,.84);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:"Cormorant Garamond",serif;font-size:26px;letter-spacing:.02em}
.brand small{display:block;font-family:"Jost",sans-serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-top:-2px}
.nav-links{display:flex;gap:30px;font-size:13px;letter-spacing:.05em;text-transform:uppercase}
.nav-links a{color:var(--mute)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{border:1px solid var(--gold);color:var(--gold);padding:10px 20px;border-radius:0;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.nav-cta:hover{background:var(--gold);color:var(--bg)}
.burger{display:none;background:none;border:0;color:var(--ink);font-size:22px;cursor:pointer}

/* hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.hero-img{position:absolute;inset:0;z-index:0}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(42,28,37,.92) 0%,rgba(42,28,37,.66) 46%,rgba(42,28,37,.2) 100%)}
.hero-in{position:relative;z-index:2;width:100%;max-width:1180px;margin:0 auto;padding:0 30px}
.hero .eyebrow{margin-bottom:22px}
.hero h1{font-size:clamp(46px,8.5vw,104px)}
.hero h1 em{font-style:italic;color:var(--blush)}
.hero-sub{max-width:520px;margin:26px 0 32px;color:#ecd9de;font-size:18px;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn{display:inline-block;padding:15px 30px;font-family:"Jost",sans-serif;font-size:13px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer}
.btn-gold{background:var(--gold);color:var(--bg);border:1px solid var(--gold)}
.btn-gold:hover{background:var(--gold-d);border-color:var(--gold-d)}
.btn-line{border:1px solid rgba(244,233,236,.4);color:var(--ink)}
.btn-line:hover{border-color:var(--ink)}
.hero-est{position:absolute;right:30px;bottom:40px;z-index:2;text-align:right;font-family:"Cormorant Garamond",serif;font-style:italic;font-size:20px;color:var(--blush);opacity:.9}
.hero-est span{display:block;font-family:"Jost",sans-serif;font-style:normal;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}

/* animated centerpiece — rotating petal ring */
.ring-wrap{position:absolute;right:-120px;top:50%;transform:translateY(-50%);z-index:2;width:420px;height:420px;pointer-events:none;opacity:.85}
@media(max-width:1024px){.ring-wrap{display:none}}
.ring{width:100%;height:100%;animation:spin 44s linear infinite}
@media (prefers-reduced-motion:reduce){.ring{animation:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.ring .petal{transform-origin:210px 210px}

/* section base */
section{padding:96px 0}
.sec-head{max-width:720px}
.sec-head h2{font-size:clamp(32px,5vw,56px)}
.sec-head h2 em{font-style:italic;color:var(--blush)}
.sec-head p{color:var(--mute);margin-top:16px;font-weight:300}

/* services editorial */
.serv{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:54px}
.serv-card{background:var(--card);border:1px solid var(--line)}
.serv-card figure{margin:0;overflow:hidden}
.serv-card img{width:100%;height:330px;object-fit:cover;transition:transform .8s ease}
.serv-card:hover img{transform:scale(1.06)}
.serv-card .bd{padding:26px 26px 30px}
.serv-card .n{font-family:"Jost",sans-serif;font-size:11px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}
.serv-card h3{font-size:28px;margin:10px 0 8px}
.serv-card p{color:var(--mute);font-size:15px;margin:0;font-weight:300}

/* split feature */
.feat{background:var(--bg2)}
.feat-in{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.feat-img img{width:100%;height:100%;min-height:520px;object-fit:cover}
.feat-txt{padding:80px}
.feat-txt h2{font-size:clamp(30px,4vw,48px)}
.feat-txt h2 em{font-style:italic;color:var(--blush)}
.feat-txt p{color:var(--mute);margin:20px 0 0;font-weight:300}
.feat-txt .sign{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:24px;color:var(--gold);margin-top:26px}

/* enquiry / consultation flow */
.book{background:linear-gradient(180deg,var(--bg) 0%,#23161e 100%)}
.book-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;margin-top:50px;align-items:start}
.steps{counter-reset:s}
.step{display:flex;gap:20px;padding:22px 0;border-top:1px solid var(--line)}
.step:first-child{border-top:0}
.step .num{counter-increment:s;font-family:"Cormorant Garamond",serif;font-size:40px;font-style:italic;color:var(--gold);line-height:1;min-width:48px}
.step .num::before{content:"0" counter(s)}
.step h4{font-family:"Cormorant Garamond",serif;font-size:24px;font-weight:500;margin:0 0 4px}
.step p{margin:0;color:var(--mute);font-size:15px;font-weight:300}
.consult{background:var(--card);border:1px solid var(--gold-d);padding:38px}
.consult h3{font-size:30px;margin-bottom:6px}
.consult .lead{color:var(--mute);font-weight:300;margin:0 0 22px;font-size:15px}
.fld{margin-bottom:18px}
.fld label{display:block;font-family:"Jost",sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.fld input,.fld select,.fld textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);color:var(--ink);padding:10px 2px;font:inherit;font-size:16px}
.fld textarea{min-height:70px;resize:vertical;border:1px solid var(--line);padding:12px}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--gold)}
.fld select option{background:var(--bg2)}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{border:1px solid var(--line);padding:9px 16px;font-size:13px;letter-spacing:.04em;color:var(--mute);cursor:pointer;user-select:none;transition:all .2s}
.chip.on,.chip:hover{border-color:var(--gold);color:var(--gold)}
.consult .two{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.submit{width:100%;background:var(--gold);color:var(--bg);border:0;padding:16px;font-family:"Jost",sans-serif;font-size:13px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;margin-top:8px}
.submit:hover{background:var(--gold-d)}
.fineprint{font-size:12px;color:var(--mute);text-align:center;margin-top:14px;font-weight:300}

/* gallery ribbon */
.ribbon{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.ribbon figure{margin:0;overflow:hidden}
.ribbon img{width:100%;height:280px;object-fit:cover;filter:saturate(.95) brightness(.96);transition:transform .7s ease,filter .7s ease}
.ribbon figure:hover img{transform:scale(1.05);filter:saturate(1.1) brightness(1)}

/* footer */
footer{background:#1d1219;color:var(--mute);padding:60px 0 40px;font-weight:300}
.foot-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-end;border-bottom:1px solid var(--line);padding-bottom:30px}
.foot-top .brand{color:var(--ink)}
.foot-x9{margin-top:24px;font-size:12px;color:#8a6f78}
.foot-x9 a{color:var(--blush)}

/* reveal motion */
@media (prefers-reduced-motion:no-preference){
  html.x9anim .anim{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
  html.x9anim .anim.in{opacity:1;transform:none}
}

@media(max-width:1024px){.feat-txt{padding:56px}}
@media(max-width:860px){
  .nav-links{display:none}.burger{display:block}
  .serv{grid-template-columns:1fr}
  .feat-in,.book-grid{grid-template-columns:1fr}
  .feat-img img{min-height:340px}
  .ribbon{grid-template-columns:1fr 1fr}
  section{padding:66px 0}
}
@media(max-width:560px){
  .nav-cta{display:none}
  .brand{font-size:22px}
  .brand small{font-size:8px}
}
@media(max-width:430px){
  .wrap,.hero-in{padding-left:18px;padding-right:18px}
  .feat-txt{padding:40px 18px}
  .consult{padding:26px 20px}
  .consult .two{grid-template-columns:1fr}
  .hero-est{right:18px}
  .ribbon{grid-template-columns:1fr}
}
