/* assets/css/pages/home.css */

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:radial-gradient(120% 90% at 70% 10%,#262220,var(--color-bg-dark))}
.hero__dust{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;opacity:.5}
.hero__layers{position:absolute;inset:0;z-index:0}
.hero__layer{position:absolute;inset:0;background-size:cover;background-position:center}
.hero__layer--room{background-image:linear-gradient(180deg,rgba(20,20,20,.2),rgba(20,20,20,.7))}
.hero__inner{position:relative;z-index:2;padding-top:6rem}
.hero__kicker{margin-bottom:1.4rem}
.hero__title{font-size:var(--fs-900);line-height:.98}
.hero__title--accent{color:var(--color-rust-glow)}
.hero__sub{margin-top:1.6rem;font-size:var(--fs-500);color:var(--color-ivory-soft);max-width:44ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__scroll{position:absolute;bottom:0.9rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:var(--fs-200);letter-spacing:.2em;text-transform:uppercase;color:var(--color-ivory-soft)}
.hero__scroll span{width:1px;height:40px;background:var(--color-rust);animation:scrolldot 2s var(--ease-in-out-quart) infinite}
@keyframes scrolldot{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1)}}

/* ===== TAGLINE BAND ===== */
.tband{padding-block:clamp(3rem,9vh,7rem);border-block:1px solid var(--color-line);background:var(--color-bg-deep)}
.tband__text{font-family:var(--font-display);font-size:clamp(1.6rem,1rem + 3vw,3.2rem);line-height:1.35;color:var(--color-ivory);max-width:24ch}
.tband__text em{color:var(--color-rust-glow);font-style:italic}

/* ===== PILLARS ===== */
/* pillars: auto-cycling showcase */
.pillars__showcase{display:grid;grid-template-columns:0.82fr 1.18fr;gap:clamp(1.5rem,3vw,3rem);margin-top:2.5rem;align-items:stretch}
.pillars__nav{display:flex;flex-direction:column;gap:.5rem}
.pillars__tab{text-align:left;padding:1.2rem 1.6rem;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-sm);cursor:pointer;position:relative;overflow:hidden;transition:border-color .35s,background .35s}
.pillars__tab:hover{border-color:var(--color-rust)}
.pillars__tab.is-active{border-color:var(--color-rust);background:rgba(192,74,32,.07)}
.pillars__tab-num{display:block;font-family:var(--font-mono);font-size:var(--fs-200);color:var(--color-rust-glow);letter-spacing:.05em;margin-bottom:.2rem}
.pillars__tab-label{font-family:var(--font-display);font-size:var(--fs-500);font-weight:600;color:var(--color-ivory)}
.pillars__tab-bar{position:absolute;bottom:0;left:0;height:2px;background:var(--color-rust-glow);width:0}
.pillars__tab.is-active .pillars__tab-bar{animation:tabBar 5s linear forwards}
@keyframes tabBar{from{width:0}to{width:100%}}
.pillars__stage{display:grid}
.pillars__panel{grid-column:1;grid-row:1;display:flex;width:100%;align-items:center;gap:clamp(1.2rem,2.5vw,2rem);padding:clamp(1.4rem,2.5vw,2.2rem);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);opacity:0;visibility:hidden;transition:opacity .45s var(--ease-out-expo)}
.pillars__panel.is-active{opacity:1;visibility:visible}
.pillars__frame{position:relative;flex:none;width:clamp(118px,15vw,178px);aspect-ratio:1;display:grid;place-items:center;background:linear-gradient(160deg,rgba(192,74,32,.12),transparent 70%);border:1px solid var(--color-line);border-radius:var(--radius-sm);overflow:hidden}
.pillars__frame::before,.pillars__frame::after{content:'';position:absolute;width:14px;height:14px;border:2px solid var(--color-rust-glow);opacity:.65}
.pillars__frame::before{top:9px;left:9px;border-right:0;border-bottom:0}
.pillars__frame::after{bottom:9px;right:9px;border-left:0;border-top:0}
.pillars__frame-num{position:absolute;top:7px;right:11px;font-family:var(--font-mono);font-size:var(--fs-200);color:var(--color-rust-glow);opacity:.6}
.pillars__frame-tag{position:absolute;bottom:9px;left:11px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-ivory-soft);opacity:.55}
.pillars__art{width:62%;color:var(--color-rust-glow)}
.pillars__art svg{width:100%;height:auto;display:block}
.pillars__panel-body{display:flex;flex-direction:column;gap:.7rem;min-width:0;flex:1}
.pillars__panel-line{font-family:var(--font-display);font-size:clamp(1.5rem,1.1rem + 1.3vw,2.1rem);font-weight:600;color:var(--color-ivory);line-height:1.15}
.pillars__panel-desc{color:var(--color-ivory-soft);font-size:var(--fs-400);line-height:1.55}
.pillars__feat{display:flex;flex-wrap:wrap;gap:.5rem;margin:.15rem 0 .35rem;list-style:none;padding:0}
.pillars__feat li{font-size:.72rem;letter-spacing:.02em;color:var(--color-ivory-soft);background:rgba(245,239,230,.05);border:1px solid var(--color-line);border-radius:100px;padding:.3rem .78rem}
.pillars__panel-link{display:inline-block;margin-top:.6rem;color:var(--color-rust-glow);font-size:var(--fs-300);font-weight:600}

