/* Mobile-Specific Styles */

/* Touch-friendly elements */
@media (max-width: 768px) {
  /* Ensure minimum touch target size (44x44px) */
  button,
  a,
  input,
  select,
  textarea {
    min-height: 44px;
  }

  /* Improve text readability on small screens */
  body {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
  }

  /* Container padding for mobile */
  .container {
    padding-inline: var(--spacing-md);
  }

  /* Hero Section - Mobile */
  .hero {
    padding-block: var(--spacing-2xl);
  }

  .hero__title {
    font-size: var(--font-size-3xl);
    line-height: var(--line-height-tight);
  }

  .hero__description {
    font-size: var(--font-size-base);
    margin-block-end: var(--spacing-lg);
  }

  .hero__actions {
    flex-direction: column;
    width: 100%;
    gap: var(--spacing-md);
  }

  .hero__actions .btn {
    width: 100%;
  }

  /* Features Grid - Mobile */
  .features__grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }

  /* Cards - Mobile */
  .card {
    padding: var(--spacing-lg);
  }

  .card__icon {
    font-size: var(--font-size-4xl);
  }

  /* About Section - Mobile */
  .about__content {
    grid-template-columns: 1fr;
    gap: var(--spacing-xl);
  }

  .placeholder-image {
    height: 250px;
  }

  /* Section Spacing - Mobile */
  section {
    padding-block: var(--spacing-2xl);
  }

  .section-title {
    font-size: var(--font-size-2xl);
    margin-block-end: var(--spacing-xl);
  }

  /* Typography - Mobile */
  h1 {
    font-size: var(--font-size-4xl);
  }

  h2 {
    font-size: var(--font-size-3xl);
  }

  h3 {
    font-size: var(--font-size-2xl);
  }

  /* Forms - Mobile */
  .register__container {
    padding: var(--spacing-lg);
    margin-inline: var(--spacing-sm);
  }

  .form__input {
    padding: var(--spacing-md);
    font-size: var(--font-size-base);
  }

  .form__label {
    font-size: var(--font-size-base);
  }

  /* Footer - Mobile */
  .footer__content {
    grid-template-columns: 1fr;
    gap: var(--spacing-xl);
    text-align: center;
  }

  .footer__links,
  .footer__contact {
    align-items: center;
  }

  .footer__links a,
  .footer__link {
    text-align: center;
  }

  .footer__links a:hover,
  .footer__link:hover {
    padding-inline-start: 0;
  }

  .footer {
    padding-block: var(--spacing-2xl);
    margin-block-start: var(--spacing-2xl);
  }

  /* Contact Page - Mobile */
  .contact__content {
    padding: var(--spacing-lg);
  }

  .contact__list li {
    font-size: var(--font-size-base);
    padding: var(--spacing-sm) var(--spacing-md);
  }

  /* Page Content - Mobile */
  .page {
    padding-block: var(--spacing-xl);
  }

  /* Buttons - Mobile Optimization */
  .btn {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
    min-height: 48px;
  }

  .btn--sm {
    min-height: 40px;
  }

  .btn--lg {
    min-height: 56px;
  }

  /* Prevent horizontal scroll */
  body {
    overflow-x: hidden;
  }

  .main {
    min-height: calc(100vh - 140px);
  }
}

/* Extra Small Devices (phones, less than 480px) */
@media (max-width: 480px) {
  .container {
    padding-inline: var(--spacing-sm);
  }

  .hero {
    padding-block: var(--spacing-xl);
  }

  .hero__title {
    font-size: var(--font-size-2xl);
  }

  .hero__description {
    font-size: var(--font-size-sm);
  }

  .section-title {
    font-size: var(--font-size-xl);
  }

  .card {
    padding: var(--spacing-md);
  }

  .card__title {
    font-size: var(--font-size-lg);
  }

  .card__description {
    font-size: var(--font-size-sm);
  }

  section {
    padding-block: var(--spacing-xl);
  }

  .footer {
    padding-block: var(--spacing-xl);
  }

  /* Typography adjustments for very small screens */
  h1 {
    font-size: var(--font-size-3xl);
  }

  h2 {
    font-size: var(--font-size-2xl);
  }

  h3 {
    font-size: var(--font-size-xl);
  }
}

/* Landscape Mobile Devices */
@media (max-height: 600px) and (orientation: landscape) {
  .hero {
    padding-block: var(--spacing-lg);
  }

  .hero__title {
    font-size: var(--font-size-2xl);
  }

  section {
    padding-block: var(--spacing-lg);
  }

  .header__nav {
    max-height: calc(100vh - 50px);
  }
}

/* Touch-specific improvements */
@media (hover: none) and (pointer: coarse) {
  /* Increase spacing for touch targets */
  .nav-link {
    padding: var(--spacing-lg);
  }

  .btn {
    padding: var(--spacing-md) var(--spacing-xl);
  }

  /* Remove hover states on touch devices */
  .nav-link:hover {
    background-color: transparent;
  }

  /* Active/tap states instead */
  .nav-link:active {
    background-color: var(--color-gray-50);
    transform: scale(0.98);
  }

  .btn:active {
    transform: scale(0.98);
  }
}

/* Prevent zoom on input focus (iOS) */
@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"],
  textarea,
  select {
    font-size: 16px; /* Prevents iOS zoom */
  }
}

/* Safe area for notched devices (iPhone X, etc.) */
@supports (padding: max(0px)) {
  .header {
    padding-inline: max(var(--spacing-md), env(safe-area-inset-right))
                     max(var(--spacing-md), env(safe-area-inset-left));
  }

  .container {
    padding-inline: max(var(--spacing-md), env(safe-area-inset-right))
                     max(var(--spacing-md), env(safe-area-inset-left));
  }

  .footer {
    padding-inline: max(var(--spacing-md), env(safe-area-inset-right))
                     max(var(--spacing-md), env(safe-area-inset-left));
    padding-block-end: max(var(--spacing-2xl), env(safe-area-inset-bottom));
  }
}
