/*
 Theme Name:   Inspiro Child for PuJOY
 Theme URI:    https://pujoystudio.com/
 Description:  Inspiro Child Theme with Cinematic Scrolling Homepage.
 Author:       PuJOY Studio
 Template:     inspiro
 Version:      1.0.0
*/
/* ─── TOKENS ─────────────────────────────────── */
:root {
  --ink:    #F7F3EE;
  --ash:    #FFFFFF;
  --slate:  #EBE5DC;
  --mist:   #D8CFC0;
  --silver: #736C65;
  --cloud:  #db8424;
  --ivory:  #242220;
  --gold:   #db8424;
  --gold-lt:#e39e4f;
  --brown:  #7b543f;
  --white:  #111111;
  --ease:   cubic-bezier(0.16,1,0.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:auto;} /* we handle smooth ourselves */
body{
  background:var(--ink);color:var(--ivory);
  font-family:'DM Sans',sans-serif;font-weight:300;line-height:1.75;
  font-size:17px;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}

/* ─── PRELOADER ──────────────────────────────── */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;
  transition:opacity .8s var(--ease),visibility .8s;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.pre-logo{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,8vw,4rem);font-weight:300;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;}
.pre-track{width:220px;height:1px;background:var(--mist);position:relative;overflow:hidden;}
.pre-fill{position:absolute;top:0;left:0;height:100%;background:var(--gold);width:0%;transition:width 2.6s var(--ease);}
.pre-pct{font-family:'Space Mono',monospace;font-size:.85rem;letter-spacing:.2em;color:var(--silver);}

/* ─── NAV ────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.5rem 4vw;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s,padding .5s;
}
nav.scrolled{background:rgba(42,31,26,.88);backdrop-filter:blur(18px);padding:1rem 4vw;}
.nav-logo{display:flex;align-items:center;}
.nav-logo img{height:75px;width:auto;object-fit:contain;transition:height .3s;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001;}
.hamburger span{width:25px;height:2px;background:var(--gold);transition:all .3s var(--ease);}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-inquire{display:none;}
.nav-links{display:flex;gap:2.5rem;list-style:none;font-size:.88rem;letter-spacing:.15em;text-transform:uppercase;align-items:center;}
.nav-links a{color:var(--cloud);position:relative;transition:color .3s;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease);}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{width:100%;}
.nav-cta{padding:.7rem 1.8rem;border:1px solid var(--gold);color:var(--gold);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:background .3s,color .3s;}
.nav-cta:hover{background:var(--gold);color:var(--white);}
.nav-cta::after{display:none;}

/* ═══════════════════════════════════════════════
   SCROLL-DRIVEN VIDEO SHOWCASE
   Each .svs-scene is 200vh tall — the first 100vh
   pins the panel while scroll scrubs the canvas;
   the second 100vh transitions out.
═══════════════════════════════════════════════ */
.svs-wrapper{
  position:relative;
}

/* sticky container */
.svs-scene{
  position:relative;
  height:200vh;          /* 2 screens = 1 pinned + 1 scroll-out */
}
.svs-sticky{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  display:flex;align-items:stretch;
}

/* canvas fills left side on desktop, full on mobile */
.svs-canvas-col{
  position:relative;
  flex:0 0 58%;
  overflow:hidden;
  background:#000;
}
.svs-canvas-col canvas{
  width:100%;height:100%;display:block;
}

/* scrubbar — thin gold line on left edge */
.svs-scrubbar{
  position:absolute;left:0;top:0;
  width:3px;height:100%;
  background:var(--mist);
  z-index:5;
}
.svs-scrubbar-fill{
  width:100%;
  background:var(--gold);
  height:0%;
  transition:height .05s linear;
}