/* ===== SOLUTIONS STRIP ===== */
.solstrip{position:relative}
.solstrip__sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.solstrip__track{display:flex;gap:2rem;padding-inline:var(--container-pad);will-change:transform}
.solstrip__intro{flex:none;width:min(80vw,420px);align-self:center}
.solstrip__intro h2{font-size:var(--fs-800);margin-top:.6rem}
.solstrip__hint{margin-top:1.5rem;color:var(--color-rust-glow);font-family:var(--font-mono)}
.solcard{flex:none;width:min(80vw,360px);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);padding:2.4rem;display:flex;flex-direction:column;justify-content:space-between;min-height:360px;transition:border-color var(--dur-fast)}
.solcard:hover{border-color:var(--color-rust)}
.solcard__num{font-size:var(--fs-700);color:var(--color-rust)}
.solcard__title{font-size:var(--fs-600);margin-top:1rem}
.solcard__desc{color:var(--color-ivory-soft);margin-top:.6rem;flex:1}
.solcard__go{color:var(--color-rust-glow);font-size:var(--fs-300)}

/* ===== INSPIRATION ===== */
.inspo__board{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.polaroid{background:var(--color-ivory);padding:.8rem .8rem 2.2rem;border-radius:2px;box-shadow:0 12px 30px rgba(0,0,0,.4);transition:transform var(--dur-mid) var(--ease-out-expo)}
.polaroid--0{transform:rotate(-2deg)}.polaroid--1{transform:rotate(1.5deg)}.polaroid--2{transform:rotate(-1deg)}
.polaroid:hover{transform:rotate(0) scale(1.03);z-index:2}
.polaroid img{width:100%;aspect-ratio:4/3;object-fit:cover}
.inspo__more{margin-top:2.5rem;text-align:center}

/* ===== BRAND WALL ===== */
.brandwall{position:relative;overflow:hidden;padding-block:clamp(2.6rem,6vh,4.2rem);background:var(--color-bg-dark);border-block:1px solid var(--color-line)}
.brandwall::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 120% at 50% 0%,rgba(192,74,32,.16),transparent 62%);pointer-events:none}
.brandwall::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-rust),transparent);opacity:.65}
.brandwall .container{position:relative;z-index:1}
.brandwall .kicker{display:flex;align-items:center;justify-content:center;gap:clamp(.8rem,2vw,1.4rem);margin:0 auto 2.2rem;color:var(--color-rust-glow);font-size:clamp(.82rem,1.4vw,1.02rem);letter-spacing:.34em;font-weight:600;text-align:center}
.brandwall .kicker::before,.brandwall .kicker::after{content:'';height:1px;width:clamp(28px,6vw,72px);background:var(--color-rust);opacity:.55}
.brandwall__marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.brandwall__track{display:flex;align-items:center;white-space:nowrap;animation:marquee 45s linear infinite}
.brandwall__name{display:inline-flex;align-items:center;justify-content:center;padding-inline:clamp(1.4rem,3.1vw,2.9rem)}
.brandwall__logo{height:clamp(3.4rem,4.5vw,4.6rem);width:auto;max-width:230px;object-fit:contain;display:block}

