:root {
      --bg: #05070a;
      --bg-soft: #0a0d13;
      --panel: rgba(13, 17, 25, 0.84);
      --panel-light: rgba(255, 255, 255, 0.045);
      --blue: #007bff;
      --blue-bright: #00c6ff;
      --silver: #c9c9c9;
      --muted: #9da3ad;
      --white: #f5f7fa;
      --line: rgba(0, 123, 255, 0.35);
      --shadow: 0 0 55px rgba(0, 123, 255, 0.18);
      --radius: 22px;
    }

    * {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: Arial, Helvetica, sans-serif;
      color: var(--white);
      background:
        radial-gradient(circle at top center, rgba(0, 123, 255, 0.16), transparent 32%),
        radial-gradient(circle at 90% 30%, rgba(0, 198, 255, 0.08), transparent 25%),
        linear-gradient(135deg, #030508, #090b10 45%, #020304);
      overflow-x: hidden;
    }

    body::before {
      content: "";
      position: fixed;
      inset: 0;
      background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
      background-size: 52px 52px;
      mask-image: radial-gradient(circle at center, black, transparent 78%);
      pointer-events: none;
      z-index: -2;
    }

    body::after {
      content: "";
      position: fixed;
      inset: 0;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='104' viewBox='0 0 180 104'%3E%3Cg fill='none' stroke='%23007BFF' stroke-opacity='.13' stroke-width='1'%3E%3Cpath d='M30 1h60l30 51-30 51H30L0 52z'/%3E%3Cpath d='M120 1h60l30 51-30 51h-60L90 52z'/%3E%3C/g%3E%3C/svg%3E");
      opacity: 0.26;
      pointer-events: none;
      z-index: -1;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    img {
      max-width: 100%;
      display: block;
    }

    .container {
      width: min(1180px, calc(100% - 36px));
      margin: 0 auto;
    }

    .nav {
      position: sticky;
      top: 0;
      z-index: 50;
      backdrop-filter: blur(16px);
      background: rgba(5, 7, 10, 0.78);
      border-bottom: 1px solid rgba(0, 123, 255, 0.22);
    }

    .nav-inner {
      height: 78px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 22px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
    }

    .brand img {
      width: 250px;
      height: 150px;
      object-fit: contain;
      filter: drop-shadow(0 0 14px rgba(0, 123, 255, 0.4));
    }

    .brand-text strong {
      display: block;
      color: var(--silver);
      font-size: 18px;
      line-height: 1;
      letter-spacing: 3px;
      text-transform: uppercase;
      white-space: nowrap;
    }

    .brand-text span {
      display: block;
      color: var(--blue-bright);
      font-size: 11px;
      letter-spacing: 4px;
      margin-top: 5px;
      text-transform: uppercase;
      white-space: nowrap;
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 26px;
      color: #d7d7d7;
      font-size: 13px;
      letter-spacing: 1.5px;
      text-transform: uppercase;
    }

    .nav-links a:hover {
      color: var(--blue-bright);
    }

    .menu-btn {
      display: none;
      width: 44px;
      height: 44px;
      border: 1px solid rgba(0, 123, 255, 0.35);
      background: rgba(255,255,255,0.03);
      border-radius: 12px;
      color: var(--white);
      cursor: pointer;
      font-size: 22px;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 0 22px;
      border-radius: 999px;
      border: 1px solid rgba(0, 198, 255, 0.55);
      background: linear-gradient(135deg, rgba(0, 123, 255, 0.95), rgba(0, 198, 255, 0.65));
      color: white;
      font-size: 13px;
      font-weight: 800;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      box-shadow: 0 0 30px rgba(0, 123, 255, 0.24);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 0 42px rgba(0, 123, 255, 0.42);
    }

    .btn.secondary {
      background: rgba(255,255,255,0.035);
      color: var(--white);
    }

    .hero {
      min-height: calc(100vh - 78px);
      display: grid;
      align-items: center;
      padding: 72px 0;
      position: relative;
    }

    .hero-grid {
      display: grid;
      grid-template-columns: 1.12fr 0.88fr;
      gap: 42px;
      align-items: center;
    }

    .eyebrow {
      color: var(--blue-bright);
      letter-spacing: 5px;
      text-transform: uppercase;
      font-weight: 800;
      font-size: 13px;
      margin-bottom: 18px;
    }

    .hero h1 {
      font-size: clamp(48px, 8vw, 96px);
      line-height: 0.94;
      text-transform: uppercase;
      letter-spacing: -3px;
      margin-bottom: 24px;
    }

    .hero h1 span {
      color: var(--blue);
      text-shadow: 0 0 32px rgba(0, 123, 255, 0.42);
    }

    .hero p {
      max-width: 680px;
      color: #d5d8dd;
      font-size: clamp(17px, 2vw, 22px);
      line-height: 1.55;
      margin-bottom: 32px;
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-bottom: 34px;
    }

    .hero-points {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
      max-width: 720px;
    }

    .point {
      border: 1px solid rgba(0, 123, 255, 0.25);
      background: rgba(255,255,255,0.025);
      border-radius: 14px;
      padding: 14px;
      color: var(--silver);
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: 1px;
    }

    .logo-panel {
      position: relative;
      padding: 34px;
      border: 1px solid rgba(0, 123, 255, 0.28);
      border-radius: var(--radius);
      background: linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.015));
      box-shadow: var(--shadow);
      overflow: hidden;
    }

    .logo-panel::before {
      content: "";
      position: absolute;
      inset: -1px;
      background: radial-gradient(circle at 50% 45%, rgba(0,198,255,0.20), transparent 48%);
      pointer-events: none;
    }

    .logo-panel img {
      position: relative;
      width: min(420px, 100%);
      margin: 0 auto;
      filter: drop-shadow(0 0 26px rgba(0, 123, 255, 0.32));
    }

    section {
      padding: 92px 0;
    }

    .section-head {
      max-width: 760px;
      margin-bottom: 38px;
    }

    .section-head h2 {
      font-size: clamp(34px, 5vw, 58px);
      text-transform: uppercase;
      line-height: 1;
      letter-spacing: -1px;
      margin-bottom: 16px;
    }

    .section-head h2 span {
      color: var(--blue);
    }

    .section-head p {
      color: var(--muted);
      font-size: 18px;
      line-height: 1.6;
    }

    .services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 18px;
    }

    .service-card,
    .industry-card,
    .process-card {
      border: 1px solid rgba(0, 123, 255, 0.24);
      background: linear-gradient(145deg, rgba(255,255,255,0.05), rgba(255,255,255,0.018));
      border-radius: var(--radius);
      padding: 26px;
      min-height: 250px;
      transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    }

    .service-card:hover,
    .industry-card:hover,
    .process-card:hover {
      transform: translateY(-5px);
      border-color: rgba(0, 198, 255, 0.55);
      box-shadow: 0 0 36px rgba(0, 123, 255, 0.16);
    }

    .icon {
      width: 52px;
      height: 52px;
      display: grid;
      place-items: center;
      border-radius: 14px;
      border: 1px solid rgba(0, 198, 255, 0.38);
      background: rgba(0, 123, 255, 0.09);
      color: var(--blue-bright);
      font-size: 24px;
      margin-bottom: 18px;
      box-shadow: 0 0 20px rgba(0, 123, 255, 0.15);
    }

    .service-card h3,
    .industry-card h3,
    .process-card h3 {
      font-size: 20px;
      text-transform: uppercase;
      letter-spacing: 1.2px;
      margin-bottom: 12px;
    }

    .service-card p,
    .industry-card p,
    .process-card p {
      color: var(--muted);
      line-height: 1.6;
      font-size: 15px;
    }

    .split {
      display: grid;
      grid-template-columns: 0.92fr 1.08fr;
      gap: 36px;
      align-items: center;
    }

    .feature-box {
      border: 1px solid rgba(0, 123, 255, 0.28);
      background: var(--panel);
      border-radius: var(--radius);
      padding: 34px;
      box-shadow: var(--shadow);
    }

    .feature-box h2 {
      font-size: clamp(32px, 5vw, 54px);
      text-transform: uppercase;
      line-height: 1;
      margin-bottom: 16px;
    }

    .feature-box h2 span {
      color: var(--blue);
    }

    .feature-box p {
      color: #d2d5db;
      line-height: 1.7;
      margin-bottom: 22px;
      font-size: 17px;
    }

    .check-list {
      display: grid;
      gap: 12px;
      list-style: none;
    }

    .check-list li {
      color: var(--silver);
      padding-left: 30px;
      position: relative;
      line-height: 1.5;
    }

    .check-list li::before {
      content: "✓";
      position: absolute;
      left: 0;
      color: var(--blue-bright);
      font-weight: 900;
    }

    .industries-grid,
    .process-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
    }

    .industry-card,
    .process-card {
      min-height: auto;
    }

    .process-card .step {
      color: var(--blue-bright);
      font-size: 13px;
      letter-spacing: 4px;
      text-transform: uppercase;
      font-weight: 800;
      margin-bottom: 14px;
    }

    .cta {
      padding: 0 0 92px;
    }

    .cta-box {
      border-radius: 28px;
      border: 1px solid rgba(0, 198, 255, 0.36);
      background:
        radial-gradient(circle at 20% 20%, rgba(0, 123, 255, 0.22), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02));
      padding: clamp(30px, 6vw, 58px);
      text-align: center;
      box-shadow: var(--shadow);
    }

    .cta-box h2 {
      font-size: clamp(36px, 6vw, 72px);
      text-transform: uppercase;
      line-height: 0.95;
      margin-bottom: 18px;
    }

    .cta-box h2 span {
      color: var(--blue);
    }

    .cta-box p {
      color: var(--muted);
      font-size: 18px;
      line-height: 1.6;
      max-width: 680px;
      margin: 0 auto 28px;
    }

    footer {
      border-top: 1px solid rgba(0, 123, 255, 0.22);
      padding: 32px 0;
      background: rgba(0,0,0,0.24);
    }

    .footer-inner {
      display: flex;
      justify-content: space-between;
      gap: 18px;
      align-items: center;
      color: var(--muted);
      font-size: 14px;
    }

    .footer-links {
      display: flex;
      gap: 18px;
      flex-wrap: wrap;
    }

    .footer-links a:hover {
      color: var(--blue-bright);
    }

    .reveal {
      opacity: 0;
      transform: translateY(20px);
      transition: opacity 0.65s ease, transform 0.65s ease;
    }

    .reveal.visible {
      opacity: 1;
      transform: translateY(0);
    }

    @media (max-width: 960px) {
      .hero-grid,
      .split {
        grid-template-columns: 1fr;
      }

      .logo-panel {
        order: -1;
      }

      .services-grid {
        grid-template-columns: repeat(2, 1fr);
      }

      .industries-grid,
      .process-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media (max-width: 760px) {
      .menu-btn {
        display: inline-grid;
        place-items: center;
      }

      .nav-links {
        position: absolute;
        left: 18px;
        right: 18px;
        top: 84px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        background: rgba(5, 7, 10, 0.96);
        border: 1px solid rgba(0, 123, 255, 0.28);
        border-radius: 18px;
        overflow: hidden;
      }

      .nav-links.open {
        display: flex;
      }

      .nav-links a {
        padding: 16px 18px;
        border-bottom: 1px solid rgba(255,255,255,0.06);
      }

      .nav-links .btn {
        margin: 14px;
      }

      .brand-text strong {
        font-size: 15px;
        letter-spacing: 2px;
      }

      .brand-text span {
        font-size: 10px;
        letter-spacing: 2.5px;
      }

      .hero {
        padding: 48px 0;
      }

      .hero h1 {
        letter-spacing: -1.5px;
      }

      .hero-points {
        grid-template-columns: 1fr;
      }

      section {
        padding: 70px 0;
      }

      .services-grid,
      .industries-grid,
      .process-grid {
        grid-template-columns: 1fr;
      }

      .footer-inner {
        flex-direction: column;
        align-items: flex-start;
      }
    }

    @media (max-width: 420px) {
      .brand img {
        width: 150px;
        height: 100px;
      }

      .brand-text strong {
        font-size: 13px;
      }

      .brand-text span {
        letter-spacing: 1.5px;
      }

      .btn {
        width: 100%;
      }
    }