/* ===========================================================
   Neo Investment Banking — single page
   Design system mirrored from neo-group.in
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Instrument+Serif:ital@0;1&display=swap');

:root{
  --bg:#000614;
  --bg-deep:#010715;
  --purple:#231A3D;
  --cream:#FFFBF2;
  --gold:#DEC587;
  --gold-text:#CFA951;
  --gold-deep:#AC8A3A;
  --lavender:#ECE5FF;
  --muted:#8D8D8D;
  --ink:#4D4D4D;
  --white:#ffffff;
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Instrument Serif',Georgia,'Times New Roman',serif;
  --max:1440px;
  --navh:133px;
  --pad:clamp(20px,5vw,72px);
  --grad-card:linear-gradient(180deg,#231A3D 0%,#000000 100%);
  --grad-up:linear-gradient(0deg,#231A3D 0%,#000000 100%);
  --grad-glow:linear-gradient(to top,rgba(255,236,188,.72),rgba(255,236,188,0));
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--white);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.serif{font-family:var(--serif)}
.ital{font-style:italic}
.gold{color:var(--gold-text)}
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* HEADER is now verbatim Neo markup styled by neo-chrome.css (.site-nav etc.) */

/* ---------- HERO — exact Neo banner: video sits BELOW the header,
   inset ~74px (5vw) each side, on a near-black #010715 section ---------- */
.hero{
  background:#010715;
  padding:0 clamp(18px,5vw,74px) clamp(0px,3vw,4px);
}
.hero-frame{
  position:relative;width:100%;
  /* Neo header is 14vh in-flow; video fills the rest of the viewport */
  height:calc(100svh - 14vh);
  min-height:460px;max-height:860px;
  overflow:hidden;background:linear-gradient(180deg,#000 0%,#231A3D 100%);
}
.hero-frame video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* Neo has NO dark overlay on the video — keep it bright. Only a very faint
   bottom wash so the breadcrumb stays legible; text relies on text-shadow. */
.hero-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(0deg,rgba(1,7,21,.34) 0%,rgba(1,7,21,0) 22%);
}
@keyframes spin{to{transform:rotate(360deg)}}
/* generic rotating mandala (used by conviction band) */
.mandala-cut{position:absolute;width:520px;height:520px;z-index:2;opacity:.5;animation:spin 60s linear infinite}
.mandala-cut svg{width:100%;height:100%}
@media (prefers-reduced-motion:reduce){.mandala-cut{animation:none}}

.hero-inner{position:absolute;z-index:3;left:clamp(20px,3.6vw,54px);bottom:clamp(34px,7vw,84px);max-width:62%}
.hero h1{
  font-family:var(--sans);font-weight:300;
  font-size:clamp(26px,3.2vw,38px);line-height:1.18;letter-spacing:normal;
  max-width:20ch;color:#fff;text-shadow:0 2px 28px rgba(0,0,0,.5);
  overflow-wrap:break-word;word-wrap:break-word;hyphens:auto;
}
.hero h1 .ser{display:block;font-family:var(--serif);font-style:normal;font-weight:400;
  font-size:clamp(38px,5.6vw,64px);line-height:1.05;color:#fff;margin-top:6px}
.hero .kick{font-size:13px;letter-spacing:.28em;color:var(--gold-text);margin-bottom:22px;text-transform:uppercase}
.breadcrumb{
  position:absolute;right:clamp(20px,3.6vw,54px);bottom:clamp(26px,4vw,46px);z-index:3;
  font-family:var(--sans);font-size:16px;font-weight:500;letter-spacing:normal;
  color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.55);
  border-top:1px dotted rgba(222,197,135,.5);padding-top:16px;min-width:min(420px,72vw);text-align:right;
}
.breadcrumb b{color:var(--gold-text);font-weight:600}

/* ---------- TAB SECTION (cream) ---------- */
.proposition{background:var(--cream);color:var(--ink);position:relative;overflow:hidden}

/* EXACT replica of Neo's `.custom-border` (between hero and tab bar on
   neo-group.in/wealth-management). Static golden-mandala.gif, semi-cut
   via a 121px overflow:hidden box + background-position:50% -125px.
   No CSS rotation — any motion is baked into the GIF itself. */
