/* BuildingLI v247 live mobile hero dock / GSC-safe override.
   Removes old pseudo-element MERCI shortening by replacing Additional CSS. */

.bli-merci-label-short { display: none; }

@media (max-width: 430px) {
  .bli-merci-label-full { display: none !important; }
  .bli-merci-label-short { display: inline !important; white-space: nowrap !important; }
}

@media (max-width: 767px) {
  .hero { position: relative !important; display: block !important; overflow: hidden !important; height: clamp(560px, 72vh, 720px) !important; min-height: 560px !important; max-height: 720px !important; background: #071a35 !important; }
  .hero:before { content: none !important; display: none !important; }
  .hero-art, .hero-bg, .hero-bg-a, .hero-bg-b { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; }
  .hero-art { z-index: 0 !important; clip-path: none !important; pointer-events: none !important; opacity: 1 !important; filter: brightness(1.08) saturate(1.06) !important; }
  .hero-bg, .hero-art .hero-bg { background-size: cover !important; background-position: center center !important; background-repeat: no-repeat !important; filter: brightness(1.08) saturate(1.06) !important; }
  .hero::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(90deg, rgba(7,26,53,.46) 0%, rgba(7,26,53,.22) 44%, rgba(7,26,53,.03) 100%), linear-gradient(180deg, rgba(7,26,53,0) 0%, rgba(7,26,53,.06) 48%, rgba(7,26,53,.42) 100%); }
  .hero-copy { position: absolute !important; left: 28px !important; right: 28px !important; bottom: 28px !important; z-index: 2 !important; max-width: none !important; max-height: 46% !important; margin: 0 !important; padding: 16px 15px 17px 16px !important; display: block !important; background: linear-gradient(90deg, rgba(7,26,53,.48), rgba(7,26,53,.36), rgba(7,26,53,.24)) !important; backdrop-filter: blur(1.5px) saturate(1.04) !important; border-left: 2px solid #d8b768 !important; border-top: 2px solid #d8b768 !important; border-radius: 0 22px 0 0 !important; box-shadow: 0 14px 28px rgba(0,0,0,.16) !important; overflow: visible !important; }
  .hero-copy h1 { margin: 0 0 8px !important; color: #fff !important; font-family: Georgia, "Times New Roman", serif !important; font-size: clamp(25px, 6.1vw, 34px) !important; line-height: 1.03 !important; letter-spacing: 0 !important; text-shadow: 0 2px 10px rgba(0,0,0,.42) !important; }
  .hero-copy .lead, .hero-copy p.lead { margin: 0 0 9px !important; color: #d8a927 !important; font-size: clamp(13px, 3.55vw, 16px) !important; line-height: 1.22 !important; font-weight: 800 !important; max-width: none !important; }
  .hero-copy .bodycopy, .hero-copy p.bodycopy { display: inline-flex !important; align-items: center !important; width: auto !important; max-width: 100% !important; margin: 0 !important; padding: 7px 12px !important; border: 1.5px solid #d8b768 !important; border-radius: 999px !important; color: #fff !important; background: rgba(7,26,53,.20) !important; font-size: 14px !important; line-height: 1.1 !important; font-weight: 700 !important; }
  .hero-copy .bodycopy::before { content: "◷"; color: #d8b768; margin-right: 7px; font-size: 16px; line-height: 1; }
  .hero-copy .start { display: none !important; }
  .hero .arrow { position: absolute !important; z-index: 4 !important; }
  .services { position: relative !important; z-index: 3 !important; margin-top: -16px !important; }
}

@media (max-width: 390px) {
  .hero { height: clamp(535px, 70vh, 670px) !important; min-height: 535px !important; max-height: 670px !important; }
  .hero-copy { left: 22px !important; right: 22px !important; bottom: 22px !important; max-height: 49% !important; padding: 15px 13px 16px 15px !important; }
  .hero-copy h1 { font-size: clamp(24px, 6.2vw, 31px) !important; }
  .hero-copy .lead, .hero-copy p.lead { font-size: 13px !important; }
  .hero-copy .bodycopy, .hero-copy p.bodycopy { font-size: 13px !important; padding: 6px 11px !important; }
}

@media (max-width: 360px) {
  .hero { height: clamp(515px, 69vh, 640px) !important; min-height: 515px !important; max-height: 640px !important; }
  .hero-copy { left: 18px !important; right: 18px !important; bottom: 20px !important; max-height: 51% !important; }
  .hero-copy h1 { font-size: 23px !important; }
  .hero-copy .lead, .hero-copy p.lead { font-size: 12.5px !important; }
}