/* ============================================
   SARANG NITIN GADKARI — OFFICIAL WEBSITE
   Premium Executive Brand System
   ============================================ */

:root{
  --midnight:#0A1628;
  --midnight-2:#0E1B33;
  --midnight-3:#142849;
  --steel:#5A6378;
  --steel-2:#8C95A8;
  --line:#1d2a44;
  --line-2:#e5e8ef;
  --white:#ffffff;
  --paper:#f6f7fa;
  --emerald:#0F7B5C;
  --emerald-2:#14a37b;
  --gold:#C8A55B;
  --gold-2:#e3c485;
  --shadow-1:0 30px 80px -30px rgba(10,22,40,.35);
  --shadow-2:0 14px 40px -18px rgba(10,22,40,.45);
  --radius-s:8px;
  --radius-m:14px;
  --radius-l:24px;
  --radius-xl:36px;
  --maxw:1320px;
  --gutter:clamp(20px,4vw,56px);
  --tx-h: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --tx-b: 'Manrope','Inter', system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
}

*,*:before,*:after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--tx-b);
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:var(--midnight);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease}
button{font:inherit}
::selection{background:var(--midnight);color:var(--gold-2)}

/* Typography */
h1,h2,h3,h4,h5{
  font-family:var(--tx-h);
  font-weight:500;
  letter-spacing:-.01em;
  line-height:1.08;
  margin:0 0 .4em;
  color:var(--midnight);
}
h1{font-size:clamp(2.4rem, 5.6vw, 4.8rem); letter-spacing:-.025em}
h2{font-size:clamp(1.9rem, 3.6vw, 3rem); letter-spacing:-.02em}
h3{font-size:clamp(1.35rem, 2.2vw, 1.75rem)}
h4{font-size:1.15rem;font-weight:600;font-family:var(--tx-b);letter-spacing:.02em}
p{margin:0 0 1rem;color:#293649}
.lede{font-size:clamp(1.05rem,1.4vw,1.2rem);color:#3a4866;line-height:1.7}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--tx-b);
  font-size:.74rem;font-weight:600;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.eyebrow:before{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--gold-2)}
.eyebrow.light:before{background:var(--gold-2)}

.serif{font-family:var(--tx-h)}
.italic{font-style:italic}
.gold{color:var(--gold)}
.emerald{color:var(--emerald)}

.container{
  width:100%;max-width:var(--maxw);
  margin:0 auto;padding:0 var(--gutter);
}

.section{padding: clamp(70px, 9vw, 130px) 0}
.section-tight{padding: clamp(50px, 6vw, 90px) 0}
.section-dark{background:var(--midnight);color:#dbe1ee}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark p{color:#bcc6d8}
.section-paper{background:var(--paper)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;
  border-radius:999px;
  font-weight:600;
  font-size:.92rem;
  letter-spacing:.04em;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
  white-space:nowrap;
}
.btn-primary{
  background:var(--midnight);color:#fff;
  box-shadow:var(--shadow-2);
}
.btn-primary:hover{background:#0d1d36;transform:translateY(-2px); box-shadow:0 22px 45px -22px rgba(10,22,40,.6)}
.btn-gold{background:var(--gold);color:#1a1a1a}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn-outline{border:1px solid var(--midnight);color:var(--midnight);background:transparent}
.btn-outline:hover{background:var(--midnight);color:#fff}
.btn .arrow{font-size:1.05rem;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ============ NAVIGATION ============ */
.nav-wrap{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(10,22,40,.06);
  transition:background .3s ease;
}
.nav-wrap.scrolled{background:rgba(255,255,255,.97)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;gap:30px;
}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-mark{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--midnight) 0%,var(--midnight-3) 100%);
  color:var(--gold-2);
  display:grid;place-items:center;
  font-family:var(--tx-h);font-size:1.05rem;font-weight:600;
  letter-spacing:.02em;
  border:1px solid rgba(200,165,91,.4);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:var(--tx-h);font-size:1.18rem;font-weight:500;color:var(--midnight)}
.brand-sub{font-size:.66rem;letter-spacing:.32em;color:var(--steel);text-transform:uppercase}

.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav-links a{
  position:relative;
  display:inline-block;
  padding:10px 14px;
  font-size:.86rem;
  font-weight:500;
  color:#26334a;
  letter-spacing:.03em;
  border-radius:8px;
}
.nav-links a:hover{color:var(--midnight)}
.nav-links a.active{color:var(--midnight);font-weight:600}
.nav-links a.active:after{
  content:"";position:absolute;bottom:2px;left:14px;right:14px;height:2px;
  background:var(--gold);border-radius:2px;
}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{
  display:none;width:46px;height:46px;border:1px solid var(--line-2);
  background:#fff;border-radius:12px;cursor:pointer;
  align-items:center;justify-content:center;
}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--midnight);position:relative}
.nav-toggle span:before,.nav-toggle span:after{
  content:"";position:absolute;left:0;width:18px;height:2px;background:var(--midnight);
}
.nav-toggle span:before{top:-6px}
.nav-toggle span:after{top:6px}

@media (max-width: 1080px){
  .nav-links{
    position:fixed;inset:78px 0 auto 0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line-2);
    padding:14px var(--gutter) 28px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .25s ease, opacity .25s ease;
    box-shadow:0 30px 60px -40px rgba(10,22,40,.3);
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a{padding:14px 4px;border-bottom:1px solid #f0f2f7;font-size:1rem}
  .nav-links a.active:after{display:none}
  .nav-toggle{display:inline-flex}
}

/* ============ ACCESS GATE (index.html) ============ */
.gate{
  min-height:100vh;
  display:grid;place-items:center;
  position:relative;
  background:radial-gradient(ellipse at top, #142849 0%, #0A1628 60%, #050b18 100%);
  color:#fff;
  padding:40px 24px;
  overflow:hidden;
}
.gate:before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 60% at 18% 30%, rgba(200,165,91,.10), transparent 60%),
    radial-gradient(50% 60% at 82% 70%, rgba(15,123,92,.12), transparent 60%);
  pointer-events:none;
}
.gate:after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  pointer-events:none;
}
.gate-orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.gate-orbs i{
  position:absolute;border-radius:50%;
  filter:blur(60px);opacity:.4;
  animation:floaty 14s ease-in-out infinite;
}
.gate-orbs i:nth-child(1){width:380px;height:380px;left:-120px;top:-120px;background:#1a3766}
.gate-orbs i:nth-child(2){width:420px;height:420px;right:-160px;bottom:-160px;background:#0F7B5C;animation-delay:-6s}
.gate-orbs i:nth-child(3){width:280px;height:280px;left:55%;top:35%;background:#C8A55B;opacity:.18;animation-delay:-3s}

@keyframes floaty{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(30px,-25px)}
}

.gate-card{
  position:relative;z-index:2;
  width:min(520px, 100%);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
  padding:clamp(34px, 4vw, 56px);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 50px 100px -30px rgba(0,0,0,.55);
  text-align:center;
  animation:gateIn .9s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes gateIn{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}

.gate-emblem{
  width:74px;height:74px;border-radius:50%;
  margin:0 auto 26px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(200,165,91,.25), rgba(200,165,91,.05));
  border:1px solid rgba(200,165,91,.35);
  color:var(--gold-2);
  position:relative;
}
.gate-emblem:before{
  content:"";position:absolute;inset:-8px;border-radius:50%;
  border:1px dashed rgba(200,165,91,.25);
  animation:rot 22s linear infinite;
}
@keyframes rot{to{transform:rotate(360deg)}}
.gate-emblem svg{width:30px;height:30px}

.gate-eyebrow{
  font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;
}
.gate h1{
  color:#fff;font-size:clamp(1.9rem,3.3vw,2.6rem);
  margin:14px 0 10px;font-weight:500;
}
.gate p.sub{
  color:#b9c2d4;font-size:1rem;margin:0 auto 30px;max-width:380px;
}
.gate-form{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.gate-input-row{position:relative}
.gate-input{
  width:100%;
  padding:18px 56px 18px 22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  color:#fff;font-size:1rem;
  letter-spacing:.06em;
  outline:none;
  transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.gate-input::placeholder{color:#7a8499;letter-spacing:.04em}
.gate-input:focus{
  border-color:var(--gold);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 4px rgba(200,165,91,.12);
}
.gate-input.error{
  border-color:#e85a6a;
  animation:shake .45s cubic-bezier(.36,.07,.19,.97);
}
@keyframes shake{
  10%,90%{transform:translateX(-2px)}
  20%,80%{transform:translateX(3px)}
  30%,50%,70%{transform:translateX(-6px)}
  40%,60%{transform:translateX(6px)}
}
.gate-toggle{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:10px;
  background:transparent;border:1px solid transparent;
  cursor:pointer;color:#7a8499;display:grid;place-items:center;
  transition:color .2s ease, background .2s ease;
}
.gate-toggle:hover{color:var(--gold-2);background:rgba(255,255,255,.05)}
.gate-toggle svg{width:18px;height:18px}

.gate-btn{
  margin-top:6px;
  padding:17px 22px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-2) 100%);
  color:#1a1a1a;
  font-weight:700;letter-spacing:.06em;
  border:none;border-radius:14px;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.gate-btn:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(200,165,91,.45)}

.gate-msg{
  font-size:.85rem;color:#e85a6a;
  min-height:1.2em;letter-spacing:.04em;
}
.gate-foot{
  margin-top:34px;font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:#5e6b85;
}
.gate-foot strong{color:#cbd2e0;letter-spacing:.04em;text-transform:none;font-weight:500}

/* ============ HERO (Home) ============ */
.hero{
  position:relative;
  background:linear-gradient(180deg, #ffffff 0%, #f6f7fa 100%);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(30px,5vw,80px);
  align-items:center;
  padding:clamp(50px,8vw,110px) 0 clamp(70px,8vw,110px);
}
.hero-copy h1{
  font-family:var(--tx-h);font-weight:400;
  margin-bottom:24px;
}
.hero-copy h1 em{font-style:italic;color:var(--gold);font-weight:500}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:30px;
  margin:34px 0 36px;padding:24px 0;
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
}
.hero-meta div{min-width:120px}
.hero-meta .num{
  display:block;font-family:var(--tx-h);font-size:1.9rem;font-weight:500;
  color:var(--midnight);line-height:1;
}
.hero-meta .lbl{
  display:block;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--steel);margin-top:6px;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}

.hero-portrait{
  position:relative;
  aspect-ratio: 4/5;
  border-radius:24px;
  overflow:hidden;
  background:#0e1c33;
  box-shadow:var(--shadow-1);
}
.hero-portrait img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 22%;
  transform:scale(1.02);
  transition:transform .8s ease;
}
.hero-portrait:hover img{transform:scale(1.05)}
.hero-portrait:after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(10,22,40,.55) 100%);
}
.hero-portrait .badge{
  position:absolute;bottom:22px;left:22px;right:22px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  color:#fff;z-index:2;
}
.hero-portrait .badge h4{
  color:#fff;margin:0;font-size:1rem;letter-spacing:.04em;
}
.hero-portrait .badge p{
  color:#cdd5e3;margin:0;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
}
.hero-portrait .seal{
  width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  display:grid;place-items:center;color:var(--gold-2);
  border:1px solid rgba(200,165,91,.35);
  font-family:var(--tx-h);font-size:.95rem;
  text-align:center;line-height:1.05;
}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:40px;padding-top:40px}
  .hero-portrait{aspect-ratio:4/5;max-width:520px}
}

