
:root{
  --navy:#14304b; --navy-d:#0e2336; --gold:#b8924f; --gold-2:#c2a36b;
  --ivory:#f7f3ea; --soft:#efe9dc; --cream:#e8dec6; --ink:#23303c;
  --warm:#6f6757; --line:rgba(184,146,79,.45);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Jost',-apple-system,Segoe UI,Roboto,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--ivory);
  font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;color:var(--navy);line-height:1.12;letter-spacing:.01em}
h2{font-size:2.6rem;font-weight:300}
h3{font-size:1.5rem;font-weight:500}
p{font-weight:300}
.container{max-width:var(--maxw);margin:0 auto;padding:0 2rem}
.narrow{max-width:780px}
.center{text-align:center}
.eyebrow{font-family:var(--sans);font-size:.74rem;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.eyebrow-light{color:var(--gold-2)}
.lead{font-size:1.18rem;color:var(--warm);line-height:1.85;margin-top:1.1rem}
.sign{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--gold);margin:1.4rem 0}
.medallion text{font-family:var(--serif)}

/* buttons */
.btn{display:inline-block;font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;padding:.95rem 2rem;border:1px solid var(--gold);
  cursor:pointer;transition:.35s;background:transparent}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:transparent;color:var(--gold)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:transparent;color:var(--navy)}
.btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-mini{padding:.55rem 1.1rem;font-size:.66rem;color:var(--navy);border-color:var(--line)}
.btn-mini:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

/* header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.4s;padding:.5rem 0}
.site-header.scrolled{background:rgba(247,243,234,.95);backdrop-filter:blur(8px);
  box-shadow:0 1px 0 rgba(20,48,75,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--navy)}
.brand .medallion{flex:none}
/* medallion colours by context */
.hero .medallion,.foot-brand .medallion,.visual--gold .medallion,.visual--navy .medallion,.product-visual .medallion{color:var(--gold-2)}
.res-medallion .medallion{color:var(--navy)}
/* light header over the home hero (until scrolled) */
.home .site-header:not(.scrolled) .brand{color:var(--ivory)}
.home .site-header:not(.scrolled) .bn-1{color:var(--ivory)}
.home .site-header:not(.scrolled) .bn-2{color:var(--gold-2)}
.home .site-header:not(.scrolled) .nav-links>a{color:rgba(255,255,255,.82)}
.home .site-header:not(.scrolled) .nav-links>a:hover,.home .site-header:not(.scrolled) .nav-links>a.active{color:var(--gold-2)}
.home .site-header:not(.scrolled) .lang-btn{color:#fff;border-color:rgba(255,255,255,.4)}
.home .site-header:not(.scrolled) .lang-btn:hover{color:var(--gold-2);border-color:var(--gold-2)}
.home .site-header:not(.scrolled) .nav-toggle span{background:#fff}
.brand-name{display:flex;flex-direction:column;line-height:1}
.bn-1{font-family:var(--serif);font-size:1.15rem;letter-spacing:.22em;color:var(--navy)}
.bn-2{font-family:var(--sans);font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links>a{font-size:.8rem;letter-spacing:.06em;color:var(--navy);position:relative;padding:.3rem 0;transition:.3s}
.nav-links>a:hover,.nav-links>a.active{color:var(--gold)}
.nav-meta{display:flex;align-items:center;gap:1.2rem;margin-left:.6rem}
.lang-switch{position:relative}
.lang-btn{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;font-weight:500;color:inherit;
  background:none;border:1px solid var(--line);padding:.4rem .7rem;cursor:pointer;display:inline-flex;
  align-items:center;gap:.35rem;text-transform:uppercase;transition:.3s}
.lang-btn:hover{color:var(--gold);border-color:var(--gold)}
.lang-caret{font-size:.6rem;line-height:1}
.lang-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:160px;list-style:none;margin:0;padding:.4rem 0;
  background:var(--ivory);border:1px solid var(--line);box-shadow:0 16px 44px rgba(20,48,75,.16);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.25s;z-index:70}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu li{margin:0}
.lang-menu a{display:block;padding:.55rem 1.3rem;font-size:.9rem;color:var(--navy);letter-spacing:.02em}
.lang-menu a:hover{background:var(--soft);color:var(--gold)}
.lang-menu a.cur{color:var(--gold)}
html[dir="rtl"] .lang-menu{right:auto;left:0;text-align:right}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:1.5px;background:var(--navy);transition:.3s}

/* hero */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 50% 0%,#1a3a59 0%,var(--navy) 45%,var(--navy-d) 100%);
  text-align:center;padding:8rem 1.5rem 4rem;position:relative}
