

:root{
  /* Brand */
  --brand: #0262C2;
  --brand-2: #1960A2;
  --brand-gray: #91989B;

  /* Light theme */
  --bg: #f3f5f7;              /* page background */
  --surface: #ffffff;         /* section surface */
  --card: rgba(17,24,39,.04); /* slate tint */
  --card-2: rgba(17,24,39,.06);

  --text: rgba(17,24,39,.92);   /* near-black */
  --muted: rgba(17,24,39,.70);
  --faint: rgba(17,24,39,.55);

  --border: rgba(17,24,39,.12);
  --shadow: 0 16px 40px rgba(2, 6, 23, .10);

  --radius: 18px;
  --radius-lg: 26px;

  --max: 1160px;
  --pad: clamp(16px, 3vw, 28px);

  --h1: clamp(32px, 4.6vw, 56px);
  --h2: clamp(22px, 2.8vw, 34px);
  --h3: clamp(18px, 2.2vw, 22px);

  --btn: 14px;
  --body: 16px;
  --small: 13px;
}

body{
  margin:0;
  font: 400 var(--body)/1.55 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background:
    radial-gradient(1100px 650px at 10% -10%, rgba(2,98,194,.14), transparent 55%),
    radial-gradient(900px 600px at 90% 0%, rgba(25,96,162,.10), transparent 55%),
    radial-gradient(900px 700px at 50% 110%, rgba(145,152,155,.14), transparent 55%),
    linear-gradient(180deg, #f7f8fa, #eef1f5 60%, #f3f5f7);
  overflow-x: hidden;
}


    /* Utilities */
    .pill{
      display:inline-flex; align-items:center; gap:10px;
      padding: 8px 12px;
      border: 1px solid var(--border);
      border-radius: 999px;
      background: rgba(255,255,255,.03);
      color: var(--muted);
      font-size: var(--small);
    }
    .grid{ display:grid; gap: 18px; }
    .muted{ color: var(--muted); }
    .faint{ color: var(--faint); }
    .card{
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: none;
    }
    .card.pad{ padding: 18px; }
    .kicker{ letter-spacing:.12em; text-transform: uppercase; font-size: 12px; color: var(--faint); }
    .h2{ font-size: var(--h2); line-height: 1.12; margin: 10px 0 10px; }
    .h3{ font-size: var(--h3); line-height: 1.2; margin: 0 0 8px; }
    .btns{ display:flex; flex-wrap: wrap; gap: 10px; }
    .btn{
      display:inline-flex; align-items:center; justify-content:center; gap:10px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid var(--border);
      font-weight: 650;
      font-size: var(--btn);
      background: rgba(255,255,255,.04);
      color: var(--text);
      transition: transform .08s ease, background .2s ease, border-color .2s ease;
      cursor:pointer;
      user-select:none;
    }
    .btn:hover{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.18); }
    .btn:active{ transform: translateY(1px); }
    .btn.primary{
      background: linear-gradient(180deg, rgba(2,98,194,.95), rgba(2,98,194,.78));
      border-color: rgba(2,98,194,.7);
    }
    .btn.primary:hover{ background: linear-gradient(180deg, rgba(2,98,194,1), rgba(2,98,194,.84)); }
    .btn.ghost{
      background: rgba(255,255,255,.02);
    }

    /* Header */
    header{
  position: sticky; top:0; z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(243,245,247,.82);
  border-bottom: 1px solid rgba(17,24,39,.08);
}

    .nav{
      display:flex; align-items:center; justify-content:space-between;
      padding: 14px 0;
      gap: 14px;
    }
    .brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 220px;
  padding-left: 8px; /* subtle inset so logo isn’t hugging edge */
}

    
    .brand img{
      width: 160px;
      height:auto;
      filter: drop-shadow(0 8px 18px rgba(0,0,0,.22));
    }
    nav ul{
  display:flex;
  align-items:center;
  gap: 20px;
  list-style:none;
  margin:0;
  padding:0;

  font-size: 16px;          /* bigger */
  font-weight: 500;
  color: rgba(17,24,39,.95); /* near-black */
}

    nav a{
  padding: 4px 2px;
  border-radius: 0;
  color: rgba(17,24,39,.95);
  text-decoration: none;
  border-bottom: 2px solid transparent;
}

