/* ── Scroll Reveal Classes (GSAP-driven) ── */
.reveal-up{opacity:0;transform:translateY(60px)}
.reveal-down{opacity:0;transform:translateY(-60px)}
.reveal-left{opacity:0;transform:translateX(-60px)}
.reveal-right{opacity:0;transform:translateX(60px)}
.reveal-scale{opacity:0;transform:scale(0.85)}
.reveal-fade{opacity:0}
.reveal-rotate{opacity:0;transform:rotate(-5deg) scale(0.9)}
/* ── Word-by-word fade (Elicyon-style statement) ── */
.statement-word{display:inline-block;opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.statement-word.is-visible{opacity:1;transform:translateY(0)}
.fade-word{opacity:0.15;transition:opacity 0.5s ease}
.fade-word.is-active{opacity:1}
/* ── Parallax image wrapper ── */
.parallax-img{will-change:transform;transition:transform 0.1s linear}
.parallax-img img{width:100%;height:100%;object-fit:cover}
/* ── Ken Burns ── */
@keyframes kenBurns{
0%{transform:scale(1)}
100%{transform:scale(1.15)}
}
.ken-burns img{animation:kenBurns 20s ease-in-out infinite alternate}
/* ── Float / Hang decorative ── */
@keyframes floatY{
0%,100%{transform:translateY(0)}
50%{transform:translateY(-15px)}
}
@keyframes floatRotate{
0%,100%{transform:translateY(0) rotate(0deg)}
50%{transform:translateY(-12px) rotate(3deg)}
}
@keyframes hangPulse{
0%,100%{transform:translateY(0)}
50%{transform:translateY(8px)}
}
.anim-float{animation:floatY 6s ease-in-out infinite}
.anim-float-rotate{animation:floatRotate 8s ease-in-out infinite}
.anim-hang{animation:hangPulse 3s ease-in-out infinite}
/* ── Shimmer line ── */
@keyframes shimmer{
0%{background-position:-200% center}
100%{background-position:200% center}
}
.shimmer-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}
/* ── Gold pulse glow ── */
@keyframes goldPulse{
0%,100%{box-shadow:0 0 20px rgba(201,169,110,0.15)}
50%{box-shadow:0 0 40px rgba(201,169,110,0.35)}
}
.gold-glow{animation:goldPulse 4s ease-in-out infinite}
/* ── Background grain overlay ── */
@keyframes grainShift{
0%,100%{transform:translate(0,0)}
10%{transform:translate(-5%,-10%)}
20%{transform:translate(-15%,5%)}
30%{transform:translate(7%,-25%)}
40%{transform:translate(-5%,25%)}
50%{transform:translate(-15%,10%)}
60%{transform:translate(15%,0%)}
70%{transform:translate(0%,15%)}
80%{transform:translate(3%,35%)}
90%{transform:translate(-10%,10%)}
}
.grain-overlay::before{
content:'';position:absolute;inset:-50%;width:200%;height:200%;
background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
animation:grainShift 8s steps(10) infinite;pointer-events:none;z-index:1;opacity:0.5
}
/* ── Ornamental separator spin ── */
@keyframes spinSlow{
0%{transform:rotate(0deg)}
100%{transform:rotate(360deg)}
}
.ornament-spin{animation:spinSlow 30s linear infinite}
/* ── Stagger children ── */
.stagger-children>*{opacity:0;transform:translateY(30px)}
.stagger-children.is-visible>*{opacity:1;transform:translateY(0)}
.stagger-children>*:nth-child(1){transition-delay:0s}
.stagger-children>*:nth-child(2){transition-delay:0.15s}
.stagger-children>*:nth-child(3){transition-delay:0.3s}
.stagger-children>*:nth-child(4){transition-delay:0.45s}
.stagger-children>*:nth-child(5){transition-delay:0.6s}
.stagger-children>*{transition:opacity 0.7s ease,transform 0.7s ease}
/* ── Clip-path reveal ── */
.clip-reveal{clip-path:inset(100% 0 0 0);transition:clip-path 1.2s cubic-bezier(0.77,0,0.175,1)}
.clip-reveal.is-visible{clip-path:inset(0% 0 0 0)}
/* ── Magnetic hover (buttons) ── */
.magnetic-wrap{display:inline-block;position:relative}
/* ── Background pattern animations ── */
@keyframes bgPanSlow{
0%{background-position:0% 0%}
50%{background-position:100% 100%}
100%{background-position:0% 0%}
}
.bg-pan-slow{animation:bgPanSlow 30s ease infinite}
@keyframes radialPulse{
0%,100%{opacity:0.03}
50%{opacity:0.08}
}
.bg-radial-pulse::after{
content:'';position:absolute;inset:0;
background:radial-gradient(ellipse at center,var(--gold) 0%,transparent 70%);
opacity:0.03;animation:radialPulse 8s ease-in-out infinite;pointer-events:none
}
/* ══════════════════════════════════════ */
/* LUXURY PATTERNS                        */
/* ══════════════════════════════════════ */