/* caption */
.svs-caption{
  flex:1;
  display:flex;flex-direction:column;justify-content:center;
  padding:5vw 5vw 5vw 6vw;
  background:var(--ash);
  position:relative;overflow:hidden;
}
.svs-num{
  font-family:'Space Mono',monospace;
  font-size:.78rem;letter-spacing:.28em;
  color:var(--gold);text-transform:uppercase;
  margin-bottom:1.8rem;
  opacity:0;transform:translateY(18px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.svs-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,5vw,4rem);font-weight:300;line-height:1.1;
  color:var(--white);margin-bottom:1.5rem;
  opacity:0;transform:translateY(28px);
  transition:opacity .8s .1s var(--ease),transform .8s .1s var(--ease);
}
.svs-title em{font-style:italic;color:var(--gold-lt);}
.svs-body{
  font-size:1.05rem;color:var(--cloud);line-height:1.85;max-width:36ch;
  opacity:0;transform:translateY(18px);
  transition:opacity .8s .2s var(--ease),transform .8s .2s var(--ease);
}
.svs-tags{
  display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem;
  opacity:0;transform:translateY(12px);
  transition:opacity .7s .35s var(--ease),transform .7s .35s var(--ease);
}
.svs-tag{
  padding:.45rem 1rem;border:1px solid rgba(219,132,36,.3);
  font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.14em;
  color:var(--gold);text-transform:uppercase;
}
.svs-scene.active .svs-num,
.svs-scene.active .svs-title,
.svs-scene.active .svs-body,
.svs-scene.active .svs-tags{opacity:1;transform:translateY(0);}

/* progress text */
.svs-progress-label{
  margin-top:3rem;
  font-family:'Space Mono',monospace;
  font-size:.75rem;letter-spacing:.2em;color:var(--silver);text-transform:uppercase;
  display:flex;align-items:center;gap:.8rem;
}
.svs-progress-label .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:breathe 2s infinite;}

/* section dots nav on right */
.svs-dots{
  position:fixed;right:2rem;top:50%;transform:translateY(-50%);
  z-index:800;
  display:flex;flex-direction:column;gap:.7rem;
}
.svs-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--mist);border:1px solid var(--silver);
  cursor:pointer;transition:background .3s,transform .3s;
}
.svs-dot.active{background:var(--gold);border-color:var(--gold);transform:scale(1.4);}

/* transition overlay between scenes */
.svs-scene-overlay{
  position:absolute;inset:0;z-index:20;
  background:var(--ink);
  opacity:0;pointer-events:none;
  transition:opacity .4s;
}

/* ─── BELOW-VIDEO SECTIONS ───────────────────── */
.marquee-strip{border-top:1px solid var(--mist);border-bottom:1px solid var(--mist);overflow:hidden;padding:1rem 0;background:var(--ash);}
.marquee-track{display:flex;gap:4rem;width:max-content;animation:marquee 28s linear infinite;}
.marquee-item{display:flex;align-items:center;gap:1.5rem;white-space:nowrap;font-family:'Space Mono',monospace;font-size:.82rem;letter-spacing:.2em;color:var(--silver);text-transform:uppercase;}
.marquee-dot{width:4px;height:4px;background:var(--gold);border-radius:50%;}

section{position:relative;}
.section-inner{max-width:1300px;margin:0 auto;padding:0 4vw;}
.section-pad{padding-top:10rem;padding-bottom:10rem;}

.reveal{opacity:0;transform:translateY(50px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.visible{opacity:1;transform:none;}

/* PROCESS */
#process{background:var(--ash);}
.process-heading-wrap{text-align:center;margin-bottom:6rem;}
.process-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5vw,4.2rem);font-weight:300;color:var(--white);}
.about-kicker{font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.25em;color:var(--gold);text-transform:uppercase;margin-bottom:1.5rem;}
.process-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--mist);}
.process-step{background:var(--ash);padding:3rem 2.5rem;position:relative;overflow:hidden;transition:background .4s;}
.process-step::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);}
.process-step:hover{background:var(--slate);}
.process-step:hover::before{transform:scaleX(1);}
.step-num{font-family:'Cormorant Garamond',serif;font-size:5rem;font-weight:300;color:rgba(219,132,36,.12);line-height:1;margin-bottom:1.5rem;}
.step-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--white);margin-bottom:1rem;}
.step-body{font-size:1rem;color:var(--silver);line-height:1.8;}

