/* Reson Luxury Hero — Pixel-perfect reference build
   BEM: rlh-hero, rlh-bgword, rlh-media, rlh-stats, rlh-ring, rlh-thumbs, rlh-slider
*/

.rlh-hero{
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  background:var(--bg,#f4f4f4);
  color:var(--text,#111);
  position:relative;
  overflow:hidden;
}

.rlh-hero *{ box-sizing:border-box; }

.rlh-hero::after{
  /* soft base gradient for editorial feel */
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(1200px 520px at 60% 35%, rgba(255,255,255,.55), rgba(255,255,255,0) 60%);
  pointer-events:none;
  z-index:0;
}

.rlh-hero--noise::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("../shared/noise.png");
  background-size:220px 220px;
  opacity:0.08; /* 0.06–0.10 per spec */
  pointer-events:none;
  z-index:2;
  mix-blend-mode:multiply;
}

.rlh-wrap{
  max-width:var(--maxw,1320px);
  margin:0 auto;
  padding-inline:clamp(18px,3vw,42px);
}

.rlh-inner{
  position:relative;
  height:var(--h,740px);
  outline:none;
}

@media (max-width:1099px){
  .rlh-inner{ height:var(--hSmall,680px); }
}

.rlh-inner:focus-visible{
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#da9fa3) 70%, transparent);
  border-radius:16px;
}

/* Critical: stage centered to container width (not viewport edges) */
.rlh-stage{
  position:absolute;
  left:50%;
  top:0;
  transform:translateX(-50%);
  width:var(--maxw,1320px);
  height:100%;
  z-index:1;
}

/* 1) Big background word */
.rlh-bgword{
  position:absolute;
  top: 212px;
  left:50%;
  transform:translateX(-50%);
  font-family:var(--serif,"Playfair Display","Didot","Bodoni MT","Times New Roman",serif);
  font-size:300px;
  line-height:0.85;
  letter-spacing:-0.02em;
  font-weight:400;
  color: rgb(255 255 255 / 37%);
  white-space:nowrap;
  user-select:none;
  pointer-events:none;
  z-index:1;
}

/* 2) Main media */
.rlh-media{
  position:absolute;
  left: 54%;
  bottom:0;
  transform:translateX(calc(-50% + var(--modelX,0px)));
  width:520px;
  height:660px;
  z-index:3;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,0.18));
}
.rlh-media__layer{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity 400ms ease;
}
.rlh-media__layer.is-active{ opacity:1; }
.rlh-media__layer.is-leaving{ opacity:0; }

