/* ============================================================
   HANIYE — Private Couture House, Dubai
   Design system: "The Register"
   Ivory silk / charcoal ink / a single bronze thread.
   ============================================================ */

:root{
  --ink:#1a1714;
  --ink-soft:#2e2924;
  --stone:#6e665c;
  --paper:#f7f4ee;
  --paper-deep:#efeae0;
  --paper-card:#fbf9f5;
  --line:#ddd5c7;
  --bronze:#8a6a3f;
  --bronze-soft:#a98d63;
  --white:#ffffff;
  --wa:#1f7a52;

  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-ui:'Jost', 'Helvetica Neue', Arial, sans-serif;

  --w-max:1280px;
  --w-text:680px;
  --pad:clamp(20px, 5vw, 64px);
  --sec:clamp(80px, 12vw, 152px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-ui);
  font-weight:300;
  font-size:16px;
  line-height:1.65;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
::selection{background:var(--bronze);color:var(--paper)}

/* ---------- type ---------- */
h1,h2,h3,.display{font-family:var(--font-display);font-weight:300;line-height:1.08;letter-spacing:.01em}
.display-xl{font-size:clamp(42px,7.2vw,104px)}
.display-lg{font-size:clamp(34px,5vw,72px)}
.display-md{font-size:clamp(28px,3.6vw,48px)}
.display-sm{font-size:clamp(22px,2.6vw,32px)}
.italic{font-style:italic}
.lede{font-family:var(--font-display);font-size:clamp(19px,2.2vw,26px);line-height:1.5;color:var(--ink-soft)}
.body-editorial{font-family:var(--font-display);font-size:clamp(18px,1.9vw,21px);line-height:1.7;color:var(--ink-soft)}
p+p{margin-top:1.1em}

.eyebrow{
  font-family:var(--font-ui);font-size:11px;font-weight:400;
  letter-spacing:.34em;text-transform:uppercase;color:var(--bronze);
}
.eyebrow--ink{color:var(--stone)}
.muted{color:var(--stone)}

/* ---------- layout ---------- */
.wrap{max-width:var(--w-max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.wrap--text{max-width:var(--w-text)}
.section{padding-top:var(--sec);padding-bottom:var(--sec)}
.section--tight{padding-top:calc(var(--sec)*.55);padding-bottom:calc(var(--sec)*.55)}
.section--deep{background:var(--paper-deep)}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink .eyebrow{color:var(--bronze-soft)}
.section--ink .muted{color:#b6ad9f}
.center{text-align:center}
.hairline{border:0;border-top:1px solid var(--line)}
.section--ink .hairline{border-top-color:#3c362f}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,96px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3.5vw,48px)}
@media(max-width:880px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* the bronze thread — signature vertical measure line */
.thread{position:relative}
.thread::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom, transparent, var(--bronze) 12%, var(--bronze) 88%, transparent);
  opacity:.45;
}
@media(max-width:880px){.thread::before{display:none}}

/* ---------- header ---------- */
.topbar{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--pad);
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.topbar.is-scrolled{border-bottom-color:var(--line)}
.brand{
  font-family:var(--font-ui);font-weight:400;font-size:17px;
  letter-spacing:.5em;text-transform:uppercase;padding-left:.5em;
}
.brand small{display:block;font-size:8.5px;letter-spacing:.36em;color:var(--bronze);margin-top:2px}
.nav{display:flex;gap:34px;align-items:center}
.nav a{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;position:relative;padding:6px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--bronze);transition:width .35s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--bronze)}
@media(max-width:1060px){.nav{display:none}}

.menu-btn{display:none;flex-direction:column;gap:5px;padding:10px;min-width:44px;min-height:44px;justify-content:center;align-items:center}
.menu-btn span{display:block;width:24px;height:1px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s}
@media(max-width:1060px){.menu-btn{display:flex}}
.menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-btn[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-btn[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-nav{
  position:fixed;inset:0;z-index:55;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:8px;
  padding:96px var(--pad) 48px;
  transform:translateY(-102%);transition:transform .5s var(--ease);
}
.mobile-nav.is-open{transform:translateY(0)}
.mobile-nav a{font-family:var(--font-display);font-size:clamp(28px,7vw,40px);padding:8px 0;border-bottom:1px solid var(--line)}
.mobile-nav .eyebrow{margin-bottom:12px}
.mobile-nav .mobile-cta{margin-top:28px}

/* ---------- buttons / CTAs ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:50px;padding:14px 34px;
  font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;font-weight:400;
  border:1px solid var(--ink);color:var(--ink);
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
  text-align:center;
}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:var(--bronze);border-color:var(--bronze);color:var(--white)}
.btn--paper{border-color:var(--paper);color:var(--paper)}
.btn--paper:hover{background:var(--paper);color:var(--ink)}
.btn--bronze{border-color:var(--bronze);color:var(--bronze)}
.btn--bronze:hover{background:var(--bronze);color:var(--white)}
.btn--wa{border-color:var(--wa);color:var(--wa)}
.btn--wa:hover{background:var(--wa);color:#fff}
.btn svg{width:15px;height:15px;flex:none}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.cta-note{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone)}

.textlink{
  font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;
  border-bottom:1px solid var(--bronze);padding-bottom:4px;color:var(--ink);
  transition:color .3s,border-color .3s;
}
.textlink:hover{color:var(--bronze)}

/* floating whatsapp (mobile-first conversion) */
.float-wa{
  position:fixed;right:18px;bottom:18px;z-index:50;
  display:flex;align-items:center;gap:10px;
  background:var(--ink);color:var(--paper);
  padding:14px 20px;border-radius:999px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  box-shadow:0 12px 32px rgba(26,23,20,.28);
  transition:transform .3s var(--ease),background .3s;
}
.float-wa:hover{background:var(--bronze);transform:translateY(-2px)}
.float-wa svg{width:17px;height:17px}
@media(min-width:1061px){.float-wa span{display:inline}}
@media(max-width:480px){.float-wa{padding:14px;border-radius:999px}.float-wa span{display:none}}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  color:var(--paper);overflow:hidden;background:var(--ink);
}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 0%;opacity:.92}
.hero__veil{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(26,23,20,.18) 0%, rgba(26,23,20,.05) 38%, rgba(26,23,20,.74) 100%)}
.hero__content{position:relative;z-index:2;width:100%;padding:0 var(--pad) clamp(48px,8vh,96px)}
.hero__mark{
  font-family:var(--font-ui);font-weight:300;
  font-size:clamp(34px,8.5vw,110px);
  letter-spacing:clamp(.32em,2vw,.6em);text-transform:uppercase;
  line-height:1;margin-bottom:clamp(20px,3vh,36px);padding-left:.5em;
}
.hero__sub{font-family:var(--font-display);font-size:clamp(19px,2.4vw,28px);font-style:italic;max-width:640px;line-height:1.5}
.hero__meta{display:flex;gap:28px;flex-wrap:wrap;margin-top:26px;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:#cfc6b8}
.hero__meta span{display:flex;align-items:center;gap:10px}
.hero__meta span::before{content:"";width:18px;height:1px;background:var(--bronze-soft)}
.hero__cta{margin-top:36px}
.hero--inner{min-height:62svh}
.hero--inner .hero__img{object-position:center 30%}

/* The women's heads sit at the very top of this photo, so there is no image above them to
   reveal. To move them DOWN on phones without exposing a dark bar, enlarge the photo from its
   top edge: the top stays pinned (no gap) while the women shift downward with space opening
   above them. Increases as the screen narrows. */
@media(max-width:760px) and (orientation:portrait){
  .hero:not(.hero--inner) .hero__img{transform:scale(1.22);transform-origin:center top}
}
@media(max-width:540px) and (orientation:portrait){
  .hero:not(.hero--inner) .hero__img{transform:scale(1.33);transform-origin:center top}
}
@media(max-width:430px) and (orientation:portrait){
  .hero:not(.hero--inner) .hero__img{transform:scale(1.44);transform-origin:center top}
}

/* page-load reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
}

/* ---------- register / catalogue ---------- */
.register-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,64px)}
.register-grid{
  display:grid;gap:clamp(28px,4vw,56px) clamp(20px,3vw,40px);
  grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));
}
.plate{position:relative}
.plate__imgwrap{
  position:relative;overflow:hidden;background:var(--paper-deep);
  aspect-ratio:2/3;cursor:zoom-in;
}
.plate__imgwrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--ease),opacity .6s;
}
.plate:hover .plate__imgwrap img{transform:scale(1.035)}
.plate__no{
  position:absolute;top:14px;left:14px;z-index:2;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--paper);background:rgba(26,23,20,.55);
  padding:7px 12px;backdrop-filter:blur(4px);
}
.plate__meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-top:14px}
.plate__name{font-family:var(--font-display);font-size:21px;font-style:italic}
.plate__edition{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone)}
.plate__cta{
  margin-top:8px;display:inline-block;
  font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze);
  border-bottom:1px solid transparent;transition:border-color .3s;padding:4px 0;
}
.plate__cta:hover{border-color:var(--bronze)}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:80;background:rgba(20,17,14,.93);
  display:none;align-items:center;justify-content:center;padding:20px 20px 78px;
}
.lightbox.is-open{display:flex}
.lightbox__stage{display:flex;flex-direction:column;align-items:center;gap:14px;max-height:86vh}
.lightbox__stage img{max-width:min(92vw,680px);max-height:68vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox__thumbs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;max-width:min(92vw,680px);max-height:15vh;overflow-y:auto}
.lightbox__thumb{width:44px;height:59px;object-fit:cover;opacity:.45;cursor:pointer;border:1px solid transparent;transition:opacity .25s,border-color .25s}
.lightbox__thumb.is-active,.lightbox__thumb:hover{opacity:1;border-color:var(--bronze)}
.lightbox__bar{
  position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);color:var(--paper);font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  background:linear-gradient(to top, rgba(0,0,0,.5), transparent);
}
.lightbox__close{position:absolute;top:16px;right:16px;color:var(--paper);font-size:11px;letter-spacing:.3em;text-transform:uppercase;padding:14px;min-width:44px;min-height:44px}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);color:var(--paper);padding:18px;font-size:26px;font-family:var(--font-display);min-width:44px;min-height:44px}
.lightbox__nav--prev{left:6px}.lightbox__nav--next{right:6px}
.lightbox a.btn{min-height:44px;padding:10px 22px}