/* WHY */
#why{background:var(--ink);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;}
.why-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,5vw,4.4rem);font-weight:300;line-height:1.1;color:var(--white);margin-bottom:2rem;}
.why-heading em{font-style:italic;color:var(--gold-lt);}
.why-body{color:var(--cloud);font-size:1.05rem;line-height:1.9;margin-bottom:3rem;}
.why-list{list-style:none;display:flex;flex-direction:column;gap:1.5rem;}
.why-item{display:flex;align-items:flex-start;gap:1.2rem;}
.why-icon{width:42px;height:42px;flex-shrink:0;background:rgba(219,132,36,.08);border:1px solid rgba(219,132,36,.25);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1rem;}
.why-item-text{font-size:1rem;color:var(--cloud);line-height:1.75;}
.why-item-label{font-weight:500;color:var(--ivory);margin-bottom:.3rem;font-size:1.05rem;}
.why-visual{position:relative;aspect-ratio:4/5;background:var(--slate);overflow:hidden;}
.why-visual canvas{width:100%;height:100%;}

/* TESTIMONIAL */
#testimonial{background:var(--ash);padding:8rem 6vw;text-align:center;}
.quote-mark{font-family:'Cormorant Garamond',serif;font-size:6rem;line-height:.5;color:var(--gold);opacity:.4;margin-bottom:1rem;}
.quote-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300;font-style:italic;color:var(--ivory);max-width:720px;margin:0 auto;line-height:1.55;}
.quote-author{margin-top:2.5rem;font-family:'Space Mono',monospace;font-size:.82rem;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;}
.quote-divider{width:50px;height:1px;background:var(--gold);margin:1.5rem auto;}

/* CONTACT */
#contact{background:var(--gold);padding:8rem 4vw;text-align:center;position:relative;overflow:hidden;}
.contact-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Cormorant Garamond',serif;font-size:clamp(6rem,18vw,16rem);font-weight:300;color:rgba(10,10,10,.06);white-space:nowrap;pointer-events:none;}
.contact-inner{position:relative;}
.contact-kicker{font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.25em;color:rgba(10,10,10,.55);text-transform:uppercase;margin-bottom:1.5rem;}
.contact-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5.5rem);font-weight:300;line-height:1.1;color:var(--ink);margin-bottom:2rem;}
.contact-details{display:flex;gap:3rem;justify-content:center;margin-top:3rem;flex-wrap:wrap;}
.contact-item{display:flex;flex-direction:column;gap:.4rem;}
.contact-item-label{font-family:'Space Mono',monospace;font-size:.75rem;letter-spacing:.18em;color:rgba(10,10,10,.5);text-transform:uppercase;}
.contact-item-val{font-size:1.05rem;color:var(--ink);font-weight:400;line-height:1.6;}
.btn-dark{display:inline-block;padding:1.1rem 3rem;background:var(--ink);color:var(--gold);font-family:'DM Sans',sans-serif;font-weight:500;font-size:.88rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border:none;margin-top:2.5rem;transition:background .3s,transform .3s;}
.btn-dark:hover{background:var(--ash);transform:translateY(-2px);}