/* ── 1. Watercolor Mask Reveal ── */
.mask-reveal-section{position:relative;overflow:hidden;min-height:100vh}
.mask-reveal-section .mask-bg{position:absolute;inset:0;z-index:1}
.mask-reveal-section .mask-bg img{width:100%;height:100%;object-fit:cover}
.mask-reveal-section .mask-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;min-height:100vh}

/* ── 2. Horizontal Scroll Gallery ── */
.hscroll-gallery{position:relative;overflow:hidden}
.hscroll-track{display:flex;gap:3rem;align-items:center;will-change:transform}
.hscroll-track .hscroll-item{flex-shrink:0;position:relative;overflow:hidden;border-radius:8px}
.hscroll-track .hscroll-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s ease}
.hscroll-track .hscroll-item:hover img{transform:scale(1.05)}
.hscroll-float{position:absolute;pointer-events:none;will-change:transform;opacity:0.4}

/* ── 3. Frosted Glass Cards ── */
.glass-card{background:rgba(246,240,237,0.12);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border:1px solid rgba(202,167,120,0.15);border-radius:16px;padding:3rem;color:#F6F0ED;position:relative;overflow:hidden;transition:transform 0.5s ease,box-shadow 0.5s ease}
.glass-card:hover{transform:translateY(-4px);box-shadow:0 24px 80px rgba(37,38,36,0.15)}
.glass-card-sage{background:rgba(187,193,178,0.12);border-color:rgba(187,193,178,0.2)}
.glass-card-blush{background:rgba(201,152,137,0.12);border-color:rgba(201,152,137,0.2)}
.glass-card .glass-label{font-family:'Montserrat',sans-serif;font-size:0.65rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(246,240,237,0.6)}
.glass-card .glass-title{font-family:'Farmhouse',cursive;font-size:2.5rem;color:#F6F0ED;margin:1rem 0}
.glass-card .glass-info{font-family:'Montserrat',sans-serif;font-weight:300;font-size:0.95rem;line-height:1.8;color:rgba(246,240,237,0.8)}
.glass-bg{position:relative;overflow:hidden}
.glass-bg>img,.glass-bg>video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ── 4. Shell Cursor ── */
.cursor-shell{position:fixed;top:0;left:0;width:40px;height:40px;pointer-events:none;z-index:9999;transition:transform 0.15s ease,opacity 0.3s ease;opacity:0}
.cursor-shell.is-visible{opacity:1}
.cursor-shell svg{width:100%;height:100%;fill:none;stroke:#CAA778;stroke-width:1.5;transition:fill 0.3s ease,transform 0.3s ease}
.cursor-shell.is-hover svg{fill:rgba(201,152,137,0.3);transform:scale(1.6)}
.cursor-shell.is-blend{mix-blend-mode:difference}
.cursor-shell.is-blend svg{stroke:#F6F0ED}

/* ── 5. Write-on Script (stroke-dashoffset) ── */
.write-on-text{stroke-dasharray:1000;stroke-dashoffset:1000;fill:none;stroke:#CAA778;stroke-width:1;transition:stroke-dashoffset 2s ease}
.write-on-text.is-visible{stroke-dashoffset:0}

/* ── 6. Scroll Speed Zones ── */
.scroll-zone-slow{--lenis-lerp:0.04}
.scroll-zone-normal{--lenis-lerp:0.1}
.scroll-zone-fast{--lenis-lerp:0.15}

/* ── 7. Split Text Animation ── */
.split-char{display:inline-block;opacity:0;transform:translateY(40px);will-change:transform,opacity}
.split-char.is-visible{opacity:1;transform:translateY(0);transition:opacity 0.5s ease,transform 0.5s cubic-bezier(0.16,1,0.3,1)}

/* ── 8. Editorial Photo Layout ── */
.editorial-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;overflow:hidden}
.editorial-split .editorial-img{position:relative;overflow:hidden}
.editorial-split .editorial-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.1);will-change:transform}
.editorial-split .editorial-text{display:flex;flex-direction:column;justify-content:center;padding:6rem 4rem}
@media(max-width:768px){
.editorial-split{grid-template-columns:1fr}
.editorial-split .editorial-text{padding:3rem 1.5rem}
}
