/* ===================================
   RESPONSIVE DESIGN STYLES
   =================================== */

/* Mobile Logo Section */
@media (max-width: 768px) {
  .logo-section {
    gap: var(--spacing-2);
  }
  
  .logo-image {
    width: 40px;
    height: 40px;
  }
  
  .business-name {
    font-size: var(--font-size-lg);
  }
  
  .business-tagline {
    font-size: var(--font-size-xs);
  }
  
  .hero {
    margin-top: 70px;
    min-height: 60vh;
  }
  
  .social-links {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .top-contact-bar {
    padding: var(--spacing-1) 0;
  }
  
  .top-contact-content {
    flex-direction: column;
    gap: var(--spacing-2);
    padding: 0 var(--spacing-4);
  }

  .contact-quick-links {
    gap: var(--spacing-4);
    font-size: var(--font-size-xs);
  }
  
  .theme-toggle {
    font-size: var(--font-size-xs);
    padding: var(--spacing-1) var(--spacing-3);
  }

  .header {
    top: 0;
  }
}

/* Small tablets and large phones */
@media (min-width: 576px) {
  .container {
    padding-left: var(--spacing-6);
    padding-right: var(--spacing-6);
  }
  
  .hero-title {
    font-size: var(--font-size-5xl);
  }
  
  .section-title {
    font-size: var(--font-size-3xl);
  }
}

/* Tablets */
@media (min-width: 768px) {
  .container {
    padding-left: var(--spacing-8);
    padding-right: var(--spacing-8);
  }
  
  .hero-title {
    font-size: var(--font-size-6xl);
  }
  
  .section-title {
    font-size: var(--font-size-4xl);
  }
  
  .portfolio-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Small laptops */
@media (min-width: 992px) {
  .portfolio-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .services-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Large screens */
@media (min-width: 1200px) {
  .container {
    max-width: 1200px;
  }
}

/* Extra large screens */
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}

/* Mobile Specific Optimizations */
@media (max-width: 767px) {
  /* Typography scaling */
  html {
    font-size: 14px;
  }
  
  /* Spacing adjustments */
  .section {
    padding: var(--spacing-12) 0;
  }
  
  .container {
    padding: 0 var(--spacing-4);
  }
  
  /* Hero adjustments */
  .hero {
    min-height: 60vh;
    padding: var(--spacing-16) 0;
    margin-top: 70px;
  }
  
  .hero-content {
    padding: 0 var(--spacing-4);
  }
  
  .hero-title {
    font-size: var(--font-size-3xl);
    margin-bottom: var(--spacing-4);
  }
  
  .hero-subtitle {
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-6);
  }
  
  .cta-button {
    padding: var(--spacing-3) var(--spacing-6);
    font-size: var(--font-size-base);
  }
  
  /* Section titles */
  .section-title {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-8);
  }
  
  .section-subtitle {
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-8);
  }
  
  /* Grid adjustments */
  .portfolio-grid,
  .services-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-6);
  }
  
  /* Service cards */
  .service-card {
    padding: var(--spacing-6);
  }
  
  .service-icon {
    width: 60px;
    height: 60px;
  }
  
  .service-icon i {
    font-size: var(--font-size-2xl);
  }
  
  /* About section */
  .about-content {
    grid-template-columns: 1fr;
    gap: var(--spacing-8);
    text-align: center;
  }
  
  .about-image {
    order: -1;
  }
  
  .specialties-list {
    grid-template-columns: 1fr;
    text-align: left;
  }
  
  /* Contact section */
  .contact-info {
    grid-template-columns: 1fr;
    gap: var(--spacing-4);
  }
  
  .contact-item {
    padding: var(--spacing-4);
    text-align: center;
    flex-direction: column;
  }
  
  .contact-buttons {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-3);
  }
  
  .contact-btn {
    width: 100%;
    max-width: 280px;
    justify-content: center;
  }
  
  /* Footer */
  .footer-content {
    grid-template-columns: 1fr;
    gap: var(--spacing-6);
    text-align: center;
  }
  
  .social-links {
    justify-content: center;
  }
  
  /* Social section */
  .social-links-container {
    flex-direction: column;
    align-items: center;
  }
  
  .social-link-card {
    width: 100%;
    max-width: 300px;
  }
}

/* Very small mobile devices */
@media (max-width: 480px) {
  html {
    font-size: 13px;
  }
  
  .container {
    padding: 0 var(--spacing-3);
  }
  
  .section {
    padding: var(--spacing-10) 0;
  }
  
  .hero {
    min-height: 50vh;
    padding: var(--spacing-12) 0;
    margin-top: 60px;
  }
  
  .hero-title {
    font-size: var(--font-size-2xl);
    line-height: 1.2;
  }
  
  .hero-subtitle {
    font-size: var(--font-size-sm);
  }
  
  .cta-button {
    padding: var(--spacing-3) var(--spacing-5);
    font-size: var(--font-size-sm);
  }
  
  .section-title {
    font-size: var(--font-size-xl);
  }
  
  .portfolio-category,
  .service-card {
    margin: 0 var(--spacing-2);
  }
  
  .portfolio-slider {
    height: 200px;
  }
  
  .modal-content {
    margin: 10% auto;
    max-width: 95%;
    padding: var(--spacing-4);
  }
}

