/* ============================================
   ELDORADO — RESPONSIVE STYLES
   Mobile-first responsive design system
   ============================================ */

/* --- Tablet (max-width: 1024px) --- */
@media (max-width: 1024px) {
  :root {
    --header-height: 70px;
  }

  .main-nav {
    display: none;
  }

  .mobile-toggle {
    display: flex;
  }

  /* Mobile nav fixes */
  .mobile-nav {
    padding-top: calc(var(--header-height) + var(--space-4));
    padding-bottom: var(--space-8);
    gap: var(--space-1);
    justify-content: flex-start;
    -webkit-overflow-scrolling: touch;
  }

  .mobile-nav a {
    font-size: var(--text-base);
    padding: var(--space-2) var(--space-4);
    flex-shrink: 0;
  }

  .mobile-nav .btn {
    margin-top: var(--space-3);
    flex-shrink: 0;
  }

  .mobile-nav .mobile-lang {
    margin-top: var(--space-4);
    flex-shrink: 0;
    padding-bottom: var(--space-4);
  }

  /* Press mentions - tablet: 2 columns */
  .press-mentions > div[style*="grid-template-columns"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .services-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  .trust-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8);
  }

  .hero-stats-inner {
    gap: var(--space-8);
    flex-wrap: wrap;
  }

  .contact-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .process-steps {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .process-steps::before {
    display: none;
  }

  .benefits-list {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .related-services-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .target-audience-grid {
    grid-template-columns: 1fr;
  }

  .consultation-wrapper {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .timeline::before {
    left: 20px;
  }

  .timeline-item,
  .timeline-item:nth-child(even) {
    padding-left: 60px;
    padding-right: 0;
    justify-content: flex-start;
  }

  [dir="rtl"] .timeline-item,
  [dir="rtl"] .timeline-item:nth-child(even) {
    padding-left: 0;
    padding-right: 60px;
  }

  .timeline-item::before {
    left: 20px;
    transform: translateX(-50%);
  }

  [dir="rtl"] .timeline::before {
    left: auto;
    right: 20px;
  }

  [dir="rtl"] .timeline-item::before {
    left: auto;
    right: 20px;
  }

  .timeline-content {
    margin: 0;
    max-width: 100%;
  }

  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }

  .slider-arrow {
    display: none;
  }

  /* Consultation page - contact grid */
  .contact-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-6) !important;
  }
}

