/* Namespace root */
:root{
  --vibe-pri:#0ea5e9;
  --vibe-sec:#8b5cf6;
  --vibe-ink:#0f172a;
  --vibe-muted:#64748b;
  --vibe-bg:#0b1220;
  --vibe-card:#0f172a;
  --vibe-grad:linear-gradient(135deg, var(--vibe-pri), var(--vibe-sec));
  --radius:14px;
}

.vibe-contact{ font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:#e2e8f0; background:#0b0f17; margin:0; }

/* Hero */
.vibe-contact__hero{ position:relative; min-height:44svh; display:grid; place-items:center; overflow:hidden; }
.vibe-contact__hero-bg{ position:absolute; inset:-10% -2%; background:radial-gradient(1200px 400px at 10% -10%, #1f2937 0, transparent 60%), url('../img/contact-hero.jpg') center/cover no-repeat; transform:translateZ(0); }
.vibe-contact__hero-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(2,6,23,.65), rgba(2,6,23,.85)); }
.vibe-contact__hero-content{ position:relative; text-align:center; padding:min(6vw,48px); }
.vibe-contact__title{ font-size:clamp(28px, 3.6vw, 42px); margin:.1rem 0 .4rem; }
.vibe-contact__subtitle{ color:#cbd5e1; max-width:62ch; margin-inline:auto; }

/* Main grid */
.vibe-contact__main{ padding: clamp(16px, 4vw, 40px); }
.vibe-contact__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:clamp(16px,3.5vw,28px);
  align-items:start;
}
@media (max-width: 900px){
  .vibe-contact__grid{ grid-template-columns:1fr; }
}

/* Cards */
.vibe-contact__card{
  background:linear-gradient(180deg, #ebecee, #9ca8c0);
  border-radius:var(--radius);
  border:1px solid rgba(148,163,184,.15);
  box-shadow:0 20px 60px rgba(199, 82, 15, 0.4);
  padding: clamp(16px, 3.5vw, 28px);
  position:relative;
  will-change:transform;
}
.vibe-contact__card-title{ margin:0 0 12px; font-size:clamp(18px,2.2vw,22px); }

/* Form */
.vibe-contact__form{ display:grid; gap:14px; }
.vibe-contact__field{ display:grid; gap:6px; }
.vibe-contact__field label{ color:#eb1212; font-weight:600; }
.vibe-contact__form input,
.vibe-contact__form textarea{
  background:#aaabaf; color:#072052; border:1px solid rgba(14, 100, 219, 0.18);
  border-radius:12px; padding:12px 14px; outline:none; width:100%;
  transition:border-color .2s, box-shadow .2s, transform .15s;
}
.vibe-contact__form input:focus,
.vibe-contact__form textarea:focus{
  border-color:transparent; box-shadow:0 0 0 2px #22d3ee inset, 0 0 0 2px #22d3ee;
}
.vibe-contact__error{ color:#fca5a5; min-height:1em; }

.vibe-contact__btn{
  display:inline-grid; place-items:center; gap:8px;
  grid-auto-flow:column;
  background:var(--vibe-grad); color:white; border:none;
  padding:12px 18px; border-radius:12px; cursor:pointer;
  font-weight:700; letter-spacing:.2px; box-shadow:0 10px 30px rgba(14,165,233,.3);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s;
}
.vibe-contact__btn:hover{ transform:translateY(-2px); box-shadow:0 16px 40px rgba(143, 6, 6, 0.3); filter:saturate(1.05); }
.vibe-contact__btn:active{ transform:translateY(0); }
.vibe-contact__btn-loader{ width:16px; height:16px; border:2px solid rgba(255,255,255,.45); border-top-color:white; border-radius:50%; display:none; animation:spin .9s linear infinite; }
.vibe-contact__btn.loading .vibe-contact__btn-text{ opacity:.35; }
.vibe-contact__btn.loading .vibe-contact__btn-loader{ display:inline-block; }

@keyframes spin{ to{ transform:rotate(1turn); } }

/* Toast */
.vibe-contact__toast{
  position:absolute; top:10px; right:10px; background:#052e2b; color:#a7f3d0;
  border:1px solid #134e4a; padding:10px 12px; border-radius:10px; font-weight:600;
}

/* Info list */
.vibe-contact__list{ list-style:none; padding:0; margin:0 0 14px; display:grid; gap:12px; }
.vibe-contact__list-item{ display:grid; grid-template-columns: 32px 1fr; gap:12px; align-items:flex-start; }
.vibe-contact__icon{ width:32px; height:32px; display:grid; place-items:center; background:#0b1220; border:1px solid rgba(148,163,184,.15); border-radius:10px; }

/* Socials */
.vibe-contact__social{ display:flex; gap:10px; flex-wrap:wrap; }
.vibe-contact__social-btn{
  width:40px; height:40px; display:grid; place-items:center; color:white; text-decoration:none;
  border-radius:12px; background:#0b1220; border:1px solid rgba(148,163,184,.18); font-weight:800;
  transition:transform .18s, box-shadow .18s, background .18s, color .18s;
}
.vibe-contact__social-btn:hover{ transform:translateY(-3px); box-shadow:0 12px 28px rgba(2,6,23,.45); }
.vibe-contact__social-btn.fb{ background:#0b65da; }
.vibe-contact__social-btn.ig{ background:linear-gradient(45deg,#feda75,#d62976,#962fbf,#4f5bd5); }
.vibe-contact__social-btn.yt{ background:#ff0033; }
.vibe-contact__social-btn.li{ background:#0a66c2; }
.vibe-contact__social-btn.x{ background:#000; }

/* Micro interactions */
.vibe-contact__form input:hover,
.vibe-contact__form textarea:hover{ transform:translateY(-1px); }

/* Utilities */
.vibe-contact__hp{ position:absolute; left:-9999px; }



/* Namespace: vch-hero (Vibe Contact Hero) */
:root{
  --vch-ink:#e5e7eb;
  --vch-muted:#cbd5e1;
  --vch-pri:#0ea5e9;
  --vch-sec:#8b5cf6;
  --vch-grad:linear-gradient(135deg, var(--vch-pri), var(--vch-sec));
  --vch-r:16px;
}

.vch-hero{
  position:relative; isolation:isolate;
  min-height:38svh;            /* compact height */
  display:grid; place-items:center;
  padding: clamp(16px, 4vw, 28px);
  overflow:hidden; color:var(--vch-ink);
  background:#0b0f17;
}
.vch-hero__bg{
  position:absolute; inset:-8% -2%;
  background:
    radial-gradient(1200px 420px at 10% -15%, rgba(14,165,233,.25), transparent 55%),
    url('Contact-hero.jpg') center/cover no-repeat;
  transform:translateZ(0);
  will-change:transform;
  filter:saturate(1.05) contrast(1.05);
}
.vch-hero__veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(2,6,23,.55), rgba(2,6,23,.88)); }

.vch-hero__inner{ position:relative; text-align:center; max-width:1100px; margin:auto; }
.vch-hero__badge{
  display:inline-grid; grid-auto-flow:column; align-items:center; gap:10px;
  background:rgba(2,6,23,.55); border:1px solid rgba(242, 245, 250, 0.25);
  padding:8px 12px; border-radius:999px; backdrop-filter:saturate(1.4) blur(6px);
  box-shadow:0 10px 30px rgba(2,6,23,.4);
  transform-style:preserve-3d;
}
.vch-hero__dot{ width:8px; height:8px; background:#22d3ee; border-radius:50%; box-shadow:0 0 16px #22d3ee; }
.vch-hero__badge-text{ font-size:.92rem; color:var(--vch-muted); }

.vch-hero__title{
  font-size: clamp(28px, 4.4vw, 46px);
  margin: clamp(8px,1.8vw,14px) 0 6px;
  letter-spacing:.2px; text-shadow:0 6px 24px rgba(0,0,0,.4);
}
.vch-hero__subtitle{
  color:var(--vch-muted); max-width:70ch; margin:0 auto;
}

.vch-hero__cta{ margin-top: clamp(10px, 2.6vw, 18px); display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.vch-hero__btn{
  display:inline-grid; place-items:center;
  padding:12px 18px; border-radius:12px; color:white; text-decoration:none;
  background:var(--vch-grad);
  box-shadow:0 10px 30px rgba(14,165,233,.28);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.vch-hero__btn:hover{ transform:translateY(-3px); box-shadow:0 16px 42px rgba(139,92,246,.32); filter:saturate(1.05); }
.vch-hero__ghost{
  display:inline-grid; place-items:center;
  padding:12px 18px; border-radius:12px; text-decoration:none; color:var(--vch-ink);
  border:1px solid rgba(13, 52, 107, 0.28); background:rgba(2,6,23,.35);
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.vch-hero__ghost:hover{ transform:translateY(-2px); border-color:#22d3ee; background:rgba(2,6,23,.5); }

/* Micro interactions */
.vch-hero__badge:hover{ box-shadow:0 16px 46px rgba(2,6,23,.55); }
.vch-hero__badge:focus-within{ outline:2px solid #22d3ee; outline-offset:3px; }

/* Responsive */
@media (max-width:720px){
  .vch-hero{ min-height:34svh; }
  .vch-hero__badge-text{ font-size:.9rem; }
}







/* Namespace: vip-contact */
:root{
  --vc-bg:#ffffff; --vc-ink:#0f172a; --vc-muted:#475569;
  --vc-line:#e2e8f0; --vc-pri:#0ea5e9; --vc-sec:#22d3ee; --vc-r:16px;
}

.vip-contact{ background:var(--vc-bg); color:var(--vc-ink); }
.vip-contact__container{
  max-width:1200px; margin:0 auto; padding:clamp(20px,5vw,64px);
}

.vip-contact__head{ text-align:left; margin-bottom:clamp(14px,3.6vw,24px); }
.vip-contact__title{ font-weight:800; font-size:clamp(26px,4.2vw,40px); margin:0 0 6px; }
.vip-contact__lead{ margin:.2rem 0; color:var(--vc-muted); }

.vip-contact__grid{
  display:grid; gap:clamp(12px,2.6vw,18px);
  grid-template-columns:repeat(3, minmax(220px,1fr));
}

.vip-contact__card{
  background:#fff; border:1px solid var(--vc-line); border-radius:var(--vc-r);
  padding:clamp(14px,2.6vw,22px);
  box-shadow:0 10px 28px rgba(2,6,23,.08);
  transition:transform .18s, box-shadow .18s, border-color .18s, filter .18s;
}
.vip-contact__card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 46px rgba(2,6,23,.12), 0 0 0 1px rgba(14,165,233,.25) inset;
  filter:saturate(1.04);
}

.vip-contact__icon{
  width:44px; height:44px; display:grid; place-items:center; border-radius:12px;
  background:rgba(14,165,233,.12); border:1px solid #bae6fd; color:#075985; margin-bottom:8px; font-size:22px;
}
.vip-contact__h3{ margin:0 0 4px; font-weight:800; }
.vip-contact__val{ margin:0; color:var(--vc-muted); }

.vip-contact__link{
  color:inherit; text-decoration:none; border-bottom:1px dashed #94a3b8;
  transition:color .18s, border-color .18s;
}
.vip-contact__link:hover{ color:#0ea5e9; border-color:#0ea5e9; }

/* Responsive */
@media (max-width:920px){
  .vip-contact__grid{ grid-template-columns:1fr; }
}











/* ===== Get Quote — CSS (Namespace: vq-) ===== */
#getQuote{
  --vq-bg:#0b1220; --vq-card:#0f172a; --vq-ink:#e6edff; --vq-muted:#9fb2ff;
  --vq-blue:#2563eb; --vq-red:#ef4444; --vq-line:#1f2a44;
  --vq-padX:clamp(18px,4vw,28px); --vq-padY:clamp(32px,8vh,96px);
}
.vq{ width:100vw; margin-left:50%; transform:translateX(-50%); background:var(--vq-bg); color:var(--vq-ink); }
.vq__wrap{ max-width:1280px; margin:0 auto; padding:var(--vq-padY) var(--vq-padX); }
.vq__head{ text-align:center; margin-bottom:clamp(20px,4vh,32px); }
.vq__title{ margin:0; font-weight:1000; font-size:clamp(28px,5.2vw,44px); letter-spacing:.2px; }
.vq__sub{ margin:.4rem 0 0; color:var(--vq-muted); }

.vq__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:stretch; }
.vq__form{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.00));
  border:1px solid var(--vq-line); border-radius:18px; padding:22px; box-shadow:0 20px 60px rgba(2,6,23,.28);
}
.vq__row{ display:grid; gap:8px; margin-bottom:14px; }
.vq__row--2{ grid-template-columns:1fr; } .vq__row--full{ grid-column:1/-1; }
.vq__label{ font:700 12px/1.2 system-ui; letter-spacing:.14em; color:#b8c7ff; text-transform:uppercase; }
.vq__input{
  width:100%; padding:14px 14px; border-radius:12px; border:1px solid #223154; background:#0e1830; color:#eaf0ff;
  outline:none; transition:border-color .2s ease, box-shadow .2s ease, transform .15s ease;
}
.vq__input:focus{ border-color:color-mix(in oklab, var(--vq-blue) 55%, var(--vq-red) 45%); box-shadow:0 0 0 4px rgba(37,99,235,.2); }
.vq__textarea{ resize:vertical; min-height:120px; }
.vq__check{ display:flex; gap:10px; align-items:flex-start; color:#cbd6ff; font-size:14px; margin:6px 0 10px; }
.vq__cta{
  display:inline-block; padding:14px 20px; border-radius:999px; border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(135deg, var(--vq-red), var(--vq-blue));
  color:#fff; font:900 14px/1 system-ui; letter-spacing:.2px;
  box-shadow:0 16px 40px rgba(2,6,23,.32); transition:transform .18s, box-shadow .18s, filter .18s;
}
.vq__cta:hover{ transform:translateY(-2px); box-shadow:0 24px 56px rgba(2,6,23,.42); filter:saturate(1.06); }
.vq__note{ color:#a9bbff; margin:10px 0 0; font-size:13px; }

.vq__art{
  position:relative; border-radius:18px; border:1px solid var(--vq-line);
  background: radial-gradient(1200px 600px at 20% -10%, rgba(37,99,235,.20), transparent 55%),
              radial-gradient(1200px 600px at 120% 120%, rgba(239,68,68,.22), transparent 50%),
              #0c1424;
  overflow:hidden; min-height:380px; box-shadow:0 20px 60px rgba(2,6,23,.28);
}
.vq__halo{ position:absolute; inset:-20%; background:radial-gradient(closest-side, rgba(255,255,255,.12), rgba(255,255,255,0)); filter:blur(22px); }
.vq__stats{ position:absolute; inset:0; display:grid; place-items:center; gap:18px; grid-auto-rows:min-content; }
.vq__stat{ display:grid; place-items:center; padding:10px 14px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid #213052; transform:translateY(0); transition:transform .25s ease; }
.vq__stat strong{ font-weight:1000; font-size:28px; }
.vq__stat span{ color:#c7d7ff; font-size:12px; letter-spacing:.14em; text-transform:uppercase; }

.vq__stat:hover{ transform:translateY(-4px); }

@media (max-width:1024px){ .vq__grid{ grid-template-columns:1fr; } }
@media (prefers-reduced-motion:reduce){
  .vq__cta, .vq__stat{ transition:none !important; }
}




















/* 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:#770606; 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; }