/* ===== SHOWREEL ===== */
.showreel__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.glimpse{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-line)}
.glimpse__img{position:relative;aspect-ratio:4/3;background-size:cover;background-position:center;background-color:var(--color-surface);transition:transform var(--dur-slow) var(--ease-out-expo)}
.glimpse__tag{position:absolute;top:.8rem;left:.8rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;color:var(--color-ivory);background:rgba(30,30,30,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(245,239,230,.16);padding:.34rem .72rem;border-radius:var(--radius-pill);z-index:1}
.glimpse:hover .glimpse__img{transform:scale(1.05)}
.glimpse__meta{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.2rem;background:var(--color-surface)}
.glimpse__go{color:var(--color-rust-glow);font-size:var(--fs-200)}

/* ===== MAP ===== */
.map__inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.map__lede{margin-top:1.2rem;color:var(--color-ivory-soft);max-width:36ch}
.map__list{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:2rem}
.map__list a{display:flex;justify-content:space-between;color:var(--color-ivory-soft);border-bottom:1px solid var(--color-line);padding:.5rem 0}
.map__list a:hover{color:var(--color-rust-glow)}
.map__list li{border-radius:var(--radius-sm);transition:background .4s}
.map__list li a{transition:color .4s}
.map__list li.is-highlighted a{color:var(--color-rust-glow)}
.map__list li.is-highlighted .metric{color:var(--color-ivory)}
.map__list .metric{color:var(--color-rust-glow)}
.map__india{width:100%;max-width:420px;margin-inline:auto}
.map__pulse{transform-origin:center;transform-box:fill-box;animation:pulse 2.4s var(--ease-in-out-quart) infinite}
@keyframes pulse{0%{r:5;opacity:1}100%{r:18;opacity:0}}

/* ===== REVIEWS ===== */
/* reviews - dark cards with accent + spotlight */
.reviews__roller{margin-top:2.5rem;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.reviews__track{display:flex;gap:1.3rem;will-change:transform}
.rev-card{flex:0 0 calc((100% - 2.6rem) / 3);box-sizing:border-box;position:relative;background:var(--color-surface);border:1px solid var(--color-line);border-left:3px solid var(--color-rust);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:1.7rem 1.6rem 1.5rem}
.rev-card__mark{position:absolute;top:.4rem;right:1rem;font-family:var(--font-display);font-size:3rem;line-height:1;color:var(--color-rust);opacity:.18}
.rev-card__text{font-family:var(--font-display);font-size:var(--fs-500);line-height:1.4;color:var(--color-ivory);min-height:5.6em}
.rev-card__by{display:flex;align-items:center;gap:.8rem;margin-top:1.2rem}
.rev-card__avatar{flex:none;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(150deg,var(--color-rust),var(--color-rust-deep));color:var(--color-ivory);font-family:var(--font-display);font-size:1.15rem;font-weight:600}
.rev-card__meta strong{display:block;color:var(--color-ivory);font-size:var(--fs-300);font-weight:600}
.rev-card__meta span{color:var(--color-ivory-soft);font-size:var(--fs-200)}
.reviews__more{margin-top:2rem;text-align:center}

/* ===== FAQ CABINET ===== */
/* FAQ - clean accordion */
.cabinet{display:grid;gap:.5rem;width:100%}
.drawer{position:relative}
.drawer__front{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.2rem 1.6rem;text-align:left;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-sm);transition:border-color .3s,background .3s}
.drawer__front:hover{border-color:var(--color-rust)}
.drawer.is-open .drawer__front{border-color:var(--color-rust);background:rgba(192,74,32,.05);border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.drawer__q{font-family:var(--font-display);font-size:var(--fs-500);font-weight:500;color:var(--color-ivory)}
.drawer__handle{flex:none;width:22px;height:22px;position:relative}
.drawer__handle::before,.drawer__handle::after{content:'';position:absolute;background:var(--color-ivory-soft);border-radius:1px;transition:transform .3s}
.drawer__handle::before{width:22px;height:2px;top:10px;left:0}
.drawer__handle::after{width:2px;height:22px;top:0;left:10px}
.drawer.is-open .drawer__handle::after{transform:scaleY(0)}
.drawer__cavity{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-in-out-quart)}
.drawer__answer{padding:1.4rem 1.6rem;background:var(--color-surface);border:1px solid var(--color-line);border-top:0;border-radius:0 0 var(--radius-sm) var(--radius-sm)}
.drawer__answer p{color:var(--color-ivory-soft);max-width:56ch;line-height:1.6;opacity:0;transition:opacity .3s .1s}
.drawer.is-open .drawer__cavity{max-height:400px}
.drawer.is-open .drawer__answer p{opacity:1}
.faq__more{margin-top:1.5rem}
.faq__inner{display:grid;grid-template-columns:0.8fr 1.2fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.faq__aside{position:sticky;top:6rem}
.faq__lede{color:var(--color-ivory-soft);margin-top:1rem;line-height:1.6;max-width:34ch}
.faq__card{margin-top:2rem;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);padding:1.6rem}
.faq__card-q{font-family:var(--font-display);font-size:var(--fs-500);color:var(--color-ivory)}
.faq__card-a{color:var(--color-ivory-soft);font-size:var(--fs-300);margin:.45rem 0 1.1rem;line-height:1.5}

/* ===== PAGE END ===== */
.pageend{padding-block:clamp(3rem,7vh,5rem)}
.pageend__head{text-align:center}
.pageend__orn{display:block;width:46px;height:2px;background:var(--color-rust);margin:0 auto 1.3rem;border-radius:2px}
.pageend__line{font-family:var(--font-display);font-size:var(--fs-700);color:var(--color-ivory);max-width:20ch;margin-inline:auto;line-height:1.12}
.pageend__sub{color:var(--color-ivory-soft);margin:1rem auto 0;max-width:54ch;line-height:1.6}
.pageend__steps{list-style:none;padding:0;margin:2.8rem 0 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;counter-reset:none}
.pstep{position:relative;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);padding:1.5rem 1.4rem 1.6rem;transition:border-color .35s,transform .35s var(--ease-out-expo)}
.pstep::before{content:'';position:absolute;left:0;top:1.6rem;width:3px;height:1.6rem;background:var(--color-rust);border-radius:0 2px 2px 0;opacity:0;transition:opacity .35s}
.pstep:hover{border-color:var(--color-rust);transform:translateY(-5px)}
.pstep:hover::before{opacity:1}
.pstep__num{font-family:var(--font-mono);font-size:var(--fs-400);color:var(--color-rust-glow);letter-spacing:.04em}
.pstep__title{font-family:var(--font-display);font-size:var(--fs-500);color:var(--color-ivory);margin-top:.55rem}
.pstep__desc{color:var(--color-ivory-soft);font-size:var(--fs-300);line-height:1.55;margin-top:.55rem}
.pageend__cta{text-align:center;margin-top:2.4rem}
.pageend__link{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-rust-glow);font-size:var(--fs-400);border:1px solid var(--color-line);border-radius:var(--radius-pill);padding:.75rem 1.7rem;transition:border-color .3s,gap .3s}
.pageend__link:hover{border-color:var(--color-rust);gap:.9rem}
@media (max-width:860px){.pageend__steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.pageend__steps{grid-template-columns:1fr}}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .inspo__board,.showreel__grid{grid-template-columns:1fr 1fr}
  .rev-card{flex-basis:calc((100% - 1.3rem) / 2)}
  .map__inner{grid-template-columns:1fr}
}
@media (max-width:768px){
  .solstrip__sticky{position:static;height:auto;padding-block:3rem}
  .solstrip__track{flex-direction:column}
  .solstrip__intro,.solcard{width:100%}
}
@media (max-width:560px){
  .inspo__board,.showreel__grid{grid-template-columns:1fr}
  .rev-card{flex-basis:100%}
  
  .map__list{grid-template-columns:1fr}
}