/* ---------- process / steps ---------- */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.step{
  display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,64px);
  padding:clamp(28px,4vw,48px) 0;border-bottom:1px solid var(--line);
}
.step__no{font-family:var(--font-display);font-size:clamp(34px,4vw,52px);color:var(--bronze);line-height:1;font-style:italic}
.step h3{font-size:clamp(21px,2.4vw,28px);margin-bottom:10px}
.step p{max-width:560px;color:var(--ink-soft)}
@media(max-width:640px){.step{grid-template-columns:1fr;gap:10px}}

/* ---------- trust strip ---------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.trust__cell{background:var(--paper);padding:clamp(24px,3vw,40px) clamp(18px,2.4vw,32px)}
.trust__cell h3{font-size:20px;margin:10px 0 6px}
.trust__cell p{font-size:14px;color:var(--stone);line-height:1.6}
.trust__cell .eyebrow{font-size:10px}
@media(max-width:980px){.trust{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.trust{grid-template-columns:1fr}}

/* ---------- editorial split ---------- */
.split-img{position:relative;overflow:hidden;background:var(--paper-deep)}
.split-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split-img--band img{aspect-ratio:21/7}
.caption{font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--stone);margin-top:12px}

/* ---------- quote ---------- */
.house-line{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(24px,3.6vw,42px);line-height:1.35;max-width:880px;margin:0 auto;
}
.house-line em{color:var(--bronze);font-style:italic}