/* Landscape orientation on mobile */
@media (max-width: 767px) and (orientation: landscape) {
  .hero {
    min-height: 100vh;
    padding: var(--spacing-8) 0;
  }
  
  .hero-title {
    font-size: var(--font-size-3xl);
  }
  
  .section {
    padding: var(--spacing-8) 0;
  }
}

/* Touch device optimizations */
@media (hover: none) and (pointer: coarse) {
  /* Increase touch targets */
  .nav-menu a,
  .dropdown-item,
  .contact-btn,
  .portfolio-nav,
  .portfolio-dot {
    min-height: 44px;
    min-width: 44px;
  }
  
  /* Remove hover effects that don't work on touch */
  .service-card:hover,
  .portfolio-category:hover,
  .contact-item:hover {
    transform: none;
  }
  
  /* Simplify animations */
  .floating-element {
    animation-duration: 8s;
  }
  
  /* Make dropdowns always visible on mobile */
  .contact-dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    background: transparent;
    padding: 0;
  }
  
  .quick-contact {
    flex-direction: column;
    gap: var(--spacing-2);
  }
}

/* High DPI displays */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  /* Sharper borders and shadows */
  .service-card,
  .portfolio-category,
  .contact-item {
    border: 0.5px solid rgba(0, 0, 0, 0.1);
  }
}

/* Print styles */
@media print {
  * {
    background: transparent !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  .header,
  .floating-elements,
  .contact-buttons,
  .modal,
  .portfolio-nav,
  .portfolio-dots,
  .mobile-menu-btn {
    display: none !important;
  }
  
  .hero {
    height: auto;
    padding: var(--spacing-8) 0;
    background: white !important;
    color: black !important;
    margin-top: 0;
  }
  
  .section {
    page-break-inside: avoid;
    padding: var(--spacing-6) 0;
  }
  
  .portfolio-category,
  .service-card {
    page-break-inside: avoid;
    margin-bottom: var(--spacing-6);
  }
  
  .portfolio-slider {
    height: auto;
  }
  
  .portfolio-slide img {
    max-height: 200px;
    object-fit: contain;
  }
  
  a {
    text-decoration: underline;
  }
  
  a[href]:after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
  }
  
  .footer {
    background: white !important;
    color: black !important;
  }
}

/* Accessibility improvements */
@media (prefers-contrast: high) {
  :root {
    --primary-pink: #d1004f;
    --primary-gold: #b8860b;
    --text-primary: #000000;
    --text-secondary: #333333;
    --gray-100: #f0f0f0;
    --gray-200: #e0e0e0;
  }
  
  .hero {
    background: #000000;
    color: #ffffff;
  }
  
  .service-card,
  .portfolio-category {
    border: 2px solid #000000;
  }
  
  .btn,
  .contact-btn,
  .cta-button {
    border: 2px solid currentColor;
  }
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  
  .floating-elements {
    display: none;
  }
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
  :root {
    --white: #1a1a1a;
    --black: #ffffff;
    --gray-100: #2d2d2d;
    --gray-200: #3d3d3d;
    --gray-300: #4d4d4d;
    --gray-400: #6d6d6d;
    --gray-500: #8d8d8d;
    --gray-600: #9d9d9d;
    --gray-700: #adadad;
    --gray-800: #cdcdcd;
    --gray-900: #eeeeee;
    --text-primary: #ffffff;
    --text-secondary: #cccccc;
    --text-muted: #999999;
  }
  
  body {
    background-color: #1a1a1a;
    color: #ffffff;
  }
  
  .header {
    background: rgba(26, 26, 26, 0.95);
  }
  
  .service-card,
  .portfolio-category {
    background: #2d2d2d;
    border-color: #3d3d3d;
  }
  
  .contact-dropdown {
    background: #2d2d2d;
    border-color: #3d3d3d;
  }
  
  .footer {
    background: #0d0d0d;
  }
}

/* Performance optimizations for older devices */
@media (max-width: 768px) {
  /* Reduce complex animations */
  .floating-element {
    display: none;
  }
  
  /* Simplify shadows */
  .service-card,
  .portfolio-category {
    box-shadow: var(--shadow-md);
  }
  
  /* Reduce backdrop-filter usage */
  .header {
    backdrop-filter: none;
    background: rgba(255, 255, 255, 0.98);
  }
  
  .contact-btn {
    backdrop-filter: none;
  }
}

/* Ensure all sections are visible on mobile */
@media (max-width: 768px) {
  .services,
  .portfolio,
  .about,
  .contact,
  .social-section,
  .footer {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  
  /* Make sure content flows properly */
  main {
    display: block;
    width: 100%;
    overflow-x: hidden;
  }
  
  /* Prevent any section from being hidden */
  section {
    display: block !important;
    min-height: auto;
  }
}