
/* Final mobile polish for Webleads Final */
@media (max-width: 767px) {
  header ul {
    align-items: stretch;
  }

  header ul li,
  header ul li a {
    width: 100%;
  }

  header ul li a {
    display: block;
  }

  #services .container {
    width: min(100% - 32px, 1152px);
  }

  #services span.absolute.top-5.right-5 {
    position: static !important;
    display: inline-flex !important;
    width: max-content;
    max-width: 100%;
    margin-bottom: 1rem;
    white-space: nowrap;
    transform: none !important;
  }

  #services .relative.h-full.p-8 {
    padding-top: 2rem !important;
  }

  #services [class*="grid-cols-1"][class*="sm:grid-cols-2"][class*="lg:grid-cols-3"] > div > div {
    min-height: auto;
  }
}

@media (max-width: 420px) {
  #services span.absolute.top-5.right-5 {
    font-size: 0.58rem !important;
    letter-spacing: 0.16em !important;
  }

  #services .text-xs.uppercase.tracking-\[0\.2em\] {
    line-height: 1.6;
  }
}

/* Latest mobile hardening after Lovable review */
@media (max-width: 767px) {
  header div[class*="md:hidden"][class*="border-t"] {
    overflow: visible !important;
  }

  header div[class*="md:hidden"][class*="border-t"] ul,
  header ul.container.py-6.flex.flex-col {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1rem !important;
    width: min(100% - 32px, 1152px) !important;
    margin-inline: auto !important;
  }

  header div[class*="md:hidden"][class*="border-t"] li,
  header ul.container.py-6.flex.flex-col li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    clear: both !important;
  }

  header div[class*="md:hidden"][class*="border-t"] a,
  header ul.container.py-6.flex.flex-col a {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    line-height: 1.28 !important;
    white-space: normal !important;
    float: none !important;
    transform: none !important;
  }

  header div[class*="md:hidden"][class*="border-t"] a[href="#webleads-projects"] {
    font-size: 1rem !important;
    color: hsl(var(--muted-foreground)) !important;
  }

  header div[class*="md:hidden"][class*="border-t"] li.pt-3 {
    padding-top: 0.75rem !important;
  }

  #services span.absolute.top-5.right-5 {
    position: static !important;
    inset: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin: 0 0 1rem 0 !important;
    white-space: nowrap !important;
    transform: none !important;
  }

  #services span.absolute.top-5.right-5 + div {
    max-width: 100% !important;
    padding-right: 0 !important;
    line-height: 1.55 !important;
  }

  #services div.relative.h-full {
    padding-top: 2rem !important;
  }

  #services .grid > div > div.group,
  #services .grid > div > div.h-full {
    min-height: auto !important;
  }
}

@media (max-width: 420px) {
  header div[class*="md:hidden"][class*="border-t"] a {
    font-size: 1rem !important;
  }

  #services span.absolute.top-5.right-5 {
    font-size: 0.56rem !important;
    letter-spacing: 0.15em !important;
    padding-inline: 0.65rem !important;
  }
}
