:root{
  /* Brand palette extracted from OmniEdge Ventures logo */
  --brandDark: #300827;     /* deep purple */
  --brandPurple: #9e64da;   /* vibrant purple */
  --brandOrange: #f85733;   /* orange accent */

  /* Base */
  --bg: #070a12;
  --panel: rgba(255,255,255,.055);
  --border: rgba(255,255,255,.12);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --muted2: rgba(255,255,255,.55);

  --radius: 16px;
  --shadow: 0 16px 44px rgba(0,0,0,.40);
  --max: 1120px;

  /* Primary/CTA */
  --primary: var(--brandPurple);
  --primaryHover: #8a56c6;

  /* Gradients */
  --gradBrand: linear-gradient(135deg, rgba(158,100,218,.90), rgba(248,87,51,.88));
  --gradGlow: linear-gradient(135deg, rgba(158,100,218,.18), rgba(248,87,51,.14), rgba(255,255,255,.05));
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x:hidden;
}

/* Ambient background */
.ambient{
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
}
.orb{
  position:absolute;
  width: 560px;
  height: 560px;
  filter: blur(64px);
  opacity:.20;
  border-radius:50%;
  transform: translate3d(0,0,0);
}
.orb-1{ left:-180px; top:-140px; background: radial-gradient(circle at 30% 30%, rgba(158,100,218,1), transparent 62%); }
.orb-2{ right:-240px; top:10vh; background: radial-gradient(circle at 30% 30%, rgba(248,87,51,1), transparent 60%); }
.orb-3{ left:18vw; bottom:-280px; background: radial-gradient(circle at 30% 30%, rgba(158,100,218,1), transparent 62%); }

.grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at 50% 20%, rgba(0,0,0,1), rgba(0,0,0,.25) 55%, rgba(0,0,0,0) 80%);
  opacity:.35;
}

/* Top bar */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 18px;
  backdrop-filter: blur(10px);
  background: rgba(7,10,18,.66);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--text);
  font-weight:800;
  letter-spacing:.2px;
}
.brand-logo{
  height: 36px;
  width: auto;
  object-fit: contain;
  border-radius: 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  padding: 6px;
}

/* ✅ Desktop nav default (prevents links disappearing) */
.nav{
  display:flex;
  gap:14px;
  align-items:center;
}
.nav a{
  color: var(--muted);
  text-decoration:none;
  font-weight:700;
  font-size:13px;
  padding:10px 10px;
  border-radius:12px;
}
.nav a:hover{ color: var(--text); background: rgba(255,255,255,.06); }

.nav-toggle{
  display:none;
  background: transparent;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:10px;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:18px;height:2px;
  background: rgba(255,255,255,.8);
  margin:4px 0;
}

/* Progress */
.progress{
  position:fixed;
  top:0; left:0;
  width:100%;
  height:3px;
  z-index:60;
  background: rgba(255,255,255,.06);
}
.progress .bar{
  width:0%;
  height:100%;
  background: linear-gradient(90deg, rgba(158,100,218,1), rgba(248,87,51,.80));
}

/* Layout */
.container{
  width:min(var(--max), calc(100% - 36px));
  margin:0 auto;
}
.section{
  padding: 90px 0;
  position:relative;
}
.card{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.muted{ color: var(--muted); }
.tiny{ font-size: 12px; line-height: 1.35; color: var(--muted2); }

.eyebrow{
  display:inline-block;
  font-weight:800;
  letter-spacing: .14em;
  text-transform:uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.84);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  padding: 8px 12px;
  border-radius: 999px;
}
.section-head{ margin-bottom: 22px; }
.section-head.center{ text-align:center; }
.headline{
  margin: 14px 0 10px;
  font-size: clamp(30px, 3.8vw, 46px);
  line-height: 1.08;
  letter-spacing: -0.03em;
}
.subhead{
  margin: 10px auto 0;
  font-size: 16px;
  line-height: 1.75;
  color: var(--muted);
  max-width: 78ch;
}

/* =========================
   BANNER (OLD BEHAVIOR)
   Full image visible + no crop + no bars
========================= */
.banner{ padding: 0; }

/* Slider container */
.banner-media{
  position: relative;
  width: 100%;
  height: auto;         /* ✅ height comes from active image */
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: #070a12;  /* ✅ no bars because container height = image height */
}

/* Slides wrapper */
.banner-slides{
  position: relative;
  width: 100%;
  height: auto;
}

/* Each slide stacked */
.banner-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 900ms ease;
  pointer-events: none;
}

