<style>
    .logo-img {
  height: 42px;
  width: auto;
  display: block;
}
   :root{ --vg-blue:#0E5FD8; --vg-blue-600:#114bb0; --ink:#0b1220; --muted:#6b7280; --bg:#f8fafc; --card:#ffffff; --foot:#0a0f1a; --radius:18px; --shadow:0 10px 30px rgba(2, 12, 38, .10); }
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0; font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial; color:var(--ink); background:var(--bg); line-height:1.6; scroll-behavior:smooth;}
a{color:inherit; text-decoration:none}
.container{width:min(1200px, 92vw); margin:0 auto}
.btn{display:inline-flex; align-items:center; gap:.6rem; background:var(--vg-blue); color:#fff; padding:.9rem 1.2rem; border-radius:999px; font-weight:600; border:0; cursor:pointer; transition:.25s transform,.25s box-shadow, .4s opacity, .4s transform}
.btn:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(14,95,216,.3)}
.btn.outline{background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7)}


header{position:fixed; inset-inline:0; top:0; z-index:40; width:100%;}
.nav{max-width:100%; width:100%; display:flex; align-items:center; justify-content:space-between; padding:14px 40px; transition:.35s background,.35s box-shadow;}
.nav.scrolled{background:#ffffff; box-shadow:var(--shadow)}
.brand{display:flex; align-items:center; gap:.7rem}
.brand strong{font-weight:800; letter-spacing:.2px}
nav ul{display:flex; list-style:none; gap:1.8rem; padding:0; margin:0}
nav a{font-weight:600; color:#111827}


.logo-img {height:42px; width:auto; display:block}

/* HAMBURGER */
.hamburger{display:none; width:44px; height:44px; border-radius:10px; border:1px solid #e5e7eb; background:#fff; box-shadow:0 2px 6px rgba(0,0,0,.05); align-items:center; justify-content:center}
.hamburger span{display:block; width:22px; height:2px; background:#111827; position:relative}
.hamburger span::before, .hamburger span::after{content:""; position:absolute; left:0; width:22px; height:2px; background:#111827;}
.hamburger span::before{top:-6px}
.hamburger span::after{top:6px}


/* MOBILE MENU PANEL */
.mobile-menu{position:fixed; inset:0; background:rgba(10,15,26,.55); backdrop-filter:blur(6px); display:none; z-index:55}
.mobile-sheet{position:absolute; top:0; right:0; height:100%; width:min(86vw, 360px); background:#ffffff; box-shadow:var(--shadow); padding:18px 18px 24px; display:flex; flex-direction:column; gap:14px; transform:translateX(100%); transition:transform .3s ease}
.mobile-menu.open{display:block}
.mobile-menu.open .mobile-sheet{transform:translateX(0)}
.mobile-head{display:flex; align-items:center; justify-content:space-between}
.close-btn{width:40px; height:40px; border-radius:10px; border:1px solid #e5e7eb; background:#fff; display:grid; place-items:center; cursor:pointer}
.mobile-links{margin-top:8px}
.mobile-links a{display:block; padding:12px 8px; border-radius:12px; color:#0b1220; font-weight:600}
.mobile-links a:hover{background:#f3f4f6}
.mobile-cta{margin-top:auto}

    /* HERO */
    .hero{position:relative; height:100svh; min-height:560px; display:grid; place-items:center; overflow:hidden}
.hero video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(105%) contrast(105%)}
.hero::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(5,12,28,.55), rgba(5,12,28,.35) 30%, rgba(5,12,28,.55)); pointer-events:none}
.hero .content{position:relative; text-align:center; color:#fff; padding:0 1rem; display:flex; flex-direction:column; justify-content:center; align-items:center; height:100%;}
.hero h1{font-size:clamp(2rem, 4.5vw, 3.4rem); line-height:1.1; margin:0 0 14px; font-weight:800}
.hero p{opacity:.92; font-size:clamp(1rem, 2.2vw, 1.25rem); margin:0 0 auto}
.hero .cta{margin-top:auto; margin-bottom:40px; display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; opacity:0; transform:translateY(40px); animation:fadeUp 1s ease forwards; animation-delay:1s}


@keyframes fadeUp{to{opacity:1; transform:translateY(0)}}


section{padding:80px 0}
.section-head{display:flex; align-items:end; justify-content:space-between; gap:1rem; margin-bottom:28px}
.eyebrow{display:inline-block; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--vg-blue)}
h2{font-size:clamp(1.5rem, 2.8vw, 2.2rem); margin:10px 0 0}
.lede{color:var(--muted)}

    /* SECTIONS */
    section{padding:80px 0}
    .section-head{display:flex; align-items:end; justify-content:space-between; gap:1rem; margin-bottom:28px}
    .eyebrow{display:inline-block; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--vg-blue)}
    h2{font-size:clamp(1.5rem, 2.8vw, 2.2rem); margin:10px 0 0}
    .lede{color:var(--muted)}

    /* ABOUT */
    .about{display:grid; grid-template-columns:1.2fr .8fr; gap:32px}
    .card{background:var(--card); border-radius:var(--radius); box-shadow:var(--shadow)}
    .about .copy{padding:28px}
    .about .media{border-radius:var(--radius); overflow:hidden}
    .about .media img{width:100%; height:100%; object-fit:cover}

    /* PRODUCTS */
    .carousel{ position:relative; overflow:hidden; }           /* hides extra cards */
.track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - 48px)/3); /* 3 visible on desktop */
  gap:24px;
  transition:transform .5s cubic-bezier(.2,.75,.25,1);
}
.product{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  display:flex; flex-direction:column;
}
.product img{ width:100%; aspect-ratio:16/10; object-fit:cover; }
.product .info{ padding:16px 18px; }
.product h3{ margin:0 0 6px; font-size:1.05rem; }

.ctrl{
  position:absolute; inset-block:38%; width:100%;
  display:flex; justify-content:space-between; pointer-events:none;
}
.ctrl button{
  pointer-events:auto; width:42px; height:42px; border-radius:50%;
  border:0; background:#fff; box-shadow:var(--shadow);
  display:grid; place-items:center; font-weight:800; cursor:pointer;
}
    /* PARTNERS */
    .partners{background:#f1f5fb}
    .logo-row{display:flex; gap:38px; align-items:center; overflow:hidden}
    .logo-track{display:flex; gap:38px; align-items:center; animation:marquee 18s linear infinite}
    .logo{height:42px; width:auto; opacity:.8; filter:grayscale(1)}
    @keyframes marquee{from{transform:translateX(0)} to{transform:translateX(-50%)} }

    .projects { padding: 4rem 0; background:#f7fafc; }
.projects-wrap { max-width: 1160px; margin: 0 auto; padding: 0 1rem;
  display:grid; grid-template-columns: 1fr; gap: 2rem; align-items:center; }
@media (min-width: 768px){
  .projects-wrap { grid-template-columns: 380px minmax(0,1fr); }
}
.media-box { position: relative; width:100%; border-radius:16px; overflow:hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.08); }
.media-box::before { content:""; display:block; padding-top:56.25%; } /* 16:9 */
.media-box > video { position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block; }

    /* CONTACT */
    .contact{display:grid; grid-template-columns:1.1fr .9fr; gap:28px}
    .map{border:0; width:100%; height:100%; min-height:360px; border-radius:var(--radius); box-shadow:var(--shadow)}
    form{background:var(--card); padding:22px; border-radius:var(--radius); box-shadow:var(--shadow)}
    .grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
    label{display:block; font-weight:600; font-size:.9rem; margin:.2rem 0}
    input, textarea{width:100%; padding:12px 14px; border:1px solid #e5e7eb; border-radius:12px; font:inherit; outline:none}
    textarea{min-height:120px; resize:vertical}

    /* FOOTER */
    footer{background:var(--foot); color:#e5e7eb; padding:48px 0 28px}
    .footgrid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:24px}
    .footgrid h4{margin:0 0 12px; color:#fff}
    .footgrid ul{list-style:none; padding:0; margin:0; display:grid; gap:10px}
    .copyright{margin-top:24px; border-top:1px solid rgba(255,255,255,.08); padding-top:18px; font-size:.9rem; color:#cbd5e1}

    /* UTIL */
    .fade-up{opacity:0; transform:translateY(16px); transition:.7s ease}
    .fade-up.visible{opacity:1; transform:none}

    /* RESPONSIVE */
    @media (max-width: 1024px){
      .about{grid-template-columns:1fr}
      .contact{grid-template-columns:1fr}
      .track{grid-auto-columns:calc((100% - 24px)/2)}
    }
    @media (max-width: 640px){
      nav{display:none}
      .track{grid-auto-columns:100%}
      .footgrid{grid-template-columns:1fr 1fr}
    }
  </style>