.rlh-media__layer img,
.rlh-media__layer video{
  width:100%;
  height:100%;
  object-fit:contain; /* NOT cover */
  display:block;
}
.rlh-media__layer video{ background:#0000; }

/* 3) Stats block - inline 3 columns */
.rlh-stats{
  position:absolute;
  right:160px;
  top:310px;
  display:grid;
  grid-auto-flow:column;
  gap:28px;
  z-index:4;
  display: none;
}
.rlh-stat{ display:flex; flex-direction:column; align-items:center; }
.rlh-stat__num{
  font-family:var(--sans,system-ui);
  font-size:22px;
  font-weight:500;
  color:#111;
  line-height:1;
}
.rlh-stat__label{
  margin-top:8px;
  font-family:var(--sans,system-ui);
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#777;
  line-height:1;
}

/* 4) Ring + play */
.rlh-ringWrap{
  position:absolute;
  left:110px;
  top:360px;
  width:220px;
  height:220px;
  z-index:4;
  display:grid;
  place-items:center;
}
.rlh-ring{
  position:absolute;
  inset:0;
  border-radius:999px;
}
.rlh-ring__svg{ width:100%; height:100%; }
.rlh-ring__text{
  font-family:var(--sans,system-ui);
  font-size:11px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  fill:#777;
}
@media (prefers-reduced-motion:no-preference){
  .rlh-ring__svg{ animation:rlhSpin 20s linear infinite; }
}
@keyframes rlhSpin{ to{ transform:rotate(360deg); } }

/* 5) Thumbnails arc cluster (absolute offsets) */
.rlh-thumbs{
  position:absolute;
  top:48px; /* ensures thumbs sit above play button visually */
  left:50%;
  transform:translateX(-50%);
  width:140px;
  height:70px;
  z-index:5;
}
.rlh-thumb{
  position:absolute;
  width:38px;
  height:38px;
  border-radius:999px;
  border:2px solid #fff;
  padding:0;
  background:transparent;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(0,0,0,0.12);
  transition:transform 180ms ease, box-shadow 180ms ease;
}
.rlh-thumb__img{
  display:block;
  width:100%;
  height:100%;
  border-radius:999px;
  background-size:cover;
  background-position:center;
}
.rlh-thumb:hover{ transform:translateY(-2px); box-shadow:0 16px 26px rgba(0,0,0,0.14); }
.rlh-thumb:focus-visible{ outline:none; box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#da9fa3) 70%, transparent), 0 16px 26px rgba(0,0,0,0.14); }

.rlh-thumb.is-active{
  box-shadow:0 0 0 2px var(--accent,#da9fa3), 0 10px 20px rgba(0,0,0,0.12);
}

/* Exact placements in shallow arc */
.rlh-thumb:nth-child(1){ left:-26px; top:-18px; }
.rlh-thumb:nth-child(2){ left: 10px; top:-34px; }
.rlh-thumb:nth-child(3){ left: 46px; top:-18px; }
.rlh-thumb:nth-child(4){ left: 82px; top: -6px; }

/* Play button center */
.rlh-play{
  width:64px;
  height:64px;
  border-radius:999px;
  border:1px solid #d9d9d9;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(6px);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
.rlh-play:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 28px rgba(0,0,0,0.12);
  border-color:color-mix(in srgb, var(--accent,#da9fa3) 70%, #d9d9d9);
}
.rlh-play:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#da9fa3) 70%, transparent);
}
.rlh-play__icon{
  width:0;height:0;
  border-left:14px solid #111;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  transform:translateX(2px);
}
.rlh-play.is-playing .rlh-play__icon{
  width:18px;height:18px;border:none;transform:none;position:relative;
}
.rlh-play.is-playing .rlh-play__icon::before,
.rlh-play.is-playing .rlh-play__icon::after{
  content:"";
  position:absolute;top:0;bottom:0;width:5px;background:#111;border-radius:2px;
}
.rlh-play.is-playing .rlh-play__icon::before{ left:3px; }
.rlh-play.is-playing .rlh-play__icon::after{ right:3px; }

.rlh-play__label{
  position:absolute;
  top:calc(50% + 44px);
  left:50%;
  transform:translateX(-50%);
  font-family:var(--sans,system-ui);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:#777;
  white-space:nowrap;
}

/* 6) Center copy */
.rlh-copy{
  position:absolute;
  left: 35%;
  top: 494px;
  transform:translateX(-50%);
  z-index:4;
  text-align:center;
}
.rlh-copy__title{
  font-family:var(--serif,"Playfair Display","Didot","Bodoni MT","Times New Roman",serif);
  font-size:34px;
  color:#111;
  line-height:1.1;
}
.rlh-copy__sub{
  margin-top:10px;
  font-family:var(--sans,system-ui);
  font-size:12px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:#777;
}

/* 7) Bottom-right slider controls */
.rlh-slider{
  position:absolute;
  right:120px;
  bottom:110px;
  display:flex;
  align-items:center;
  gap:18px;
  z-index:4;
}
.rlh-arrow{
  width:56px;height:56px;
  border-radius:999px;
  border:1px solid #e3e3e3;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform 200ms ease, box-shadow 200ms ease;
}
.rlh-arrow:hover{ transform:translateY(-2px); box-shadow:0 16px 28px rgba(0,0,0,0.12); }
.rlh-arrow:focus-visible{ outline:none; box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#da9fa3) 70%, transparent); }

.rlh-arrow--light{background: #d49b9f;color: #ffffff;}
.rlh-arrow--dark{background: #da9fa3;border-color: #ffffff;color:#fff;}

.rlh-arrow__icon{
  width:14px;height:14px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(135deg);
}
.rlh-arrow__icon--r{ transform:rotate(-45deg); }

.rlh-page{
  font-family:var(--sans,system-ui);
  font-size:12px;
  color:#777;
  letter-spacing:0.12em;
  display:flex;
  align-items:center;
  gap:10px;
}
.rlh-page__now{ color:#111; }

/* Modal */
.rlh-modal{ position:fixed; inset:0; z-index:99999; }
.rlh-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,0.55); }
.rlh-modal__dialog{
  position:relative;
  max-width:min(1100px,92vw);
  max-height:88vh;
  margin:5vh auto;
  background:#fff;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,0.35);
}
.rlh-modal__close{
  position:absolute; right:12px; top:8px;
  width:44px;height:44px;border-radius:999px;
  border:1px solid rgba(0,0,0,0.12);
  background:#fff; cursor:pointer;
  font-size:26px; line-height:1;
}
.rlh-modal__body{ padding:18px; display:grid; place-items:center; }
.rlh-modal__body img,.rlh-modal__body video{ max-width:100%; max-height:78vh; border-radius:16px; }

/* =========================================================
   MOBILE — Editorial Absolute Layout (match reference phone)
   Paste at END of hero.css
========================================================= */
@media (max-width: 900px){

  /* Canvas */
  .rlh-hero{
    width:100vw !important;
    max-width:100vw !important;
    margin-left:calc(50% - 50vw) !important;
    margin-right:calc(50% - 50vw) !important;
    overflow:hidden !important;
    position:relative !important;
    background: var(--bg, #f4f4f4) !important; /* reference gray */
  }

  .rlh-wrap{ max-width:100% !important; padding-inline:18px !important; }

  .rlh-inner{
    position:relative !important;
    height:100svh !important;
    min-height:720px !important;
    padding:0 !important;
  }

  /* Kill desktop centering */
  .rlh-stage{
    position:absolute !important;
    inset:0 !important;
    left:0 !important;
    top:0 !important;
    transform:none !important;
    width:100% !important;
    height:100% !important;
  }

  /* Layering */
  .rlh-bgword{ z-index:1 !important; }
  .rlh-media{ z-index:4 !important; }
  .rlh-ringWrap{ z-index:6 !important; }
  .rlh-thumbs{ z-index:7 !important; }
  .rlh-slider{ z-index:8 !important; }

  /* Hide desktop copy/stats on mobile like reference */
  .rlh-copy, .rlh-stats{ display:none !important; }

  /* Big background word (very light) */
  .rlh-bgword{
    position:absolute !important;
    left:52% !important;
    top:72px !important;
    transform:translateX(-50%) !important;
    font-size:220px !important;
    line-height:0.86 !important;
    letter-spacing:-0.03em !important;
    opacity:0.10 !important;           /* super subtle */
    color:#111 !important;             /* still dark but low opacity */
    pointer-events:none !important;
    white-space:nowrap !important;
  }

  /* Main model — LARGE and slightly right (reference) */
  .rlh-media{
    position:absolute !important;
    bottom:36px !important;
    left:auto !important;
    right:6% !important;               /* shift right */
    transform:none !important;

    width:min(420px, 92vw) !important; /* BIG */
    height:min(640px, 76vh) !important;

    filter:drop-shadow(0 18px 26px rgba(0,0,0,0.14)) !important;
  }

  .rlh-media__layer img,
  .rlh-media__layer video{
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
    display:block !important;
  }

  /* Ring — small on LEFT like reference */
  .rlh-ringWrap{
    position:absolute !important;
    left:22% !important;
    top:42% !important;                /* around model shoulder area */
    transform:translate(-50%, -50%) !important;

    width:150px !important;
    height:150px !important;
    opacity:0.85 !important;
  }

  /* Play button — bottom-center-ish (reference) */
  .rlh-play{
    width:62px !important;
    height:62px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,0.55) !important;
    border:1px solid rgba(0,0,0,0.14) !important;
    backdrop-filter:blur(8px) !important;
  }

  .rlh-play__label{
    top:calc(50% + 46px) !important;
    font-size:10px !important;
    letter-spacing:0.22em !important;
    color:rgba(0,0,0,0.55) !important;
  }

  /* Thumbnails — ARC cluster (NOT a row) */
  .rlh-thumbs{
    position:absolute !important;
    left:50% !important;
    bottom:170px !important;
    transform:translateX(-50%) !important;

    width:260px !important;
    height:86px !important;

    display:block !important;          /* stop grid/row */
  }

  .rlh-thumb{
    position:absolute !important;
    width:62px !important;
    height:62px !important;
    border-radius:18px !important;
    overflow:hidden !important;
    border:2px solid rgba(255,255,255,0.90) !important;
    background:rgba(255,255,255,0.12) !important;
    transform:none !important;
  }

  /* Arc placement */
  .rlh-thumb:nth-child(1){ left:0px;   top:12px; }
  .rlh-thumb:nth-child(2){ left:66px;  top:0px;  }
  .rlh-thumb:nth-child(3){ left:132px; top:0px;  }
  .rlh-thumb:nth-child(4){ left:198px; top:12px; }

  .rlh-thumb.is-active{
    box-shadow:0 0 0 2px var(--accent,#da9fa3) !important;
  }

  /* Slider — hide on reference mobile (usually not visible) */
  .rlh-slider{ display:none !important; }

  /* Respect reduced motion */
  @media (prefers-reduced-motion: reduce){
    .rlh-ring__svg{ animation:none !important; }
    .rlh-media__layer, .rlh-thumb, .rlh-play{ transition:none !important; }
  }
}

/* Small phones */
@media (max-width: 380px){
  .rlh-bgword{ font-size:195px !important; top:78px !important; }
  .rlh-media{ right:2% !important; width:min(390px, 94vw) !important; height:min(600px, 74vh) !important; }
  .rlh-ringWrap{ left:20% !important; width:138px !important; height:138px !important; }
  .rlh-thumbs{ width:244px !important; }
  .rlh-thumb{ width:58px !important; height:58px !important; }
  .rlh-thumb:nth-child(2){ left:62px; }
  .rlh-thumb:nth-child(3){ left:124px; }
  .rlh-thumb:nth-child(4){ left:186px; }
}
