:root{
      --bg:#ffffff;
      --text:#0b1220;
      --muted:#5b6b80;

      --border:#dfeafc;
      --card:#ffffff;

      --blue:#3b82f6;
      --blue2:#2563eb;
      --blue3:#60a5fa;

      --sky:#eff6ff;
      --sky2:#f6f9ff;

      --shadow: 0 14px 40px rgba(2, 18, 60, .10);
      --shadow2: 0 10px 24px rgba(2, 18, 60, .12);

      --radius: 18px;
      --radius2: 22px;

      --btnText:#ffffff;

      --fieldBg:#ffffff;
      --fieldBorder:#cfe0ff;

      --ok:#16a34a;
      --danger:#ef4444;

      --max: 1440px;

      --safe-top: env(safe-area-inset-top, 0px);
      --safe-right: env(safe-area-inset-right, 0px);
      --safe-bottom: env(safe-area-inset-bottom, 0px);
      --safe-left: env(safe-area-inset-left, 0px);
    }

    *{ box-sizing:border-box; }
    html,body{ height:100%; }
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
      color:var(--text);
      background: linear-gradient(180deg, var(--sky2) 0%, #ffffff 28%, #ffffff 100%);
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }
    a{ color:inherit; text-decoration:none; }
    button, input, textarea{ font: inherit; color: inherit; }

    .wrap{
      width: min(var(--max), 100%);
      margin: 0 auto;
      padding: 0 18px;
    }

    .header{
      position: sticky;
      top: 0;
      z-index: 30;
      background: rgba(255,255,255,.88);
      backdrop-filter: blur(12px);
      border-bottom: 1px solid rgba(223,234,252,.95);
    }
    .header__inner{
      height: 72px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 14px;
      padding-top: var(--safe-top);
    }
    .brand{
      display:flex;
      align-items:center;
      gap: 10px;
      min-width: 160px;
    }
    .brand__logo{
      width: 160px;
      height: 40px;
      display:block;
      object-fit: contain;
      object-position: left center;
      filter: saturate(1.06);
    }

    .contactBtn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      height: 42px;
      padding: 0 16px;
      border: 1px solid rgba(59,130,246,.22);
      border-radius: 999px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue2) 100%);
      color: var(--btnText);
      box-shadow: 0 16px 36px rgba(59,130,246,.22);
      cursor:pointer;
      transition: transform .15s ease, opacity .15s ease, filter .15s ease;
      white-space: nowrap;
      -webkit-tap-highlight-color: transparent;
    }
    .contactBtn:hover{ opacity:.95; filter:saturate(1.06); }
    .contactBtn:active{ transform: scale(.99); }

    .contactDot{
      width:8px;height:8px;border-radius:99px;background: #93c5fd;
      box-shadow: 0 0 0 6px rgba(147,197,253,.22);
      flex: 0 0 auto;
    }

    main{ padding: 0; }
    .stack{ width: 100%; margin: 0; padding: 0; }

    .bannerCard{
      width: 100%;
      background: var(--card);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      overflow:hidden;
      position:relative;
      height: clamp(460px, 62vh, 820px);
    }
    .bannerCard:first-child{
      border-top: 0;
      border-top-left-radius: var(--radius2);
      border-top-right-radius: var(--radius2);
    }
    .bannerCard:last-child{
      border-bottom-left-radius: var(--radius2);
      border-bottom-right-radius: var(--radius2);
    }

    .bannerMedia{
      width: 100%;
      height: 100%;
      display:block;
      object-fit: cover;
      object-position: center;
      filter: saturate(1.06) contrast(1.02);
      transform: scale(1.01);
    }

    .bannerShade{
      position:absolute;
      inset:0;
      pointer-events:none;
      background:
        linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.18) 46%, rgba(0,0,0,0) 70%),
        linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,0) 44%, rgba(0,0,0,.16) 100%);
    }

    .bannerCopy{
      position:absolute;
      left: clamp(18px, 3vw, 44px);
      bottom: clamp(120px, 12vh, 200px);
      width: min(760px, calc(100% - 36px));
      color:#fff;
      z-index: 2;
      pointer-events:auto;
      text-shadow: 0 10px 30px rgba(0,0,0,.35);
    }
    .bannerKicker{
      font-size: 14px;
      letter-spacing: .2px;
      opacity:.92;
      margin:0 0 10px;
    }
    .bannerTitle{
      margin:0 0 10px;
      font-size: clamp(15px, 4.4vw, 31px);
      font-weight: 950;
      letter-spacing: .2px;
      line-height: 1.02;
    }
    .bannerSub{
      margin:0 0 8px;
      font-size: 15px;
      line-height: 1.45;
      opacity:.92;
      max-width: 62ch;
    }

    .bannerCopyCenter{
      position:absolute;
      inset: 0;
      z-index: 2;
      display:flex;
      align-items:center;
      justify-content:center;
      padding: 24px;
      text-align:center;
      color:#fff;
      pointer-events:auto;
      text-shadow: 0 10px 30px rgba(0,0,0,.35);
    }
    .bannerCenterInner{
      width: min(1280px, 100%);
      display:flex;
      flex-direction:column;
      align-items:center;
      gap: 12px;
    }
    .bannerCenterTitle{
      margin: 0;
      font-size: clamp(17px, 4.8vw, 34px);
      font-weight: 950;
      letter-spacing: .2px;
      line-height: 1.06;
    }
    .bannerCenterSub{
      margin: 0;
      font-size: 15px;
      line-height: 1.7;
      opacity: .94;
      max-width: 120ch;
    }

    .leadBox{
      position:absolute;
      top: 50%;
      right: clamp(14px, 2.2vw, 22px);
      transform: translateY(-50%);
      width: min(500px, calc(100% - 28px));
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(207,224,255,.95);
      border-radius: 18px;
      box-shadow: 0 18px 55px rgba(2,18,60,.16);
      padding: 16px;
      pointer-events:auto;
      z-index: 3;
    }

    .leadTitle{
      margin: 2px 0 8px;
      font-size: 16px;
      font-weight: 850;
      letter-spacing: .2px;
    }
    .leadSub{
      margin: 0 0 12px;
      font-size: 13px;
      color: var(--muted);
      line-height: 1.45;
    }

    .formGrid{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }
    .field{ display:flex; flex-direction:column; gap: 6px; }
    .field--full{ grid-column: 1 / -1; }

    .label{ font-size: 12px; color: var(--muted); }
    .input, .textarea{
      width:100%;
      border: 1px solid var(--fieldBorder);
      background: var(--fieldBg);
      border-radius: 12px;
      padding: 11px 12px;
      outline: none;
      transition: border-color .15s ease, box-shadow .15s ease;
    }
    .textarea{ min-height: 96px; resize: vertical; }
    .input:focus, .textarea:focus{
      border-color: rgba(59,130,246,.80);
      box-shadow: 0 0 0 4px rgba(59,130,246,.14);
    }

    .actions{
      display:flex;
      gap: 10px;
      align-items:center;
      justify-content: space-between;
      margin-top: 10px;
    }

    .submitBtn{
      flex: 1 1 auto;
      height: 44px;
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 14px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue2) 100%);
      color: #fff;
      cursor:pointer;
      box-shadow: 0 16px 36px rgba(59,130,246,.22);
      transition: transform .15s ease, opacity .15s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .submitBtn:hover{ opacity:.95; }
    .submitBtn:active{ transform: scale(.99); }
    .submitBtn[disabled]{ opacity:.55; cursor:not-allowed; }

    .miniNote{ font-size: 12px; color: var(--muted); white-space: nowrap; }

    .status{
      margin-top: 10px;
      font-size: 13px;
      line-height: 1.35;
      display:none;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid rgba(223,234,252,.95);
      background: #f8fbff;
    }
    .status.ok{
      display:block;
      border-color: rgba(22,163,74,.25);
      background: rgba(22,163,74,.08);
      color: #0f3d22;
    }
    .status.err{
      display:block;
      border-color: rgba(239,68,68,.25);
      background: rgba(239,68,68,.08);
      color: #4a1212;
    }

    .mission3{
      --mission3-gap: 118px;
      padding: 22px 0 52px;
      background: linear-gradient(180deg, rgba(239,246,255,.70) 0%, #ffffff 80%);
      border-top: 1px solid rgba(223,234,252,.95);
      border-bottom: 1px solid rgba(223,234,252,.95);
    }
    .mission3Title{
      text-align:center;
      font-weight: 900;
      letter-spacing: .1px;
      font-size: clamp(16px, 2.0vw, 22px);
      margin: 0 auto var(--mission3-gap);
      max-width: 1080px;
      line-height: 1.65;
      color: #0b1220;
    }

    .mission3MainTitle{
      font-size: clamp(20px, 2.2vw, 50px);
      font-weight: 950;
      letter-spacing: .12px;
      text-align: center;
      margin: 0 auto 16px;
      color: #0b1220;
    }

    .mission3Row{
      width: min(1100px, 100%);
      margin: 0 auto;
      display:grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px 14px;
    }
    .m3Card{
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 20px;
      background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
      box-shadow: 0 10px 26px rgba(2,18,60,.06);
      padding: 18px 16px;
      text-align:center;
      min-width: 0;
    }
    .m3Icon{
      width: 58px;
      height: 58px;
      border-radius: 999px;
      margin: 0 auto 12px;
      display:grid;
      place-items:center;
      background: rgba(59,130,246,.10);
      border: 1px solid rgba(59,130,246,.18);
      font-size: 24px;
      color:#1f3566;
    }
    .m3Main{
      margin: 0 0 6px;
      font-weight: 950;
      letter-spacing: .1px;
      font-size: 14px;
    }
    .m3Sub{
      margin: 0;
      color: var(--muted);
      font-size: 13px;
      line-height: 1.55;
    }

    .section{
      padding: 46px 0 58px;
      background: #ffffff;
    }

    .sectionTitle{
      text-align:center;
      font-weight: 950;
      letter-spacing: .15px;
      font-size: clamp(18px, 2.2vw, 30px);
      margin: 0 0 10px;
    }

    .sectionSub{
      text-align:center;
      color: var(--muted);
      margin: 0 auto 22px;
      max-width: 980px;
      line-height: 1.6;
      font-size: 14px;
    }

    .casesGrid{
      width: min(1280px, 100%);
      margin: 0 auto;
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px 20px;
    }
    .caseCard{
      display: flex;
      align-items: center;
      gap: 14px;
      padding: 14px 16px;
      border-radius: 16px;
      background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
      border: 1px solid rgba(223,234,252,.95);
      box-shadow: 0 10px 26px rgba(2,18,60,.06);
      min-width: 0;
      cursor:pointer;
      transition: transform .15s ease, border-color .15s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .caseCard:hover{
      transform: translateY(-2px);
      border-color: rgba(59,130,246,.28);
    }
    .caseThumb{
      width: 84px;
      height: 56px;
      flex-shrink: 0;
      border-radius: 10px;
      object-fit: cover;
      object-position: center;
      display: block;
      background: #eaf1ff;
      border: 1px solid rgba(207,224,255,.85);
    }
    .caseMain{
      display:flex;
      flex-direction:column;
      gap: 6px;
      min-width: 0;
      flex: 1 1 auto;
    }
    .caseName{
      font-size: 15px;
      font-weight: 900;
      line-height: 1.25;
      white-space: normal;
      overflow: hidden;
    }
    .caseMeta{
      font-size: 13px;
      color: #6b7a99;
      line-height: 1.45;
      white-space: normal;
      word-break: break-word;
      overflow-wrap: anywhere;
    }
    .caseArrow{
      margin-left: auto;
      font-size: 20px;
      color: #4f83ff;
      flex-shrink: 0;
    }

    .fp-solutions{
      padding: 48px 0 56px;
      background: linear-gradient(180deg, rgba(239,246,255,.70) 0%, #ffffff 75%);
      border-top: 1px solid rgba(223,234,252,.95);
      border-bottom: 1px solid rgba(223,234,252,.95);
    }
    .fp-solutions__head{
      text-align:center;
      max-width: 980px;
      margin: 0 auto 26px;
    }
    .fp-solutions__title{
      margin:0 0 10px;
      font-weight: 950;
      letter-spacing: .15px;
      font-size: clamp(20px, 2.4vw, 32px);
    }
    .fp-solutions__sub{
      margin:0;
      color: var(--muted);
      line-height: 1.65;
      font-size: 14px;
    }
    .fp-grid{
      width: min(1280px, 100%);
      margin: 0 auto;
      display: grid;
      gap: 14px;
    }
    .fp-row{
      display:grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 16px 18px;
      align-items: stretch;
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 20px;
      background: rgba(255,255,255,.92);
      box-shadow: 0 14px 36px rgba(2,18,60,.08);
      overflow:hidden;
    }
    .fp-row--reverse{
      grid-template-columns: .95fr 1.05fr;
    }

    .fp-copy{
      padding: 18px 18px;
      display:flex;
      flex-direction:column;
      justify-content: center;
      align-items: flex-start;
      gap: 10px;
      min-width: 0;
    }

    .fp-kicker{
      display:inline-flex;
      align-items:center;
      gap: 10px;
      font-size: 12px;
      color: #1f3566;
      padding: 8px 10px;
      border: 1px solid rgba(207,224,255,.95);
      background: rgba(239,246,255,.92);
      border-radius: 999px;
      width: fit-content;
    }
    .fp-dot{
      width: 8px;height:8px;border-radius:999px;background: var(--blue);
      box-shadow: 0 0 0 6px rgba(59,130,246,.10);
    }
    .fp-h3{
      margin:0;
      font-size: 18px;
      font-weight: 950;
      letter-spacing: .12px;
      line-height: 1.25;
    }
    .fp-h4{
      margin: -4px 0 0;
      font-size: 14px;
      font-weight: 850;
      color: #0b1220;
      opacity: .92;
      line-height: 1.4;
    }
    .fp-list{
      margin: 0;
      padding-left: 18px;
      color: var(--muted);
      font-size: 13.5px;
      line-height: 1.65;
    }
    .fp-list li{ margin: 6px 0; }

    .fp-media{
      position:relative;
      min-height: 240px;
      background: #eef5ff;
    }
    .fp-img{
      width:100%;
      height:100%;
      display:block;
      object-fit: cover;
      object-position: center;
      filter: saturate(1.05) contrast(1.02);
    }
    .fp-media::after{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background:
        radial-gradient(720px 320px at 70% 25%, rgba(96,165,250,.25) 0%, rgba(96,165,250,0) 60%),
        linear-gradient(90deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,0) 45%, rgba(0,0,0,.10) 100%);
    }

    .webFeatures{
      padding: 40px 0 56px;
      background:#ffffff;
      border-top: 1px solid rgba(223,234,252,.95);
      border-bottom: 1px solid rgba(223,234,252,.95);
    }
    .featureRow{
      width: min(1280px, 100%);
      margin: 0 auto;
      display:grid;
      grid-template-columns: repeat(6, 1fr);
      gap: 14px 14px;
    }
    .feat{
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 20px;
      background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
      box-shadow: 0 10px 26px rgba(2,18,60,.06);
      padding: 16px 14px;
      text-align:center;
      min-width: 0;
    }
    .featIcon{
      width: 54px;
      height: 54px;
      border-radius: 999px;
      margin: 0 auto 10px;
      display:grid;
      place-items:center;
      background: rgba(59,130,246,.10);
      border: 1px solid rgba(59,130,246,.16);
      font-size: 22px;
      color:#1f3566;
    }
    .featTitle{
      margin: 0 0 6px;
      font-weight: 950;
      letter-spacing: .1px;
      font-size: 13.5px;
    }
    .featDesc{
      margin: 0;
      color: var(--muted);
      font-size: 12.5px;
      line-height: 1.5;
    }

    .strength {
      padding: 54px 0 60px;
      background:
        radial-gradient(880px 380px at 50% 18%, rgba(96,165,250,.22) 0%, rgba(96,165,250,0) 60%),
        linear-gradient(180deg, rgba(239,246,255,.78) 0%, #ffffff 78%);
      border-top: 1px solid rgba(223,234,252,.95);
      border-bottom: 1px solid rgba(223,234,252,.95);
    }
    .strengthInner{ width: min(1280px, 100%); margin: 0 auto; }

    .strengthHero{
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 22px;
      background: rgba(255,255,255,.88);
      box-shadow: 0 14px 40px rgba(2,18,60,.08);
      overflow: hidden;
      position: relative;
    }
    .strengthHeroBg{
      position:absolute;
      inset:0;
      background-image: url("https://picsum.photos/seed/strength-bg/1600/900");
      background-size: cover;
      background-position: center;
      filter: saturate(1.05) contrast(1.02);
      opacity: .22;
    }
    .strengthHeroOverlay{
      position:absolute;
      inset:0;
      background:
        radial-gradient(860px 420px at 50% 18%, rgba(96,165,250,.30) 0%, rgba(96,165,250,0) 62%),
        linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.80) 100%);
    }
    .strengthHeroContent{
      position:relative;
      padding: 18px 18px 16px;
      text-align: center;
    }
    .strengthQuote{
      margin: 0 auto;
      max-width: 1200px;
      font-size: 15px;
      line-height: 1.7;
      color: #0b1220;
      font-weight: 700;
      letter-spacing: .1px;
    }

    .strengthStats{
      position:relative;
      display:grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 0;
      margin-top: 14px;
      border-top: 1px solid rgba(223,234,252,.95);
      background: rgba(239,246,255,.55);
    }
    .stat{
      padding: 14px 10px 16px;
      text-align:center;
      min-width: 0;
      position: relative;
    }
    .stat:not(:last-child)::after{
      content:"";
      position:absolute;
      right:0;
      top: 18px;
      bottom: 18px;
      width: 1px;
      background: rgba(59,130,246,.22);
    }
    .statNum{
      font-size: 20px;
      font-weight: 950;
      letter-spacing: .15px;
      color: rgba(37,99,235,.98);
      margin: 0 0 4px;
    }
    .statLabel{
      margin: 0;
      font-size: 12.5px;
      color: var(--muted);
      line-height: 1.45;
    }

    .strengthCards{
      display:grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px 16px;
      margin-top: 14px;
    }
    .strengthCard{
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 20px;
      background: rgba(255,255,255,.92);
      box-shadow: 0 12px 30px rgba(2,18,60,.06);
      overflow:hidden;
      position: relative;
      display:flex;
      flex-direction:column;
      min-width: 0;
    }
    .strengthCard::before{
      content:"";
      position:absolute;
      inset: -110px -110px auto auto;
      width: 260px;
      height: 260px;
      background: radial-gradient(circle at 30% 30%, rgba(96,165,250,.22), rgba(96,165,250,0) 62%);
      transform: rotate(18deg);
      pointer-events:none;
    }
    .strengthCardHead{
      padding: 14px 14px 12px;
      border-bottom: 1px solid rgba(223,234,252,.95);
      background: linear-gradient(180deg, rgba(239,246,255,.90) 0%, rgba(255,255,255,1) 100%);
      display:flex;
      align-items:center;
      justify-content: space-between;
      gap: 10px;
      position: relative;
      z-index: 1;
    }
    .strengthCardHead b {
      display: -webkit-box;
      display: box; /* 标准兼容写法 */

      -webkit-box-orient: vertical;
      box-orient: vertical;

      -webkit-line-clamp: 2;
      line-clamp: 2;

      overflow: hidden;

      min-height: 44px;
      line-height: 22px;
    }

    .strengthCardMedia{
      position: relative;
      width: 100%;
      height: 160px;
      background: #eef5ff;
      border-bottom: 1px solid rgba(223,234,252,.95);
      overflow:hidden;
      z-index: 1;
    }
    .strengthCardImg{
      width: 100%;
      height: 100%;
      display:block;
      object-fit: cover;
      object-position: center;
      filter: saturate(1.05) contrast(1.02);
      transform: scale(1.02);
    }
    .strengthCardMedia::after{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background:
        radial-gradient(520px 220px at 72% 28%, rgba(96,165,250,.22) 0%, rgba(96,165,250,0) 62%),
        linear-gradient(90deg, rgba(0,0,0,.06) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,.08) 100%);
    }

    .strengthCardBody{
      padding: 14px;
      position: relative;
      z-index: 1;
      display:grid;
      gap: 10px;
      flex: 1 1 auto;
    }
    .strengthText{
      margin: 0;
      font-size: 13.5px;
      color: #0b1220;
      line-height: 1.65;
    }
    .strengthText.muted{
      color: var(--muted);
      font-size: 13.2px;
    }

    .contactSection{
      padding: 46px 0 58px;
      background: #ffffff;
      border-top: 1px solid rgba(223,234,252,.95);
    }
    .contactGrid{
      width: min(1280px, 100%);
      margin: 0 auto;
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 18px 22px;
      align-items: stretch;
    }
    .panel{
      border: 1px solid rgba(223,234,252,.95);
      background: #ffffff;
      border-radius: 18px;
      box-shadow: 0 12px 30px rgba(2,18,60,.07);
      overflow:hidden;
    }
    .panelHead{
      padding: 14px 16px;
      border-bottom: 1px solid rgba(223,234,252,.95);
      display:flex;
      align-items:center;
      justify-content: space-between;
      gap: 10px;
      background: linear-gradient(180deg, rgba(239,246,255,.92) 0%, rgba(255,255,255,1) 100%);
    }
    .panelHead h3{
      margin:0;
      font-size: 15px;
      font-weight: 950;
      letter-spacing: .15px;
    }
    .pillLink{
      display:inline-flex;
      align-items:center;
      gap: 8px;
      height: 34px;
      padding: 0 12px;
      border-radius: 999px;
      border: 1px solid rgba(59,130,246,.22);
      background: rgba(239,246,255,.92);
      font-size: 12px;
      color: #1f3566;
      cursor:pointer;
      transition: transform .12s ease, opacity .12s ease;
      white-space: nowrap;
      -webkit-tap-highlight-color: transparent;
    }
    .pillLink:hover{ opacity:.92; }
    .pillLink:active{ transform: scale(.99); }

    .mapWrap{
      position: relative;
      width: 100%;
      height: 360px;
      background:#eef2f7;
    }
    .mapFrame{
      width: 100%;
      height: 100%;
      border: 0;
      display:block;
    }
    .mapOverlayLink{
      position:absolute;
      inset:0;
      z-index: 2;
      display:block;
    }

    .infoBody{
      padding: 16px;
      display:grid;
      gap: 12px;
    }
    .infoRow{
      border: 1px solid rgba(223,234,252,.95);
      background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
      border-radius: 14px;
      padding: 12px 14px;
      display:flex;
      justify-content: space-between;
      align-items:flex-start;
      gap: 12px;
      flex-wrap: wrap;
    }
    .infoRow--address{
      align-items: center;
    }

    .infoRow--address > div{
      display: flex;
      flex-direction: column;
      justify-content: center;
      min-width: 0;
      flex: 1 1 auto;
    }
    .infoLabel{
      font-size: 12px;
      color: var(--muted);
      margin-bottom: 4px;
    }
    .infoValue{
      font-size: 14px;
      font-weight: 900;
      letter-spacing: .1px;
      word-break: break-word;
      overflow-wrap: anywhere;
      line-height: 1.35;
    }

    .miniBtn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      width:auto;
      padding: 0 12px;
      height:36px;
      border-radius:999px;
      border: 1px solid rgba(59,130,246,.22);
      background: rgba(239,246,255,.85);
      cursor:pointer;
      transition: transform .12s ease, background .12s ease, opacity .12s ease;
      font-size: 12px;
      white-space: nowrap;
      color:#1f3566;
      -webkit-tap-highlight-color: transparent;
    }
    .miniBtn:hover{ background: rgba(239,246,255,.98); opacity:.96; }
    .miniBtn:active{ transform: scale(.99); }

    .modalBackdrop{
      position: fixed;
      inset: 0;
      background: rgba(2, 10, 30, .52);
      backdrop-filter: blur(10px);
      display:none;
      align-items:center;
      justify-content:center;
      z-index: 100;
      padding: calc(18px + var(--safe-top)) calc(18px + var(--safe-right)) calc(18px + var(--safe-bottom)) calc(18px + var(--safe-left));
    }
    .modalBackdrop.open{ display:flex; }
    .modal{
      width: min(640px, 100%);
      background: #fff;
      border-radius: 22px;
      border: 1px solid rgba(223,234,252,.95);
      box-shadow: 0 28px 80px rgba(0,0,0,.28);
      overflow:hidden;
    }
    .modalHeader{
      display:flex;
      align-items:center;
      justify-content:space-between;
      padding: 14px 16px;
      border-bottom: 1px solid rgba(223,234,252,.95);
      background: linear-gradient(180deg, rgba(239,246,255,.92) 0%, rgba(255,255,255,1) 100%);
    }
    .modalTitle{ font-weight: 950; letter-spacing: .15px; }
    .closeBtn{
      width: 40px;
      height: 40px;
      border-radius: 12px;
      border: 1px solid rgba(223,234,252,.95);
      background: rgba(239,246,255,.90);
      cursor:pointer;
      transition: transform .12s ease, background .12s ease, opacity .12s ease;
      color:#1f3566;
      -webkit-tap-highlight-color: transparent;
    }
    .closeBtn:hover{ background: rgba(239,246,255,.98); opacity:.96; }
    .closeBtn:active{ transform: scale(.98); }
    .modalBody{ padding: 16px; }

    .modalCards{
      display:grid;
      gap: 12px;
    }
    .modalCard{
      border: 1px solid rgba(223,234,252,.95);
      border-radius: 16px;
      padding: 14px;
      background: rgba(239,246,255,.65);
      display:flex;
      justify-content:space-between;
      gap: 12px;
      align-items:flex-start;
      flex-wrap:wrap;
    }
    .modalCardLabel{
      color: var(--muted);
      font-size: 12px;
    }
    .modalCardValue{
      font-weight: 900;
      letter-spacing: .1px;
    }

    .floatingContact{
      position: fixed;
      right: calc(16px + var(--safe-right));
      top: 80%;
      transform: translateY(-50%);
      z-index: 120;
      display:flex;
      align-items:center;
      gap: 10px;
      height: 50px;
      padding: 0 16px;
      border-radius: 999px;
      border: 1px solid rgba(59,130,246,.22);
      background: rgba(255,255,255,.92);
      backdrop-filter: blur(12px);
      box-shadow: 0 18px 45px rgba(2,18,60,.16);
      cursor:pointer;
      transition: transform .15s ease, opacity .15s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .floatingContact:hover{ opacity:.94; }
    .floatingContact:active{ transform: translateY(-50%) scale(.99); }
    .floatingIcon{
      width: 34px;
      height: 34px;
      border-radius: 999px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue2) 100%);
      color: #fff;
      display:grid;
      place-items:center;
      font-weight: 950;
      line-height: 1;
      flex: 0 0 auto;
      box-shadow: 0 12px 26px rgba(59,130,246,.22);
    }
    .floatingText{
      display:flex;
      flex-direction:column;
      gap: 1px;
      text-align:left;
    }
    .floatingText b{ font-size: 13px; letter-spacing: .15px; }
    .floatingText span{
      font-size: 12px;
      color: var(--muted);
      line-height: 1.1;
      white-space: nowrap;
    }

    footer{
      border-top: 1px solid rgba(223,234,252,.95);
      padding: 22px 0 28px;
      color: var(--muted);
      font-size: 13px;
      background: linear-gradient(180deg, #ffffff 0%, var(--sky2) 100%);
      padding-bottom: calc(28px + var(--safe-bottom));
    }
    .footerInner{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 12px;
      flex-wrap: wrap;
    }

    @media (max-width: 1100px){
      .featureRow{ grid-template-columns: repeat(3, 1fr); }
      .strengthCards{ grid-template-columns: 1fr; }
      .mission3Row{ grid-template-columns: 1fr; }
    }

    @media (max-width: 960px){
      .wrap{ padding: 0 12px; }

      .bannerCard{
        height: clamp(520px, 78vh, 980px);
        border-radius: 20px;
        border: 1px solid var(--border);
      }
      .bannerCard:first-child,
      .bannerCard:last-child{
        border-radius: 20px;
      }

      .leadBox{
        left: 50%;
        right: auto;
        transform: translate(-50%, -50%);
        width: min(640px, calc(100% - 18px));
        padding: 14px;
        border-radius: 18px;
      }

      .formGrid{ grid-template-columns: 1fr; gap: 10px; }
      .textarea{ min-height: 92px; }

      .casesGrid{ grid-template-columns: 1fr; gap: 12px; }

      .fp-row, .fp-row--reverse{ grid-template-columns: 1fr; }
      .fp-media{ min-height: 220px; }

      .strengthStats{ grid-template-columns: 1fr; }
      .stat:not(:last-child)::after{ display:none; }

      .contactGrid{ grid-template-columns: 1fr; gap: 12px; }
      .mapWrap{ height: 320px; }

      .bannerShade{
        background:
          linear-gradient(90deg, rgba(0,0,0,.62) 0%, rgba(0,0,0,.20) 60%, rgba(0,0,0,0) 82%),
          linear-gradient(180deg, rgba(0,0,0,.24) 0%, rgba(0,0,0,0) 46%, rgba(0,0,0,.18) 100%);
      }

      .strengthCardMedia{ height: 180px; }
    }

    @media (max-width: 520px){
      .header__inner{
        height: 62px;
        padding-top: calc(var(--safe-top) * .6);
      }
      .brand__logo{ width: 122px; height: 32px; }
      .contactBtn{
        height: 38px;
        padding: 0 12px;
        gap: 8px;
      }
      .contactBtn span:last-child{ font-size: 13px; }

      .bannerCard{ height: clamp(620px, 86vh, 1100px); border-radius: 18px; }

      .miniNote{ display:none; }

      .floatingContact{
        top: auto;
        bottom: calc(14px + var(--safe-bottom));
        right: calc(12px + var(--safe-right));
        transform: none;
      }
      .floatingContact:active{ transform: scale(.99); }
      .floatingText span{ display:none; }

      .featureRow{ grid-template-columns: 1fr; }
      .strengthCardMedia{ height: 170px; }
    }

/* Extracted from former inline styles */
.websiteBannerCopy{
  text-align: left;
  max-width: 720px;
}

.websiteBannerTitle{
  font-weight: 950;
}

.websiteBannerHeading{
  margin: 12px 0 68px;
  font-size: clamp(24px, 3vw, 38px);
  font-weight: 900;
}

.websiteBannerSub{
  max-width: 65ch;
}

.webFeaturesTitle{
  margin-bottom: 8px;
}

.webFeaturesSub{
  margin-bottom: 18px;
}

.modalLeadTitleReset,
.modalLeadSubReset{
  margin-top: 0;
}
