
  /* ── Base ── */
  body { font-family:'Plus Jakarta Sans',sans-serif; }

  /* ── Hero ── */
  .hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
  .hero-bg { position:absolute; inset:0; z-index:0; }
  .hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(15,23,42,.80) 0%,rgba(14,116,144,.40) 100%); }
  .hero-bg video { width:100%; height:100%; object-fit:cover; display:block; }

  .hero-grid { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:calc(var(--nav-h) + 2rem) 1.5rem 3rem; display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; width:100%; }

  /* Badge */
  .hero-badge { display:inline-flex; align-items:center; gap:.5rem; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); color:#67e8f9; font-size:.82rem; font-weight:700; padding:.4rem 1rem; border-radius:999px; margin-bottom:1.25rem; letter-spacing:.04em; }
  .ping { width:9px; height:9px; border-radius:50%; background:#4ade80; display:inline-block; animation:ping-anim 1.5s ease-in-out infinite; flex-shrink:0; }
  @keyframes ping-anim { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.5)} }

  /* Heading */
  .hero h1 { font-size:clamp(2.2rem,5vw,3.5rem); font-weight:900; color:#fff; line-height:1.1; margin-bottom:1.25rem; }
  .hero h1 .gradient { background:linear-gradient(90deg,#67e8f9,#fff); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
  .hero-sub { color:rgba(255,255,255,.8); font-size:1.05rem; line-height:1.7; margin-bottom:1.75rem; max-width:480px; }

  /* Buttons */
  .hero-btns { display:flex; gap:1rem; flex-wrap:wrap; }
  .hero-btns .btn-primary { background:var(--cyan); color:#fff; padding:.78rem 1.75rem; border-radius:999px; font-weight:700; font-size:.95rem; border:none; cursor:pointer; transition:background .25s,transform .2s; text-decoration:none; display:inline-flex; align-items:center; gap:.4rem; }
  .hero-btns .btn-primary:hover { background:var(--cyan-d); transform:translateY(-2px); }
  .hero-btns .btn-outline { background:rgba(255,255,255,.1); color:#fff; padding:.75rem 1.65rem; border-radius:999px; border:1.5px solid rgba(255,255,255,.35); font-weight:700; font-size:.95rem; cursor:pointer; transition:background .25s,transform .2s; text-decoration:none; display:inline-flex; align-items:center; gap:.4rem; }
  .hero-btns .btn-outline:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }

  /* Video teaser card */
  .video-card { border-radius:1.25rem; overflow:hidden; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.05); backdrop-filter:blur(8px); }
  .vc-inner { position:relative; aspect-ratio:16/9; overflow:hidden; background:#0f172a; }
  .vc-inner video { width:100%; height:100%; object-fit:cover; display:block; }
  .vc-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(15,23,42,.55) 0%,transparent 60%); display:flex; align-items:flex-end; gap:.75rem; padding:.85rem 1rem; }
  .vc-btn { background:var(--cyan); color:#fff; border:none; padding:.4rem .9rem; border-radius:999px; font-size:.8rem; font-weight:700; cursor:pointer; transition:background .2s; }
  .vc-btn:hover { background:var(--cyan-d); }
  .vc-link { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); color:#fff; padding:.4rem .9rem; border-radius:999px; font-size:.8rem; font-weight:600; text-decoration:none; transition:background .2s; }
  .vc-link:hover { background:rgba(255,255,255,.22); }
  .vc-caption { padding:.65rem 1rem; font-size:.78rem; color:rgba(255,255,255,.6); }

  /* Stats */
  .hero-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:.85rem; margin-top:1.75rem; }
  .stat-box { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.1); border-radius:1rem; padding:.9rem .75rem; text-align:center; backdrop-filter:blur(8px); }
  .stat-box .num { font-size:1.8rem; font-weight:900; color:#67e8f9; line-height:1; }
  .stat-box .label { font-size:.72rem; color:rgba(255,255,255,.65); margin-top:.25rem; }

  /* Right panel */
  .hero-right-panel { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); border-radius:1.5rem; padding:1.75rem; backdrop-filter:blur(16px); }
  .hrp-video { aspect-ratio:16/9; border-radius:1rem; overflow:hidden; background:#0f172a; margin-bottom:1.25rem; }
  .hrp-video video { width:100%; height:100%; object-fit:cover; display:block; }
  .hrp-chips { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; }
  .hrp-chip { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); border-radius:.75rem; padding:.75rem .6rem; }
  .hrp-chip .ct { font-size:.72rem; font-weight:700; color:#67e8f9; margin-bottom:.2rem; }
  .hrp-chip .cv { font-size:.68rem; color:rgba(255,255,255,.6); }

  /* Fade in */
  .fade-in { animation:fadeUp .8s ease both; }
  @keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

  /* Service Cards */
  .svc-section { background:#fff; padding:5rem 0; }
  .svc-grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.5rem; margin-top:3rem; }
  .svc4-card { border-radius:1.25rem; overflow:hidden; border:1px solid var(--gray-200); box-shadow:var(--shadow); transition:transform .3s,box-shadow .3s; }
  .svc4-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-l); }
  .svc4-card img { width:100%; height:200px; object-fit:cover; }
  .svc4-body { padding:1.25rem; }
  .svc4-body h3 { font-weight:800; color:var(--navy); margin-bottom:.35rem; }
  .svc4-body p { font-size:.875rem; color:var(--slate); }
  .svc4-body a { display:inline-flex; align-items:center; gap:.3rem; color:var(--cyan); font-size:.8rem; font-weight:700; margin-top:.75rem; }

  /* Process */
  .process-section { background:linear-gradient(135deg,#f0f9ff,#e0f2fe); padding:5rem 0; }

  /* Area Tags */
  .area-tags { display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center; margin:1.5rem 0; }
  .area-tag { padding:.5rem 1.25rem; border-radius:999px; font-weight:600; font-size:.875rem; }

  /* Responsive */
  @media(max-width:900px){
    .hero-grid { grid-template-columns:1fr; padding:calc(var(--nav-h) + 1rem) 1.25rem 3rem; }
    .hero-right-panel { display:none; }
    .hero-sub { max-width:100%; }
  }
  @media(max-width:480px){
    .hero h1 { font-size:1.9rem; }
    .hero-stats { gap:.5rem; }
    .stat-box .num { font-size:1.5rem; }
    .hero-btns { flex-direction:column; }
    .hero-btns a { text-align:center; justify-content:center; }
  }

.orbit-wrap {
  position: relative;
  max-width: 780px;
  margin: 3.5rem auto 1rem;
  height: 420px;
}

/* Oval background track */
.orbit-track {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%) rotate(6deg);
  width: 72%; height: 58%;
  border: 2px solid rgba(14,165,233,.18);
  border-radius: 50%;
  pointer-events: none;
}

/* Spinning arc */
.orbit-arc {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%) rotate(6deg);
  width: 72%; height: 58%;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top: 3px solid rgba(14,165,233,.35);
  border-right: 3px solid rgba(56,189,248,.2);
  animation: orbit-spin 10s linear infinite;
  pointer-events: none;
}
@keyframes orbit-spin {
  from { transform: translate(-50%,-50%) rotate(6deg); }
  to   { transform: translate(-50%,-50%) rotate(366deg); }
}

