












/* Namespace: vip-greenwhy */
:root{
  --vgw-ink:#0f172a; --vgw-muted:#334155; --vgw-line:#e2e8f0;
  --vgw-pri:#16a34a; --vgw-sec:#22d3ee; --vgw-grad:linear-gradient(135deg, var(--vgw-pri), var(--vgw-sec));
  --vgw-r:16px;
}

/* Full-screen white section */
.vip-greenwhy{
  position:relative; width:100vw; min-height:100svh; margin-left:50%; transform:translateX(-50%);
  background:#ffffff; color:var(--vgw-ink); overflow:hidden; isolation:isolate;
}

/* 3D background with parallax; you will replace the image */
.vgw__bg{
  position:absolute; inset:-12% -6%;
  background:
    radial-gradient(1200px 420px at 10% -10%, rgba(34,197,94,.15), transparent 60%),
    var(--vgw-img) center/cover no-repeat;
  transform:translateZ(0); will-change:transform; filter:saturate(1.05) contrast(1.05);
  opacity:.8;
}

/* Inner container */
.vgw__container{ position:relative; z-index:1; max-width:1200px; margin:0 auto; padding:clamp(16px,4vw,40px); }

/* Header */
.vgw__header{ text-align:center; margin-bottom:clamp(12px,2.8vw,18px); }
.vgw__eyebrow{
  display:inline-block; padding:6px 10px; border-radius:999px; color:#065f46;
  background:rgba(22,163,74,.12); border:1px solid #bbf7d0;
}
.vgw__title{ margin:.3rem 0 .2rem; font-weight:800; font-size:clamp(26px,4.4vw,44px); }
.vgw__lead{ color:var(--vgw-muted); max-width:75ch; margin:0 auto; }

/* Cards */
.vgw__grid{
  display:grid; gap:clamp(14px,3vw,22px);
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  margin-top:clamp(10px,2.6vw,14px);
}
.vgw__card{
  background:#ffffff; border:1px solid var(--vgw-line); border-radius:var(--vgw-r);
  box-shadow:0 8px 30px rgba(2,6,23,.06);
  padding:clamp(14px,2.6vw,22px);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
}
.vgw__card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 46px rgba(2,6,23,.10), 0 0 0 1px rgba(34,197,94,.35) inset;
  filter:saturate(1.05);
}
.vgw__icon{
  width:42px; height:42px; display:grid; place-items:center; border-radius:12px;
  background:rgba(22,163,74,.12); border:1px solid #bbf7d0; color:#065f46; margin-bottom:10px;
}
.vgw__h3{ margin:0 0 6px; font-weight:800; }
.vgw__p{ margin:0; color:var(--vgw-muted); }

/* Commitment band */
.vgw__commit{ text-align:center; margin:clamp(12px,3vw,20px) 0; }
.vgw__commit-badge{
  display:inline-grid; place-items:center; padding:8px 14px; border-radius:999px; color:#065f46;
  background:rgba(22,163,74,.12); border:1px solid #bbf7d0; font-weight:700;
  box-shadow:0 10px 30px rgba(22,163,74,.15);
}
.vgw__commit-text{ max-width:80ch; margin:.5rem auto 0; color:var(--vgw-muted); }