.custom-border{
  position:relative;
  width:735px;max-width:100%;
  height:121px;
  margin:43px auto 0;       /* Neo: ~43px cream gap between video and the line */
  overflow:hidden;
}
.custom-border::before{               /* faint full-width gold hairline */
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:100vw;height:1px;z-index:1;
  background:linear-gradient(90deg,rgba(172,138,58,0) 0%,var(--gold-deep) 14%,var(--gold-deep) 86%,rgba(172,138,58,0) 100%);
}
.custom-border::after{
  content:"";position:absolute;top:0;left:0;right:0;height:120px;
  background:url("assets/golden-mandala.gif") 50% -125px / 250px no-repeat;
}

/* tab bar — carbon copy of neo-group .tabsection / .tabs / .tabsactive */
.tabbar-wrap{position:relative;z-index:2;margin-top:78px;background:linear-gradient(to top,rgba(255,236,188,.718),rgba(255,236,188,0))}
.tabbar{display:flex;justify-content:center;flex-wrap:wrap;max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.tab{
  font-family:var(--serif);font-size:clamp(20px,2vw,28px);color:rgb(77,77,77);font-weight:400;
  background:none;border:0;cursor:pointer;padding:20px 30px;position:relative;line-height:1;
  transition:background-image .3s ease;
}
.tab:hover{color:var(--purple)}
.tab.active{color:rgb(77,77,77);background-image:linear-gradient(to top,rgb(236,229,255),rgba(35,26,61,0))}
.tab.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:rgb(35,26,61)}

.panel-zone{position:relative;padding:64px var(--pad) 110px;max-width:var(--max);margin:0 auto;
  background:
    radial-gradient(620px 620px at -8% 64%,rgba(172,138,58,.10),transparent 60%);}