/* ===== HERO (redesigned: 2-col + live isometric scene) ===== */
.hero__inner{display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:clamp(1.5rem,4vw,3.5rem);padding-top:clamp(6rem,10vh,8rem);padding-bottom:clamp(2.5rem,5vh,4rem)}
.hero__content{position:relative;z-index:3;display:flex;flex-direction:column;min-width:0}
.hero__kicker{margin-bottom:1.2rem}
.hero__title{font-size:var(--fs-800);line-height:1.02}
.hero__sub{margin-top:1.4rem;font-size:var(--fs-400);color:var(--color-ivory-soft);max-width:46ch;line-height:1.55}
.hero__stats{display:flex;flex-wrap:nowrap;gap:clamp(.7rem,1.8vw,1.4rem);margin-top:2rem;padding-top:1.3rem;border-top:1px solid var(--color-line)}
.hero__stat{display:flex;flex-direction:column;flex:1 1 0;min-width:0}
.hero__stat dt{font-family:var(--font-mono);font-size:clamp(1.35rem,.9rem + 1.1vw,1.8rem);color:var(--color-ivory);line-height:1}
.hero__stat dd{margin:.4rem 0 0;font-size:.66rem;letter-spacing:.07em;text-transform:uppercase;color:var(--color-ivory-soft);opacity:.72;line-height:1.25}
.hero__stat--accent dt{color:var(--color-rust-glow)}
.hero__actions{margin-top:2.2rem}
/* scene */
.hero-scene{position:relative;z-index:2;width:100%;max-width:520px;margin-inline:auto;aspect-ratio:600/480}
.hero-scene__svg{width:100%;height:auto;display:block;transition:transform .45s var(--ease-out-expo);overflow:visible}
.hero-scene__svg .fl{opacity:0;animation:scFade .7s ease forwards}
.hero-scene__svg .ln{stroke-dasharray:1;stroke-dashoffset:1;animation:scDraw .9s var(--ease-out-expo) forwards}
.hero-scene__svg .fp{opacity:0;transform:translateY(13px);animation:scRise .8s var(--ease-out-expo) forwards}
.hero-scene__svg text{opacity:0;animation:scFade .7s ease forwards}
.hero-scene__svg .d0{animation-delay:.15s}.hero-scene__svg .d1{animation-delay:.4s}.hero-scene__svg .d2{animation-delay:.7s}.hero-scene__svg .d3{animation-delay:1s}.hero-scene__svg .d4{animation-delay:1.3s}.hero-scene__svg .d5{animation-delay:1.6s}.hero-scene__svg .d6{animation-delay:2s}
.hero-scene__svg .dimlabel{fill:#b8ad9c;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em}
.hero-scene__svg .tag{fill:var(--color-rust-glow);font-family:var(--font-mono);font-size:12px;letter-spacing:.22em}
.hero-scene__svg .glow{animation:scGlow 4.5s ease-in-out 2.2s infinite}
.hero-scene__svg #pendant{animation:scSway 6s ease-in-out 2.4s infinite}
.hero-scene__svg .scan{opacity:0;animation:scScanIn .8s ease 2.2s forwards}
.hero-scene__svg .scan polygon{animation:scScan 6.5s ease-in-out 3s infinite}
.hero-scene__svg .iso-rot{transform-box:view-box;transform-origin:300px 300px;animation:scFloat 11s ease-in-out 2.6s infinite alternate}
@keyframes scFade{to{opacity:1}}
@keyframes scDraw{to{stroke-dashoffset:0}}
@keyframes scRise{to{opacity:1;transform:translateY(0)}}
@keyframes scGlow{0%,100%{opacity:.7}50%{opacity:1}}
@keyframes scSway{0%,100%{transform:rotate(-2.2deg)}50%{transform:rotate(2.2deg)}}
@keyframes scScanIn{to{opacity:1}}
@keyframes scScan{0%,100%{transform:translateX(-22px)}50%{transform:translateX(22px)}}
@keyframes scFloat{from{transform:rotate(-.5deg) translateY(0)}to{transform:rotate(.5deg) translateY(-7px)}}
.hero__visual{width:100%;max-width:540px;margin-inline:auto;display:flex;flex-direction:column;min-width:0}
.hero__scene-cap{margin-top:.7rem;text-align:center;font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.16em;text-transform:uppercase;color:var(--color-ivory-soft);opacity:.55}
.hero__visual .hero__stats{margin-top:1.1rem}
@media (max-width:980px){.hero__inner{grid-template-columns:1fr;padding-top:6rem;padding-bottom:2.5rem;gap:2rem}.hero__visual{max-width:490px;order:2}.hero__content{order:1}.hero__actions{margin-top:1.6rem}}
@media (max-width:560px){
  .hero__inner{padding-top:5.5rem;gap:1.5rem}
  .hero-scene,.hero__scene-cap{display:none}
  .hero__stats{flex-wrap:wrap}
  .hero__stat{flex:1 0 30%}
  .hero__stat dt{font-size:1.7rem}
  .hero__stat dd{white-space:normal}
}
@media (prefers-reduced-motion:reduce){
  .hero-scene__svg .fl,.hero-scene__svg .ln,.hero-scene__svg .fp,.hero-scene__svg text,.hero-scene__svg .scan{animation:none!important;opacity:1!important;transform:none!important;stroke-dashoffset:0!important}
  .hero-scene__svg .glow,.hero-scene__svg #pendant,.hero-scene__svg .scan polygon,.hero-scene__svg .iso-rot{animation:none!important}
}

/* hero centre watermark: drifting floor-plan */
.hero__motif{position:absolute;top:50%;left:0;transform:translateY(-50%);width:min(560px,46vw);z-index:1;pointer-events:none}
.hero-motif__svg{width:100%;height:auto;display:block;opacity:0;animation:motifIn 1.6s ease .5s forwards}
.hero-motif__svg .motif-rot{transform-box:view-box;transform-origin:235px 190px;animation:motifFloat 24s ease-in-out 1.6s infinite alternate}
.hero-motif__svg .motif-spark{animation:motifSpark 9s ease-in-out 1.8s infinite alternate}
@keyframes motifIn{to{opacity:1}}
@keyframes motifFloat{from{transform:rotate(-1.6deg) scale(1)}to{transform:rotate(1.6deg) scale(1.03)}}
@keyframes motifSpark{from{transform:translateX(0)}to{transform:translateX(360px)}}
@media (max-width:980px){.hero__motif{display:none}}
@media (prefers-reduced-motion:reduce){.hero-motif__svg{opacity:1;animation:none}.hero-motif__svg .motif-rot,.hero-motif__svg .motif-spark{animation:none}}

/* map city auto-highlight */
.map__india{width:100%;max-width:440px;margin-inline:auto;display:block;overflow:visible}
.map__land{transition:fill .4s}
.map__dot{opacity:.4;transition:opacity .6s}
.map__dot text{font-family:var(--font-body);transition:fill .5s,font-weight .3s}
.map__core{transition:r .4s var(--ease-out-expo)}
.map__halo{opacity:0;transform-box:fill-box;transform-origin:center;transition:opacity .4s}
.map__dot.is-highlighted{opacity:1}
.map__dot.is-highlighted .map__core{r:6}
.map__dot.is-highlighted .map__halo{opacity:1;animation:mapPulse 1.8s var(--ease-in-out-quart) infinite}
.map__dot.is-highlighted text{fill:var(--color-ivory);font-weight:600}
@keyframes mapPulse{0%{r:4.5;opacity:.9}70%{r:13;opacity:0}100%{r:13;opacity:0}}
/* responsive: new pillars */
@media (max-width:820px){.pillars__showcase{grid-template-columns:1fr;gap:1.4rem}.pillars__nav{flex-direction:row;flex-wrap:wrap;gap:.4rem}.pillars__tab{flex:1 1 44%;padding:.9rem 1rem}.faq__inner{grid-template-columns:1fr;gap:2rem}.faq__aside{position:static}}
@media (max-width:520px){.pillars__panel{flex-direction:column;align-items:flex-start;text-align:left}.pillars__frame{width:96px}}
/* ===== Journey: how we approach (auto-walking) ===== */
.journey__head{text-align:center;max-width:46rem;margin-inline:auto}
.journey__lede{color:var(--color-ivory-soft);margin-top:1rem;line-height:1.6}
.journey__path{list-style:none;padding:0;margin:3.4rem 0 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;position:relative}
.journey__path::before{content:'';position:absolute;top:32px;left:12.5%;right:12.5%;height:2px;background:repeating-linear-gradient(90deg,var(--color-line) 0 9px,transparent 9px 18px);opacity:.8;z-index:0}
.jstep{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.jstep__badge{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:var(--color-surface);border:2px solid var(--color-line);transition:border-color .45s,background .45s,box-shadow .45s,transform .45s var(--ease-out-expo)}
.jstep__badge svg{width:30px;height:30px;color:var(--color-ivory-soft);transition:color .45s}
.jstep__num{font-family:var(--font-mono);font-size:var(--fs-300);color:var(--color-rust-glow);margin-top:1rem;letter-spacing:.05em}
.jstep__title{font-family:var(--font-display);font-size:var(--fs-500);color:var(--color-ivory);margin-top:.3rem}
.jstep__desc{color:var(--color-ivory-soft);font-size:var(--fs-300);line-height:1.55;margin-top:.55rem;max-width:26ch}
.jstep:hover .jstep__badge{border-color:var(--color-rust);transform:translateY(-5px)}
.jstep.is-active .jstep__badge{border-color:var(--color-rust);background:var(--color-rust);box-shadow:0 0 0 7px rgba(192,74,32,.14);transform:translateY(-5px)}
.jstep.is-active .jstep__badge svg{color:var(--color-ivory)}
.journey__cta{text-align:center;margin-top:2.8rem}
@media (max-width:820px){.journey__path{grid-template-columns:1fr 1fr;gap:2.2rem 1.2rem}.journey__path::before{display:none}}
@media (max-width:520px){.journey__path{grid-template-columns:1fr}}