/* Active slide defines the height */
.banner-slide.is-active{
  opacity: 1;
  position: relative;  /* ✅ critical */
  pointer-events: none;
}

/* Full image visible (no crop) */
.banner-slide img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  object-position: center;
  transform: none !important;
  filter: none !important;
}

/* Remove dark overlay */
.banner-overlay{ display: none !important; }

/* Text overlay */
.banner-content{
  position: absolute;
  inset: 0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 22px;
  pointer-events: none;

  opacity: 1;
  visibility: visible;
  transition: opacity 240ms ease, visibility 240ms ease;
}
.banner-content.is-hidden{
  opacity: 0;
  visibility: hidden;
}

/* Text readability */
.banner-content .banner-pill,
.banner-content .banner-title,
.banner-content .banner-subtitle,
.banner-content .pill{
  text-shadow: 0 3px 18px rgba(0,0,0,.85);
}

/* Typography */
.banner-pill{
  font-size: clamp(28px, 3.2vw, 56px);
  padding: 0;
  letter-spacing: .10em;
  font-weight: 900;
  background: transparent;
  border: none;
  margin: 0;
}
.banner-title{
  margin-top: 10px;
  font-size: clamp(18px, 2.2vw, 28px);
  line-height: 1.15;
  font-weight: 800;
}
.banner-subtitle{
  font-size: clamp(14px, 1.5vw, 18px);
  line-height: 1.7;
  max-width: 80ch;
}

/* Fallback */
.banner-fallback{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding: 22px;
}
.banner-media.is-missing .banner-fallback{ display:flex; }
.banner-media.is-missing .banner-slides{ display:none; }

.banner-fallback-inner{
  width:min(var(--max), calc(100% - 36px));
  text-align:center;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  box-shadow: var(--shadow);
}

/* Hero pills */
.hero-pills{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top: 14px;
}
.pill{
  font-size: 14px;
  font-weight:800;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  padding: 10px 14px;
  border-radius: 999px;
}

/* Mini list */
.mini-list{
  margin: 10px 0 14px;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.7;
}
.mini-list li{ margin: 4px 0; }

/* Welcome cards */
.welcome-cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 18px;
}
.stat{ padding: 16px; }
.stat h3{ margin: 0 0 8px; font-size: 16px; }
.stat p{ margin: 0; line-height: 1.7; }

/* Companies */
.companies-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 18px;
  align-items: stretch;
}
.company-card{
  padding: 18px;
  position:relative;
  overflow:hidden;
}
.company-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: var(--gradGlow);
  opacity: .75;
}
.company-card > *{ position:relative; }

.company-media{
  width: 100%;
  margin: 0 0 14px;
}
.company-media img{
  width: 100%;
  height: 210px;
  display: block;
  object-fit: cover;
  object-position: center;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
}

.company-name{
  margin: 0 0 8px;
  font-size: 20px;
  letter-spacing: -0.02em;
}
.company-desc{ margin: 0 0 12px; line-height: 1.7; }
.company-link{
  display:inline-flex;
  text-decoration:none;
  font-weight:800;
  color: rgba(255,255,255,.90);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}
.company-link:hover{ background: rgba(255,255,255,.10); }

.company-left{ justify-self: end; max-width: 520px; }
.company-right{ justify-self: start; max-width: 520px; }

/* Services */
.services-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 18px;
}
.service{ padding: 16px; }
.service h3{ margin: 0 0 6px; font-size: 16px; }
.service p{ margin: 0 0 10px; line-height: 1.7; }
.tag{
  display:inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.78);
}

/* Vision/Strategy */
.vm-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}
.vm{
  padding: 18px;
  position:relative;
  overflow:hidden;
}
.vm::before{
  content:"";
  position:absolute;
  inset:-2px;
  opacity:.9;
}
.vm-vision::before{
  background: radial-gradient(circle at 20% 30%, rgba(158,100,218,.28), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.28));
}
.vm-mission::before{
  background: radial-gradient(circle at 80% 30%, rgba(248,87,51,.22), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.28));
}
.vm > *{ position:relative; }
.vm h3{ margin: 0 0 10px; font-size: 18px; }
.vm p{ margin: 0; line-height: 1.75; }

/* Team */
.team-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 18px;
}
.member{ padding: 16px; text-align:center; }
.avatar{
  width: 150px;
  height: 150px;
  margin: 0 auto 12px;
  border-radius: 22px;
  overflow:hidden;
  position:relative;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
}
.avatar img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.avatar.is-missing img{ display:none; }

