
:root{
  --us-blue:#0a3161;
  --us-red:#e11f27;
  --ink:#0b1220;
  --muted:#64748b;
  --soft:#f7f9fc;
  --r12:12px;
  --r16:16px;
  --r20:20px;
  --shadow-sm: 0 10px 24px rgba(16,24,40,.08);
  --shadow-md: 0 18px 46px rgba(16,24,40,.12);
}
html{ scroll-behavior:smooth; }
body{ color:var(--ink); }

/* Fluid spacing system */
.section-fluid{
  padding-left: clamp(18px, 3.2vw, 44px);
  padding-right: clamp(18px, 3.2vw, 44px);
}
.container-fluid-max{
  max-width: 1320px;
  margin-left:auto;
  margin-right:auto;
}

/* Topbar */
.topbar-usa{
  background: linear-gradient(90deg, #071a3a 0%, #050b18 100%);
  border-bottom: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.82);
}
.topbar-usa .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 8px 0;
}
.topbar-usa .left{ display:flex; align-items:center; gap:10px; }
.topbar-usa .soc{
  width:34px;height:34px;border-radius: 12px;
  display:grid;place-items:center;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  transition: transform .15s ease, background .15s ease;
}
.topbar-usa .soc:hover{ transform: translateY(-1px); background: rgba(255,255,255,.12); color:#fff; }
.topbar-usa .right{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end;
}
.topbar-pill{
  display:inline-flex; align-items:center; gap:10px;
  padding: 8px 12px; border-radius:999px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff; font-weight:850; letter-spacing:.01em;
}
.topbar-pill .flag{
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Apple Color Emoji", "Segoe UI Emoji";
  font-size: 1.05rem; line-height:1;
}
.topbar-pill small{
  color: rgba(255,255,255,.70);
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
}
.topbar-pill a{ color:#fff; text-decoration:none; }
.topbar-pill a:hover{ color:#fff; text-decoration:underline; }
@media (max-width: 575.98px){
  .topbar-usa .wrap{ flex-direction:column; align-items:flex-start; }
  .topbar-usa .right{ width:100%; justify-content:flex-start; }
}

/* Navbar (WHITE) */
.nav-white{
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
}
.navbar .nav-link{
  font-weight:800;
  color:#0b1220 !important;
  opacity:.86;
}
.navbar .nav-link:hover{ opacity:1; color:#0b1220 !important; }
.navbar .nav-link.active{ opacity:1; }
.brand-badge{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--us-blue),var(--us-red));
  color:#fff;font-weight:900;
  box-shadow: 0 14px 28px rgba(10,49,97,.18);
  flex:0 0 auto;
}
@media (max-width:575.98px){
  .brand-badge{ width:30px;height:30px;border-radius:10px; }
  .navbar-brand .fw-bold{ font-size:.98rem; }
}

/* Banner */
.banner.bg-detail{
  position:relative;
  min-height:78vh;
  display:flex;
  align-items:center;
  color:#fff;
  background-size:cover;
  background-position:center;
  overflow:hidden;
  isolation:isolate;
}
.banner.bg-detail::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 420px at 20% 20%, rgba(10,49,97,.55), transparent 60%),
    radial-gradient(900px 420px at 80% 15%, rgba(179,25,66,.45), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.82));
  z-index:0;
}
.banner.bg-detail::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:10px;
  background: linear-gradient(90deg, var(--us-blue) 0 40%, #fff 40% 60%, var(--us-red) 60% 100%);
  opacity:.95;
  z-index:1;
}
.banner-content{ position:relative; z-index:2; }
.banner-content .h1{
  font-weight:950;
  letter-spacing:-.03em;
  line-height:1.15;
  text-wrap:balance;
  font-size: clamp(2rem, 3.6vw, 3.4rem);
  margin-bottom:.8rem;
}
.banner-content h1 span{
  color:#fff;
  background: rgba(179,25,66,.22);
  border: 1px solid rgba(179,25,66,.42);
  padding:.06em .22em;
  border-radius:.5rem;
  box-shadow: 0 12px 30px rgba(179,25,66,.20);
}
.banner-content p{
  color: rgba(255,255,255,.86);
  max-width: 820px;
  margin: 0 auto 1.35rem;
  font-size: clamp(1rem, 1.2vw, 1.15rem);
}
.pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .75rem; border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.92);
  font-size:.92rem;
}

