/* home.css */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:100px 5% 0;overflow:hidden;background:var(--white)}
#heroCanvas{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;width:100%;max-width:1300px;margin:0 auto}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,5.5vw,5rem);font-weight:700;line-height:1.06;letter-spacing:-.03em;color:var(--black);margin-bottom:1.6rem}
.hero-title em{font-style:italic;color:var(--cherry)}
.hero-sub{font-size:1.02rem;color:var(--gray);max-width:440px;line-height:1.8;margin-bottom:2.2rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-trust{display:flex;align-items:center;gap:.9rem}
.av-stack{display:flex}
.av-stack span{width:32px;height:32px;border-radius:50%;background:var(--cherry);color:var(--white);font-size:.73rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);margin-left:-8px}
.av-stack span:first-child{margin-left:0}
.hero-trust p{font-size:.84rem;color:var(--gray)}
.hero-trust strong{color:var(--ink)}
.hero-img-wrap{position:relative;border-radius:4px;overflow:visible}
.hero-img-wrap img{width:100%;height:520px;object-fit:cover;border-radius:4px;box-shadow:var(--sh-md)}
.hero-float{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--white);padding:1.3rem 1.7rem;border-radius:4px;box-shadow:var(--sh-md);display:flex;flex-direction:column;gap:.7rem;min-width:185px}
.hf-row{display:flex;align-items:center;gap:.8rem}
.hf-n{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;color:var(--cherry);line-height:1}
.hf-l{font-size:.74rem;color:var(--gray);line-height:1.3;max-width:75px}

/* why */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-g);border:1px solid var(--border-g);border-radius:var(--radius);overflow:hidden;margin-top:3rem}
.why-card{background:var(--white-alt);padding:2.2rem 2rem;position:relative;overflow:hidden;transition:background .3s}
.why-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--cherry);transition:width .4s}
.why-card:hover{background:var(--white)}
.why-card:hover::after{width:100%}
.wi{font-size:1.5rem;margin-bottom:1rem}
.why-card h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:700;color:var(--black);margin-bottom:.5rem}
.why-card p{font-size:.87rem;color:var(--gray);line-height:1.7}

/* services */
.sec-hdr{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;margin-bottom:2.5rem}
.svc-list{display:flex;flex-direction:column;border:1px solid var(--border-g);border-radius:var(--radius);overflow:hidden}
.svc-row{display:grid;grid-template-columns:56px 1fr auto auto 36px;align-items:center;gap:1.5rem;padding:1.5rem 2rem;border-bottom:1px solid var(--border-g);background:var(--white);transition:background .25s,padding-left .25s}
.svc-row:last-child{border-bottom:none}
.svc-row:hover{background:var(--cherry-pale);padding-left:2.5rem}
.svc-num{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--cherry);opacity:.45}
.svc-body h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:700;color:var(--black);margin-bottom:.2rem}
.svc-body p{font-size:.84rem;color:var(--gray);line-height:1.55}
.svc-tags{display:flex;gap:.35rem;flex-wrap:wrap}
.svc-tags span{font-size:.67rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;border:1px solid var(--border);color:var(--cherry);padding:.18rem .5rem;border-radius:1px}
.svc-price{font-size:.85rem;color:var(--gray);white-space:nowrap}
.svc-price strong{color:var(--cherry);font-size:1rem}
.svc-arr{font-size:1.1rem;color:var(--cherry);opacity:0;transition:opacity .2s,transform .2s}
.svc-row:hover .svc-arr{opacity:1;transform:translateX(4px)}

/* works */
.works-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:1rem}
.work-col{display:flex;flex-direction:column;gap:1rem}
.work-card{display:block;border-radius:var(--radius);overflow:hidden}
.work-img{position:relative;overflow:hidden}
.work-img img{width:100%;height:280px;object-fit:cover;transition:transform .6s}
.works-grid>.work-card .work-img img{height:576px}
.work-card:hover .work-img img{transform:scale(1.05)}
.wov{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.82) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.4rem;opacity:0;transition:opacity .35s}
.work-card:hover .wov{opacity:1}
.wcat{font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cherry-mid);margin-bottom:.3rem}
.wov h3{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:700;color:var(--white)}

/* testi */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.testi-card{padding:2rem;border:1px solid var(--border-g);border-radius:var(--radius);transition:box-shadow .3s,transform .3s;background:var(--white)}
.testi-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.ts{color:var(--cherry);font-size:.85rem;letter-spacing:2px;margin-bottom:1rem}
.tt{font-size:.91rem;color:var(--gray);line-height:1.8;font-style:italic;margin-bottom:1.5rem}
.ta{display:flex;align-items:center;gap:.9rem}
.tav{width:38px;height:38px;border-radius:50%;background:var(--cherry);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.84rem;flex-shrink:0}
.ta strong{display:block;font-size:.9rem;color:var(--black)}
.ta span{font-size:.76rem;color:var(--gray)}

/* cta */
.cta-sec{background:var(--cherry);padding:6rem 5%;text-align:center}
.cta-in{max-width:620px;margin:0 auto}
.cta-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:700;color:var(--white);letter-spacing:-.02em;line-height:1.1;margin-bottom:1rem}
.cta-title em{font-style:italic;opacity:.8}
.cta-sub{font-size:.97rem;color:rgba(255,255,255,.7);max-width:430px;margin:0 auto 2.5rem;line-height:1.75}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr}.hero-right{display:none}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr 1fr}
  .works-grid{grid-template-columns:1fr}
  .work-col{flex-direction:row}
  .works-grid>.work-card .work-img img{height:340px}
  .svc-row{grid-template-columns:50px 1fr}.svc-tags,.svc-arr{display:none}
}
@media(max-width:768px){
  .why-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .work-col{flex-direction:column}
}
@media(max-width:480px){
  .why-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
}