/* ─── HERO ─── */
      #services-hero {
        min-height: 68vh; padding-top: 72px;
        background: linear-gradient(160deg, #ffffff 0%, #eef6ff 40%, #f0f9ff 100%);
        position: relative; overflow: hidden; display: flex; align-items: center;
      }
      .hero-bg-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
      .hero-blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.18; }
      .blob1 { width: 600px; height: 600px; background: var(--primary); top: -200px; right: -100px; animation: floatBlob 8s ease-in-out infinite; }
      .blob2 { width: 400px; height: 400px; background: var(--secondary); bottom: -100px; left: -100px; animation: floatBlob 10s ease-in-out infinite reverse; }
      .hero-grid {
        position: absolute; inset: 0;
        background-image: linear-gradient(rgba(37,99,235,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(37,99,235,0.04) 1px, transparent 1px);
        background-size: 48px 48px;
      }
      @keyframes floatBlob { 0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-30px) scale(1.06);} }

      .services-hero-inner {
        max-width: 1280px; margin: 0 auto; padding: 80px 5%;
        position: relative; z-index: 2; width: 100%;
      }
      .hero-badge {
        display: inline-flex; align-items: center; gap: 8px;
        background: rgba(37,99,235,0.08); border: 1px solid rgba(37,99,235,0.15);
        padding: 6px 16px; border-radius: 50px; font-size: 12.5px; font-weight: 600;
        color: var(--primary); margin-bottom: 24px; animation: fadeInUp 0.6s ease both;
      }
      .badge-dot { width: 7px; height: 7px; background: var(--secondary); border-radius: 50%; animation: pulse 2s infinite; }
      @keyframes pulse { 0%,100%{opacity:1;}50%{opacity:0.4;} }
      .services-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
      .services-hero-title {
        font-family: "Manrope", sans-serif;
        font-size: clamp(36px, 4.5vw, 58px);
        font-weight: 800; line-height: 1.1; letter-spacing: -1.5px;
        color: var(--text); margin-bottom: 22px; animation: fadeInUp 0.7s ease 0.1s both;
      }
      .services-hero-title .grad {
        background: linear-gradient(135deg, var(--primary), var(--accent));
        -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
      }
      .services-hero-sub {
        font-size: 16.5px; color: var(--muted); line-height: 1.75;
        margin-bottom: 36px; animation: fadeInUp 0.7s ease 0.2s both;
      }
      .hero-cta-row {
        display: flex; gap: 14px; flex-wrap: wrap;
        animation: fadeInUp 0.7s ease 0.3s both;
      }
      .btn-hero-primary {
        display: inline-flex; align-items: center; gap: 9px;
        background: linear-gradient(135deg, var(--primary), var(--accent));
        color: #fff; font-weight: 700; font-size: 15px;
        padding: 14px 28px; border-radius: 12px; border: none; cursor: pointer;
        text-decoration: none; box-shadow: 0 6px 24px rgba(37,99,235,0.38);
        transition: all 0.25s; font-family: "Plus Jakarta Sans", sans-serif;
      }
      .btn-hero-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(37,99,235,0.5); }
      .btn-hero-ghost {
        display: inline-flex; align-items: center; gap: 9px;
        background: rgba(255,255,255,0.8); color: var(--text); font-weight: 600; font-size: 15px;
        padding: 13px 26px; border-radius: 12px; border: 1.5px solid var(--border);
        cursor: pointer; text-decoration: none; backdrop-filter: blur(10px);
        transition: all 0.25s; font-family: "Plus Jakarta Sans", sans-serif;
      }
      .btn-hero-ghost:hover { border-color: var(--primary); color: var(--primary); background: var(--bg3); }

      /* Service area quick-links on hero right */
      .hero-service-pills {
        display: flex; flex-direction: column; gap: 10px;
        animation: fadeInUp 0.7s ease 0.25s both;
      }
      .hero-pill {
        display: flex; align-items: center; gap: 14px;
        background: rgba(255,255,255,0.85); border: 1px solid var(--border);
        border-radius: 14px; padding: 14px 18px;
        backdrop-filter: blur(10px); text-decoration: none;
        transition: all 0.25s; cursor: pointer;
      }
      .hero-pill:hover { border-color: rgba(37,99,235,0.3); background: #fff; transform: translateX(5px); box-shadow: var(--shadow); }
      .hp-icon {
        width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
        background: linear-gradient(135deg, var(--primary), var(--accent));
        display: flex; align-items: center; justify-content: center; font-size: 16px;
      }
      .hp-name { font-size: 13.5px; font-weight: 700; color: var(--text); }
      .hp-desc { font-size: 12px; color: var(--muted); margin-top: 1px; }
      .hp-arrow { margin-left: auto; color: var(--muted); font-size: 14px; transition: all 0.2s; }
      .hero-pill:hover .hp-arrow { color: var(--primary); transform: translateX(3px); }

      @keyframes fadeInUp { from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);} }

      /* ─── SERVICE OVERVIEW TABLE ─── */
      #service-overview { background: var(--bg2); }
      .overview-table-wrap { border: 1px solid var(--border); border-radius: 20px; overflow: hidden; box-shadow: var(--shadow); }
      .overview-table { width: 100%; border-collapse: collapse; }
      .overview-table thead tr { background: linear-gradient(135deg, var(--primary), var(--accent)); }
      .overview-table thead th { padding: 18px 28px; text-align: left; font-size: 12.5px; font-weight: 700; color: #fff; letter-spacing: 0.5px; text-transform: uppercase; }
      .overview-table tbody tr { border-bottom: 1px solid var(--border); transition: background 0.2s; }
      .overview-table tbody tr:last-child { border-bottom: none; }
      .overview-table tbody tr:hover { background: var(--bg3); }
      .overview-table td { padding: 18px 28px; font-size: 14px; color: var(--muted); vertical-align: middle; }
      .overview-table td:first-child { font-weight: 700; color: var(--text); white-space: nowrap; }
      .ot-icon { font-size: 20px; margin-right: 10px; }

      /* ─── SERVICE DETAIL SECTIONS ─── */
      .service-section { padding: 80px 5%; }
      .service-section:nth-child(odd) { background: #fff; }
      .service-section:nth-child(even) { background: var(--bg2); }

      .service-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
      .service-detail-grid.reverse { direction: rtl; }
      .service-detail-grid.reverse > * { direction: ltr; }

      .service-detail-content {}
      .service-num {
        font-size: 11px; font-weight: 800; color: var(--primary);
        text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 10px;
      }
      .service-detail-title {
        font-family: "Manrope", sans-serif; font-weight: 800;
        font-size: clamp(24px, 2.8vw, 36px); color: var(--text);
        letter-spacing: -0.5px; line-height: 1.2; margin-bottom: 6px;
      }
      .service-detail-tagline {
        font-size: 15px; color: var(--primary); font-weight: 600;
        margin-bottom: 18px;
      }
      .service-detail-desc { font-size: 15px; color: var(--muted); line-height: 1.8; margin-bottom: 28px; }

      /* Capabilities panel */
      .capabilities-panel {
        background: linear-gradient(145deg, var(--bg3), rgba(56,189,248,0.08));
        border: 1px solid rgba(37,99,235,0.15);
        border-radius: 20px; padding: 32px 28px;
      }
      .cap-header {
        font-size: 11px; font-weight: 800; color: var(--muted);
        text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 18px;
        display: flex; align-items: center; gap: 8px;
      }
      .cap-header::before { content: ""; width: 20px; height: 2px; background: var(--primary); border-radius: 2px; }
      .cap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
      .cap-item {
        display: flex; align-items: center; gap: 9px;
        font-size: 13.5px; color: var(--text); font-weight: 500;
        padding: 10px 12px; border-radius: 10px;
        background: #fff; border: 1px solid var(--border);
        transition: all 0.2s;
      }
      .cap-item:hover { border-color: rgba(37,99,235,0.25); background: var(--bg3); color: var(--primary); }
      .cap-dot {
        width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0;
        background: linear-gradient(135deg, var(--primary), var(--accent));
        display: flex; align-items: center; justify-content: center;
        font-size: 8px; color: #fff; font-weight: 800;
      }

      /* Visual card panel */
      .service-visual {
        position: relative;
      }
      .service-visual-card {
        border-radius: 24px; overflow: hidden;
        box-shadow: var(--shadow-lg); position: relative;
      }
      .svc-card-header {
        padding: 32px 32px 24px;
        display: flex; align-items: center; gap: 18px;
      }
      .svc-big-icon {
        width: 64px; height: 64px; border-radius: 18px; flex-shrink: 0;
        background: rgba(255,255,255,0.2);
        display: flex; align-items: center; justify-content: center;
        font-size: 28px;
      }
      .svc-card-title { font-family: "Manrope",sans-serif; font-weight: 800; font-size: 20px; color: #fff; line-height: 1.2; }
      .svc-card-sub { font-size: 13px; color: rgba(255,255,255,0.75); margin-top: 4px; }
      .svc-card-body { background: #fff; padding: 28px 32px; }
      .svc-stat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 20px; }
      .svc-stat { text-align: center; padding: 16px 10px; border-radius: 12px; background: var(--bg2); border: 1px solid var(--border); }
      .svc-stat-num { font-family: "Manrope",sans-serif; font-weight: 800; font-size: 22px; color: var(--primary); line-height: 1; }
      .svc-stat-label { font-size: 11px; color: var(--muted); font-weight: 500; margin-top: 4px; line-height: 1.3; }
      .svc-tags { display: flex; flex-wrap: wrap; gap: 8px; }
      .svc-tag {
        font-size: 12px; font-weight: 600; color: var(--primary);
        background: var(--bg3); border: 1px solid rgba(37,99,235,0.15);
        padding: 4px 12px; border-radius: 20px; transition: all 0.2s;
      }
      .svc-tag:hover { background: var(--primary); color: #fff; }

      /* gradient headers per service */
      .grad-sw   { background: linear-gradient(135deg, #1e3a8a, #2563eb); }
      .grad-cloud { background: linear-gradient(135deg, #0c4a6e, #0ea5e9); }
      .grad-data  { background: linear-gradient(135deg, #1e1b4b, #7c3aed); }
      .grad-ai    { background: linear-gradient(135deg, #064e3b, #059669); }
      .grad-qa    { background: linear-gradient(135deg, #7c2d12, #ea580c); }
      .grad-sysadm { background: linear-gradient(135deg, #1c1917, #44403c); }
      .grad-pm    { background: linear-gradient(135deg, #701a75, #c026d3); }

      /* Float badges on visual */
      .visual-float-badge {
        position: absolute; display: flex; align-items: center; gap: 8px;
        background: #fff; border: 1px solid var(--border);
        border-radius: 12px; padding: 10px 14px;
        box-shadow: var(--shadow-lg); font-size: 12.5px; font-weight: 700; color: var(--text);
      }
      .vfb-left  { bottom: -16px; left: -16px; }
      .vfb-right { top: -16px; right: -16px; }
      .vfb-dot { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; animation: pulse 2s infinite; }

      /* ─── WHY CHOOSE ─── */
      #why-choose { background: #fff; }
      .why-table-wrap { border: 1px solid var(--border); border-radius: 20px; overflow: hidden; box-shadow: var(--shadow); }
      .why-table { width: 100%; border-collapse: collapse; }
      .why-table thead tr { background: linear-gradient(135deg, var(--primary), var(--accent)); }
      .why-table thead th { padding: 18px 28px; text-align: left; font-size: 12.5px; font-weight: 700; color: #fff; letter-spacing: 0.5px; text-transform: uppercase; }
      .why-table tbody tr { border-bottom: 1px solid var(--border); transition: background 0.2s; }
      .why-table tbody tr:last-child { border-bottom: none; }
      .why-table tbody tr:hover { background: var(--bg3); }
      .why-table td { padding: 18px 28px; font-size: 14px; vertical-align: middle; }
      .why-table td:first-child { font-weight: 700; color: var(--text); }
      .why-table td:last-child { color: var(--primary); font-weight: 600; }
      .why-arrow { color: var(--primary); margin-right: 8px; }
      
       /* ─── RESPONSIVE ─── */
      @media (max-width: 1100px) {
        .services-hero-grid { grid-template-columns: 1fr; gap: 48px; }
        .service-detail-grid { grid-template-columns: 1fr; gap: 48px; }
        .service-detail-grid.reverse { direction: ltr; }
        .footer-top { grid-template-columns: 1fr 1fr 1fr; }
      }
      @media (max-width: 900px) {
        .cap-grid { grid-template-columns: 1fr; }
        .cta-inner { flex-direction: column; text-align: center; }
        .cta-sub { max-width: 100%; }
        .svc-stat-row { grid-template-columns: repeat(3,1fr); }
      }
      @media (max-width: 700px) {
        .nav-links, .nav-cta { display: none; }
        .hamburger { display: flex; }
        .hero-service-pills { display: none; }
        .svc-stat-row { grid-template-columns: repeat(3,1fr); gap: 8px; }
        section { padding: 70px 5%; }
        .service-section { padding: 70px 5%; }
        .cta-inner { padding: 40px 28px; }
        .footer-top { grid-template-columns: 1fr 1fr; }
        .vfb-left, .vfb-right { display: none; }
      }