/* Centre water drop pulse */
.orbit-centre {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 72px; height: 72px;
  background: linear-gradient(135deg,#bae6fd,#7dd3fc);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  animation: centre-pulse 2.5s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(14,165,233,.4);
}
@keyframes centre-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(14,165,233,.35); }
  50%      { box-shadow: 0 0 0 18px rgba(14,165,233,.0); }
}

/* Each step node */
.orbit-step {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  transform: translateX(-50%);
  width: 130px;
}
.os-icon {
  width: 58px; height: 58px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 20px rgba(0,0,0,.15);
  transition: transform .3s;
  cursor: default;
}
.orbit-step:hover .os-icon { transform: scale(1.12); }
.os-label {
  display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: .15rem;
}
.os-label strong {
  font-size: .9rem; font-weight: 800; color: #1e293b;
}
.os-label span {
  font-size: .75rem; color: #64748b; line-height: 1.4;
}

/* Mobile: stack linearly */
@media (max-width: 680px) {
  .orbit-wrap {
    height: auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    align-items: center;
    padding: 1rem 0;
  }
  .orbit-track, .orbit-arc, .orbit-centre { display: none; }
  .orbit-step {
    position: static !important;
    transform: none !important;
    flex-direction: row;
    align-items: center;
    width: 100%;
    max-width: 320px;
    gap: 1rem;
    text-align: left;
  }
  .os-label { align-items: flex-start; text-align: left; }
  .os-icon { flex-shrink: 0; }
}

.mini-cta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,.1);
  min-height: 0;
}
.mini-cta-left {
  background: #f0fdf4;
  border: 1.5px solid #bbf7d0;
  border-right: none;
  border-radius: 1.5rem 0 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 2.5rem;
  position: relative;
  overflow: hidden;
}
.mini-cta-blob {
  position: absolute;
  width: 260px; height: 260px;
  border-radius: 50%;
  border: 1.5px solid rgba(134,239,172,.5);
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  pointer-events: none;
}
.mini-cta-note {
  font-size: .95rem;
  font-weight: 700;
  color: #166534;
  text-align: center;
  position: relative;
  z-index: 1;
  line-height: 1.6;
}
.mini-cta-right {
  background: rgba(15,28,55,.78);
  padding: 2rem 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 0 1.5rem 1.5rem 0;
}
.mini-cta-right h3 {
  font-size: clamp(1.1rem,2.5vw,1.5rem);
  font-weight: 900;
  color: #fff;
  margin-bottom: .6rem;
}
.mini-cta-right p {
  font-size: .85rem;
  color: rgba(255,255,255,.7);
  line-height: 1.6;
  margin-bottom: 1.25rem;
  max-width: 320px;
}
.mini-cta-btns {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  justify-content: center;
}
.mini-btn-white {
  background: #fff;
  color: #0f172a;
  padding: .55rem 1.35rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .85rem;
  text-decoration: none;
  transition: background .2s, transform .2s;
  border: none;
}
.mini-btn-white:hover { background: #f1f5f9; transform: translateY(-2px); }
.mini-btn-outline {
  background: transparent;
  color: #fff;
  padding: .55rem 1.35rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .85rem;
  text-decoration: none;
  border: 1.5px solid rgba(255,255,255,.4);
  transition: background .2s, transform .2s;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}
.mini-btn-outline:hover { background: rgba(255,255,255,.1); transform: translateY(-2px); }

@media (max-width: 600px) {
  .mini-cta { grid-template-columns: 1fr; }
  .mini-cta-left { border-right: 1.5px solid #bbf7d0; border-bottom: none; border-radius: 1.5rem 1.5rem 0 0; padding: 1.5rem; }
  .mini-cta-right { border-radius: 0 0 1.5rem 1.5rem; padding: 1.5rem; }
}