/* ---------- faq ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 4px;font-family:var(--font-display);font-size:clamp(19px,2.1vw,24px);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-display);font-size:26px;color:var(--bronze);transition:transform .3s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq__a{padding:0 4px 26px;max-width:680px;color:var(--ink-soft)}

/* ---------- appointment panel ---------- */
.appt{
  background:var(--ink);color:var(--paper);
  padding:clamp(48px,7vw,96px) var(--pad);
}
.appt__inner{max-width:var(--w-max);margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,6vw,96px)}
@media(max-width:880px){.appt__inner{grid-template-columns:1fr}}
.appt .eyebrow{color:var(--bronze-soft)}
.appt h2{color:var(--paper)}
.appt p{color:#cfc6b8}
.appt__list{list-style:none;margin:22px 0 0}
.appt__list li{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid #353029;font-size:14.5px;color:#d8d0c2}
.appt__list li::before{content:"—";color:var(--bronze-soft)}
.appt__contact{display:grid;gap:14px;margin-top:30px}
.appt__contact a{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid #353029;padding:13px 2px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;transition:color .3s}
.appt__contact a:hover{color:var(--bronze-soft)}
.appt__contact a small{letter-spacing:.1em;color:#9a9183;text-transform:none;font-size:12px}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#b6ad9f;padding:clamp(48px,7vw,88px) var(--pad) 36px;border-top:1px solid #2c2722}
.foot{max-width:var(--w-max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
@media(max-width:880px){.foot{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.foot{grid-template-columns:1fr}}
.foot__brand{font-family:var(--font-ui);letter-spacing:.5em;text-transform:uppercase;color:var(--paper);font-size:16px;padding-left:.5em}
.foot__tag{font-family:var(--font-display);font-style:italic;font-size:17px;margin-top:14px;color:#cfc6b8;max-width:300px}
.foot h4{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze-soft);font-weight:400;margin-bottom:18px}
.foot ul{list-style:none;display:grid;gap:11px}
.foot a{font-size:13.5px;transition:color .3s}
.foot a:hover{color:var(--paper)}
.foot address{font-style:normal;font-size:13.5px;line-height:1.8}
.foot__base{max-width:var(--w-max);margin:48px auto 0;padding-top:24px;border-top:1px solid #2c2722;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.foot__base a:hover{color:var(--paper)}

/* ---------- landing page extras ---------- */
.kicker-rule{display:flex;align-items:center;gap:18px;margin-bottom:18px}
.kicker-rule::after{content:"";flex:1;height:1px;background:var(--line)}
.landing-hero{padding:calc(var(--sec) + 64px) 0 var(--sec)}
.two-col-copy{columns:2;column-gap:clamp(32px,5vw,72px)}
.two-col-copy p{break-inside:avoid}
@media(max-width:780px){.two-col-copy{columns:1}}
.checklist{list-style:none;display:grid;gap:14px;margin-top:22px}
.checklist li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-soft)}
.checklist li::before{content:"";width:7px;height:7px;border:1px solid var(--bronze);transform:rotate(45deg);margin-top:8px;flex:none}

.crumbs{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--stone);display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.crumbs a:hover{color:var(--bronze)}
.crumbs span{color:var(--line)}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:12px 20px;z-index:100}
.skip:focus{left:12px;top:12px}
:focus-visible{outline:2px solid var(--bronze);outline-offset:3px}

/* tiny utility */
.mt-1{margin-top:12px}.mt-2{margin-top:24px}.mt-3{margin-top:40px}.mt-4{margin-top:64px}
.mb-1{margin-bottom:12px}.mb-2{margin-bottom:24px}.mb-3{margin-bottom:40px}
.maxw{max-width:760px}

/* ===== Journal / articles ===== */
.landing-hero--article{padding-bottom:clamp(20px,4vw,40px)}
.article-body{max-width:var(--w-text);margin:0 auto}
.article-body h2{font-family:var(--font-display);font-weight:400;font-size:clamp(26px,4vw,38px);line-height:1.16;color:var(--ink);margin:1.9em 0 .45em}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.6vw,25px);line-height:1.25;color:var(--ink);margin:1.7em 0 .35em}
.article-body p{font-family:var(--font-ui);font-weight:300;font-size:17px;line-height:1.8;color:var(--ink-soft);margin:0 0 1.15em}
.article-body ul{list-style:none;margin:0 0 1.4em;padding:0}
.article-body li{position:relative;padding-left:24px;margin:0 0 .7em;font-family:var(--font-ui);font-weight:300;font-size:17px;line-height:1.75;color:var(--ink-soft)}
.article-body li::before{content:"";position:absolute;left:0;top:.72em;width:11px;height:1px;background:var(--bronze)}
.article-body li strong{color:var(--ink);font-weight:400}
.article-body a{color:var(--bronze);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:.5px}
.article-body a:hover{color:var(--ink)}
.article-body .pull{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(22px,3.2vw,30px);line-height:1.32;color:var(--ink);border-left:2px solid var(--bronze);padding:.15em 0 .15em 26px;margin:1.6em 0}
.jcard{display:block}
.jcard .display-sm{transition:color .3s var(--ease)}
.jcard:hover .display-sm{color:var(--bronze)}
