/* ============================================================
   MELHOR GROUP — cinematic motion layer (motion.css)
   Loaded after styles.css. Vanilla CSS, transform/opacity only.
   ============================================================ */

/* ---------- preloader: percentage + split-curtain ---------- */
#preloader{background:transparent}
#preloader .pl-half{position:absolute;left:0;right:0;height:50.5%;background:var(--olive-deep);
  transition:transform .9s cubic-bezier(.76,0,.24,1) .15s}
#preloader .pl-top{top:0}
#preloader .pl-bot{bottom:0}
#preloader .pl-inner{position:relative;z-index:2;transition:opacity .35s var(--ease)}
#preloader .pl-count{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,4rem);color:var(--hampton);
  line-height:1;font-variant-numeric:tabular-nums}
#preloader img{position:relative}
#preloader img::after{content:""}
body.booted #preloader .pl-inner{opacity:0}
body.booted #preloader .pl-top{transform:translateY(-101%)}
body.booted #preloader .pl-bot{transform:translateY(101%)}
/* logo shimmer */
@keyframes plShimmer{0%{opacity:.55;filter:brightness(.9)}50%{opacity:1;filter:brightness(1.25)}100%{opacity:.55;filter:brightness(.9)}}
#preloader img{animation:plShimmer 1.4s ease-in-out infinite}

/* ---------- big outlined marquee ---------- */
.marq{overflow:hidden;padding:clamp(1.6rem,3.5vw,3rem) 0;background:var(--bone);border-block:1px solid var(--line)}
.marq-track{display:flex;gap:clamp(2rem,4vw,4rem);white-space:nowrap;width:max-content;will-change:transform}
.marq-track span{font-family:var(--font-display);font-weight:500;font-size:clamp(3rem,8vw,7.5rem);line-height:1;
  color:transparent;-webkit-text-stroke:1.5px var(--clay);display:inline-flex;align-items:center;gap:clamp(2rem,4vw,4rem)}
.marq-track span::after{content:"\2726";color:var(--clay);-webkit-text-stroke:0;font-size:.35em}
.marq-track span:nth-child(even){color:var(--ink);-webkit-text-stroke:0;opacity:.92}

/* ---------- horizontal pinned showcase ---------- */
.hscroll{height:320vh;position:relative;background:var(--ink)}
.hs-sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.hs-track{display:flex;height:100%;will-change:transform}
.hs-panel{position:relative;flex:none;width:100vw;height:100%;overflow:hidden;cursor:pointer}
.hs-panel img{width:100%;height:100%;object-fit:cover;transform:scale(calc(1.18 - .18 * var(--pp,0)));will-change:transform}
.hs-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,32,26,.34) 0%,rgba(20,32,26,.05) 45%,rgba(20,32,26,.78) 100%)}
.hs-cap{position:absolute;left:var(--gutter);bottom:clamp(2.2rem,5vw,4.5rem);z-index:2;color:var(--bone)}
.hs-cap .hs-status{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--hampton);
  display:inline-flex;align-items:center;gap:.6em;margin-bottom:.8rem;opacity:0;transform:translateY(16px);transition:.6s var(--ease) .1s}
.hs-cap .hs-name{font-family:var(--font-display);font-size:clamp(3.4rem,8vw,7.5rem);line-height:.95;color:var(--bone);
  display:block;overflow:hidden}
