/* ── INDEX PAGE STYLES ── */

/* HERO */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;overflow:hidden;}
.hs-wrap{position:absolute;inset:0;}
.hs{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease;}
.hs.on{opacity:1;}
.hero-vignette{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.35) 55%,rgba(0,0,0,.55) 100%);}
.hero-grain{position:absolute;inset:0;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.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.6;pointer-events:none;}
.h-content{position:relative;z-index:2;padding-top:7rem;padding-bottom:3rem;}
.h-eyebrow{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1.8rem;display:block;}
.h-title{font-family:var(--ff-display);font-size:clamp(3.0rem,11vw,8.5rem);line-height:.9;letter-spacing:.01em;color:var(--white);margin-bottom:2rem;}
.h-title span{display:block;}
.h-title .h-gold{color:var(--gold);}
.h-title .h-gold em{font-family:var(--ff-serif);font-style:italic;font-size:.85em;font-weight:300;}
.h-sub{max-width:540px;font-size:1.05rem;line-height:1.78;color:rgba(255,255,255,.72);margin-bottom:2.8rem;font-weight:300;}
.h-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:4rem;}
.h-stats{display:flex;align-items:center;gap:0;flex-wrap:wrap;}
.h-stat{padding:0 2.8rem;}
.h-stat:first-child{padding-left:0;}
.h-num{font-family:var(--ff-display);font-size:3.2rem;color:var(--gold);line-height:1;}
.h-stat sup{font-family:var(--ff-display);font-size:1.8rem;color:var(--gold);vertical-align:super;}
.h-stat p{font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-top:.3rem;}
.h-div{width:1px;height:52px;background:rgba(255,255,255,.12);}
.h-scroll-hint{position:absolute;bottom:2.5rem;left:2.5rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.8rem;}
.h-scroll-hint span{font-size:.58rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.3);writing-mode:vertical-lr;}
.h-scr-line{width:1px;height:56px;background:linear-gradient(to bottom,rgba(201,168,76,.6),transparent);animation:scr 2.2s ease infinite;}
@keyframes scr{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}
.h-dots{position:absolute;bottom:2.5rem;right:2.5rem;z-index:2;display:flex;gap:.6rem;}
.h-dot{width:28px;height:2px;background:rgba(255,255,255,.22);cursor:pointer;transition:all .3s;border-radius:99px;}
.h-dot.on{background:var(--gold);width:48px;}

/* INTRO STRIP */
.intro-strip{background:var(--light);padding:8rem 0;}
.is-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;}
.is-text .eyebrow{margin-bottom:1rem;}
.is-h{font-family:var(--ff-serif);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:600;line-height:1.15;color:var(--dark);margin-bottom:1.5rem;}
.is-h em{font-style:italic;color:var(--gold-dk);}
.is-text p{font-size:.92rem;line-height:1.85;color:var(--muted);}
.is-badges{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.5rem;}
.is-badge{background:var(--white);border:1px solid rgba(0,0,0,.07);border-radius:var(--r-lg);padding:1rem;text-align:center;box-shadow:var(--sh);}
.is-badge span{display:block;font-family:var(--ff-display);font-size:1.4rem;color:var(--gold);letter-spacing:.05em;}
.is-badge p{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.3rem;font-weight:600;line-height:1.3;}
.is-imgs{position:relative;}
.is-img-main{border-radius:var(--r-lg);overflow:hidden;height:560px;position:relative;}
.is-img-sm{position:absolute;bottom:-3.5rem;right:-3rem;width:52%;height:270px;border-radius:var(--r-lg);overflow:hidden;border:6px solid var(--light);box-shadow:var(--sh-lg);}
.is-badge-float{position:absolute;top:2rem;left:2rem;background:var(--gold);color:var(--dark);padding:1.2rem 1.5rem;border-radius:var(--r);text-align:center;}
.ibf-num{display:block;font-family:var(--ff-display);font-size:2.8rem;line-height:1;}
.ibf-num sup{font-size:1.6rem;}
.ibf-txt{display:block;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-top:.3rem;}

/* SERVICES GRID */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.05);}
.srv-card{background:var(--dark3);overflow:hidden;cursor:pointer;transition:background .3s;}
.srv-card:hover{background:var(--dark4);}
.srv-card:hover .srv-img img{transform:scale(1.06);}
.srv-img{height:200px;overflow:hidden;}
.srv-img img{transition:transform .65s var(--ease);}
.srv-body{padding:2rem;}
.srv-num{font-family:var(--ff-display);font-size:3.5rem;color:rgba(201,168,76,.1);line-height:1;margin-bottom:.5rem;}
.srv-body h3{font-family:var(--ff-serif);font-size:1.35rem;color:var(--white);margin-bottom:.8rem;font-weight:600;}
.srv-body p{font-size:.8rem;line-height:1.78;color:rgba(255,255,255,.45);margin-bottom:1.5rem;}
.srv-arrow{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;transition:letter-spacing .3s;}
.srv-arrow:hover{letter-spacing:.28em;}
.srv-cta{text-align:center;margin-top:3.5rem;}

