
:root{
  --bg: #0b1220;
  --card: #0f172a;
  --ink: #e6eefc;
  --muted:#94a3b8;
  --brand:#2dd4bf;
  --brand-2:#60a5fa;
  --ring: rgba(96,165,250,.35);
  --border: #1e293b;
  --shadow: 0 10px 30px rgba(2,8,23,.45);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);
  background: radial-gradient(1200px 600px at 80% -10%, rgba(96,165,250,.15), transparent 60%),
              radial-gradient(1000px 500px at -10% 0%, rgba(45,212,191,.12), transparent 60%),
              linear-gradient(180deg, #0b1220 0%, #0b1220 100%);}
img{max-width:100%;height:auto;display:block;border-radius:12px}
.container{width:min(1180px, 92%);margin:0 auto}
.center{text-align:center}
.small{font-size:.9rem;color:var(--muted)}
a{color:inherit;text-decoration:none}
a:hover{opacity:.9}
.site-header{position:sticky; top:0; z-index:20;background: rgba(11,18,32,.8);backdrop-filter: blur(8px);border-bottom:1px solid var(--border)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{display:flex;align-items:center;gap:10px;font-weight:700}
.logo img{width:28px;height:28px}
.nav{display:flex;gap:24px;align-items:center}
.nav a{opacity:.9}
.nav .btn.small{padding:.5rem .9rem}
.menu{display:none;background:none;border:none;cursor:pointer}
.menu span{display:block;width:24px;height:2px;background:#cbd5e1;margin:5px 0;border-radius:2px}
.btn{display:inline-block;background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#0b1220;padding:.9rem 1.15rem;border-radius:999px;font-weight:700;box-shadow:var(--shadow);border:0}
.btn.ghost{background:transparent;border:1px solid var(--border);color:var(--ink)}
.btn.white{background:white;color:#0b1220}
.hero{padding:64px 0 32px;border-bottom:1px solid var(--border)}
.hero-inner{display:grid;grid-template-columns: 1.2fr .8fr;gap:32px;align-items:center;min-height:70vh}
.hero-copy h1{font-size: clamp(2rem, 1.8rem + 2vw, 3.2rem); line-height:1.1;margin:0 0 12px}
.accent{background: linear-gradient(90deg,#fff, #a5b4fc, #60a5fa, #2dd4bf);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-copy p{color:var(--muted);font-size:1.1rem}
.cta{display:flex;gap:12px;margin:18px 0 8px}
.trust{display:grid;grid-template-columns: repeat(3, minmax(0,1fr));gap:10px;margin:16px 0 0;padding:0}
.trust li{list-style:none;background:#0b1530;border:1px solid var(--border);padding:10px 12px;border-radius:10px;color:#cbd5e1}
.hero-art{position:relative;min-height:360px}
.shape{position:absolute;border-radius:24px;filter:blur(12px);opacity:.8}
.shape.a{top:0;right:0;width:220px;height:220px;background:radial-gradient(circle,#60a5fa,transparent 70%)}
.shape.b{bottom:10%;left:10%;width:180px;height:180px;background:radial-gradient(circle,#2dd4bf,transparent 70%)}
.shape.c{bottom:0;right:20%;width:260px;height:140px;background:radial-gradient(circle,#a78bfa,transparent 70%)}
.section{padding:64px 0;border-bottom:1px solid var(--border)}
.grid-2{display:grid;grid-template-columns: 1.1fr .9fr;gap:28px;align-items:start}
.grid-3{display:grid;grid-template-columns: repeat(3, 1fr);gap:22px}
.grid-4{display:grid;grid-template-columns: repeat(4, 1fr);gap:22px}
.card{background:var(--card);border:1px solid var(--border);padding:22px;border-radius:14px;box-shadow:var(--shadow)}
.cards .card h3{margin-top:0}
.bullets{padding-left:18px}
.bullets li{margin:.25rem 0;color:#cbd5e1}
.band{background:linear-gradient(90deg,#0b1530,#0b1220);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.band-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 0}
.band .btn.white{box-shadow:none}
.projects .project{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--border);background:#0b1530}
.project img{aspect-ratio: 4/3; object-fit:cover; width:100%}
.project-meta{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg, transparent, rgba(11,18,32,.9));padding:14px 16px}
.page-hero{padding:72px 0 26px;border-bottom:1px solid var(--border)}
.page-hero h1{margin:0}
.panel{background:rgba(96,165,250,.07);border:1px solid var(--ring);padding:18px;border-radius:12px}
.form{display:grid;gap:14px}
.form label{display:grid;gap:6px;font-weight:600}
.form input,.form select,.form textarea{background:#0b1530;border:1px solid var(--border);color:var(--ink);padding:.8rem .9rem;border-radius:10px;outline:none}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px var(--ring)}
.map-placeholder{height:220px;background:#0b1530;border:1px dashed var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#94a3b8}
.site-footer{padding:36px 0;background:#0b0f1b;border-top:1px solid var(--border)}
.site-footer h4{margin:0 0 10px}
.site-footer h5{margin:0 0 8px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.35rem 0;color:#cbd5e1}
/* CTA + mobile fixes */
@media (max-width: 768px){
  .hero-inner{grid-template-columns: 1fr}
  .grid-2{grid-template-columns: 1fr}
  .grid-3{grid-template-columns: 1fr 1fr}
  .grid-4{grid-template-columns: 1fr 1fr}
  .trust{grid-template-columns: 1fr 1fr}
  .nav{position:fixed;inset:70px 0 auto 0;display:none;flex-direction:column;background:#0b1220;border-bottom:1px solid var(--border);padding:16px}
  .nav.open{display:flex}
  .menu{display:block}
  .band-inner{flex-direction: column; align-items: stretch; text-align: center; gap: 12px;}
  .band .btn, .band .btn.white{display:block;width:100%;border-radius:12px;padding:1rem 1rem;line-height:1.2;white-space:normal;flex:0 0 auto}
}
@media (max-width: 640px){
  .grid-3{grid-template-columns: 1fr}
  .grid-4{grid-template-columns: 1fr}
}
/* Video blocks */
.video-break{padding:36px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:linear-gradient(90deg,rgba(96,165,250,.07),rgba(45,212,191,.06))}
.video-card{background:#0b1530;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.video-card video{display:block;width:100%;height:auto;max-height:520px;object-fit:cover}
/* Hero video if used */
.hero-video-wrap{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--border);background:#0b1530;margin-bottom:14px}
.video-bg{width:100%;height:100%;display:block;object-fit:cover;max-height:540px;filter:saturate(1.05) contrast(1.05)}


/* --- Minimal Lightbox --- */
.lightbox-overlay{position:fixed;inset:0;background:rgba(5,10,20,.9);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1000}
.lightbox-overlay.open{display:flex}
.lightbox-stage{position:relative;max-width:min(92vw,1200px);max-height:90vh;display:flex;align-items:center;justify-content:center}
.lightbox-stage img{max-width:100%;max-height:90vh;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);object-fit:contain}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:absolute;top:50%;transform:translateY(-50%);background:rgba(15,23,42,.6);border:1px solid var(--border);
  color:#e6eefc;border-radius:999px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;user-select:none;backdrop-filter:blur(4px)
}
.lightbox-close{top:10px;right:10px;transform:none}
.lightbox-prev{left:-56px}
.lightbox-next{right:-56px}
.lightbox-caption{position:absolute;left:0;right:0;bottom:-54px;text-align:center;color:#cbd5e1;font-size:.95rem}
@media (max-width: 900px){
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
  .lightbox-caption{bottom:-42px;font-size:.9rem}
}
body.noscroll{overflow:hidden}
/* --- Project image tiles --- */
.projects .project-img img{aspect-ratio: 4/3; width:100%; height:auto; object-fit:cover; border-radius:12px}


/* Top-of-page video banner */
.page-top-video{padding:18px 0 0;border-bottom:1px solid var(--border)}
.page-top-video .video-card{background:#0b1530;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.page-top-video .video-bg{display:block;width:100%;height:auto;max-height:520px;object-fit:cover}

/* Ensure project meta doesn't overlap */
.project-meta{pointer-events:none}
.projects .project{display:block}


/* --- Anti-overlap hardening for lists/typography --- */
.cards, .projects, .bullets {gap: 16px;}
.cards .card h3, .cards .card p, .cards .card li {position: static;}
.cards .card h3 {margin: 0 0 .5rem 0; line-height: 1.25;}
.cards .card p {margin: 0 0 .75rem 0; line-height: 1.5;}
.cards .card ul.bullets {margin: 0 0 .75rem 1rem; padding: 0;}
.cards .card ul.bullets li {display: list-item; list-style: disc; margin: .25rem 0; line-height: 1.5;}
/* Prevent any absolute-positioned label overlays from stacking */
.project .project-meta, .card .label {position: static;}
/* Ensure headings/lists never overlap due to transforms */
* {text-rendering: optimizeLegibility;}


/* --- Footer badge: Powered by LaunchOne --- */
.footer-powered {margin-top: 8px; padding-top: 10px; border-top: 1px solid rgba(148,163,184,.15); display:flex; justify-content:flex-end; font-size:.95rem; color:#94a3b8}
.footer-powered a{color:#94a3b8; text-decoration:none; font-weight:600}
.footer-powered a:hover{color:#e6eefc; text-decoration:underline}


/* Services polish */
.service-intro{max-width:900px}
.service-cards .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.svc-card{background:#0f172a;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.svc-card h3{margin:0 0 .5rem 0}
.svc-card h4{margin:1rem 0 .5rem 0;color:#a3b3cc}
.svc-card p{margin:0 0 .5rem 0;line-height:1.6}
.svc-card ul{margin:.25rem 0 .5rem 1.25rem}
.svc-card li{margin:.25rem 0}
@media (max-width: 900px){
  .service-cards .grid-2{grid-template-columns:1fr}
}


/* Services polish (full content) */
.service-intro{max-width:900px}
.service-cards .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.svc-card{background:#0f172a;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.svc-card h3{margin:0 0 .5rem 0}
.svc-card h4{margin:1rem 0 .5rem 0;color:#a3b3cc}
.svc-card p{margin:0 0 .5rem 0;line-height:1.6}
.svc-card ul{margin:.25rem 0 .5rem 1.25rem}
.svc-card li{margin:.25rem 0}
@media (max-width: 900px){
  .service-cards .grid-2{grid-template-columns:1fr}
}


/* ===== Services visual polish v2 ===== */
.service-intro{max-width:980px}
.service-cards{position:relative}
.svc-card{
  background: linear-gradient(180deg, rgba(15,23,42,.85) 0%, rgba(10,14,28,.92) 100%);
  border:1px solid rgba(148,163,184,.16);
  border-radius:18px;
  padding:22px;
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.svc-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
  border-color: rgba(148,163,184,.28);
}
.svc-card h3{margin:0 0 .6rem 0; letter-spacing:.2px}
.svc-card h4{margin:1rem 0 .5rem 0; color:#a9bbd6}
.svc-card p{margin:0 0 .6rem 0; line-height:1.7}
.svc-card ul{margin:.25rem 0 .75rem 1.1rem}
.svc-card li{margin:.3rem 0}
.service-cards .grid-2{display:grid; grid-template-columns:1fr 1fr; gap:26px}
@media (max-width: 1024px){
  .service-cards .grid-2{gap:20px}
}
@media (max-width: 900px){
  .service-cards .grid-2{grid-template-columns:1fr}
}
/* Projects grid containment tidy-up */
.container.projects.grid-3 { align-items: stretch; }
.project { display:block; border-radius:14px; overflow:hidden; border:1px solid rgba(148,163,184,.18); background:#0b1224; }
.project img{ display:block; width:100%; height:260px; object-fit:cover; }
.project .project-meta{ padding:10px 12px; }
.project .project-meta h4{ margin:0; font-weight:600; font-size:1rem; }


/* ===== Services v3: unified cards w/ collapsible ===== */
.service-cards .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.svc-card{display:flex;flex-direction:column;min-height:420px}
.svc-card .svc-actions{margin-top:auto}
.btn-read{
  display:inline-block; padding:10px 14px; border-radius:10px; border:1px solid rgba(148,163,184,.25);
  background:transparent; color:#dbe6ff; cursor:pointer; transition:all .18s ease; font-weight:600;
}
.btn-read:hover{transform:translateY(-1px); border-color:rgba(148,163,184,.45)}
.svc-more{margin-top:.5rem}
@media (max-width: 900px){
  .service-cards .grid-2{grid-template-columns:1fr}
  .svc-card{min-height:unset}
}


/* --- Services preview & toggle --- */
.svc-card {background:var(--card); border:1px solid var(--border); border-radius:16px; padding:20px; box-shadow: var(--shadow);}
.svc-card h3{margin-top:6px}
.svc-preview{color:var(--muted); margin:.5rem 0 1rem; line-height:1.5; display:block}
.svc-more[hidden]{display:none !important}
.svc-actions{display:flex; gap:10px; margin-top:8px}
.btn-read{cursor:pointer; border:1px solid var(--ring); background:transparent; color:var(--ink); border-radius:999px; padding:8px 14px}
.btn-read[aria-expanded="true"]{background:rgba(96,165,250,.08)}


/* --- Services preview & toggle (robust) --- */
.svc-card {background:var(--card); border:1px solid var(--border); border-radius:16px; padding:20px; box-shadow: var(--shadow);}
.svc-card h3{margin-top:6px}
.svc-preview{color:var(--muted); margin:.5rem 0 1rem; line-height:1.5; display:block}
.svc-more[hidden]{display:none !important}
.svc-actions{display:flex; gap:10px; margin-top:8px}
.btn-read{cursor:pointer; border:1px solid var(--ring); background:transparent; color:var(--ink); border-radius:999px; padding:8px 14px}
.btn-read[aria-expanded="true"]{background:rgba(96,165,250,.08)}


/* === MEC Tech Hero Enhancements (injected) === */
.hero{
  position:relative; min-height:72vh; display:grid; place-items:center;
  overflow:hidden; border-radius:20px; margin:24px 0; padding:24px; background:#0b1320;
  box-shadow: 0 20px 80px rgba(0,0,0,.35);
}
.hero video.hero-video, .hero > video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter:brightness(.82) contrast(1.05) saturate(1.08);
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 10% 10%, rgba(46,139,192,.22) 0%, rgba(13,24,41,.75) 55%, rgba(9,14,24,.95) 100%),
    linear-gradient(120deg, rgba(24,195,176,.18), rgba(94,134,255,.18) 60%, transparent);
  pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute; inset:-2px; z-index:2; pointer-events:none; opacity:.45;
  background:
    repeating-linear-gradient(100deg, rgba(120,180,255,.10) 0 1px, transparent 1px 14px),
    repeating-linear-gradient( 10deg, rgba(24,195,176,.07) 0 1px, transparent 1px 18px);
  -webkit-mask: radial-gradient(80% 60% at 40% 40%, #000 55%, transparent 100%);
          mask: radial-gradient(80% 60% at 40% 40%, #000 55%, transparent 100%);
  animation: mecDrift 18s linear infinite;
}
@keyframes mecDrift{
  0%{transform:translate3d(-2%, -2%, 0)}
  50%{transform:translate3d(2%, 2%, 0)}
  100%{transform:translate3d(-2%, -2%, 0)}
}
.video-break{position:relative; width:100%; height:min(56vw,560px); overflow:hidden; margin:48px 0; background:#0a101c; border-radius:16px}
.video-break .break-video, .video-break > video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.85) contrast(1.05)}
.video-break .break-overlay{position:absolute; inset:0; background:linear-gradient(to bottom, rgba(9,14,24,.9), rgba(9,14,24,.15) 40%, rgba(9,14,24,.9)); pointer-events:none}
/* === End MEC injection === */

/* injected: center services grid on index */
.cards--center .grid{justify-content:center}
.cards--center .card{margin-left:auto; margin-right:auto; text-align:center}


/* === Mobile nav dropdown fix (injected) === */
.nav-toggle{
  display:none; position:relative; z-index:60; width:42px; height:38px;
  border:1px solid rgba(255,255,255,.15); border-radius:10px; background:rgba(255,255,255,.05);
  backdrop-filter: blur(6px);
}
.nav-toggle-bar{display:block; width:22px; height:2px; margin:6px auto; background:#fff; border-radius:2px}
@media (max-width: 900px){
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .topbar .wrap{gap:.5rem}
  .nav{
    position:fixed; top:64px; right:12px; left:12px;
    background:rgba(6,10,18,.96); border:1px solid rgba(255,255,255,.08);
    border-radius:14px; padding:12px; display:none; flex-direction:column; gap:.25rem;
    max-height:70vh; overflow:auto; z-index:55;
  }
  .nav.is-open{display:flex}
  .nav a{padding:.7rem .8rem; border-radius:10px}
  .nav a:active{background:rgba(255,255,255,.06)}
  .nav .has-submenu{position:relative; list-style:none}
  .nav .has-submenu > a{padding-right:2.2rem}
  .nav .submenu{
    display:none; flex-direction:column; gap:.15rem; margin:.25rem 0 .5rem 0; padding-left:.5rem;
    border-left:2px solid rgba(255,255,255,.08);
  }
  .nav .has-submenu.open > .submenu{display:flex}
  .submenu-toggle{
    position:absolute; top:.35rem; right:.35rem; width:32px; height:32px;
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:8px;
  }
  body.nav-lock{overflow:hidden}
}
/* === End mobile nav dropdown fix === */


/* Single-dropdown mobile nav (normalized) */



/* === Mobile Inline Nav (no dropdown) === */
@media (max-width: 900px){
  .menu-toggle, .nav-toggle, .menu { display: none !important; }
  .nav {
    display: flex !important;
    position: static !important;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    padding: 0 !important;
    gap: 12px !important;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .nav a { padding: .5rem .6rem; border-radius: .6rem; }
  .nav-wrap { gap: .5rem; }
}

/* === Unified mobile dropdown (ChatGPT) === */
@media (max-width: 900px){
  /* toggle button visible on mobile */
  .menu, .nav-toggle { display:inline-flex; align-items:center; justify-content:center }
  /* dropdown panel */
  .nav{
    position:fixed; top:64px; right:12px; left:12px;
    background:rgba(6,10,18,.96);
    border:1px solid rgba(255,255,255,.08);
    border-radius:14px;
    padding:12px;
    display:none;
    flex-direction:column;
    gap:.25rem;
    max-height:70vh;
    overflow:auto;
    z-index:55;
  }
  .nav.open{ display:flex }
  .nav a{ padding:.7rem .8rem; border-radius:10px }
  .nav a:active{ background:rgba(255,255,255,.06) }
  body.nav-lock{ overflow:hidden }
}

/* === HARD MOBILE DROPDOWN OVERRIDE (ChatGPT) ===
   Forces the nav to be HIDDEN on mobile unless `.open` is present.
   Adds !important so older rules or other stylesheets (e.g., pro.css) cannot override.
*/
@media (max-width: 900px){
  .site-header .menu,
  .site-header .nav-toggle{ display:inline-flex !important; align-items:center; justify-content:center }

  .site-header .nav,
  .nav-wrap > .nav{
    display:none !important;
    position:fixed !important;
    top:64px; right:12px; left:12px;
    background:rgba(6,10,18,.96) !important;
    border:1px solid rgba(255,255,255,.08) !important;
    border-radius:14px !important;
    padding:12px !important;
    flex-direction:column !important;
    gap:.25rem !important;
    max-height:70vh !important;
    overflow:auto !important;
    z-index:999 !important;
  }
  .site-header .nav.open{ display:flex !important; }

  .site-header .nav a{ display:block !important; padding:.7rem .8rem !important; border-radius:10px !important; }
  .site-header .nav a:active{ background:rgba(255,255,255,.06) !important; }

  body.nav-lock{ overflow:hidden !important; }
}