nav a:hover{
  border-bottom: 2px solid rgba(17,24,39,.9); /* clean underline */
}

    .nav-cta{ display:flex; gap: 10px; align-items:center; }
    .hamburger{
      display:none;
      width: 44px; height: 44px;
      border-radius: 12px;
      border: 1px solid var(--border);
      background: rgba(255,255,255,.03);
      align-items:center; justify-content:center;
      cursor:pointer;
    }
    .hamburger span{
      width: 18px; height: 2px; background: rgba(255,255,255,.82); display:block; position:relative;
    }
    .hamburger span:before,.hamburger span:after{
      content:""; position:absolute; left:0; width:18px; height:2px; background: rgba(255,255,255,.82);
    }
    .hamburger span:before{ top:-6px; }
    .hamburger span:after{ top:6px; }

    .mobile{
      display:none;
      padding: 0 0 14px;
    }
    .mobile a{
      display:block;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.02);
      margin-top: 8px;
      color: var(--muted);
    }
    .mobile a:hover{ color: var(--text); border-color: rgba(255,255,255,.14); }

    /* Hero */
    .hero{ padding: 42px 0 26px; }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.2fr .8fr;
      gap: 18px;
      align-items: stretch;
    }
    .hero h1{
      font-size: var(--h1);
      line-height: 1.02;
      margin: 12px 0 12px;
      letter-spacing: -.02em;
    }
    .hero p{ margin: 0 0 18px; color: var(--muted); font-size: 17px; }
    .hero .panel{
      border-radius: var(--radius-lg);
      background:
        radial-gradient(800px 420px at 20% 10%, rgba(2,98,194,.28), transparent 55%),
        radial-gradient(600px 320px at 90% 0%, rgba(145,152,155,.18), transparent 60%),
        rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.12);
      padding: 22px;
      box-shadow: var(--shadow);
    }
    .trust{
      display:grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
      margin-top: 16px;
    }
    .trust .item{
      display:flex; gap:10px; align-items:flex-start;
      padding: 12px;
      border-radius: 14px;
      background: rgba(255,255,255,.03);
      border: 1px solid rgba(255,255,255,.10);
    }
    .dot{
      width: 10px; height: 10px; margin-top: 6px; border-radius: 999px;
      background: var(--brand);
      box-shadow: 0 0 0 6px rgba(2,98,194,.15);
    }
.hero-side{
  border-radius: var(--radius-lg);
  padding: 22px;
  border: 1px solid rgba(17,24,39,.10);
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.95),
    rgba(247,249,252,.95)
  );
  box-shadow: var(--shadow);
}
    .contact-box{
      display:grid;
      gap: 12px;
      padding-top: 6px;
    }
    .contact-row{
      display:flex; justify-content:space-between; align-items:center;
      padding: 12px 12px;
      border-radius: 14px;
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
      color: var(--muted);
      font-size: 14px;
    }
    .contact-row strong{ color: var(--text); font-weight: 700; }
    .mini{
      font-size: 12px;
      color: var(--faint);
      margin-top: 10px;
    }

    /* Sections */
    section{ padding: 34px 0; }
    .section-head{
      display:flex; align-items:flex-end; justify-content:space-between;
      gap: 18px;
      margin-bottom: 16px;
    }
    .section-head .left{ max-width: 720px; }
    .section-head p{ margin: 0; color: var(--muted); }

    /* Services */
    .services{ grid-template-columns: repeat(3, minmax(0,1fr)); }
    .svc{
      padding: 18px;
      border-radius: var(--radius);
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.10);
      transition: transform .12s ease, border-color .2s ease, background .2s ease;
      min-height: 160px;
    }
/* --- Services cards with translucent background images --- */
.svc{
  position: relative;
  overflow: hidden;
}

/* background image layer */
.svc .bg{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.30; /* translucent */
  filter: grayscale(1) saturate(0.4) contrast(1.05);
  transform: scale(1.03);
  transition: opacity .25s ease, filter .25s ease, transform .25s ease;
  z-index: 0;
}

/* light overlay so text stays readable */
.svc::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.80),
    rgba(255,255,255,.92)
  );
  transition: background .25s ease;
  z-index: 1;
}

/* keep icon + text above image */
.svc > *{
  position: relative;
  z-index: 2;
}

/* hover state: image becomes full color */
.svc:hover .bg{
  opacity: 0.85;
  filter: grayscale(0) saturate(1.05);
  transform: scale(1.06);
}