/* Buttons */
.btn-us-primary{
  background: linear-gradient(135deg, var(--us-red), #d11f4d);
  border: 0;
  color:#fff;
  font-weight:900;
  letter-spacing:.06em;
  padding: .95rem 1.25rem;
  border-radius: 14px;
  box-shadow: 0 20px 46px rgba(179,25,66,.28);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn-us-primary:hover{
  transform: translateY(-2px);
  filter: brightness(.98);
  box-shadow: 0 26px 60px rgba(179,25,66,.36);
  color:#fff;
}
.btn-ghost{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-weight:800;
  padding:.95rem 1.25rem;
  border-radius:14px;
}
.btn-ghost:hover{ background:rgba(255,255,255,.14); color:#fff; }

/* Sticky CTA */
.sticky-cta{
  position:fixed;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  z-index:1050;
}
.sticky-cta button{
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  border-radius: 14px 0 0 14px;
  padding: 12px 10px;
  background: linear-gradient(180deg, var(--us-blue), #07254b);
  color:#fff;
  font-weight:900;
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 42px rgba(10,49,97,.30);
  letter-spacing:.06em;
}
.sticky-cta button:hover{ filter:brightness(.97); }
@media (max-width: 991.98px){ .banner.bg-detail{ min-height: 68vh; } .sticky-cta{ display:none; } }

/* Trust strip logos */
.trust-strip{ margin-top:-38px; position:relative; z-index:4; }
.trust-card{
  background:#fff;
  border-radius: 20px;
  box-shadow: var(--shadow-md);
  border:1px solid rgba(15,23,42,.08);
}
.trust-title{
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:950;
  color:#0b1220;
}
.client-logos{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 34px;
  flex-wrap:wrap;
}
.logo-item{
  height: 42px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 14px;
  background:#fff;
  border:1px solid rgba(15,23,42,.06);
  box-shadow: 0 10px 22px rgba(16,24,40,.06);
  transition: transform .16s ease, box-shadow .16s ease, filter .16s ease, background .16s ease;
}
.logo-item img{
  height: 26px;
  width:auto;
  display:block;
  filter: grayscale(1) contrast(1.05) opacity(.82);
  transition: filter .16s ease, transform .16s ease;
}
.logo-item:hover{ transform: translateY(-2px); box-shadow: 0 16px 34px rgba(16,24,40,.10); background:#fbfbff; }
.logo-item:hover img{ filter: grayscale(0) opacity(1); transform: scale(1.02); }
@media (max-width: 991.98px){
  .client-logos{ flex-wrap: nowrap; overflow-x: auto; padding-bottom: 6px; scroll-snap-type: x mandatory; }
  .client-logos::-webkit-scrollbar{ height:0; }
  .logo-item{ scroll-snap-align: center; flex:0 0 auto; }
}

/* Section headings + cards */
.section-kicker{ letter-spacing:.28em; text-transform:uppercase; color:var(--muted); font-size:.78rem; font-weight:900; }
.section-title{ font-weight:950; letter-spacing:-.03em; text-wrap:balance; }
.card-pro{
  border-radius: var(--r20);
  border:1px solid rgba(15,23,42,.08);
  box-shadow: var(--shadow-sm);
  overflow:hidden;
  height:100%;
  background:#fff;
  transition: transform .18s ease, box-shadow .18s ease;
}
.card-pro:hover{ box-shadow: var(--shadow-md); transform: translateY(-2px); }

/* Services cards */
.service-top{
  background: linear-gradient(135deg, #070a12, #0c1220);
  color:#fff;
  padding:18px 18px 12px;
  min-height:128px;
}
.service-top h5{ margin:0; font-weight:950; letter-spacing:-.01em; }
.service-top p{ margin:.55rem 0 0; color:rgba(255,255,255,.74); font-size:.95rem; }
.service-img{
  height:220px;
  position:relative;
  background-size: cover;
  background-position:center;
}
.service-img::before{ content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.60)); }
.service-img::after{ content:""; position:absolute; inset:14px; border-radius:14px; border:1px dashed rgba(255,255,255,.22); }
.service-cta{
  position:absolute; right:14px; bottom:14px;
  width:42px; height:42px;
  border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--us-red), #d11f4d);
  color:#fff;
  box-shadow: 0 16px 34px rgba(179,25,66,.26);
  z-index:2;
}

/* Dark sections */
.portfolio-wrap, .dark-wrap, .lead-wrap{
  background:
    radial-gradient(1100px 480px at 70% 10%, rgba(179,25,66,.10), transparent 55%),
    radial-gradient(900px 520px at 30% 20%, rgba(10,49,97,.10), transparent 55%),
    linear-gradient(180deg, #0a0f17 0%, #060914 100%);
  color:#fff;
}
.glass{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--r20);
}
.muted-w{ color:rgba(255,255,255,.72); }

/* Testimonials (with photos) */
.t-card{
  border-radius: var(--r20);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  padding: 18px;
  height: 100%;
}
.t-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 12px; }
.t-person{ display:flex; align-items:center; gap:12px; min-width:0; }
.t-photo{
  width:46px; height:46px;
  border-radius:16px;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 14px 30px rgba(0,0,0,.25);
  flex:0 0 auto;
}
.t-name{ font-weight:950; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.t-role{ color:rgba(255,255,255,.70); font-size:.92rem; }
.stars{ color:#ffd400; display:flex; gap:2px; flex:0 0 auto; }
.t-quote{ color:rgba(255,255,255,.82); line-height:1.65; position:relative; padding-left: 34px; }
.t-quote:before{
  content:"\F6B0";
  font-family: "bootstrap-icons";
  position:absolute;
  left:0; top:0;
  font-size: 1.2rem;
  opacity:.9;
  color: rgba(255,255,255,.70);
}

/* Stats */
.stats-wrap{ background:#f5f7fb; }
.stats-title{
  font-weight:950; letter-spacing:-.02em;
  color:#0b1b3a; text-align:center;
  font-size: clamp(2rem, 3vw, 2.6rem);
}
.stats-box{ border: 2px solid rgba(230,0,4,.55); border-radius: 14px; background: #f5f7fb; padding: 22px 18px; }
.stat-icon{ font-size: 2.2rem; color: rgba(230,0,4,.95); line-height: 1; margin-bottom: 10px; animation: statPulse 2.8s ease-in-out infinite; }
@keyframes statPulse{ 0%,100%{ transform: translateY(0); opacity:1; } 50%{ transform: translateY(-2px); opacity:.95; } }
.stat-num{ font-weight: 950; letter-spacing: -.03em; font-size: clamp(2.4rem, 4vw, 3.6rem); color:#070b2a; margin: 6px 0 6px; font-variant-numeric: tabular-nums; }
.stat-label{ color:#6b7280; font-weight: 600; font-size: 1rem; max-width: 260px; margin: 0 auto; }

/* Forms */
.form-dark .form-control, .form-dark .form-select{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
  color:#fff;
  border-radius:14px;
}
.form-dark .form-control::placeholder{ color:rgba(255,255,255,.55); }
.form-dark label{ color:rgba(255,255,255,.80); font-weight:800; }
.form-dark .form-select:required:invalid{ color:rgba(255,255,255,.80); }
.form-dark .form-select option{ color:#0b1220; }
.phone-country{
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-weight: 800;
  letter-spacing: .02em;
}
.phone-grid{ display:grid; grid-template-columns: 170px 1fr; gap:10px; }
@media (max-width: 575.98px){ .phone-grid{ grid-template-columns: 1fr; } }

/* Consultation modal (more padding + cleaner field spacing) */
.consult-modal .modal-dialog{ max-width: 560px; }
.consult-modal .modal-content{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: radial-gradient(900px 520px at 30% 0%, rgba(10,49,97,.18), transparent 55%),
              radial-gradient(900px 520px at 80% 30%, rgba(179,25,66,.14), transparent 55%),
              linear-gradient(180deg, #0b0f18 0%, #060914 100%);
  color:#fff;
  overflow:hidden;
  box-shadow: 0 40px 120px rgba(0,0,0,.60);
}
.consult-modal .modal-header{ border-bottom:1px solid rgba(255,255,255,.10); padding: 18px 22px; }
.consult-modal .modal-body{ padding: 18px 22px 22px; }
.consult-modal .modal-footer{ padding: 0 22px 18px; }
.consult-badgeTop{
  width: fit-content;
  margin: 0 auto;
  padding: 12px 18px;
  border-radius: 0 0 18px 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-top: 0;
  font-weight:950;
  letter-spacing:-.01em;
}
.consult-badgeTop b{ color:#ffd400; }
.consult-pill{
  display:inline-block;
  background: rgba(230,0,4,.92);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff;
  font-weight:950;
  padding: 6px 10px;
  border-radius: 10px;
  letter-spacing:.04em;
}
.form-light .form-control, .form-light .form-select{
  background:#fff;
  border:0;
  border-radius: 12px;
  padding: .95rem 1rem;
  font-weight:700;
  color:#0b1220;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.10);
}
.form-light .form-control::placeholder{ color:#6b7280; font-weight:600; }
.form-light .form-select:required:invalid{ color:#6b7280; }
.form-light .form-select option{ color:#0b1220; }
.btn-consult{
  background: linear-gradient(135deg, #10b981, #16a34a);
  border:0;
  color:#fff;
  font-weight:950;
  letter-spacing:.06em;
  text-transform:uppercase;
  border-radius: 12px;
  padding: 1rem 1rem;
  box-shadow: 0 18px 34px rgba(16,185,129,.18);
}
.btn-consult:hover{ filter:brightness(.98); color:#fff; }

/* Exit intent offer modal */
.exit-offer .modal-content{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(900px 520px at 20% 0%, rgba(10,49,97,.22), transparent 60%),
    radial-gradient(900px 520px at 80% 30%, rgba(230,0,4,.14), transparent 60%),
    linear-gradient(180deg, #0b0f18 0%, #060914 100%);
  color:#fff;
  overflow:hidden;
  box-shadow: 0 40px 120px rgba(0,0,0,.60);
}
.exit-offer .offer-topbar{
  height: 10px;
  background: linear-gradient(90deg, var(--us-blue) 0 40%, #fff 40% 60%, var(--us-red) 60% 100%);
}
.offer-badge{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 14px; border-radius: 999px;
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  font-weight: 950; letter-spacing:.08em;
  text-transform:uppercase; font-size:.78rem;
}
.offer-50{ font-size: clamp(2.2rem, 4vw, 3.2rem); font-weight: 950; letter-spacing:-.03em; line-height:1.05; }
.offer-50 b{ color:#ffd400; }
.offer-sub{ color: rgba(255,255,255,.82); font-weight: 650; line-height:1.55; }
.btn-offer{
  background: linear-gradient(135deg, var(--us-red), #ff2f61);
  border:0; color:#fff;
  font-weight: 950;
  border-radius: 999px;
  padding: 12px 18px;
  box-shadow: 0 18px 44px rgba(255,47,97,.25);
}
.btn-offer:hover{ transform: translateY(-1px); color:#fff; }

* PROCESS */
    .process-wrap{ background:#fff; }
    .process-head{ text-align:center; margin-bottom: 26px; }
    .process-head .kicker{
      letter-spacing:.32em;
      text-transform:uppercase;
      font-weight:800;
      color:#111;
      opacity:.85;
      font-size:.9rem;
    }
    .process-head h2{
      font-weight:900;
      letter-spacing:-.02em;
      margin:.75rem 0 0;
      font-size: clamp(2rem, 4vw, 3.25rem);
      line-height:1.1;
    }
    .steps-badge{
      display:inline-block;
      margin-top: 14px;
      background: var(--us-red);
      color:#fff;
      font-weight: 950;
      padding: .6rem 1.2rem;
      border-radius: 0;
      font-size: 1.2rem;
      letter-spacing:-.01em;
    }
    .process-sub{
      max-width: 980px;
      margin: 16px auto 0;
      font-size: 1.15rem;
      color:#111;
      opacity:.9;
    }
    .process-step{ position:relative; padding: 10px 10px 0; }
    .process-step .big-no{
  position: absolute;
  top: 38px;
  left: -20px;
  font-size: 4.2rem;
  font-weight: 900;
  color: #16a34a;
  opacity: 0.5;
  line-height: 1;
  user-select: none;
  pointer-events: none;
}
    }
    .process-step h4{
      font-weight:900;
      letter-spacing:-.01em;
      margin-left: 26px;
      margin-top: 26px;
      font-size: 1.35rem;
    }
    .process-step p{
      margin-left: 26px;
      color:#111;
      opacity:.9;
      font-size: 1.03rem;
      line-height: 1.55;
      max-width: 92%;
    }
    .process-cta{
      margin-top: 40px;
      display:flex;
      align-items:center;
      justify-content:center;
      gap: 32px;
      flex-wrap: wrap;
      text-align:center;
    }
    .process-cta .label{
      letter-spacing:.32em;
      text-transform:uppercase;
      font-weight:800;
      opacity:.7;
    }
    .process-cta .phone{
      font-size: 2rem;
      font-weight: 950;
      letter-spacing:-.02em;
    }
    .process-cta .iconCircle{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #082850;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: var(--shadow-sm);
  color: #fff;
    }
    .btn-quote{
      background: linear-gradient(135deg, #16a34a, #10b981);
      border:0;
      color:#fff;
      font-weight:950;
      padding:.9rem 1.2rem;
      border-radius: 10px;
      letter-spacing:.03em;
      box-shadow: 0 18px 34px rgba(16,185,129,.18);
    }
    .btn-quote:hover{ filter:brightness(.98); color:#fff; }
    .liveChat{ display:flex; align-items:center; gap:14px; }
    .liveChat .t1{
      letter-spacing:.32em;
      text-transform:uppercase;
      font-weight:800;
      opacity:.75;
    }
    .liveChat .t2{
      font-size: 2rem;
      font-weight: 950;
      letter-spacing:-.02em;
      line-height: 1.05;
    }

/* -----------------------------------------
   MOBILE: <= 576px
   - tighter paddings
   - full-width cards
   - center aligned
   - larger tap targets
   ----------------------------------------- */
@media (max-width: 576px) {
  #process {
    padding-top: 2.25rem !important;
    padding-bottom: 2.25rem !important;
  }

  #process .container-fluid-max {
    padding-left: 14px;
    padding-right: 14px;
  }

  #process .text-center {
    padding-left: 4px;
    padding-right: 4px;
  }

  #process .eyebrow {
    font-size: 12px;
    letter-spacing: .16em;
  }

  #process h2.h2 {
    font-size: 1.55rem;
    margin-bottom: .5rem;
  }

  #process .text-muted {
    font-size: 0.98rem;
  }

  /* Ensure each step card takes full width nicely */
  #process .row.g-4 {
    --bs-gutter-x: 0.9rem;
    --bs-gutter-y: 0.9rem;
  }

  #process .step-card {
    padding: 16px;
    border-radius: 16px;
  }

  #process .step-num {
    width: 42px;
    height: 42px;
    border-radius: 13px;
  }

  #process .step-card h3 {
    font-size: 1.1rem;
  }

  #process .step-card p {
    font-size: 0.98rem;
  }

  /* CTA buttons stacked and full width */
  #process .process-cta .d-inline-flex,
  #process .process-cta .d-inline-flex.flex-wrap {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 10px !important;
  }

  #process .process-cta .btn {
    width: 100%;
    padding: 12px 14px;
    font-size: 0.95rem;
  }

  #process .process-cta .small {
    padding-left: 8px;
    padding-right: 8px;
    line-height: 1.45;
  }
}

/* -----------------------------------------
   SMALL TABLETS: 577px – 767px
   - still comfortable padding
   - cards remain responsive
   ----------------------------------------- */
@media (min-width: 577px) and (max-width: 767px) {
  #process {
    padding-top: 2.75rem !important;
    padding-bottom: 2.75rem !important;
  }

  #process .container-fluid-max {
    padding-left: 18px;
    padding-right: 18px;
  }

  #process h2.h2 {
    font-size: 1.85rem;
  }

  #process .step-card {
    padding: 18px;
    border-radius: 18px;
  }

  /* CTA: 2 columns when space allows */
  #process .process-cta .d-inline-flex {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 12px !important;
    width: 100%;
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
  }

  #process .process-cta .btn {
    width: 100%;
    padding: 12px 14px;
  }
}

/* -----------------------------------------
   TABLETS: 768px – 991px
   ----------------------------------------- */
@media (min-width: 768px) and (max-width: 991px) {
  #process .container-fluid-max {
    padding-left: 22px;
    padding-right: 22px;
  }

  #process h2.h2 {
    font-size: 2.05rem;
  }

  #process .step-card {
    padding: 20px;
  }

  #process .process-cta .btn {
    padding: 12px 16px;
  }
}

