/* ================================================== */
/* RESPONSIVE DESIGN FIXES FOR ALL DEVICES */
/* ================================================== */

/* Extra Small Devices (320px and up) */
@media (max-width: 320px) {
  #gettingStarted h1 {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
  }
  
  .navbar-nav .nav-link {
    font-size: 13px !important;
    padding: 0.3rem 0.5rem;
  }
  
  .popup-content {
    padding: 1.2rem;
    border-radius: 12px;
  }
  
  .navbar-brand img {
    height: 60px !important;
  }
}

/* Small Devices (480px and up) */
@media (max-width: 480px) {
  #gettingStarted h1 {
    font-size: 2rem;
  }
  
  .primary_text {
    font-size: 1.8rem;
  }
  
  .popup-content input,
  .popup-content textarea,
  .popup-content select {
    font-size: 16px;
    padding: 0.8rem 1rem;
  }
  
  .about-text {
    font-size: 0.95rem;
  }
  
  .services-card {
    padding: 0 15px;
  }
  
  .home h1 {
    font-size: 2.5rem;
  }
  
  .home h2 {
    font-size: 1rem;
  }
}

/* Medium Devices (576px and up) */
@media (max-width: 576px) {
  .navbar-brand img {
    height: 70px !important;
  }
  
  #gettingStarted {
    padding: 60px 0;
  }
  
  .popup-content h2 {
    font-size: 1.5rem;
  }
  
  .featurette-heading {
    font-size: 2.5rem;
  }
  
  .team-img {
    width: 100%;
    max-width: 200px;
  }
  
  .service-content h2 {
    font-size: 2.2em;
  }
  
  .details-section {
    padding: 60px 0;
  }
}

/* Tablet and Lower (768px and down) */
@media (max-width: 768px) {
  .navbar-nav {
    margin-top: 1rem;
  }
  
  .navbar-nav .nav-link {
    padding: 0.6rem 0 !important;
    font-size: 15px !important;
  }
  
  #gettingStarted {
    padding: 80px 1rem;
  }
  
  .popup-content {
    padding: 1.5rem;
    width: 95%;
  }
  
  .about-text {
    margin-bottom: 20px;
  }
  
  .service-content {
    padding-left: 0;
  }
  
  #ourclient .service-content h2 {
    font-size: 1.8rem;
    white-space: normal;
  }
  
  .home {
    min-height: 80vh;
  }
}

/* Tablet (769px to 1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  #gettingStarted h1 {
    font-size: 3rem;
  }
  
  .primary_text {
    font-size: 2.5rem;
  }
  
  .service-content h2 {
    font-size: 2.8em;
  }
}

/* Large Devices (991px and down) */
@media (max-width: 991px) {
  .details-section .col-lg-3 {
    margin-bottom: 1.5rem;
  }
  
  .service-content h2 {
    font-size: 2.5em;
  }
  
  .navbar {
    padding: 0.5rem 0;
  }
}

/* Landscape Mode Adjustments */
@media (max-height: 500px) and (orientation: landscape) {
  .navbar {
    min-height: 45px;
  }
  
  .navbar-brand img {
    height: 50px !important;
  }
  
  .home {
    min-height: 50vh;
    padding: 20px 0;
  }
  
  .home h1 {
    font-size: 2rem;
  }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
  .services-card,
  .popup-content .close,
  .navbar-nav .nav-link {
    -webkit-tap-highlight-color: rgba(199, 58, 58, 0.2);
  }
  
  button,
  a,
  .nav-link,
  .dropdown-item {
    min-height: 44px;
    min-width: 44px;
  }
  
  /* Larger touch targets for buttons */
  .btn-md-green,
  .btn-md-green-secondary,
  .popup-submit-btn {
    min-height: 48px;
    padding: 1rem 2rem;
  }
}

/* High DPI / Retina Screen Optimization */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  img {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
  
  body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/* Print Optimization */
@media print {
  .navbar,
  .footerwave,
  #gettingStarted,
  .popup {
    display: none !important;
  }
}

/* Firefox-specific fixes */
@-moz-document url-prefix() {
  input, textarea, select {
    background-color: transparent;
  }
}

/* Safari-specific fixes */
@supports (-webkit-appearance: none) {
  input, textarea, select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }
  
  input:focus, textarea:focus, select:focus {
    -webkit-appearance: none;
  }
}

/* Edge/IE fixes */
@supports (display: flex) {
  .popup {
    display: flex !important;
  }
}