/* Marquee strip */
.tickers{
  background:var(--midnight);color:#cbd5e6;
  padding:20px 0;border-top:1px solid #0d1d36;
  overflow:hidden;
}
.tickers-track{
  display:flex;gap:60px;align-items:center;
  white-space:nowrap;
  animation:marquee 38s linear infinite;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tickers span{
  font-family:var(--tx-h);font-size:1.1rem;font-style:italic;color:#cbd5e6;
}
.tickers em{font-style:normal;color:var(--gold-2);margin:0 22px;font-size:.7rem;letter-spacing:.4em}

/* Pillars / Snapshot grid */
.pillars{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px,1fr));
  gap:24px;margin-top:60px;
}
.pillar{
  padding:36px 28px 30px;
  border:1px solid var(--line-2);
  border-radius:20px;
  background:#fff;
  position:relative;
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.pillar:hover{transform:translateY(-4px);border-color:rgba(10,22,40,.18);box-shadow:var(--shadow-2)}
.pillar .num{
  font-family:var(--tx-h);font-size:.78rem;font-weight:500;
  color:var(--gold);letter-spacing:.3em;text-transform:uppercase;
}
.pillar h3{font-size:1.35rem;margin:14px 0 12px}
.pillar p{font-size:.94rem;color:#48556e;margin:0}
.pillar:before{
  content:"";position:absolute;left:28px;top:0;width:34px;height:3px;
  background:var(--gold);
}

/* Two-column feature */
.feature{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(30px,5vw,80px);align-items:center;
}
.feature.reverse{direction:rtl}
.feature.reverse > *{direction:ltr}
.feature-img{
  position:relative;border-radius:24px;overflow:hidden;
  aspect-ratio:5/4;background:#0e1c33;
  box-shadow:var(--shadow-1);
}
.feature-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
}
.feature-img.tall{aspect-ratio:4/5}
.feature-img.wide{aspect-ratio:16/10}
.feature-img.contain{background:#0c1a31}
.feature-img.contain img{object-fit:contain;background:#0c1a31}

.feature-copy h2{margin-bottom:14px}
.feature-copy ul{padding-left:0;list-style:none;margin:18px 0 26px}
.feature-copy ul li{
  position:relative;padding-left:28px;margin-bottom:10px;
  font-size:.96rem;color:#3a4866;
}
.feature-copy ul li:before{
  content:"";position:absolute;left:0;top:.65em;
  width:14px;height:1px;background:var(--gold);
}
@media (max-width:880px){
  .feature{grid-template-columns:1fr;gap:30px}
}

/* ============ Page Hero ============ */
.page-hero{
  position:relative;
  background:linear-gradient(180deg, #0A1628 0%, #0e1d36 100%);
  color:#fff;
  padding:clamp(80px, 10vw, 150px) 0 clamp(70px, 8vw, 120px);
  overflow:hidden;
}
.page-hero:before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(50% 50% at 80% 0%, rgba(200,165,91,.14), transparent 60%),
    radial-gradient(40% 60% at 0% 100%, rgba(15,123,92,.20), transparent 60%);
  pointer-events:none;
}
.page-hero h1{color:#fff;font-weight:400;margin-bottom:18px}
.page-hero .lede{color:#bcc6d8;max-width:660px}
.page-hero .crumbs{
  display:flex;gap:14px;align-items:center;
  font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:18px;
}
.page-hero .crumbs a{color:#94a0bb}
.page-hero .crumbs a:hover{color:#fff}
.page-hero .crumbs span{opacity:.5}

/* ============ TIMELINE ============ */
.timeline{position:relative;padding:30px 0}
.timeline:before{
  content:"";position:absolute;left:50%;top:0;bottom:0;
  width:1px;background:linear-gradient(180deg,transparent, var(--line-2) 8%, var(--line-2) 92%, transparent);
  transform:translateX(-50%);
}
.tl-item{
  position:relative;display:grid;
  grid-template-columns:1fr 80px 1fr;
  gap:20px;margin-bottom:38px;
  align-items:start;
}
.tl-item .dot{
  grid-column:2;
  width:18px;height:18px;border-radius:50%;
  background:var(--midnight);border:3px solid #fff;
  box-shadow:0 0 0 1px var(--line-2);
  margin:18px auto 0;
  position:relative;z-index:2;
  justify-self:center;
}
.tl-item .yr{
  font-family:var(--tx-h);font-size:.85rem;font-weight:500;
  color:var(--gold);letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:8px;
}
.tl-card{
  background:#fff;border:1px solid var(--line-2);
  padding:26px 28px;border-radius:18px;
  box-shadow:0 4px 18px -10px rgba(10,22,40,.1);
}
.tl-card h3{font-size:1.25rem;margin-bottom:8px}
.tl-card p{margin:0;font-size:.95rem;color:#445069}

/* Odd items: card on left (col 1), right card hidden */
.tl-item:nth-child(odd) .tl-card-l{grid-column:1;text-align:right}
.tl-item:nth-child(odd) .tl-card-r{display:none}
/* Even items: card on right (col 3), left card hidden */
.tl-item:nth-child(even) .tl-card-l{display:none}
.tl-item:nth-child(even) .tl-card-r{grid-column:3}

@media (max-width:820px){
  .timeline:before{left:18px}
  .tl-item{grid-template-columns:36px 1fr;gap:14px}
  .tl-item .dot{grid-column:1;margin:18px 0 0;justify-self:start}
  .tl-item .tl-card-l{display:none !important}
  .tl-item .tl-card-r{display:block !important;grid-column:2 !important;text-align:left !important}
  .tl-item:nth-child(odd) .tl-card-r{display:block !important;grid-column:2 !important}
  .tl-item:nth-child(even) .tl-card-l{display:none !important}
}

/* ============ PORTFOLIO CARDS ============ */
.sector-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
  gap:26px;
}
.sector{
  position:relative;border-radius:22px;overflow:hidden;
  background:#0e1c33;color:#fff;
  min-height:340px;
  padding:30px 28px;display:flex;flex-direction:column;justify-content:flex-end;
  border:1px solid #18294a;
  transition:transform .35s ease, box-shadow .35s ease;
}
.sector:hover{transform:translateY(-4px);box-shadow:var(--shadow-1)}
.sector .ic{
  width:54px;height:54px;border-radius:14px;
  background:rgba(200,165,91,.14);color:var(--gold-2);
  display:grid;place-items:center;margin-bottom:18px;
  border:1px solid rgba(200,165,91,.3);
}
.sector h3{color:#fff;margin-bottom:10px}
.sector p{color:#b9c4d8;font-size:.95rem;margin:0}
.sector .tag{
  position:absolute;top:22px;right:22px;
  font-size:.65rem;letter-spacing:.32em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
  background:rgba(15,123,92,.16);color:#5fd0a6;
  border:1px solid rgba(15,123,92,.4);
}
.sector.gold .ic{background:rgba(200,165,91,.18);color:var(--gold-2)}
.sector.gold .tag{background:rgba(200,165,91,.16);color:var(--gold-2);border-color:rgba(200,165,91,.4)}

.company-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
}
.company{
  background:#fff;border:1px solid var(--line-2);
  padding:30px;border-radius:20px;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .35s ease, box-shadow .35s ease;
}
.company:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.company .logo-tile{
  width:84px;height:84px;border-radius:16px;
  background:#f6f7fa;display:grid;place-items:center;
  border:1px solid var(--line-2);overflow:hidden;
}
.company .logo-tile img{width:90%;height:90%;object-fit:contain}
.company .role{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}
.company h3{font-size:1.15rem;margin:0}
.company p{margin:0;color:#48556e;font-size:.92rem}
.company .meta{
  display:flex;gap:16px;margin-top:6px;font-size:.78rem;color:var(--steel);
  letter-spacing:.04em;
}
.company .meta b{color:var(--midnight);font-weight:600}

/* Stats band */
.stat-band{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:0;
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
}
.stat-band > div{
  padding:34px 26px;border-right:1px solid var(--line-2);
  text-align:center;
}
.stat-band > div:last-child{border-right:none}
.stat-band .n{
  font-family:var(--tx-h);font-size:clamp(2.4rem,4.8vw,3.6rem);
  font-weight:500;color:var(--midnight);line-height:1;
}
.stat-band .l{
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--steel);margin-top:10px;
}
.stat-band > div:nth-child(2n) .n{color:var(--emerald)}
.stat-band > div:nth-child(3n) .n{color:var(--gold)}

/* ============ VISION QUOTES ============ */
.quote-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:26px;
}
.quote{
  background:#fff;border:1px solid var(--line-2);
  padding:34px 30px;border-radius:20px;
  position:relative;
}
.quote:before{
  content:"\201C";font-family:var(--tx-h);font-size:5rem;
  position:absolute;top:6px;left:18px;color:var(--gold);opacity:.18;line-height:1;
}
.quote h3{font-size:1.15rem;margin-bottom:10px}
.quote p{margin:0;color:#3a4866;font-size:.96rem}
.quote .tag{
  display:inline-block;margin-top:14px;
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--emerald);font-weight:600;
}

.section-dark .quote{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08)}
.section-dark .quote h3{color:#fff}
.section-dark .quote p{color:#bcc6d8}
.section-dark .quote:before{color:var(--gold-2);opacity:.25}

/* Big pull quote */
.pull{
  max-width:820px;margin:0 auto;text-align:center;padding:24px 0;
}
.pull q{
  font-family:var(--tx-h);font-size:clamp(1.6rem,3vw,2.4rem);
  font-style:italic;font-weight:400;line-height:1.3;
  color:var(--midnight);
  quotes:"\201C" "\201D";
}
.pull .by{
  margin-top:22px;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--steel);
}
.section-dark .pull q{color:#fff}
.section-dark .pull .by{color:var(--gold-2)}

/* ============ GALLERY ============ */
.masonry{
  columns: 3 280px;
  column-gap:18px;
}
.masonry .tile{
  break-inside:avoid;margin:0 0 18px;
  border-radius:16px;overflow:hidden;
  background:#0e1c33;
  position:relative;cursor:pointer;
  transition:transform .35s ease;
}
.masonry .tile img{
  width:100%;display:block;
  transition:transform .8s ease;
}
.masonry .tile:hover img{transform:scale(1.05)}
.masonry .tile:after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(10,22,40,.55) 100%);
  opacity:0;transition:opacity .3s ease;
}
.masonry .tile:hover:after{opacity:1}
.masonry .tile .cap{
  position:absolute;left:18px;right:18px;bottom:14px;color:#fff;
  font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  opacity:0;transform:translateY(8px);transition:.3s ease;
}
.masonry .tile:hover .cap{opacity:1;transform:none}

.lightbox{
  position:fixed;inset:0;background:rgba(7,12,22,.92);
  display:none;align-items:center;justify-content:center;
  z-index:200;padding:30px;
  backdrop-filter:blur(10px);
}
.lightbox.open{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lightbox img{
  max-width:min(1100px, 95vw);max-height:90vh;
  border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.lightbox .close{
  position:absolute;top:24px;right:24px;
  background:rgba(255,255,255,.08);color:#fff;border:none;
  width:46px;height:46px;border-radius:50%;cursor:pointer;
  font-size:1.5rem;line-height:1;
}
.lightbox .close:hover{background:rgba(255,255,255,.16)}

/* ============ CONTACT ============ */
.contact-grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:44px;
  align-items:start;
}
@media (max-width:920px){.contact-grid{grid-template-columns:1fr}}

.form{
  background:#fff;border:1px solid var(--line-2);border-radius:24px;
  padding:36px;box-shadow:var(--shadow-2);
}
.form h2{margin-bottom:8px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:600px){.form .row{grid-template-columns:1fr}}
.field{margin-top:18px}
.field label{
  display:block;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--steel);margin-bottom:8px;font-weight:600;
}
.field input,.field textarea,.field select{
  width:100%;padding:14px 16px;
  background:#fff;
  border:1px solid var(--line-2);border-radius:12px;
  font:inherit;color:var(--midnight);
  transition:border-color .25s ease, box-shadow .25s ease;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--midnight);
  box-shadow:0 0 0 4px rgba(10,22,40,.06);
}

.contact-info{
  background:linear-gradient(180deg,#0A1628,#0e1d36);
  color:#fff;border-radius:24px;padding:40px;
  position:relative;overflow:hidden;
}
.contact-info:before{
  content:"";position:absolute;inset:auto -40% -40% auto;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle, rgba(200,165,91,.2) 0%, transparent 70%);
}
.contact-info h3{color:#fff}
.contact-info .item{
  display:flex;gap:14px;align-items:flex-start;
  padding:18px 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.contact-info .item:last-of-type{border-bottom:none}
.contact-info .item .ic{
  width:40px;height:40px;border-radius:10px;
  background:rgba(200,165,91,.15);color:var(--gold-2);
  display:grid;place-items:center;flex-shrink:0;
}
.contact-info .item .lbl{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:#94a0bb;margin-bottom:4px;
}
.contact-info .item a, .contact-info .item span{
  color:#fff;font-size:1rem;font-weight:500;
}
.contact-info .item a:hover{color:var(--gold-2)}

.map-band{
  margin-top:36px;border-radius:20px;overflow:hidden;
  border:1px solid var(--line-2);
  height:340px;position:relative;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(15,123,92,.08), transparent 60%),
    radial-gradient(60% 60% at 70% 70%, rgba(200,165,91,.08), transparent 60%),
    linear-gradient(180deg,#f6f7fa,#eceff5);
}
.map-band:before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(10,22,40,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10,22,40,.06) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.map-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  text-align:center;
}
.map-pin .pin{
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,var(--midnight),var(--midnight-3));
  color:var(--gold-2);
  display:grid;place-items:center;margin:0 auto 14px;
  box-shadow:0 18px 40px -14px rgba(10,22,40,.4);
  position:relative;
}
.map-pin .pin:after{
  content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);
  width:14px;height:14px;border-radius:50%;background:rgba(10,22,40,.18);
  filter:blur(4px);
}
.map-pin h4{margin:0 0 4px;color:var(--midnight)}
.map-pin p{margin:0;font-size:.84rem;color:var(--steel)}

/* ============ FOOTER ============ */
footer.site{
  background:#070d1a;color:#aab4c8;
  padding:70px 0 28px;
  position:relative;
}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
}
@media (max-width:880px){.footer-top{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:560px){.footer-top{grid-template-columns:1fr}}
.footer-brand .brand-name{color:#fff;font-size:1.25rem}
.footer-brand .brand-sub{color:var(--gold-2)}
.footer-brand p{color:#8d97ad;font-size:.92rem;margin-top:14px;max-width:300px}
.footer-col h5{
  color:#fff;font-size:.78rem;letter-spacing:.28em;
  text-transform:uppercase;margin-bottom:18px;font-family:var(--tx-b);
  font-weight:600;
}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:10px;font-size:.92rem}
.footer-col a{color:#aab4c8}
.footer-col a:hover{color:var(--gold-2)}

.footer-bottom{
  margin-top:50px;padding-top:24px;
  border-top:1px solid #16213a;
  display:flex;justify-content:space-between;align-items:center;
  gap:20px;flex-wrap:wrap;
  font-size:.82rem;color:#6f7a93;
}
.footer-bottom a{color:#9aa4ba}
.footer-bottom a:hover{color:var(--gold-2)}
.footer-credit{font-size:.82rem}
.footer-credit a{color:var(--gold-2)}
.footer-credit a:hover{color:#fff}

.socials{display:flex;gap:10px}
.socials a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.04);
  display:grid;place-items:center;color:#aab4c8;
  border:1px solid rgba(255,255,255,.08);
  transition:.25s ease;
}
.socials a:hover{background:var(--gold);color:#1a1a1a;border-color:var(--gold)}
.socials a svg{width:16px;height:16px}

.contact-strip{
  display:flex;flex-wrap:wrap;gap:18px;align-items:center;
  margin-top:14px;font-size:.88rem;
}
.contact-strip span{color:#6f7a93}
.contact-strip a{color:#cbd2e0}
.contact-strip a:hover{color:var(--gold-2)}

/* ============ Reveal Animations ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}

/* ============ Section heads ============ */
.head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:30px;margin-bottom:50px;flex-wrap:wrap;
}
.head .l{max-width:680px}
.head h2{margin-bottom:10px}
.head p{color:#48556e;margin:0;font-size:1.02rem}
.section-dark .head p{color:#bcc6d8}

/* ============ Values list ============ */
.values{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(220px,1fr));gap:0;
  border-top:1px solid var(--line-2);
}
.values > div{
  padding:30px 24px;border-bottom:1px solid var(--line-2);
  border-right:1px solid var(--line-2);
}
.values > div:last-child{border-right:none}
.values .k{
  font-family:var(--tx-h);font-size:.8rem;font-weight:500;
  color:var(--gold);letter-spacing:.3em;text-transform:uppercase;
  margin-bottom:10px;
}
.values h4{font-family:var(--tx-h);font-size:1.4rem;font-weight:500;margin:0 0 10px}
.values p{font-size:.92rem;color:#48556e;margin:0}

/* Updates list */
.updates{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.update{
  background:#fff;border:1px solid var(--line-2);border-radius:18px;
  padding:26px;display:flex;flex-direction:column;gap:10px;
}
.update .date{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--steel);
}
.update h4{margin:0;font-family:var(--tx-h);font-size:1.2rem;font-weight:500}
.update p{margin:0;font-size:.92rem;color:#48556e}
.update a.more{
  margin-top:6px;font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--midnight);font-weight:600;
}
.update a.more:hover{color:var(--gold)}

/* Two-column intro for About */
.bio-grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(30px,5vw,80px);align-items:start;
}
.bio-portrait{
  position:sticky;top:100px;
  border-radius:24px;overflow:hidden;
  aspect-ratio:4/5;background:#0e1c33;
  box-shadow:var(--shadow-1);
}
.bio-portrait img{
  width:100%;height:100%;object-fit:cover;object-position:center 22%;
}
@media (max-width:920px){
  .bio-grid{grid-template-columns:1fr}
  .bio-portrait{position:relative;top:auto;max-width:520px}
}

/* Strategy cards (Ventures) */
.strategy{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;
}
.strategy .card{
  padding:34px 28px;border-radius:20px;background:#fff;
  border:1px solid var(--line-2);
}
.strategy .card .step{
  font-family:var(--tx-h);font-size:.9rem;font-weight:500;
  color:var(--gold);letter-spacing:.28em;text-transform:uppercase;
}
.strategy .card h3{font-size:1.3rem;margin:14px 0 10px}
.strategy .card p{margin:0;color:#48556e;font-size:.95rem}

/* Watchlist (sectors of focus) */
.watchlist{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;
  border:1px solid #18294a;border-radius:18px;overflow:hidden;
}
.watchlist > div{
  padding:26px 22px;border-right:1px solid #18294a;border-bottom:1px solid #18294a;
}
.watchlist > div:last-child{border-right:none}
.watchlist h4{color:#fff;margin:0 0 6px;font-family:var(--tx-h);font-size:1.2rem;font-weight:500}
.watchlist p{color:#a0acc4;margin:0;font-size:.88rem}
.watchlist .pct{
  font-family:var(--tx-h);font-size:1.6rem;font-weight:500;color:var(--gold-2);
  margin-bottom:4px;line-height:1;
}

/* Wide quote band */
.quote-band{
  background:linear-gradient(180deg,#0A1628,#0e1d36);
  color:#fff;padding:80px 0;border-radius:0;text-align:center;
}
.quote-band q{
  font-family:var(--tx-h);font-style:italic;
  font-size:clamp(1.5rem,2.6vw,2.2rem);
  display:inline-block;max-width:920px;line-height:1.4;
  color:#fff;
}
.quote-band .by{
  display:block;margin-top:24px;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold-2);
}

/* Wide banner image */
.wide-banner{
  position:relative;border-radius:24px;overflow:hidden;
  background:#0e1c33;
  aspect-ratio:21/9;
  box-shadow:var(--shadow-1);
}
.wide-banner img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.wide-banner .ovl{
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(10,22,40,.75), rgba(10,22,40,.0) 60%);
  display:flex;align-items:center;
  padding:0 clamp(24px,5vw,60px);
}
.wide-banner .ovl > div{max-width:520px;color:#fff}
.wide-banner h3{color:#fff;font-size:clamp(1.4rem,2.4vw,2rem);margin-bottom:8px}
.wide-banner p{color:#cdd5e3;margin:0}
@media (max-width:680px){
  .wide-banner{aspect-ratio:4/5}
  .wide-banner .ovl{background:linear-gradient(180deg, transparent 30%, rgba(10,22,40,.85) 100%);align-items:flex-end;padding-bottom:30px}
}

/* CTA panel */
.cta-panel{
  background:linear-gradient(135deg,#0A1628 0%, #0e1d36 60%, #142849 100%);
  color:#fff;border-radius:30px;
  padding:clamp(40px,5vw,72px);
  display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-panel:before{
  content:"";position:absolute;inset:auto -10% -60% auto;width:520px;height:520px;
  background:radial-gradient(circle, rgba(200,165,91,.16) 0%, transparent 70%);
}
.cta-panel h2{color:#fff;margin-bottom:8px}
.cta-panel p{color:#bcc6d8;margin:0;max-width:520px}
.cta-panel .actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}
@media (max-width:760px){
  .cta-panel{grid-template-columns:1fr;text-align:left}
  .cta-panel .actions{justify-content:flex-start}
}

/* small chip */
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(15,123,92,.1);color:var(--emerald);
  border:1px solid rgba(15,123,92,.28);
}
.section-dark .chip{background:rgba(200,165,91,.12);color:var(--gold-2);border-color:rgba(200,165,91,.3)}

/* avatars */
.author{display:flex;align-items:center;gap:14px;margin-top:18px}
.author .av{
  width:48px;height:48px;border-radius:50%;
  background:#eef1f6;overflow:hidden;border:2px solid #fff;box-shadow:0 0 0 1px var(--line-2);
}
.author .av img{width:100%;height:100%;object-fit:cover}
.author .nm{font-weight:600;font-size:.92rem}
.author .rl{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--steel)}

/* utility */
.center{text-align:center}
.mt-0{margin-top:0}
.mt-1{margin-top:8px}
.mt-2{margin-top:18px}
.mt-3{margin-top:30px}
.mt-4{margin-top:50px}
.mb-0{margin-bottom:0 !important}
.divider{height:1px;background:var(--line-2);margin:50px 0}
.section-dark .divider{background:rgba(255,255,255,.08)}