/* slightly reduce overlay on hover */
.svc:hover::after{
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.65),
    rgba(255,255,255,.85)
  );
}

    .svc:hover{
      transform: translateY(-2px);
      border-color: rgba(2,98,194,.45);
      background: rgba(2,98,194,.06);
    }
    .svc .icon{
      width: 44px; height: 44px;
      border-radius: 14px;
      background: rgba(2,98,194,.18);
      border: 1px solid rgba(2,98,194,.30);
      display:flex; align-items:center; justify-content:center;
      margin-bottom: 12px;
    }
    .svc .icon svg{ width: 22px; height: 22px; fill: rgba(255,255,255,.88); }

    /* Proof */
    .proof{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
      align-items: stretch;
    }
    .proof ul{
      margin: 10px 0 0;
      padding-left: 18px;
      color: var(--muted);
    }
    .proof li{ margin: 8px 0; }

    /* Projects */
    .projects{
      grid-template-columns: repeat(3, minmax(0,1fr));
    }
    .proj{
      overflow:hidden;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
    }
    .proj .img{
      aspect-ratio: 4/3;
      background:
        radial-gradient(700px 240px at 10% 0%, rgba(2,98,194,.25), transparent 60%),
        linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
      display:flex; align-items:center; justify-content:center;
      color: rgba(255,255,255,.55);
      font-size: 13px;
    }
    .proj .meta{ padding: 14px 14px 16px; }
    .proj .meta .tag{
      display:inline-flex; align-items:center; gap:8px;
      color: rgba(255,255,255,.76);
      font-size: 12px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.10);
      padding: 6px 10px;
      border-radius: 999px;
      margin-bottom: 10px;
    }

    /* Reviews */
    .reviews{
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 18px;
      align-items: stretch;
    }
    .review-card{
      padding: 18px;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.04);
      min-height: 168px;
    }
    .stars{ color: rgba(255,255,255,.85); letter-spacing: .12em; }
    .review-card p{ margin: 10px 0 10px; color: var(--muted); }
    .review-card .who{ color: rgba(255,255,255,.78); font-size: 13px; }

    .review-controls{
      display:flex; gap: 10px; margin-top: 12px;
    }

    /* Process + Problems */
    .two-col{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
      align-items: start;
    }
    .steps{ display:grid; gap: 10px; }
    .step{
      display:flex; gap: 12px; align-items:flex-start;
      padding: 14px;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
    }
    .num{
      width: 30px; height: 30px;
      border-radius: 10px;
      background: rgba(2,98,194,.18);
      border: 1px solid rgba(2,98,194,.30);
      display:flex; align-items:center; justify-content:center;
      font-weight: 800;
      color: rgba(255,255,255,.9);
      flex: 0 0 auto;
    }
    details{
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.03);
      padding: 14px;
    }
    details + details{ margin-top: 10px; }
    summary{
      cursor:pointer;
      list-style:none;
      font-weight: 700;
      color: rgba(255,255,255,.88);
    }
    summary::-webkit-details-marker{ display:none; }
    details p{ margin: 10px 0 0; color: var(--muted); }

    /* Form */
    .form{
      padding: 18px;
      border-radius: var(--radius-lg);
      border: 1px solid rgba(255,255,255,.12);
      background:
        radial-gradient(900px 360px at 15% 0%, rgba(2,98,194,.22), transparent 55%),
        rgba(255,255,255,.03);
      box-shadow: var(--shadow);
    }
    form{ display:grid; gap: 12px; }
    .fields{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }
    label{ font-size: 13px; color: var(--faint); display:block; margin-bottom: 6px; }
    input, select, textarea{
      width: 100%;
      padding: 12px 12px;
      border-radius: 12px;
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(10,16,28,.55);
      color: var(--text);
      outline: none;
    }
    input:focus, select:focus, textarea:focus{
      border-color: rgba(2,98,194,.70);
      box-shadow: 0 0 0 5px rgba(2,98,194,.15);
    }
    textarea{ min-height: 110px; resize: vertical; }
    .form .fineprint{ font-size: 12px; color: var(--faint); }

    /* Footer */
    footer{
      padding: 26px 0 40px;
      border-top: 1px solid rgba(255,255,255,.08);
      color: var(--muted);
    }
    .footer-grid{
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 18px;
      align-items:start;
    }
    .footer-links{
      display:grid; grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
      font-size: 14px;
    }
    .footer-links a{
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.02);
    }
    .footer-links a:hover{
      border-color: rgba(255,255,255,.14);
      background: rgba(255,255,255,.03);
      color: var(--text);
    }

    /* Responsive */
    @media (max-width: 960px){
      .hero-grid{ grid-template-columns: 1fr; }
      .services{ grid-template-columns: repeat(2, minmax(0,1fr)); }
      .projects{ grid-template-columns: repeat(2, minmax(0,1fr)); }
      .proof{ grid-template-columns: 1fr; }
      .reviews{ grid-template-columns: 1fr; }
      .two-col{ grid-template-columns: 1fr; }
      .footer-grid{ grid-template-columns: 1fr; }
    }
    @media (max-width: 720px){
      nav ul{ display:none; }
      .hamburger{ display:flex; }
      .mobile{ display:none; }
      .mobile.open{ display:block; }
      .services{ grid-template-columns: 1fr; }
      .projects{ grid-template-columns: 1fr; }
      .trust{ grid-template-columns: 1fr; }
      .fields{ grid-template-columns: 1fr; }
      .brand img{ width: 150px; }
      .nav-cta .btn{ display:none; }
      .nav-cta .btn.primary{ display:inline-flex; }
    }