/* FEATURED PROJECTS */
.fp-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:start;}
.fp-main{background:var(--white);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);}
.fp-img{height:400px;overflow:hidden;}
.fp-img img{transition:transform .6s var(--ease);}
.fp-main:hover .fp-img img{transform:scale(1.04);}
.fp-info{padding:2.5rem;}
.fp-tag{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--gold-dk);margin-bottom:.7rem;display:block;}
.fp-info h3{font-family:var(--ff-serif);font-size:1.8rem;color:var(--dark);margin-bottom:.8rem;font-weight:600;}
.fp-info p{font-size:.88rem;line-height:1.8;color:var(--muted);}
.fp-side{display:flex;flex-direction:column;gap:1.5rem;}
.fp-sm{display:grid;grid-template-columns:140px 1fr;gap:0;background:var(--white);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);transition:transform .3s,box-shadow .3s;}
.fp-sm:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);}
.fp-sm-img{height:140px;}
.fp-sm-img img{transition:transform .5s var(--ease);}
.fp-sm:hover .fp-sm-img img{transform:scale(1.06);}
.fp-sm-info{padding:1.4rem;}
.fp-sm-info h4{font-family:var(--ff-serif);font-size:1.1rem;color:var(--dark);margin-bottom:.5rem;font-weight:600;}
.fp-sm-info p{font-size:.77rem;line-height:1.65;color:var(--muted);}
.fp-cta{text-align:center;margin-top:3rem;}

/* GALLERY STRIP */
.gallery-strip{overflow:hidden;height:230px;background:var(--dark);}
.gallery-track{display:flex;height:100%;animation:gscrl 28s linear infinite;}
.gallery-track img{min-width:340px;height:230px;object-fit:cover;opacity:.55;filter:grayscale(20%);transition:opacity .4s,filter .4s;}
.gallery-track img:hover{opacity:1;filter:grayscale(0);}
@keyframes gscrl{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* STATS BAND */
.stats-band{background:var(--dark);border-top:1px solid var(--border-w);border-bottom:1px solid var(--border-w);padding:5rem 0;}
.sb-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;}
.sb-item{text-align:center;padding:0 1.5rem;border-right:1px solid var(--border-w);}
.sb-item:last-child{border-right:none;}
.sb-num{font-family:var(--ff-display);font-size:4rem;color:var(--gold);letter-spacing:.02em;}
.sb-item sup{font-family:var(--ff-display);font-size:2rem;color:var(--gold);vertical-align:super;}
.sb-item p{font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:.4rem;font-weight:600;}

/* TESTIMONIALS */
.test-wrap{max-width:860px;margin:0 auto;}
.t-cards{position:relative;min-height:280px;}
.t-card{position:absolute;inset:0;opacity:0;transition:opacity .6s ease;padding:3.5rem;background:rgba(255,255,255,.04);border:1px solid var(--border-w);border-radius:var(--r-lg);pointer-events:none;}
.t-card.on{opacity:1;position:relative;pointer-events:auto;}
.t-stars{color:var(--gold);font-size:1.1rem;letter-spacing:.1em;margin-bottom:1.5rem;}
.t-quote{font-family:var(--ff-serif);font-size:1.2rem;font-style:italic;line-height:1.75;color:rgba(255,255,255,.82);margin-bottom:2rem;}
.t-client{display:flex;gap:1rem;align-items:center;}
.t-client img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.t-client strong{display:block;font-size:.88rem;color:var(--white);margin-bottom:.25rem;}
.t-client span{font-size:.72rem;color:rgba(255,255,255,.38);letter-spacing:.06em;}
.t-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:2.5rem;}
.t-arrow{width:42px;height:42px;border:1.5px solid rgba(255,255,255,.14);border-radius:50%;color:rgba(255,255,255,.5);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;background:none;}
.t-arrow:hover{border-color:var(--gold);color:var(--gold);}
.t-dot-wrap{display:flex;gap:.5rem;}
.t-dot{width:22px;height:2px;background:rgba(255,255,255,.18);border-radius:99px;cursor:pointer;transition:all .3s;}
.t-dot.on{background:var(--gold);width:38px;}

/* CTA PARALLAX */
.cta-parallax{position:relative;padding:10rem 0;overflow:hidden;}
.cta-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed;}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.78),rgba(0,0,0,.55));}
.cta-body{position:relative;z-index:1;max-width:780px;}
.cta-body h2{font-family:var(--ff-serif);font-size:clamp(2.2rem,4vw,3.8rem);color:var(--white);margin-bottom:1.2rem;font-weight:600;line-height:1.15;}
.cta-body h2 em{font-style:italic;color:var(--gold);}
.cta-body p{font-size:1rem;line-height:1.8;color:rgba(255,255,255,.68);margin-bottom:2.5rem;max-width:600px;}
.cta-actions{display:flex;gap:1rem;flex-wrap:wrap;}

/* RESPONSIVE */
@media(max-width:1024px){
  .is-grid,.fp-grid{grid-template-columns:1fr;gap:4rem;}
  .is-img-sm{right:0;bottom:-2rem;}
  .srv-grid{grid-template-columns:1fr 1fr;}
  .sb-grid{grid-template-columns:repeat(3,1fr);row-gap:3rem;}
  .sb-item:nth-child(3){border-right:none;}
}
@media(max-width:768px){
  .h-title{font-size:clamp(3.5rem,13vw,5.5rem);}
  .h-stats{gap:0;}
  .h-stat{padding:0 1.5rem;}
  .h-num{font-size:2.2rem;}
  .is-badges{grid-template-columns:1fr 1fr;}
  .srv-grid{grid-template-columns:1fr;}
  .fp-sm{grid-template-columns:1fr;}
  .fp-sm-img{height:200px;}
  .sb-grid{grid-template-columns:1fr 1fr;}
  .sb-item:nth-child(3){border-right:1px solid var(--border-w);}
  .sb-item:nth-child(2){border-right:none;}
  .sb-item:nth-child(4){border-right:none;}
  .t-card{padding:2rem;}
  .t-quote{font-size:1rem;}
}
@media(max-width:480px){
  .h-actions{flex-direction:column;}
  .h-stats{flex-direction:column;gap:1.5rem;align-items:flex-start;}
  .h-div{display:none;}
  .h-stat{padding:0;}
  .cta-actions{flex-direction:column;}
}