.mandala-wm{position:absolute;left:-220px;top:120px;width:540px;height:540px;opacity:.16;pointer-events:none;animation:spin 120s linear infinite}
.mandala-wm svg{width:100%;height:100%}
.panel{display:none}
.panel.active{display:block;animation:fade .6s ease}
@keyframes fade{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.panel-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:46px}
.panel-head h2{font-family:var(--serif);font-size:clamp(38px,5.2vw,72px);font-weight:400;line-height:1.04;color:var(--purple);max-width:9ch}
.panel-head p{max-width:42ch;font-size:15px;color:#6f6a5c}
.deck-nav{display:flex;gap:14px}
.deck-nav button{width:50px;height:50px;border-radius:50%;border:1px solid var(--gold-deep);background:none;color:var(--gold-deep);cursor:pointer;font-size:18px;transition:.3s}
.deck-nav button:hover{background:var(--gold-deep);color:var(--cream)}

/* deck of rounded navy cards */
.deck{position:relative;min-height:380px}
.card{
  position:relative;border-radius:10px;overflow:hidden;color:#fff;
  background:linear-gradient(180deg,rgb(35,26,61),rgb(0,0,0));
  padding:60px 50px;min-height:373px;
  display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:0 40px 80px -30px rgba(20,12,45,.6);
  transition:transform .7s cubic-bezier(.16,1,.3,1),opacity .6s;
}
.deck.stacked .card{position:absolute;inset:0}
.deck.stacked .card:nth-child(1){transform:translate(0,0) scale(1);z-index:5}
.deck.stacked .card:nth-child(2){transform:translate(22px,-16px) scale(.97);z-index:4;opacity:.85}
.deck.stacked .card:nth-child(3){transform:translate(44px,-32px) scale(.94);z-index:3;opacity:.7}
.deck.stacked .card:nth-child(n+4){transform:translate(66px,-48px) scale(.91);z-index:2;opacity:.5}
.card .num{font-family:var(--serif);font-size:96px;line-height:.8;color:rgba(172,138,58,.227);position:absolute;top:46px;left:50px}
.card h3{font-family:var(--serif);font-size:clamp(30px,3.4vw,40px);font-weight:300;color:#fff;margin-bottom:16px}
.card p{font-family:var(--sans);font-size:16.8px;color:rgba(255,255,255,.8);max-width:60ch;line-height:1.6}
.card .cwm{position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:360px;height:360px;opacity:.22;pointer-events:none}
.card .cwm svg{width:100%;height:100%;animation:spin 90s linear infinite}

/* people grid — B&W → colour on hover, gold inset frame, name/role overlay */
.people-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.person{position:relative;display:block;aspect-ratio:3/4;overflow:hidden;background:#0c0820;color:#fff}
.person img,.person .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.02) brightness(.9);
  transition:filter .55s ease,transform 1.1s cubic-bezier(.16,1,.3,1)}
/* tonal placeholder when no photo yet */
.person .ph{background:
  radial-gradient(60% 45% at 50% 32%,#5a5168 0%,#2c2740 45%,#16121f 100%);
  display:flex;align-items:flex-end;justify-content:center}
.person .ph::after{content:"";width:46%;height:58%;border-radius:50% 50% 46% 46%/60% 60% 40% 40%;
  background:linear-gradient(180deg,#7c7390,#3a3550);margin-bottom:-4%}
.person::before{content:"";position:absolute;inset:14px;border:1px solid rgba(222,197,135,0);
  z-index:3;transition:border-color .5s ease;pointer-events:none}
.person .meta{position:absolute;left:0;right:0;bottom:0;z-index:4;
  padding:26px 24px;
  background:linear-gradient(to top,rgba(8,5,18,.92),rgba(8,5,18,.55) 55%,rgba(8,5,18,0));
  opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease}
.person .meta h4{font-family:var(--serif);font-size:clamp(20px,1.7vw,26px);font-weight:400;margin-bottom:8px}
.person .meta span{display:block;font-size:12px;line-height:1.5;color:rgba(255,255,255,.82);letter-spacing:.02em}
.person .meta .div{color:var(--gold-text);margin-top:4px;font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.person:hover img,.person:hover .ph,.person:focus-visible img,.person:focus-visible .ph{filter:none;transform:scale(1.04)}
.person:hover::before,.person:focus-visible::before{border-color:rgba(222,197,135,.85)}
.person:hover .meta,.person:focus-visible .meta{opacity:1;transform:none}
@media (hover:none){.person .meta{opacity:1;transform:none}.person img,.person .ph{filter:none}}

.panel-head h2 em{font-style:italic;color:var(--gold-deep)}
#p-team .panel-head h2{max-width:none;white-space:nowrap}
@media (max-width:680px){#p-team .panel-head h2{white-space:normal}}

/* OFFERINGS — Neo Swiper-style carousel: rounded navy cards,
   active centred, neighbours peeking (carbon copy of .card1.card11) */
.off-carousel{position:relative;overflow:hidden;padding:10px 0 14px}
.off-track{display:flex;gap:clamp(20px,2.4vw,34px);
  transition:transform .65s cubic-bezier(.16,1,.3,1);will-change:transform}
.off-card{
  flex:0 0 clamp(280px,40vw,445px);
  min-height:clamp(400px,46vw,500px);
  border-radius:30px;
  background:linear-gradient(180deg,#231A3D 0%,#000 100%);
  padding:clamp(28px,3.2vw,40px);
  color:#fff;display:flex;flex-direction:column;
  transition:opacity .55s ease,transform .55s ease;
  opacity:.4;transform:scale(.9);
}
.off-card.is-active{opacity:1;transform:scale(1)}
.off-title{font-family:var(--serif);font-size:clamp(28px,3vw,35px);font-weight:400;
  line-height:1.1;margin-bottom:20px}
.off-desc{font-family:var(--sans);font-size:clamp(15px,1.1vw,16.5px);
  color:rgba(255,255,255,.82);line-height:1.7;flex:1}
.off-tag{display:block;margin-top:26px;color:rgb(184,141,46);
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.04em}

/* TRANSACTIONS — Group-site card style (#123): navy gradient rounded cards */
.tomb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tomb{position:relative;border-radius:24px;
  background:linear-gradient(180deg,#231A3D 0%,#000 100%);
  padding:42px 32px 36px;min-height:220px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;overflow:hidden;
  transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s}
.tomb::before{content:"";position:absolute;right:-80px;top:50%;width:300px;height:300px;transform:translateY(-50%);
  background:radial-gradient(circle,rgba(222,197,135,.10),transparent 60%);pointer-events:none}
.tomb:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(0,0,0,.65)}
.tomb-tag{position:absolute;top:22px;right:24px;font-size:11px;letter-spacing:.18em;
  color:rgb(184,141,46);font-weight:600}
.tomb-deal{font-family:var(--serif);font-size:clamp(22px,1.9vw,28px);color:#fff;font-weight:300;line-height:1.18}
.tomb-meta{margin-top:12px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.tomb-note{margin-top:30px;font-size:12.5px;color:#8d8d8d;font-style:italic}
@media (max-width:900px){.tomb-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.tomb-grid{grid-template-columns:1fr}}

/* PLATFORM — "Backed by the Neo platform" (#56) — 6 mandala-marked cards */
.platform{margin-top:clamp(60px,8vw,110px);padding-top:clamp(40px,6vw,80px);border-top:1px solid rgba(172,138,58,.28)}
.platform-head{text-align:center;max-width:760px;margin:0 auto clamp(40px,5vw,64px)}
.platform-head h2{font-family:var(--serif);font-size:clamp(34px,4.4vw,60px);font-weight:400;color:var(--purple);line-height:1.05;margin-bottom:18px}
.platform-head h2 em{font-style:italic;color:var(--gold-deep)}
.platform-head p{font-family:var(--sans);font-size:clamp(15px,1.15vw,18px);color:#6f6a5c;line-height:1.7;max-width:60ch;margin:0 auto}
.platform-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;list-style:none;padding:0}
.platform-grid li{position:relative;background:linear-gradient(180deg,rgba(255,236,188,.5),rgba(255,251,242,.2));
  border:1px solid rgba(172,138,58,.32);border-radius:18px;padding:38px 28px;text-align:center;overflow:hidden;
  transition:transform .45s ease,box-shadow .45s,border-color .35s}
.platform-grid li:hover{transform:translateY(-4px);border-color:var(--gold-deep);box-shadow:0 22px 48px -28px rgba(172,138,58,.5)}
.pf-mandala{display:block;width:54px;height:54px;margin:0 auto 18px;opacity:.55}
.pf-mandala svg{width:100%;height:100%}
.platform-grid h4{font-family:var(--serif);font-size:clamp(18px,1.5vw,22px);font-weight:400;color:var(--purple);line-height:1.25}
@media (max-width:900px){.platform-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.platform-grid{grid-template-columns:1fr}}

/* TEAM — sub-heading only (#75 remove section heading) + single col mobile (#122) */
.team-head{text-align:center;max-width:760px;margin:0 auto clamp(40px,5vw,56px)}
.team-sub{font-family:var(--sans);font-size:clamp(15px,1.15vw,18px);color:#6f6a5c;line-height:1.7}
@media (max-width:680px){.people-grid{grid-template-columns:1fr!important}}

/* ---------- CONVICTION BAND ---------- */
.band{position:relative;background:var(--grad-up);padding:clamp(90px,12vw,160px) 0;overflow:hidden;text-align:center}
.band .mandala-cut{right:auto;left:50%;top:auto;bottom:-260px;transform:translateX(-50%);opacity:.22}
.band q{font-family:var(--serif);font-size:clamp(28px,4vw,54px);font-weight:400;line-height:1.28;color:#f1edf6;max-width:20ch;display:block;margin:0 auto;quotes:none}
.band .attr{margin-top:34px;font-size:12px;letter-spacing:.24em;color:var(--gold-text);text-transform:uppercase}
/* footer gold railing — cream backdrop + whitespace above it, like Neo
   (cream content → padding → gold ornament → purple footer) */
.foot-railing{background:var(--cream);padding-top:clamp(56px,8vw,96px);line-height:0}
.foot-railing img{display:block;width:100%;margin:0;padding:0}

/* FOOTER is now verbatim Neo markup styled by neo-chrome.css (.footer/.footer2 etc.) */

/* ---------- RESPONSIVE ---------- */
@media (max-width:1180px){
  .people-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  :root{--pad:22px}
  .hero{padding:0 14px 0}
  .hero-frame{min-height:520px}
  .hero-inner{left:22px;right:22px;bottom:34px;max-width:none}
  .hero h1{font-size:26px;max-width:18ch}
  .hero h1 .ser{font-size:40px}
  .breadcrumb{left:22px;right:22px;min-width:0;text-align:left;bottom:24px}
  .tab{font-size:20px;padding:16px 14px}
  .panel-head h2{font-size:34px}
  .deck.stacked .card{position:relative;inset:auto;transform:none!important;opacity:1!important;margin-bottom:16px}
  .deck{min-height:0}
  .card .cwm{opacity:.12}
  .people-grid{grid-template-columns:repeat(2,1fr)}
  .mandala-wm{display:none}
}
