
/* Deep UI/UX + Responsive fixes (site-wide) */
:root{
  --container-pad: clamp(16px, 3vw, 28px);
  --radius-lg: 18px;
  --radius-md: 14px;
  --shadow-soft: 0 10px 30px rgba(0,0,0,.10);
}

/* Prevent horizontal overflow on mobile */
html, body { max-width: 100%; overflow-x: hidden; }

/* Improve readability */
body{
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

/* Universal media safety */
img, video, iframe { max-width: 100%; height: auto; }

/* Containers: ensure padding on small screens */
.container, .container-fluid, .page-container, .content, main{
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}

/* Buttons + tap targets */
button, .btn, a.btn, .nav-link, .menu-toggle, .hamburger, .navbar-toggler{
  min-height: 44px;
  min-width: 44px;
}

/* Fix hamburger visibility + layering */
.navbar, header, .header, .site-header { position: relative; z-index: 50; }
.navbar-toggler, .menu-toggle, .hamburger{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}
.navbar-toggler svg, .menu-toggle svg, .hamburger svg{ width: 24px; height: 24px; }

/* Dropdowns / menus on mobile */
.navbar-collapse, .mobile-menu, .nav-menu{
  z-index: 1500;
}

/* Cards */
.card, .project-card, .feature-card, .team-card, .blog-card{
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

/* Forms */
input, select, textarea{
  border-radius: 12px;
}
.form-row, .form-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 768px){
  .form-row, .form-grid{ grid-template-columns: 1fr; }
}

/* Project hero + gallery */
.project-hero, .hero, .project-header{
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.project-gallery, .gallery, .image-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 900px){
  .project-gallery, .gallery, .image-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .project-gallery, .gallery, .image-grid{ grid-template-columns: 1fr; }
}

/* Tables on mobile */
table{ width: 100%; }
.table-responsive, .table-wrap{
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 14px;
}

/* Map containers: avoid squished maps */
#map, .map, .leaflet-container{
  min-height: 320px;
  border-radius: 16px;
}
@media (max-width: 560px){
  #map, .map, .leaflet-container{ min-height: 280px; }
}

/* Fix widget overlap (WhatsApp + Ask AI) */
.whatsapp-widget, .wa-widget, .whatsapp-float, .floating-whatsapp{
  bottom: 18px !important;
  right: 18px !important;
  z-index: 3000 !important;
}
.ask-ai, .ai-widget, .floating-ai{
  bottom: 88px !important;
  right: 18px !important;
  z-index: 2999 !important;
}

/* Reduce huge gaps */
section{ scroll-margin-top: 90px; }
@media (max-width: 768px){
  section{ padding-top: 28px !important; padding-bottom: 28px !important; }
}