.hero-inner{max-width:760px}
.hero .medallion{margin:0 auto 1.8rem}
.hero-word{font-size:clamp(2.6rem,7vw,4.8rem);font-weight:300;letter-spacing:.22em;color:var(--ivory);text-indent:.22em}
.hero-tag{font-family:var(--serif);font-style:italic;font-size:1.6rem;color:var(--gold-2);margin:1.1rem 0 .4rem}
.hero-desc{font-size:.95rem;letter-spacing:.06em;color:#b9c3cf;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.4rem}

/* sections */
.section{padding:6.5rem 0}
.section--soft{background:var(--soft)}
.section--navy{background:var(--navy);color:#fff}
.section--navy .lead{color:#c6cfd9}
.on-navy{color:var(--ivory)} .on-navy-soft{color:#c6cfd9}
.sec-head{margin-bottom:3.2rem}
.sec-head.center{text-align:center}

/* subhero */
.subhero{padding:11rem 0 4rem;background:var(--soft);text-align:center}
.subhero-h{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:300}
.subhero-p{max-width:620px;margin:1.2rem auto 0;color:var(--warm);font-size:1.1rem}

/* cards / pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.card{background:#fff;border:1px solid var(--line);padding:2.6rem 2rem;transition:.4s;position:relative}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 50px rgba(20,48,75,.1)}
.pill{display:block}
.pill-num{font-family:var(--serif);font-size:1.1rem;color:var(--gold);letter-spacing:.1em}
.card h3{margin:.7rem 0 .8rem}
.card p{color:var(--warm);font-size:1rem}
.card-more{position:absolute;bottom:2rem;right:2rem;color:var(--gold);font-size:1.1rem;opacity:.6;transition:.3s}
.pill:hover .card-more{opacity:1;transform:translateX(4px)}

/* journeys */
.journeys{display:flex;flex-direction:column;gap:0}
.journey{display:flex;gap:2rem;align-items:center;padding:2rem 0;border-top:1px solid rgba(255,255,255,.16)}
.journey:last-child{border-bottom:1px solid rgba(255,255,255,.16)}
.journey .j-num{font-family:var(--serif);font-size:2rem;color:var(--gold-2);min-width:60px}
.journey h3{color:#fff}.journey p{color:#c6cfd9}
.journey.light{border-color:var(--line)}
.journey.light h3{color:var(--navy)}.journey.light p{color:var(--warm)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split-text h2{margin-bottom:.4rem}
.split-text .btn{margin-top:1.8rem}
.split-visual{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.visual--gold{background:linear-gradient(135deg,#f3ead7,#e8dcc0)}
.visual--navy{background:radial-gradient(120% 120% at 50% 20%,#1a3a59,var(--navy));color:#fff}
.visual--navy .initials{font-family:var(--serif);font-size:4rem;letter-spacing:.1em;color:var(--gold-2)}

/* quote */
.quote-sec{padding:7rem 0}
.quote{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.5rem,3vw,2.1rem);
  line-height:1.5;color:var(--ivory)}
.quote-sig{margin-top:2rem;font-family:var(--sans);font-size:.74rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold-2)}

/* trio / values */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.val{text-align:center}

/* soins list */
.soins-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.soin{padding:2.2rem 1.8rem;border:1px solid var(--line);background:#fff}
.soin h3{margin-bottom:.6rem}.soin p{color:var(--warm)}

/* ticks */
.ticks{list-style:none;margin:1.6rem 0}
.ticks li{padding:.5rem 0 .5rem 1.7rem;position:relative;color:var(--warm)}
.ticks li:before{content:"";position:absolute;left:0;top:1.05rem;width:9px;height:9px;background:var(--gold)}

/* boutique */
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.product{background:#fff;border:1px solid var(--line);padding:0 0 1.8rem;text-align:center;transition:.4s}
.product:hover{transform:translateY(-6px);box-shadow:0 18px 50px rgba(20,48,75,.1)}
.product-visual{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#f3ead7,#e8dcc0);margin-bottom:1.4rem}
.product h3{font-size:1.25rem;padding:0 1.4rem}
.product p{color:var(--warm);font-size:.95rem;padding:.5rem 1.4rem 1rem}
.product-foot{display:flex;flex-direction:column;gap:.8rem;align-items:center}
.price{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.05rem}
.boutique-note{text-align:center;max-width:620px;margin:3rem auto 0;color:var(--warm);font-size:.95rem}

/* cart */
.cart-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:45;background:var(--navy);color:#fff;
  border:1px solid var(--gold);padding:.85rem 1.4rem;font-family:var(--sans);font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:.3s}
.cart-fab:hover{background:var(--gold)}
.cart-fab #cart-count{color:var(--gold-2);font-weight:500}.cart-fab:hover #cart-count{color:#fff}
.cart-drawer{position:fixed;top:0;right:-420px;width:380px;max-width:88vw;height:100%;background:var(--ivory);
  z-index:60;box-shadow:-18px 0 50px rgba(20,48,75,.18);transition:right .4s;display:flex;flex-direction:column;padding:2rem}
.cart-drawer.open{right:0}
.cart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;
  border-bottom:1px solid var(--line);padding-bottom:1rem}
.cart-x,.modal-x{background:none;border:0;font-size:1.8rem;color:var(--navy);cursor:pointer;line-height:1}
.cart-items{list-style:none;flex:1;overflow:auto}
.cart-items li{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0;border-bottom:1px solid rgba(184,146,79,.2);font-size:.95rem}
.cart-items .rm{color:var(--gold);cursor:pointer;font-size:1.2rem}
.cart-empty-msg{color:var(--warm);font-style:italic;padding:1rem 0}
.cart-send{margin-top:1.2rem;width:100%}
.cart-overlay{position:fixed;inset:0;background:rgba(14,35,54,.4);z-index:55;opacity:0;visibility:hidden;transition:.4s}
.cart-overlay.show{opacity:1;visibility:visible}

/* reservation */
.res-split{align-items:flex-start;gap:3.5rem}
.res-form{display:flex;flex-direction:column;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:.95rem;padding:.8rem .9rem;
  border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:300}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.res-form .btn{margin-top:.6rem}
.form-note{font-size:.8rem;color:var(--warm);font-style:italic}
.res-aside{border:1px solid var(--line);padding:2.4rem;background:#fff;text-align:center}
.res-medallion{display:flex;justify-content:center;margin:1.2rem 0 1.6rem}
.res-contact{list-style:none;line-height:2.2}
.res-contact a:hover{color:var(--gold)}
.res-hours{color:var(--warm);font-style:italic;margin-top:.6rem}

.cta-final{background:var(--soft)}

/* footer */
.site-footer{background:var(--navy);color:#cdd5de;padding:5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-word{font-family:var(--serif);font-size:1.5rem;letter-spacing:.2em;color:var(--ivory);margin-top:1rem}
.foot-sub{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-2);margin-top:.3rem}
.foot-tag{font-family:var(--serif);font-style:italic;color:var(--gold-2);margin-top:1rem}
.foot-col h4{color:var(--ivory);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;font-family:var(--sans);font-weight:500;margin-bottom:1.2rem}
.foot-col ul{list-style:none;line-height:2.3}
.foot-col a:hover{color:var(--gold-2)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;font-size:.78rem}
.foot-endorse{color:var(--gold-2);letter-spacing:.06em}
.foot-links{display:flex;gap:1.4rem}.foot-links a:hover{color:var(--gold-2)}
.foot-copy{color:#8b96a3}

/* modal */
.modal{position:fixed;inset:0;background:rgba(14,35,54,.55);z-index:70;display:none;align-items:center;justify-content:center;padding:1.5rem}
.modal.open{display:flex}
.modal-box{background:var(--ivory);max-width:600px;padding:2.6rem;position:relative}
.modal-box h3{margin-bottom:1rem}.modal-box p{color:var(--warm)}
.modal-x{position:absolute;top:1rem;right:1.2rem}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
[data-reveal].is-visible{opacity:1;transform:none}

/* per-language fonts + RTL */
html[lang="ru"]{--serif:'Playfair Display',Georgia,serif;--sans:'Montserrat',-apple-system,sans-serif}
html[lang="zh"]{--serif:'Noto Serif SC',Georgia,serif;--sans:'Noto Sans SC',-apple-system,sans-serif}
html[lang="ar"]{--serif:'Amiri',Georgia,serif;--sans:'Noto Sans Arabic',-apple-system,sans-serif}
.hero-word,.bn-1,.foot-word,.medallion text{font-family:'Cormorant Garamond',Georgia,serif}
html[lang="zh"] h1,html[lang="zh"] h2,html[lang="zh"] h3{font-weight:500}
html[dir="rtl"] .ticks li{padding-left:0;padding-right:1.7rem}
html[dir="rtl"] .ticks li:before{left:auto;right:0}
html[dir="rtl"] .card-more{right:auto;left:2rem}
html[dir="rtl"] .pill-num,html[dir="rtl"] .j-num{text-align:right}
/* Arabic: letter-spacing/tracking breaks Arabic letter shaping — normalise it */
html[lang="ar"] .eyebrow,html[lang="ar"] .nav-links>a,html[lang="ar"] .btn,html[lang="ar"] .foot-col h4,
html[lang="ar"] .foot-sub,html[lang="ar"] .quote-sig,html[lang="ar"] .hero-desc,html[lang="ar"] .field label,
html[lang="ar"] .lang-menu a,html[lang="ar"] .price{letter-spacing:normal}
html[lang="ar"] .eyebrow,html[lang="ar"] .nav-links>a,html[lang="ar"] .foot-col h4,
html[lang="ar"] .field label,html[lang="ar"] .hero-desc{text-transform:none}

/* responsive */
@media(max-width:900px){
  h2{font-size:2.1rem}
  .pillars,.trio,.soins-list,.products{grid-template-columns:1fr}
  .split,.res-split,.field-row{grid-template-columns:1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem;text-align:center}
  .foot-brand .medallion{margin:0 auto}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:78%;max-width:340px;height:100vh;background:var(--ivory);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.6rem;padding:3rem 2.4rem;
    box-shadow:-18px 0 50px rgba(20,48,75,.18);transition:right .4s}
  .nav-links.open{right:0}
  .home .site-header:not(.scrolled) .nav-links>a{color:var(--navy)}
  .home .site-header:not(.scrolled) .lang-btn{color:var(--navy);border-color:var(--line)}
  .lang-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:.3rem 0 0;background:transparent;min-width:0}
  .lang-menu a{padding:.5rem 0}
  .nav-meta{flex-direction:column;align-items:flex-start;margin-left:0;margin-top:1rem}
  .foot-bottom{flex-direction:column;text-align:center}
}
@media(max-width:520px){.container{padding:0 1.3rem}.section{padding:4.5rem 0}}