/* --- Mobile (max-width: 768px) --- */
@media (max-width: 768px) {
  :root {
    --header-height: 64px;
  }

  .section {
    padding: var(--space-12) 0;
  }

  .section-sm {
    padding: var(--space-8) 0;
  }

  .container,
  .container-narrow {
    padding: 0 var(--space-4);
  }

  h1 { font-size: var(--text-4xl); }
  h2 { font-size: var(--text-3xl); }
  h3 { font-size: var(--text-2xl); }

  /* Mobile Nav - ensure scrolling and all items visible */
  .mobile-nav {
    padding-top: calc(var(--header-height) + var(--space-2));
    padding-bottom: calc(var(--space-8) + env(safe-area-inset-bottom, 0px));
    gap: 0;
    justify-content: flex-start;
    align-items: stretch;
  }

  .mobile-nav a {
    font-size: var(--text-sm);
    padding: var(--space-2) var(--space-4);
    max-width: 100%;
    text-align: center;
  }

  .mobile-nav .btn {
    margin-top: var(--space-3);
    max-width: 280px;
    align-self: center;
  }

  .mobile-nav .mobile-lang {
    margin-top: var(--space-3);
    justify-content: center;
    padding-bottom: var(--space-4);
  }

  /* Press mentions - mobile: 1 column */
  .press-mentions > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  /* Press card images shorter on mobile */
  .press-card > div:first-child {
    height: 220px !important;
  }

  /* Hero */
  .hero-slider {
    min-height: 550px;
  }

  .hero-slide-content h1 {
    font-size: var(--text-4xl);
    max-width: 100%;
  }

  .hero-slide-content .hero-subtitle {
    font-size: var(--text-base);
    max-width: 100%;
  }

  .hero-cta-group {
    flex-direction: column;
    gap: var(--space-3);
  }

  .hero-cta-group .btn {
    width: 100%;
    justify-content: center;
  }

  .hero-stats-inner {
    flex-direction: column;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-4);
    align-items: flex-start;
  }

  /* Slider dots - keep visible above the tall stats bar on mobile */
  .slider-nav {
    bottom: auto;
    top: 55%;
    z-index: 6;
  }

  /* Services */
  .services-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .service-card {
    padding: var(--space-6);
  }

  /* Trust */
  .trust-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .footer-bottom {
    flex-direction: column;
    gap: var(--space-3);
    text-align: center;
  }

  .footer-bottom-links {
    flex-wrap: wrap;
    justify-content: center;
  }

  /* Contact */
  .contact-info-grid {
    grid-template-columns: 1fr;
  }

  /* Process */
  .process-steps {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  /* Benefits */
  .benefits-list {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  /* Target Audience */
  .target-audience-grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  /* Blog */
  .blog-grid {
    grid-template-columns: 1fr;
  }

  /* Related Services */
  .related-services-grid {
    grid-template-columns: 1fr;
  }

  /* Timeline */
  .timeline::before {
    left: 15px;
  }

  .timeline-item,
  .timeline-item:nth-child(even) {
    padding-left: 50px;
    padding-right: 0;
  }

  [dir="rtl"] .timeline-item,
  [dir="rtl"] .timeline-item:nth-child(even) {
    padding-left: 0;
    padding-right: 50px;
  }

  .timeline-item::before {
    left: 15px;
    width: 12px;
    height: 12px;
  }

  [dir="rtl"] .timeline::before {
    left: auto;
    right: 15px;
  }

  [dir="rtl"] .timeline-item::before {
    left: auto;
    right: 15px;
  }

  .timeline-content {
    padding: var(--space-4);
  }

  /* Grid */
  .grid-3 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }

  /* Page Hero */
  .page-hero {
    padding: calc(var(--header-height) + var(--space-10)) 0 var(--space-10);
  }

  /* Buttons */
  .btn-lg {
    padding: var(--space-3) var(--space-6);
    font-size: var(--text-sm);
  }

  /* Section Title */
  .section-title {
    margin-bottom: var(--space-8);
  }

  /* Form Row */
  .form-row {
    grid-template-columns: 1fr !important;
  }

  /* About page grid */
  .grid[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }

  /* WhatsApp Floating */
  .whatsapp-float {
    bottom: var(--space-4);
    right: var(--space-4);
    width: 50px;
    height: 50px;
  }

  [dir="rtl"] .whatsapp-float {
    right: auto;
    left: var(--space-4);
  }

  .whatsapp-float svg {
    width: 24px;
    height: 24px;
  }

  /* Header logo */
  .header-logo img {
    height: 42px;
  }

  .site-header.scrolled .header-logo img {
    height: 38px;
  }

  /* Hide header actions on mobile (available in mobile nav) */
  .header-actions {
    display: none;
  }

  /* Map */
  .map-container {
    height: 300px;
  }

  /* Consultation Wrapper */
  .consultation-wrapper {
    grid-template-columns: 1fr;
  }

  /* Consultation page - contact grid to single column */
  .contact-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-4) !important;
  }

  /* Consultation form wrapper - smaller padding on mobile */
  .contact-form-wrapper {
    padding: var(--space-4) !important;
  }

  /* Stepper on mobile */
  .form-stepper {
    gap: 0;
  }
  .stepper-label {
    font-size: 0.65rem !important;
    white-space: normal !important;
    text-align: center;
    max-width: 60px;
  }
  .stepper-circle {
    width: 36px !important;
    height: 36px !important;
    font-size: 0.85rem !important;
  }
  .stepper-line {
    top: -8px !important;
  }

  /* Form navigation buttons - stack on very small screens */
  .form-nav {
    flex-wrap: wrap;
  }
  .btn-step {
    padding: 0.75rem 1.25rem !important;
    font-size: 0.85rem !important;
  }

  /* Sidebar feature items */
  .sidebar-feature-icon {
    min-width: 36px !important;
    width: 36px !important;
    height: 36px !important;
  }

  /* Contact page - grid to single column */
  .grid[style*="1.2fr 0.8fr"],
  .grid[style*="1.2fr"] {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
}

/* --- Small Mobile (max-width: 480px) --- */
@media (max-width: 480px) {
  .hero-slider {
    min-height: 500px;
  }

  .hero-slide-content h1 {
    font-size: var(--text-3xl);
  }

  .hero-slide-content .hero-subtitle {
    font-size: var(--text-sm);
  }

  .service-card {
    padding: var(--space-5);
  }

  .service-card-icon {
    width: 52px;
    height: 52px;
  }

  .header-logo img {
    height: 36px;
  }

  .btn {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-xs);
  }

  .btn-lg {
    padding: var(--space-3) var(--space-5);
    font-size: var(--text-sm);
  }

  .news-badge {
    font-size: 0.65rem;
    padding: var(--space-1) var(--space-3);
  }

  .blog-categories {
    gap: var(--space-1);
  }

  .blog-category-btn {
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
  }

  /* Consultation form - tighter on very small screens */
  .contact-form-wrapper {
    padding: var(--space-3) !important;
  }

  /* Review summary - single column on small mobile */
  #review-summary > div {
    grid-template-columns: 1fr !important;
  }

  /* Stepper even smaller */
  .stepper-label {
    font-size: 0.6rem !important;
    max-width: 50px;
  }
  .stepper-circle {
    width: 32px !important;
    height: 32px !important;
    font-size: 0.75rem !important;
  }

  /* Form step headings */
  .form-step h2 {
    font-size: var(--text-xl) !important;
  }

  /* Sidebar cards padding */
  .reveal-delay-1 > div {
    padding: 1.25rem !important;
  }
}

/* --- Print --- */
@media print {
  .site-header,
  .site-footer,
  .whatsapp-float,
  .slider-arrow,
  .slider-nav {
    display: none !important;
  }

  .hero-slider {
    height: auto;
    min-height: auto;
  }

  .section {
    padding: 1rem 0;
  }

  body {
    color: #000;
  }
}
