/* ===================================================
   TOYOSOFT — RESPONSIVE STYLES
   =================================================== */

/* ===================================================
   LARGE DESKTOPS (≤ 1280px)
   =================================================== */
@media (max-width: 1280px) {
  .hero-inner { gap: 40px; }
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 36px; }
}

/* ===================================================
   LAPTOPS / TABLETS (≤ 1024px)
   =================================================== */
@media (max-width: 1024px) {

  :root { --section-py: 80px; }

  /* Nav */
  .nav-links, .btn-nav-cta { display: none; }
  .hamburger { display: flex; }

  /* Hero */
  .hero-inner { grid-template-columns: 1fr; gap: 48px; }
  .hero-visual { display: none; }
  .hero { text-align: center; min-height: auto; padding: 100px 0 80px; }
  .hero-cta { justify-content: center; }
  .hero-stats { justify-content: center; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr); }

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

  /* Projects */
  .projects-grid { grid-template-columns: repeat(2, 1fr); }

  /* Featured */
  .featured-grid { grid-template-columns: repeat(2, 1fr); }

  /* Tech Grid */
  .tech-grid { grid-template-columns: repeat(4, 1fr); }

  /* Process */
  .process-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .process-grid::before { display: none; }

  /* About */
  .about-story { grid-template-columns: 1fr; gap: 48px; }
  .about-image-block { max-width: 480px; margin: 0 auto; }

  /* Values */
  .values-grid { grid-template-columns: repeat(2, 1fr); }

  /* Team */
  .team-grid { grid-template-columns: repeat(2, 1fr); }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }

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

  /* Contact */
  .contact-layout { grid-template-columns: 1fr; gap: 48px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .footer-brand { grid-column: 1 / -1; }
}

/* ===================================================
   TABLETS / LARGE PHONES (≤ 768px)
   =================================================== */
@media (max-width: 768px) {

  :root { --section-py: 64px; }

  h2 { font-size: clamp(1.7rem, 5vw, 2.2rem); }

  /* Stats */
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stat-item { padding: 32px 20px; }

  /* Grids */
  .services-grid,
  .projects-grid,
  .featured-grid,
  .testimonials-grid,
  .team-grid,
  .values-grid,
  .benefits-grid { grid-template-columns: 1fr; }

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

  /* Process */
  .process-grid { grid-template-columns: 1fr; }

  /* Job Card */
  .job-card { flex-direction: column; align-items: flex-start; gap: 16px; }
  .job-actions { width: 100%; }
  .job-actions .btn { flex: 1; justify-content: center; }

  /* Contact Form */
  .contact-form-wrapper { padding: 28px 20px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }

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

  /* CTA Banner */
  .cta-banner { padding: 60px 0; }

  /* Page Hero */
  .page-hero { padding: 80px 0 52px; }

  /* Hero */
  .hero { padding: 90px 0 60px; }
  .hero-stats { gap: 24px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .footer-legal { justify-content: center; }

  /* Section header */
  .section-header { margin-bottom: 48px; }
}

/* ===================================================
   PHONES (≤ 480px)
   =================================================== */
@media (max-width: 480px) {

  :root { --section-py: 52px; }

  .container { padding: 0 16px; }

  /* Stats */
  .stats-grid { grid-template-columns: 1fr; }

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

  .footer-grid { grid-template-columns: 1fr; }

  .filter-tabs { gap: 6px; }
  .filter-btn { padding: 7px 16px; font-size: 0.82rem; }

  .btn { padding: 12px 22px; font-size: 0.9rem; }

  .hero-stats { flex-direction: column; gap: 16px; }

  .form-row { grid-template-columns: 1fr; }

  .about-image-main { height: 300px; }

  /* Nav inner */
  .nav-inner { padding: 0 16px; }

  /* Mobile menu */
  .mobile-menu { padding: 16px 16px 24px; }
}

/* ===================================================
   PRINT STYLES
   =================================================== */
@media print {
  .navbar, .footer, .cta-banner, .hamburger, .mobile-menu, .theme-toggle { display: none !important; }
  .page-content { padding-top: 0; }
  body { color: #000; background: #fff; }
}