.map-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 650px));
  justify-content: center;
  gap: 24px;
}
.map-card{ padding: 16px; }
.map-card h3{ margin: 0 0 6px; font-size: 16px; }
.map-card p{ margin: 0 0 12px; line-height: 1.7; }
.map-frame{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  height: 400px;
  background: rgba(255,255,255,.04);
}
.map-frame iframe{
  width:100%;
  height:100%;
  border:0;
}

/* Footer */
.footer{
  padding: 40px 0 52px;
  border-top: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(7,10,18,.40), rgba(7,10,18,.92));
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr .8fr;
  gap: 16px;
  align-items:start;
}
.footer-brand-top{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom: 10px;
}
.footer-logo{
  height: 34px;
  width: auto;
  object-fit: contain;
  border-radius: 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  padding: 6px;
}
.footer-col h4{
  margin: 0 0 10px;
  font-size: 13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(255,255,255,.84);
}
.footer a{
  color: rgba(255,255,255,.88);
  text-decoration:none;
}
.footer a:hover{ text-decoration:underline; }
.footer-links{
  display:grid;
  gap: 8px;
}

/* Responsive */
@media (max-width: 980px){
  .welcome-cards{ grid-template-columns: 1fr; }
  .companies-grid{ grid-template-columns: 1fr; }
  .company-left, .company-right{ justify-self: center; max-width: 560px; }
  .services-grid{ grid-template-columns: 1fr 1fr; }
  .vm-grid{ grid-template-columns: 1fr; }
  .team-grid{ grid-template-columns: 1fr; }
  .map-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
}

/* Mobile */
@media (max-width: 760px){

  /* keep hamburger visible */
  .nav{
    position:fixed;
    top:58px; right:18px; left:18px;
    display:none;
    flex-direction:column;
    background: rgba(7,10,18,.92);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    padding: 10px;
  }
  .nav a{ padding: 12px 12px; }
  .nav-toggle{ display:block; }
  .services-grid{ grid-template-columns: 1fr; }
  .brand-logo{ height: 32px; }
  .footer-logo{ height: 32px; }

  /* ✅ Keep FULL image (no crop) */
  .banner-slide img{
    width: 100%;
    height: auto;
    object-fit: contain;
  }

  /* ✅ Smaller text + less top padding so pills don't get clipped */
  .banner-content{
    padding: 54px 12px 12px;
    justify-content: flex-start;
    gap: 4px;
  }

  .banner-pill{
    font-size: clamp(13px, 4.3vw, 16px);
    line-height: 1.05;
    letter-spacing: .05em;
    margin: 0;
  }

  .banner-title{
    font-size: clamp(12px, 3.6vw, 15px);
    line-height: 1.15;
    margin: 4px 0 0;
  }

  .banner-subtitle{
    font-size: clamp(11px, 3.0vw, 13px);
    line-height: 1.35;
    max-width: 38ch;
    margin: 4px 0 0;
  }

  /* ✅ Pills: smaller + single row on most phones */
  .hero-pills{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    width: 100%;
    max-width: 420px;
    margin: 8px auto 0;
    padding: 0 8px;
    justify-items: stretch;
  }

  .pill{
    width: 100%;
    text-align: center;
    font-size: clamp(9px, 2.3vw, 11px);
    padding: 5px 6px;
    line-height: 1.1;

    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .hero-pills .pill:nth-child(3){
    grid-column: auto;
  }

  .company-media img{ height: 190px; }
}

/* Narrow phones: 2 columns + last pill full width */
@media (max-width: 420px){
  .hero-pills{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 360px;
  }
  .hero-pills .pill:nth-child(3){
    grid-column: 1 / -1;
  }
}

/* Extra-small devices (iPhone SE etc.): stack */
@media (max-width: 360px){
  .hero-pills{
    grid-template-columns: 1fr;
    max-width: 320px;
  }
  .hero-pills .pill:nth-child(3){
    grid-column: auto;
  }
}

/* ✅ Short-height phones (address bar etc.) — reduce banner content further */
@media (max-width: 760px) and (max-height: 740px){
  .banner-content{ padding: 44px 10px 10px; gap: 3px; }
  .banner-pill{ font-size: clamp(12px, 4.0vw, 14px); }
  .banner-title{ font-size: clamp(11px, 3.4vw, 14px); }
  .banner-subtitle{ font-size: clamp(10px, 2.8vw, 12px); }
  .pill{ font-size: clamp(9px, 2.2vw, 10px); padding: 4px 6px; }
}
