
.who-cards-grid {
  grid-template-columns: 1fr;
}

.container {
  max-width: 100%;
}
h1 {
  font-size: 2rem;
}

.hero-section {
  height: auto;
  padding: 80px 0;
}
.hero-content-wrapper {
  flex-direction: column;
  gap: 2rem;
}
.hero-title {
  font-size: 2.5rem;
}

.service-floating-card {
  flex: 0 0 85vw;
  width: 85vw;
  padding: 2rem;
}

.carousel-controls-bar {
  justify-content: center;
}

.hero-center-content {
  max-width: 100%;
  margin-top: 6rem;
}

.hero-title {
  font-size: 2rem;
}

.hero-subtitle {
  font-size: 0.9rem;
}

.services-masonry-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 1.5rem !important;
  height: auto !important; 
}

.service-glass-card {
  width: 100% !important;
  max-width: 100% !important;
  margin-bottom: 0 !important;
  position: static !important; 
  transform: none !important; 
}


.services-main-title,
.portfolio-title,
.contact-title,
.pricing-title {
  font-size: 2rem !important;
  line-height: 1.2 !important;
}

.services-subtitle,
.portfolio-description,
.contact-description,
.pricing-subtitle {
  font-size: 1rem !important;
  line-height: 1.4 !important;
}

.service-details-tabs {
  grid-template-columns: 1fr !important; 
  gap: 10px !important;
}

.service-tab-btn {
  width: 100% !important;
  text-align: center !important;
  padding: 14px 20px !important;
}

.details-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2 !important;
  max-width: 80%; 
  margin-left: auto;
  margin-right: auto;
}


.footer-content {
  gap: 2rem !important;
  display: flex !important;
  flex-direction: column !important;
}

.footer-col {
  width: 100%;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding: 1.5rem 0;
  margin: 0 !important;
}

.footer-col:last-child {
  border-bottom: none;
}

/* Hide Footer Contact Column on Small Mobile */
.footer-col.footer-contact {
  display: none !important;
}

/* Remove bottom border from Support column (last visible child) */
.footer-col.footer-support {
  border-bottom: none !important;
}

.footer-brand {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  width: 100% !important;
}

.footer-brand-name {
  font-size: 1.75rem !important;
  margin-top: 1.5rem !important;
  text-align: center !important;
  width: 100% !important;
  display: block !important;
}

.footer-brand-slogan {
  font-size: 0.9rem !important;
  max-width: 100%;
  padding: 0 1rem;
  text-align: center !important;
}

.footer-social {
  justify-content: center !important;
  display: flex !important;
}

.footer-cta-section {
    padding: 2.5rem 1rem;
}

.footer-cta-title {
    font-size: 1.5rem !important;
}

/* Accordion Styles for Small Mobile */
.footer-col-title {
  cursor: pointer;
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center !important;
  width: 100%;
  text-align: center !important;
}

.footer-col-title::after {
  content: '\f078';
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 0.875rem;
  margin-left: 0.75rem;
  transition: transform 0.3s ease;
  color: var(--primary-color);
}

.footer-col.active .footer-col-title::after {
  transform: rotate(180deg);
}

.footer-menu,
.footer-list,
.footer-col ul,
.footer-col .menu {
  display: none !important;
  padding-top: 1rem !important;
  animation: slideDown 0.3s ease-out forwards;
  width: 100% !important;
  text-align: center !important;
}

.footer-col.active .footer-menu,
.footer-col.active .footer-list,
.footer-col.active ul,
.footer-col.active .menu {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.footer-menu li,
.footer-list li,
.footer-col ul li,
.footer-col .menu li {
  justify-content: center !important;
  text-align: center !important;
  width: 100% !important;
  display: flex !important;
}

/* HIGH SPECIFICITY CONTACT SECTION OVERRIDES FOR SMALL MOBILE */
#contact-section .contact-text-column {
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding-right: 0 !important;
}

#contact-section .contact-text-column .services-badge {
  margin-left: auto !important;
  margin-right: auto !important;
  display: inline-flex !important;
}

#contact-section .contact-title,
#contact-section .contact-description,
#contact-section .contact-manual-contact {
  text-align: center !important;
  width: 100% !important;
}

#contact-section .contact-form-column {
  width: 100% !important;
  padding: 0 !important;
}

#contact-section .contact-form {
  padding: 1rem !important;
  width: 100% !important;
}

#contact-section .contact-form .form-row,
#contact-section .form-row.two-col {
  display: flex !important;
  flex-direction: column !important;
  gap: 1.5rem !important;
  grid-template-columns: 1fr !important;
}

#contact-section .contact-form .form-row .form-group {
  width: 100% !important;
}

#contact-section .contact-text-column h2 {
  font-size: 1.75rem !important; 
  margin-bottom: 1rem !important;
}

#contact-section .contact-text-column .section-subtitle {
  font-size: 1rem !important; 
  margin-bottom: 1.5rem !important;
}