/* CTAs */
.vgw__ctas{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:clamp(10px,2.6vw,14px); }
.vgw__btn{
  display:inline-grid; place-items:center; padding:12px 18px; border-radius:12px; color:#fff; text-decoration:none;
  background:var(--vgw-grad); font-weight:700; box-shadow:0 12px 34px rgba(34,197,94,.28);
  transition:transform .18s, box-shadow .18s, filter .18s;
}
.vgw__btn:hover{ transform:translateY(-3px); box-shadow:0 18px 46px rgba(34,211,238,.3); filter:saturate(1.05); }
.vgw__ghost{
  display:inline-grid; place-items:center; padding:12px 18px; border-radius:12px; color:var(--vgw-ink);
  border:1px solid var(--vgw-line); background:#ffffff; text-decoration:none; transition:transform .18s, border-color .18s, background .18s;
}
.vgw__ghost:hover{ transform:translateY(-2px); border-color:#86efac; background:#f8fafc; }

/* Responsiveness */
@media (max-width:560px){
  .vgw__title{ font-size:clamp(24px, 6vw, 36px); }
}




















/* ============ VIBE ABOUT PAGE (Namespaced) ============ */
/* All classes prefixed with .vip-about to avoid conflicts */

:root {
  --vip-c-bg-dark: #0f172a;
  --vip-c-bg-mid: #1e293b;
  --vip-c-bg-soft: #e2e8f0;
  --vip-c-white: #ffffff;
  --vip-c-brand: #2866c9;
  --vip-c-accent: #f93237;
  --vip-c-muted: #94a3b8;
  --vip-c-card: rgba(255,255,255,.08);

  --vip-rad-xl: 24px;
  --vip-rad-lg: 18px;
  --vip-rad-md: 14px;

  --vip-shadow-1: 0 8px 24px rgba(0,0,0,.16);
  --vip-shadow-2: 0 16px 40px rgba(40,102,201,.25);
}

.vip-about-body { background: var(--vip-c-bg-dark); color: var(--vip-c-white); margin:0; }

/* utility */
.vip-about__container{ width:min(1200px, 92vw); margin-inline:auto; }
.vip-about__i{ pointer-events:none; }

/* ===== HERO ===== */
.vip-about__hero{ position:relative; min-height:100vh; overflow:hidden; }
.vip-about__hero-bg{ position:absolute; inset:0; }
.vip-about__layer{ position:absolute; inset:-10%; background-repeat:no-repeat; background-size:cover; opacity:.7; }
.vip-about__layer--back{ background-image: radial-gradient(60% 60% at 20% 20%, rgba(40,102,201,.35), transparent 60%), radial-gradient(50% 50% at 80% 80%, rgba(249,50,55,.35), transparent 60%), linear-gradient(120deg, #0b1224 0%, #111a30 100%); }
.vip-about__layer--mid{ background-image: url('about-hero.jpg'); mix-blend-mode: overlay; opacity:.25; }
.vip-about__layer--front{ background-image: radial-gradient(30% 30% at 50% 30%, rgba(255,255,255,.08), transparent 70%); }

.vip-about__hero-inner{ position:relative; z-index:2; display:grid; place-items:center; text-align:center; padding-top: clamp(100px, 12vh, 160px); padding-inline:20px; }
.vip-about__badge{ display:inline-flex; align-items:center; gap:10px; padding:10px 16px; border-radius:999px; background: rgba(40,102,201,.18); border:1px solid rgba(96,165,250,.28); box-shadow: var(--vip-shadow-1); color:#bfdbfe; margin-bottom:18px; font-weight:700; }
.vip-about__title{ font-size: clamp(2.2rem, 5vw, 4rem); font-weight:900; line-height:1.1; margin:0 0 8px; background: linear-gradient(135deg, #fff, #93c5fd, #fca5a5); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.vip-about__title-brand{ text-shadow:0 8px 24px rgba(249,50,55,.28); }
.vip-about__subtitle{ color:#ffdede; font-weight:800; letter-spacing:.2px; margin:0 0 8px; }
.vip-about__lead{ color:#e5eefc; max-width:780px; margin-inline:auto; opacity:.95; margin-bottom:20px; }
.vip-about__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

.vip-about__btn{ display:inline-flex; align-items:center; gap:10px; padding:12px 20px; border-radius:999px; font-weight:800; text-decoration:none; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease; }
.vip-about__btn--primary{ background: linear-gradient(135deg, var(--vip-c-accent), #ff6b6b); color:#fff; box-shadow: var(--vip-shadow-2); }
.vip-about__btn--primary:hover{ transform: translateY(-2px) scale(1.02); }
.vip-about__btn--ghost{ background: rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.3); color:#fff; backdrop-filter: blur(8px); }
.vip-about__btn--ghost:hover{ transform: translateY(-2px) scale(1.02); }

.vip-about__scroll-cue{ position:absolute; bottom:16px; left:50%; transform:translateX(-50%); width:44px; height:44px; border-radius:999px; border:1px solid rgba(255,255,255,.35); background: rgba(255,255,255,.15); color:#fff; display:grid; place-items:center; cursor:pointer; z-index:3; }
.vip-about__scroll-cue:hover{ transform: translateX(-50%) translateY(-4px); }

/* ===== STATS ===== */
.vip-about__stats{ padding:80px 0; background: linear-gradient(180deg, transparent, rgba(255,255,255,.04)); }
.vip-about__stats-grid{ display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:18px; }
.vip-about__stat-card{ background: var(--vip-c-card); border:1px solid rgba(255,255,255,.18); border-radius: var(--vip-rad-xl); padding:24px; text-align:center; box-shadow: var(--vip-shadow-1); transition: transform .25s ease, box-shadow .25s ease, background .25s ease; will-change: transform; }
.vip-about__stat-card:hover{ background: rgba(255,255,255,.18); box-shadow: var(--vip-shadow-2); }
.vip-about__stat-icon{ font-size:22px; color:#bfdbfe; margin-bottom:10px; }
.vip-about__stat-num{ font-size: clamp(1.8rem, 3vw, 2.2rem); font-weight:900; }
.vip-about__stat-label{ color: var(--vip-c-muted); font-weight:700; }

@media (max-width:900px){ .vip-about__stats-grid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:520px){ .vip-about__stats-grid{ grid-template-columns:1fr; } }

/* ===== SECTION HEAD ===== */
.vip-about__section-head{ text-align:center; margin-bottom:24px; }
.vip-about__eyebrow{ display:inline-block; background: rgba(40,102,201,.18); border:1px solid rgba(96,165,250,.28); color:#bfdbfe; padding:6px 12px; border-radius:999px; font-weight:700; margin-bottom:10px; }
.vip-about__h2{ font-size: clamp(1.6rem, 3.2vw, 2.4rem); margin:8px 0; }
.vip-about__desc{ color:#d6e3ff; opacity:.9; max-width:700px; margin:0 auto; }

/* ===== MVV ===== */
.vip-about__mvv{ padding:80px 0; }
.vip-about__mvv-grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px; }
.vip-about__mvv-card{ background: linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.06)); border:1px solid rgba(255,255,255,.18); border-radius: var(--vip-rad-xl); padding:24px; box-shadow: var(--vip-shadow-1); transition: transform .25s ease, box-shadow .25s ease; }
.vip-about__mvv-card:hover{ box-shadow: var(--vip-shadow-2); }
.vip-about__mvv-icon{ width:56px; height:56px; display:grid; place-items:center; background: linear-gradient(135deg, var(--vip-c-brand), #1e40af); border-radius:14px; margin-bottom:12px; }
.vip-about__list{ margin:0; padding-left:18px; }

@media (max-width:900px){ .vip-about__mvv-grid{ grid-template-columns:1fr; } }

/* ===== CAPABILITIES ===== */
.vip-about__capabilities{ padding:80px 0; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); }
.vip-about__caps-grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px; }
.vip-about__cap-card{ position:relative; display:block; overflow:hidden; border-radius: var(--vip-rad-xl); border:1px solid rgba(255,255,255,.18); background: #0f162a; box-shadow: var(--vip-shadow-1); transform-style: preserve-3d; }
.vip-about__cap-media{ position:absolute; inset:0; background-size:cover; background-position:center; filter: brightness(.92) contrast(1.05); transform: translateZ(0); transition: transform .45s ease; }
.vip-about__cap-content{ position:relative; z-index:2; padding:22px; background: linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.45) 100%); margin-top: clamp(120px, 22vh, 180px); }
.vip-about__cap-card:hover .vip-about__cap-media{ transform: scale(1.06); }

@media (max-width:1000px){ .vip-about__caps-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .vip-about__caps-grid{ grid-template-columns:1fr; } }





/* Namespace: vip-mdq (MD Quote) */
:root{
  --mdq-ink:#0f172a; --mdq-muted:#334155; --mdq-bg:#ffffff;
  --mdq-line:#e2e8f0; --mdq-pri:#0ea5e9; --mdq-sec:#8b5cf6;
  --mdq-grad:linear-gradient(135deg, var(--mdq-pri), var(--mdq-sec));
  --mdq-r:16px;
}

.vip-mdq{
  position:relative; width:100vw; min-height:100svh;
  margin-left:50%; transform:translateX(-50%);
  background:var(--mdq-bg); color:var(--mdq-ink); display:grid;
  grid-template-columns:minmax(300px, 1.05fr) minmax(340px, 1fr);
  overflow:hidden; isolation:isolate;
}

/* Left image panel with parallax */
.vip-mdq__photo{
  position:relative; margin:0; min-height:100%;
  background:var(--mdq-bg);
}
.vip-mdq__photo::before{
  content:""; position:absolute; inset:0;
  background:var(--mdq-img) center/cover no-repeat;
  transform:translateZ(0); will-change:transform; /* moved by JS */
}
.vip-mdq__img{ position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }

/* Right content column */
.vip-mdq__content{
  position:relative; display:flex; flex-direction:column; justify-content:center;
  padding:clamp(18px,4vw,48px);
}

/* Adani-style speech bubble */
.vip-mdq__bubble{
  position:relative; border:2px solid #334155; border-radius:16px;
  padding:clamp(14px,2.6vw,22px); background:#ffffff; box-shadow:0 12px 34px rgba(2,6,23,.08);
}
.vip-mdq__bubble::after{
  content:""; position:absolute; left:clamp(22px, 9vw, 120px); bottom:-18px;
  width:64px; height:24px; background:transparent; 
  border-bottom:2px solid #334155; border-right:2px solid #334155;
  transform:skewX(-28deg);
}
.vip-mdq__quote{
  margin:.2rem 0; font-size:clamp(16px, 1.6vw, 18px); line-height:1.7; color:#111827;
}
.vip-mdq__quote em, .vip-mdq__quote strong{ font-weight:800; }

/* Signature block */
.vip-mdq__sig{ margin:clamp(12px,2vw,18px) 0 0; }
.vip-mdq__name{ font-weight:800; }
.vip-mdq__role{ color:var(--mdq-muted); }

/* CTAs */
.vip-mdq__ctas{ display:flex; gap:10px; flex-wrap:wrap; margin-top:clamp(10px,2vw,16px); }
.vip-mdq__btn{
  display:inline-grid; place-items:center; padding:12px 18px; border-radius:12px; color:#fff; text-decoration:none;
  background:var(--mdq-grad); font-weight:700; box-shadow:0 12px 34px rgba(14,165,233,.32);
  transition:transform .18s, box-shadow .18s, filter .18s;
}
.vip-mdq__btn:hover{ transform:translateY(-3px); box-shadow:0 18px 46px rgba(139,92,246,.35); filter:saturate(1.05); }
.vip-mdq__ghost{
  display:inline-grid; place-items:center; padding:12px 18px; border-radius:12px; color:var(--mdq-ink);
  border:1px solid var(--mdq-line); background:#ffffff; text-decoration:none;
  transition:transform .18s, border-color .18s, background .18s;
}
.vip-mdq__ghost:hover{ transform:translateY(-2px); border-color:#93c5fd; background:#f8fafc; }

/* Micro interaction on hover of bubble */
.vip-mdq__content:hover .vip-mdq__bubble{
  border-color:#1f2937; box-shadow:0 18px 46px rgba(2,6,23,.12), 0 0 0 1px rgba(14,165,233,.22) inset;
}

/* Responsive stack */
@media (max-width: 980px){
  .vip-mdq{ grid-template-columns:1fr; }
  .vip-mdq__photo{ min-height:48svh; }
  .vip-mdq__bubble::after{ left:28px; }
}







/* ===== TIMELINE ===== */
.vip-about__timeline{ padding:80px 0; background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.04)); }
.vip-about__timeline-list{ position:relative; margin:32px auto 0; padding-left:22px; max-width:900px; }
.vip-about__timeline-list::before{ content:''; position:absolute; left:10px; top:0; bottom:0; width:2px; background: linear-gradient(180deg, #93c5fd, transparent); }
.vip-about__timeline-item{ position:relative; margin: 0 0 28px; transform: translateY(24px); opacity:0; transition: transform .6s ease, opacity .6s ease; }
.vip-about__timeline-item.is-visible{ transform:none; opacity:1; }
.vip-about__tl-dot{ position:absolute; left:-2px; top:8px; width:14px; height:14px; border-radius:999px; background: linear-gradient(135deg, var(--vip-c-accent), #ff6b6b); box-shadow: 0 0 18px rgba(249,50,55,.4); }
.vip-about__tl-card{ margin-left:24px; background: var(--vip-c-card); border:1px solid rgba(255,255,255,.18); border-radius: var(--vip-rad-lg); padding:16px 18px; box-shadow: var(--vip-shadow-1); }

/* ===== BADGES MARQUEE ===== */
.vip-about__badges{ overflow:hidden; border-block:1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.03); }
.vip-about__badges-track{ display:flex; align-items:center; gap:28px; padding:16px 0; width:max-content; animation: vip-scroll 28s linear infinite; }
.vip-about__badges img{ height:38px; filter: brightness(1.05) contrast(1.05) grayscale(.08); opacity:.9; transition: transform .25s ease; }
.vip-about__badges img:hover{ transform: translateY(-3px) scale(1.06); }
@keyframes vip-scroll{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-50%); }
}

/* ===== FAQ ===== */
.vip-about__faq{ padding:80px 0; }
.vip-about__faq-item{ background: var(--vip-c-card); border:1px solid rgba(255,255,255,.18); border-radius: var(--vip-rad-lg); margin:0 0 12px; overflow:hidden; }
.vip-about__faq-item summary{ list-style:none; cursor:pointer; padding:14px 16px; display:flex; align-items:center; gap:10px; font-weight:800; }
.vip-about__faq-item summary::-webkit-details-marker{ display:none; }
.vip-about__faq-item[open] summary{ background: rgba(255,255,255,.06); }
.vip-about__faq-content{ padding:0 16px 14px; color:#e6f0ff; }

/* ===== CTA BAND ===== */
.vip-about__cta-band{ padding:80px 0; background: linear-gradient(120deg, rgba(40,102,201,.18), rgba(249,50,55,.18)); }
.vip-about__cta-inner{ text-align:center; }
.vip-about__cta-inner .vip-about__btn--primary{ margin-top:10px; }

/* ===== Reduced Motion ===== */
@media (prefers-reduced-motion: reduce){
  .vip-about__badges-track{ animation:none; }
  .vip-about__timeline-item{ transition:none; }
}



/* What We Do: text color override only */
.vip-about__cap-card .vip-about__h3,
.vip-about__cap-card .vip-about__desc,
.vip-about__cap-card a,
.vip-about__cap-card a:visited{
  color:#f0f0f0 !important;        /* pure white for maximum contrast */
}

/* Optional: थोड़ा subtle glow ताकि bright फोटो पर भी clear दिखे */
.vip-about__cap-card .vip-about__h3{ text-shadow:0 1px 6px rgba(0,0,0,.55); }
.vip-about__cap-card .vip-about__desc{ text-shadow:0 1px 4px rgba(0,0,0,.45); }
/* What We Do cards: force white for both title and description */
.vip-about__cap-card .p,
.vip-about__cap-card .vip-about__content,
.vip-about__cap-card .vip-about__desc,
.vip-about__cap-card a,
.vip-about__cap-card a:visited{
  color:#ffffff !important;
}

/* Optional readability boost */
.vip-about__cap-card .vip-about__h3{ text-shadow:0 1px 6px rgba(0,0,0,.55); }
.vip-about__cap-card .vip-about__desc,
.vip-about__cap-card .vip-about__content{ text-shadow:0 1px 4px rgba(0,0,0,.45); }









/* Namespace: vip-vfull */
.vip-vfull{
  position:relative; width:100vw; height:100svh;
  margin-left:50%; transform:translateX(-50%);
  overflow:hidden; isolation:isolate; background:#000;
}

/* Video covers entire viewport */
.vip-vfull__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
}

/* Subtle overlay (optional) */
.vip-vfull__veil{
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.12));
}

/* Remove any page default gap with fixed/sticky navs if needed */
html, body{ margin:0; padding:0; }













/* ================= VIFE FOOTER FULL (Namespace: viff-) ================= */
:root{
  --viff-blue:#2866c9;
  --viff-red:#f93237;
  --viff-bg1:#0b1224;
  --viff-bg2:#0f172a;
  --viff-white:#fff;
  --viff-muted:#a9b6c8;

  --viff-glass:rgba(255,255,255,.10);
  --viff-stroke:rgba(255,255,255,.18);

  --viff-shadow-1:0 10px 30px rgba(0,0,0,.25);
  --viff-shadow-2:0 18px 50px rgba(40,102,201,.28);
}

.viff{ position:relative; color:var(--viff-white);
  background: radial-gradient(60% 60% at 15% 15%, rgba(40,102,201,.14), transparent 60%),
              radial-gradient(50% 50% at 85% 80%, rgba(249,50,55,.12), transparent 60%),
              linear-gradient(180deg, var(--viff-bg2), var(--viff-bg1));
  overflow:hidden;
}
.viff__container{ width:min(1200px,92vw); margin:auto; padding:48px 0 20px; }

/* Parallax glow layers */
.viff__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.viff__layer{ position:absolute; inset:-30%; opacity:.22; mix-blend-mode:screen; }
.viff__layer--back{  background:radial-gradient(40% 60% at 15% 20%, rgba(40,102,201,.35), transparent 60%); }
.viff__layer--mid{   background:radial-gradient(50% 50% at 85% 80%, rgba(249,50,55,.35), transparent 60%); }
.viff__layer--front{ background:radial-gradient(25% 25% at 60% 30%, rgba(255,255,255,.18), transparent 70%); }

/* Brand row (open layout) */
.viff__brand{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.viff__brand-tilt{ display:flex; align-items:center; gap:14px; }
.viff__logo{ width:68px; height:68px; object-fit:contain; filter:drop-shadow(0 6px 12px rgba(0,0,0,.28)); }
.viff__name{ margin:0; font-size:1.2rem; font-weight:900; letter-spacing:.2px; }
.viff__tag{ margin:0; color:#cfe0ff; font-weight:700; }

/* Social (open) */
.viff__social{ display:flex; align-items:center; gap:10px; }
.viff__soc{
  width:42px; height:42px; display:grid; place-items:center; border-radius:12px;
  color:#fff; background:var(--viff-glass); border:1px solid var(--viff-stroke);
  transition:transform .22s ease, background .22s ease, box-shadow .22s ease;
}
.viff__soc:hover{ transform:translateY(-3px) scale(1.05); background:linear-gradient(135deg,var(--viff-blue),#1e40af); box-shadow:var(--viff-shadow-2); }

/* Divider */
.viff__rule{ height:1px; border:0; margin:18px 0; background:linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent); }
.viff__rule--soft{ background:linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent); }

/* Link rows (open, no boxes) */
.viff__links{ position:relative; z-index:1; display:grid; gap:16px; grid-template-columns:repeat(4, minmax(0,1fr)); }
@media (max-width:900px){ .viff__links{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .viff__links{ grid-template-columns:1fr;} }

.viff__col{ transform-style:preserve-3d; }
.viff__h{ margin:0 0 8px; font-size:1.02rem; font-weight:900; }
.viff__list{ list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.viff__list--contact i{ margin-right:8px; }
.viff__link{
  color:#fff; text-decoration:none; font-weight:850; letter-spacing:.2px;
  background: linear-gradient(90deg, #fff, #fff) no-repeat left bottom/0 2px;
  transition: background-size .25s ease, color .25s ease, transform .2s ease;
}
.viff__link:hover{ background-size:100% 2px; transform:translateX(2px); }
.viff__text{ color:#e6f0ff; font-weight:700; }

/* Bottom bar */
.viff__bottom{ position:relative; z-index:1; margin-top:12px;
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.viff__copy{ color:#dfe8ff; font-weight:800; }
.viff__managed{ color:#dfe8ff; font-weight:800; }
.viff__managed-link{ color:#93c5fd; text-decoration:none; font-weight:900; }
.viff__managed-link:hover{ text-decoration:underline; }
.viff__policies{ list-style:none; margin:0; padding:0; display:flex; gap:12px; }
.viff__plink{ color:#bfdbfe; font-weight:800; text-decoration:none; }
.viff__plink:hover{ text-decoration:underline; }

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .viff__layer{ transform:none !important; }
  .viff__soc, .viff__link{ transition:none !important; }
}
/* Page shell to push footer at bottom and avoid clipping */
html, body { height: 100%; }
.page-shell { min-height: 100%; display: flex; flex-direction: column; }
main { flex: 1 0 auto; }
footer.viff { flex-shrink: 0; position: relative; z-index: 10; isolation: isolate; }

/* Any page-level wrapper should not clip footer */
.vip-about, .viph-hero, .vipc, .about-wrapper, .page-wrapper {
  overflow: visible !important;
}

/* CTA band/last section spacing */
section:last-of-type { margin-bottom: 0; }

/* If any overlay/header is sticky with higher z-index, keep it below footer */
.header-overlay, .page-gradient, .section-overlay {
  z-index: 1;
}
/* Page scaffold so footer sticks at bottom and is not clipped */
html, body { height: 100%; }
.page-shell { min-height: 100%; display: flex; flex-direction: column; }
#aboutMain { flex: 1 0 auto; }
footer.viff, footer.vipf, footer.vifx { flex-shrink: 0; position: relative; z-index: 10; isolation: isolate; }

/* Make sure no parent clips footer */
.about-wrapper, .vip-about, .page-wrapper, .cta-band, .section-wrap {
  overflow: visible !important;
}

/* Any gradient/overlay on sections should sit below footer */
.section-overlay, .hero-overlay, .page-gradient { z-index: 1; position: relative; }

/* Last section spacing */
section:last-of-type { margin-bottom: 0; }

/* If your footer namespace is viff- (from last pack) keep it visible */
.viff { position: relative; z-index: 10; isolation: isolate; }