/* FOOTER */
footer{background:var(--ink);padding:4rem 4vw 2rem;border-top:1px solid var(--mist);}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;flex-wrap:wrap;gap:2rem;}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:2.1rem;font-weight:300;color:var(--white);letter-spacing:.1em;}
.footer-brand span{color:var(--gold);}
.footer-tagline{font-size:.95rem;color:var(--silver);margin-top:.6rem;max-width:28ch;line-height:1.7;}
.footer-links{display:flex;gap:5rem;flex-wrap:wrap;}
.footer-col-title{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.75rem;}
.footer-col ul a{font-size:1rem;color:var(--silver);transition:color .3s;}
.footer-col ul a:hover{color:var(--ivory);}
.footer-bottom{border-top:1px solid var(--mist);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.footer-copy{font-size:.85rem;color:var(--silver);}
.footer-social{display:flex;gap:1.2rem;}
.social-link{width:38px;height:38px;border:1px solid var(--mist);display:flex;align-items:center;justify-content:center;color:var(--silver);font-size:.85rem;transition:border-color .3s,color .3s;}
.social-link:hover{border-color:var(--gold);color:var(--gold);}

/* ─── KEYFRAMES ──────────────────────────────── */
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{to{opacity:1;}}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes breathe{0%,100%{opacity:1;}50%{opacity:.2;}}
@keyframes scrollPulse{0%,100%{opacity:1;}50%{opacity:.15;}}

/* ─── HERO (static pin intro) ────────────────── */
#hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero-canvas-wrap{position:absolute;inset:0;}
#hero-canvas{width:100%;height:100%;display:block;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(247,243,238,.3) 0%,rgba(247,243,238,.5) 50%,rgba(247,243,238,.9) 100%);}
.hero-content{position:relative;z-index:10;text-align:center;padding:0 2rem;padding-bottom:5rem;}
.hero-eyebrow{font-family:'Space Mono',monospace;font-size:.82rem;letter-spacing:.28em;color:var(--gold);text-transform:uppercase;margin-bottom:1.5rem;opacity:0;transform:translateY(20px);animation:fadeUp 1s 1.2s var(--ease) forwards;}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3.8rem,11vw,9.5rem);font-weight:300;line-height:.95;color:var(--white);}
.text-reveal{display:inline-block;overflow:hidden;vertical-align:bottom;}
.text-reveal > span, .text-reveal > em {display:inline-block;transform:translateY(120%);animation:textRevealAnim 1s var(--delay) var(--ease) forwards;}
.text-reveal em{font-style:italic;color:var(--gold-lt);}
@keyframes textRevealAnim{to{transform:translateY(0);}}
.glow-text{position:relative;white-space:nowrap;}
.glow-text::after{content:'TO LIFE';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.8) 50%, transparent 100%);background-size:200% auto;color:transparent;-webkit-background-clip:text;background-clip:text;animation:shine 4s linear infinite;animation-delay:2.5s;opacity:0;}
@keyframes shine{0%{background-position:200% center;opacity:1;}20%{background-position:-200% center;opacity:1;}21%{opacity:0;}100%{opacity:0;}}
.hero-sub{margin-top:2rem;font-size:clamp(1rem,2vw,1.15rem);color:var(--cloud);letter-spacing:.05em;max-width:42ch;margin-left:auto;margin-right:auto;opacity:0;transform:translateY(20px);animation:fadeUp 1s 1.8s var(--ease) forwards;line-height:1.8;}
.hero-actions{margin-top:2rem;display:flex;gap:1.2rem;justify-content:center;align-items:center;flex-wrap:wrap;opacity:0;transform:translateY(20px);animation:fadeUp 1s 2.1s var(--ease) forwards;}
.btn-primary{padding:1rem 2.6rem;background:var(--gold);color:var(--white);font-size:.88rem;letter-spacing:.18em;text-transform:uppercase;font-family:'DM Sans',sans-serif;font-weight:500;cursor:pointer;border:none;transition:background .3s,transform .3s;}
.btn-primary:hover{background:var(--gold-lt);transform:translateY(-2px);}
.btn-ghost{padding:1rem 2.6rem;border:1px solid rgba(200,195,187,.4);color:var(--cloud);font-size:.88rem;letter-spacing:.18em;text-transform:uppercase;font-family:'DM Sans',sans-serif;cursor:pointer;transition:border-color .3s,color .3s,transform .3s;}
.btn-ghost:hover{border-color:var(--ivory);color:var(--ivory);transform:translateY(-2px);}
.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fadeIn 1s 2.5s forwards;}
.scroll-label{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.28em;color:var(--silver);text-transform:uppercase;}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s 3s infinite;}