/* -----------------------------------------
   SAFETY: If some theme CSS forces fixed heights
   ----------------------------------------- */
#process .step-card,
#process .step-card * {
  max-width: 100%;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

/* Optional: prevent horizontal scroll on tiny devices */
@media (max-width: 420px) {
  #process .container-fluid-max {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* Team (with photos) */
.team-wrap{
  background:
    radial-gradient(1100px 520px at 10% 10%, rgba(10,49,97,.10), transparent 55%),
    radial-gradient(900px 520px at 90% 30%, rgba(230,0,4,.10), transparent 55%),
    linear-gradient(180deg, #f6f8fd 0%, #ffffff 100%);
}
.team-card{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.08);
  background: #fff;
  box-shadow: 0 18px 46px rgba(16,24,40,.10);
  overflow: hidden;
  height: 100%;
  transition: transform .18s ease, box-shadow .18s ease;
}
.team-card:hover{ transform: translateY(-4px); box-shadow: 0 26px 70px rgba(16,24,40,.14); }
.team-top{ padding: 18px 18px 0; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.team-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding: 8px 10px; border-radius: 999px;
  background: rgba(10,49,97,.08);
  border: 1px solid rgba(10,49,97,.14);
  font-weight: 900; color: #0b1b3a;
  letter-spacing: .02em; font-size: .88rem;
}
.team-badge.red{ background: rgba(230,0,4,.08); border-color: rgba(230,0,4,.16); color: #5b0b15; }
.team-photo{
  width: 54px; height: 54px;
  border-radius: 18px;
  object-fit: cover;
  border: 1px solid rgba(15,23,42,.12);
  box-shadow: 0 18px 38px rgba(10,49,97,.16);
  flex:0 0 auto;
}
.team-body{ padding: 14px 18px 18px; }
.team-name{ font-weight: 950; letter-spacing: -.02em; margin: 10px 0 2px; font-size: 1.15rem; color: #0b1220; }
.team-role{ color: #475569; font-weight: 800; font-size: .95rem; margin-bottom: 12px; }
.team-points{ list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.team-points li{ display:flex; gap:10px; align-items:flex-start; color: #334155; font-weight: 650; font-size: .95rem; line-height: 1.35; }
.team-points i{ color: var(--us-red); margin-top: 2px; flex: 0 0 auto; }
.team-footer{ padding: 0 18px 18px; display:flex; justify-content:space-between; align-items:center; gap: 10px; flex-wrap: wrap; }
.team-skill{ display:inline-flex; align-items:center; gap:8px; padding: 8px 10px; border-radius: 12px; background: #f3f5fb; border: 1px solid rgba(15,23,42,.08); font-weight: 850; color:#0b1220; font-size: .88rem; }

/* Footer */
.footer-usa{
  background:
    radial-gradient(900px 520px at 20% 20%, rgba(230,0,4,.16), transparent 58%),
    radial-gradient(900px 520px at 80% 10%, rgba(255,255,255,.10), transparent 58%),
    linear-gradient(180deg, #081a3a 0%, #050b18 100%);
  color: rgba(255,255,255,.82);
  border-top: 1px solid rgba(255,255,255,.10);
}
.footer-usa .footer-topbar{
  height: 10px;
  background: linear-gradient(90deg, var(--us-blue) 0 40%, #fff 40% 60%, var(--us-red) 60% 100%);
  opacity: .95;
}
.footer-usa .footer-brand{ display:flex; align-items:center; gap: 12px; }
.footer-usa .brand-mark{
  width:44px;height:44px;border-radius: 16px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--us-blue), var(--us-red));
  color:#fff; font-weight: 950;
  box-shadow: 0 18px 40px rgba(10,49,97,.22);
  flex:0 0 auto;
}
.footer-usa .brand-name{ font-weight: 950; letter-spacing: -.02em; font-size: 1.15rem; color:#fff; margin:0; }
.footer-usa .brand-sub{ margin:0; color: rgba(255,255,255,.70); font-weight: 650; font-size: .95rem; }
.footer-usa .footer-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 16px;
  height: 100%;
}
.footer-usa .footer-h{ color:#fff; font-weight: 900; letter-spacing: -.01em; margin:0 0 10px; }
.footer-usa a{ color: rgba(255,255,255,.78); text-decoration:none; font-weight: 650; }
.footer-usa a:hover{ color:#fff; }
.footer-usa .footer-links{ display:grid; gap: 8px; font-size: .95rem; }
.footer-usa .footer-mini{ display:flex; gap: 10px; flex-wrap: wrap; }
.footer-usa .pill-contact{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 12px; border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff; font-weight: 900; letter-spacing: .01em;
}
.footer-usa .pill-contact .flag{
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Apple Color Emoji", "Segoe UI Emoji";
  font-size: 1.05rem; line-height: 1;
}
.footer-usa .social-btn{
  width: 40px; height: 40px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff;
  transition: transform .15s ease, background .15s ease;
}
.footer-usa .social-btn:hover{ transform: translateY(-2px); background: rgba(255,255,255,.12); color:#fff; }
.footer-usa .footer-bottom{ border-top: 1px solid rgba(255,255,255,.10); }

/* Utility */
.py-lg-6{ padding-top: 4rem !important; padding-bottom: 4rem !important; }
 .bannerlogoclient{
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 16px;
      padding: 14px 16px;
      display:inline-block;
    }

    /* Right sticky CTA */
    .sticky-cta{
      position:fixed;
      right:12px;
      top:50%;
      transform:translateY(-50%);
      z-index:1050;
    }
    .sticky-cta button{
      writing-mode: vertical-rl;
      transform: rotate(180deg);
      border-radius: 14px 0 0 14px;
      padding: 12px 10px;
      background: linear-gradient(180deg, var(--us-blue), #07254b);
      color:#fff;
      font-weight:900;
      border:1px solid rgba(255,255,255,.18);
      box-shadow: 0 18px 42px rgba(10,49,97,.30);
      letter-spacing:.06em;
    }
    .sticky-cta button:hover{ filter:brightness(.97); }
    @media (max-width: 991.98px){
      .banner.bg-detail{ min-height: 68vh; }
      .sticky-cta{ display:none; }
    }

    /* ===== Parallel CTA blocks (fluid + parallax + animation) ===== */
    .cta-fluid-shell{
      border-radius: 22px;
      overflow:hidden;
      border: 1px solid rgba(255,255,255,.14);
      box-shadow: 0 34px 110px rgba(10,49,97,.18);
    }
    .cta-fluid-topbar{
      height: 10px;
      background: linear-gradient(90deg, var(--us-blue) 0 40%, #fff 40% 60%, var(--us-red) 60% 100%);
      opacity:.95;
    }
    .cta-parallax{
      position: relative;
      color:#fff;
      overflow:hidden;
      border-radius: 0;
      background:
        linear-gradient(90deg, rgba(7,10,28,.92), rgba(7,10,28,.55)),
        var(--cta-bg, url('/assets/img/cta/cta-bg.jpg'));
      background-size: cover;
      background-position: center;
      background-attachment: fixed;
    }
    @media (max-width: 991.98px){
      .cta-parallax{ background-attachment: scroll; }
    }
    .cta-parallax::before{
      content:"";
      position:absolute; inset:-40px;
      background:
        radial-gradient(800px 380px at 20% 20%, rgba(10,49,97,.45), transparent 60%),
        radial-gradient(700px 340px at 70% 30%, rgba(230,0,4,.25), transparent 60%);
      opacity:.9;
      pointer-events:none;
    }
    .cta-parallax::after{
      content:"";
      position:absolute; inset:0;
      background: linear-gradient(90deg, rgba(10,49,97,.35), rgba(230,0,4,.12));
      pointer-events:none;
    }
    .cta-inner{
      position:relative;
      z-index:2;
      padding: 54px 34px;
    }
    @media (max-width: 991.98px){
      .cta-inner{ padding: 34px 18px; text-align:center; }
    }
    .cta-float{
      position:absolute;
      right: -40px;
      top: -40px;
      width: 220px;
      height: 220px;
      border-radius: 50%;
      background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), rgba(255,255,255,.06));
      border: 1px solid rgba(255,255,255,.12);
      z-index:1;
      animation: floaty 6.5s ease-in-out infinite;
      pointer-events:none;
    }
    .cta-float.two{
      right: 26%;
      top: auto;
      bottom: -70px;
      width: 260px;
      height: 260px;
      animation-delay: 1.2s;
      opacity:.75;
    }
    @keyframes floaty{
      0%,100%{ transform: translate3d(0,0,0); }
      50%{ transform: translate3d(-14px, 10px, 0); }
    }
    .cta-kicker{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding: 10px 14px;
      border-radius: 999px;
      background: rgba(255,255,255,.10);
      border: 1px solid rgba(255,255,255,.14);
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
      font-size: .78rem;
    }
    .cta-title{
      font-weight: 950;
      letter-spacing: -.03em;
      line-height: 1.12;
      font-size: clamp(1.9rem, 3.2vw, 2.8rem);
      margin: 16px 0 10px;
      text-wrap: balance;
    }
    .cta-sub{
      color: rgba(255,255,255,.84);
      font-weight: 650;
      max-width: 860px;
      font-size: 1.05rem;
      line-height: 1.55;
      margin: 0 0 18px;
    }
    .cta-btn-animated{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      background: linear-gradient(135deg, var(--us-red), #ff2f61);
      color:#fff;
      font-weight: 950;
      border:0;
      border-radius: 999px;
      padding: 12px 24px;
      box-shadow: 0 18px 44px rgba(255,47,97,.25);
      position: relative;
      overflow:hidden;
      will-change: transform;
    }
    .cta-btn-animated::before{
      content:"";
      position:absolute;
      top:0; left:-60%;
      width: 60%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
      transform: skewX(-18deg);
      animation: shine 2.8s ease-in-out infinite;
    }
    @keyframes shine{
      0%{ left:-60%; }
      60%{ left:120%; }
      100%{ left:120%; }
    }
    .cta-btn-animated:hover{ transform: translateY(-2px); color:#fff; }
    .cta-mini{
      display:flex;
      gap:14px;
      flex-wrap: wrap;
      align-items:center;
      margin-top: 18px;
      color: rgba(255,255,255,.82);
      font-weight: 700;
      font-size: .95rem;
    }
    .cta-mini span{
      display:inline-flex; gap:8px; align-items:center;
      padding: 10px 12px;
      border-radius: 14px;
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.12);
    }
    .cta-mini i{ color: #ffd400; }


    .banner-seals .seal-img{height:64px;width:auto;border-radius:14px;box-shadow:0 10px 24px rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.28);}
    .banner-seals .seal-link{display:inline-flex;align-items:center;justify-content:center;}
    .cta-band .cta-card{background:linear-gradient(135deg, rgba(47,168,79,.12), rgba(255,193,7,.10)); border:1px solid rgba(17,24,39,.08); box-shadow:0 14px 36px rgba(17,24,39,.10);}
    .cta-band .eyebrow{font-weight:800;letter-spacing:.14em;color:#2fa84f;}
    .google-review-seal{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);text-decoration:none;}
    .google-review-seal:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);}
    .google-review-seal img{border-radius:10px;border:1px solid rgba(255,255,255,.18);}
/* =========================
   WhatsApp Floating Widget — PRO UI + MOBILE
   ========================= */

:root{
  --wf-wa: #25D366;
  --wf-wa-dark: #0b1b12;
  --wf-wa-shadow: rgba(0,0,0,.22);
}

/* Floating button */
.wf-wa-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9998;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 5px 14px 5px 12px;
  border-radius: 999px;
  text-decoration: none;

  background: linear-gradient(135deg, #1fce5e, var(--wf-wa));
  color: var(--wf-wa-dark);

  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 44px var(--wf-wa-shadow);

  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
  font-family: inherit;
  -webkit-tap-highlight-color: transparent;
}

.wf-wa-fab:hover{
  transform: translateY(-2px);
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
  filter: brightness(.99);
}

.wf-wa-fab:active{
  transform: translateY(0);
}

/* Icon */
.wf-wa-icon{
  width: 44px;
  height: 44px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255,255,255,.25);
  border: 1px solid rgba(255,255,255,.25);

  font-size: 22px;
  color: var(--wf-wa-dark);

  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10);
}

.wf-wa-text{
  font-weight: 900;
  letter-spacing: .02em;
  font-size: 0.98rem;
  line-height: 1;
  padding-right: 2px;
}

/* Subtle ping dot (premium feel) */
.wf-wa-ping{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 0 0 0 rgba(255,255,255,.0);
  position: relative;
}
.wf-wa-ping::after{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.65);
  transform: scale(.55);
  opacity: .0;
  animation: wf-wa-pulse 2.2s ease-out infinite;
}
@keyframes wf-wa-pulse{
  0%   { transform: scale(.55); opacity: .0; }
  20%  { opacity: .55; }
  100% { transform: scale(1); opacity: 0; }
}

/* Welcome bubble */
.wf-wa-toast{
  position: fixed;
  right: 18px;
  bottom: 92px; /* above button */
  z-index: 9999;

  width: min(380px, calc(100vw - 36px));
  background: #0f172a;
  color: #fff;

  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  box-shadow: 0 26px 78px rgba(0,0,0,.34);

  padding: 14px 14px 12px;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;

  transition: opacity .22s ease, transform .22s ease;
}

.wf-wa-toast.is-show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.wf-wa-close{
  position: absolute;
  top: 10px;
  right: 10px;

  width: 34px;
  height: 34px;
  border-radius: 12px;

  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);

  display: inline-flex;
  align-items: center;
  justify-content: center;

  cursor: pointer;
  transition: background .18s ease, transform .18s ease;
}
.wf-wa-close:hover{ background: rgba(255,255,255,.10); transform: translateY(-1px); }

.wf-wa-toast-body{ padding-right: 40px; }

.wf-wa-toast-title{
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 900;
  letter-spacing: -.01em;
  margin-bottom: 8px;
}

.wf-wa-badge{
  width: 36px;
  height: 36px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(37,211,102,.18);
  color: var(--wf-wa);

  border: 1px solid rgba(37,211,102,.28);
  font-size: 18px;
}

.wf-wa-toast-msg{
  color: rgba(255,255,255,.80);
  font-weight: 650;
  line-height: 1.5;
  margin-bottom: 12px;
}

.wf-wa-actions{
  display: grid;
  grid-template-columns: 1fr 96px;
  gap: 10px;
}

.wf-wa-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;

  padding: 10px 12px;
  border-radius: 14px;

  text-decoration: none;
  font-weight: 900;
  letter-spacing: .02em;

  border: 1px solid rgba(255,255,255,.10);
  background: var(--wf-wa);
  color: var(--wf-wa-dark);

  transition: transform .18s ease, filter .18s ease;
}

.wf-wa-btn:hover{ transform: translateY(-1px); filter: brightness(.98); }

.wf-wa-btn-ghost{
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  border-color: rgba(255,255,255,.12);
}
.wf-wa-btn-ghost:hover{ background: rgba(255,255,255,.10); }

/* =========================
   MOBILE POLISH
   ========================= */
@media (max-width: 576px){
  /* More thumb-friendly placement */
  .wf-wa-fab{
    right: 14px;
    bottom: 14px;

    width: 56px;           /* compact */
    height: 56px;
    padding: 0;
    border-radius: 18px;   /* modern square */
    justify-content: center;
    gap: 0;
  }

  .wf-wa-icon{
    width: 44px;
    height: 44px;
    background: rgba(255,255,255,.22);
    border-radius: 16px;
  }

  .wf-wa-ping{
    position: absolute;
    top: 8px;
    right: 8px;
    width: 10px;
    height: 10px;
  }

  .wf-wa-toast{
    right: 14px;
    bottom: 78px;
    width: min(360px, calc(100vw - 28px));
  }

  .wf-wa-actions{
    grid-template-columns: 1fr; /* stack buttons */
  }

  .wf-wa-btn{
    width: 100%;
    padding: 11px 12px;
  }
}

/* Prevent overlap with iOS safe area */
@supports (padding: max(0px)){
  .wf-wa-fab{ bottom: max(14px, env(safe-area-inset-bottom)); }
  .wf-wa-toast{ bottom: max(78px, calc(env(safe-area-inset-bottom) + 64px)); }
  .wf-wa-toast{ bottom: max(78px, calc(env(safe-area-inset-bottom) + 64px)); }
}