.hs-cap .hs-name > span{display:inline-block;transform:translateY(105%);transition:transform .8s var(--ease) .15s}
.hs-cap .hs-sub{font-size:.95rem;color:#e3ddd2;margin-top:.8rem;opacity:0;transform:translateY(14px);transition:.6s var(--ease) .3s}
.hs-panel.on .hs-status,.hs-panel.on .hs-sub{opacity:1;transform:none}
.hs-panel.on .hs-name > span{transform:none}
.hs-head{position:absolute;top:clamp(1.6rem,4vw,3rem);left:var(--gutter);z-index:3;color:var(--bone);
  display:flex;align-items:center;gap:1rem;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:#cdb79f}
.hs-head::before{content:"";width:30px;height:1px;background:#cdb79f}
.hs-prog{position:absolute;bottom:clamp(1.2rem,3vw,2rem);right:var(--gutter);z-index:3;display:flex;gap:.5rem;align-items:center}
.hs-prog i{width:34px;height:2px;background:rgba(232,229,226,.25);display:block;position:relative;overflow:hidden}
.hs-prog i::after{content:"";position:absolute;inset:0;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.hs-prog i.on::after{transform:scaleX(1)}
@media (max-width:760px){.hscroll{display:none}}
@media (min-width:761px){.featured-mobile{display:none}}
@media (prefers-reduced-motion:reduce){
  .hscroll{display:none}
  .featured-mobile{display:block !important}
}

/* ---------- image curtain reveal ---------- */
.img-reveal{position:relative;overflow:hidden}
.img-reveal::after{content:"";position:absolute;inset:0;background:var(--clay);transform:scaleX(1);transform-origin:right;z-index:3}
.img-reveal img{transform:scale(1.2)}
.img-reveal.ir-in::after{transform:scaleX(0);transition:transform .9s cubic-bezier(.76,0,.24,1) .05s}
.img-reveal.ir-in img{transform:scale(1);transition:transform 1.3s var(--ease) .15s}
@media (prefers-reduced-motion:reduce){
  .img-reveal::after{display:none}
  .img-reveal img{transform:none}
}

/* ---------- odometer stats ---------- */
.odo{display:inline-block;overflow:hidden;height:1em;line-height:1;vertical-align:baseline}
.odo-strip{display:inline-flex;flex-direction:column;transition:transform 1.5s cubic-bezier(.22,1,.36,1);will-change:transform}
.odo-strip span{height:1em;line-height:1;display:block}
.odo-ch{display:inline-block}

/* ---------- timeline year roll ---------- */
.ms .yr{overflow:hidden}
.ms .yr > span{display:inline-block;transform:translateY(110%);transition:transform .8s var(--ease)}
.htimeline.in .ms .yr > span{transform:none}
.htimeline.in .ms:nth-child(1) .yr > span{transition-delay:.1s}
.htimeline.in .ms:nth-child(2) .yr > span{transition-delay:.3s}
.htimeline.in .ms:nth-child(3) .yr > span{transition-delay:.5s}
.htimeline.in .ms:nth-child(4) .yr > span{transition-delay:.7s}
.htimeline.in .ms:nth-child(5) .yr > span{transition-delay:.9s}
.htimeline.in .ms:nth-child(6) .yr > span{transition-delay:1.1s}

/* ---------- eyebrow type-out ---------- */
.eyebrow.typing::after{content:"\258D";color:var(--clay);margin-left:.15em;animation:caretBlink .7s steps(1) infinite}
@keyframes caretBlink{50%{opacity:0}}

/* ---------- card tilt + sheen ---------- */
.pcard,.prow-media{transform-style:preserve-3d}
.sheen{position:relative}
.sheen::before{content:"";position:absolute;inset:0;z-index:2;opacity:0;pointer-events:none;transition:opacity .4s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(227,208,167,.28),transparent 65%)}
.sheen:hover::before{opacity:1}

/* ---------- gallery focus dim ---------- */
@media (hover:hover){
  .gal-page:has(.gal-item:hover) .gal-item:not(:hover){
    transform:scale(.97);filter:grayscale(.55) brightness(.92);
    transition:transform .5s var(--ease),filter .5s var(--ease)}
}

/* ---------- form card gradient glow + floating labels ---------- */
@property --ga{syntax:"<angle>";initial-value:0deg;inherits:false}
.form-card.glow{position:relative;background:var(--bone)}
.form-card.glow::before{content:"";position:absolute;inset:-1px;border-radius:var(--r-card);z-index:-1;
  background:conic-gradient(from var(--ga),transparent 0 62%,var(--clay) 76%,var(--hampton) 84%,transparent 96%);
  animation:gaSpin 7s linear infinite}
@keyframes gaSpin{to{--ga:360deg}}
.ffield label{position:absolute;left:1.05em;top:1.05em;margin:0;pointer-events:none;z-index:2;
  font-size:.95rem;letter-spacing:.01em;text-transform:none;font-weight:500;color:#8e887c;
  transition:top .3s var(--ease),font-size .3s var(--ease),letter-spacing .3s var(--ease),color .3s}
.ffield input,.ffield textarea{padding:1.5em 1em .6em}
.ffield.on label{top:.5em;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--clay)}
.ffield{position:relative}
.ffield::after{content:"";position:absolute;left:50%;right:50%;bottom:0;height:2px;background:var(--clay);
  transition:left .4s var(--ease),right .4s var(--ease)}
.ffield:focus-within::after{left:8px;right:8px}

/* gold particle burst */
.burst-dot{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--clay);pointer-events:none;z-index:5}

/* ---------- ambient: dust, breathing, grain on imagery ---------- */
.dust-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero .dust-canvas{z-index:1}
.dark{position:relative;animation:breathe 14s ease-in-out infinite}
@keyframes breathe{0%,100%{background-color:var(--olive-deep)}50%{background-color:#1c241e}}
.dark .container{position:relative;z-index:2}
.cta-hero .inner{z-index:2}
.hero-media::after,.ph-media::after{content:"";position:absolute;inset:0;opacity:.06;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url%28%23n%29' opacity='0.6'/%3E%3C/svg%3E")}

/* ---------- scroll-to-top progress ring ---------- */
.fab.totop{position:relative}
.fab.totop .ring{position:absolute;inset:-3px;width:calc(100% + 6px);height:calc(100% + 6px);transform:rotate(-90deg);pointer-events:none}
.fab.totop .ring circle{fill:none;stroke:var(--clay);stroke-width:2.5;stroke-linecap:round;
  stroke-dasharray:163;stroke-dashoffset:163}

/* ---------- velocity skew targets ---------- */
.gal-page,.pindex{will-change:transform}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  #preloader{display:none !important}
  .marq-track{transform:none !important}
  .odo-strip{transition:none}
  .ms .yr > span{transform:none;transition:none}
  .eyebrow.typing::after{display:none}
  .sheen::before{display:none}
  .form-card.glow::before{animation:none}
  .dark{animation:none}
  .cursor-dot,.cursor-ring{display:none !important}
}
@media (max-width:760px){
  .marq-track span{font-size:2.4rem}
  .cursor-dot,.cursor-ring{display:none}
}