/* ─── RESPONSIVE ─────────────────────────────── */
@media(max-width:900px){
  .svs-sticky{flex-direction:column;}
  .svs-canvas-col{flex:0 0 52vh;}
  .svs-caption{padding:2.8rem 6vw 3rem;}
  .svs-scrubbar{display:none;}
  .svs-num{margin-bottom:1rem;}
  .svs-dots{display:none;}
  .why-grid{grid-template-columns:1fr;gap:3rem;}
  .process-steps{grid-template-columns:1fr;}
  .footer-links{display:none;}
}
@media(max-width:600px){
  /* Nav */
  .hamburger{display:flex;}
  .desktop-only{display:none;}
  .mobile-inquire{display:block;margin-top:2rem;}
  .mobile-inquire a{display:inline-block;padding:.8rem 2rem;}
  .nav-links{
    display:flex;flex-direction:column;position:fixed;top:0;right:-100%;width:80%;height:100vh;
    background:rgba(247,243,238,.98);backdrop-filter:blur(10px);padding:6rem 2vw;
    transition:right .5s var(--ease);z-index:1000;gap:2rem;align-items:center;
  }
  .nav-links.active{right:0;}
  .nav-links a{font-size:1.2rem;}
  .nav-logo img{height:28px;}
  .nav-cta{font-size:.78rem;padding:.6rem 1.2rem;}

  /* Hero */
  .hero-eyebrow{font-size:.72rem;letter-spacing:.2em;}
  .hero-title{font-size:clamp(3rem,14vw,5rem);}
  .hero-sub{font-size:1rem;max-width:100%;}
  .btn-primary,.btn-ghost{font-size:.82rem;padding:.9rem 1.8rem;}
  .scroll-label{font-size:.68rem;}

  /* Showcase captions */
  .svs-canvas-col{flex:0 0 46vh;}
  .svs-num{font-size:.72rem;}
  .svs-title{font-size:clamp(2rem,7vw,2.8rem);}
  .svs-body{font-size:1rem;max-width:100%;}
  .svs-tag{font-size:.68rem;padding:.4rem .8rem;}
  .svs-progress-label{font-size:.68rem;}

  /* Process */
  .process-heading{font-size:clamp(2rem,8vw,3rem);}
  .about-kicker{font-size:.72rem;}
  .step-title{font-size:1.75rem;}
  .step-body{font-size:1rem;}
  .section-pad{padding-top:6rem;padding-bottom:6rem;}

  /* Why */
  .why-heading{font-size:clamp(2.2rem,8vw,3.2rem);}
  .why-body{font-size:1rem;}
  .why-item-text{font-size:1rem;}
  .why-item-label{font-size:1rem;}

  /* Testimonial */
  #testimonial{padding:5rem 6vw;}
  .quote-text{font-size:clamp(1.3rem,5vw,1.8rem);}
  .quote-author{font-size:.75rem;}

  /* Contact */
  #contact{padding:5rem 6vw;}
  .contact-heading{font-size:clamp(2.2rem,10vw,3.5rem);}
  .contact-kicker{font-size:.72rem;}
  .contact-item-label{font-size:.7rem;}
  .contact-item-val{font-size:1rem;}
  .contact-details{gap:2rem;}
  .btn-dark{font-size:.82rem;padding:1rem 2.2rem;}

  /* Footer */
  .footer-brand{font-size:1.8rem;}
  .footer-tagline{font-size:.95rem;}
  .footer-copy{font-size:.82rem;}
}


/* --- OVERRIDES ---------------------------------- */
.home #header, .home #site-header, .home .site-header, .home header,
.home #footer, .home #site-footer, .home .site-footer, .home footer.site-footer {
  display: none !important;
}

