/*
  FOXLAW mobile overrides
  Added as a clean extension layer so the base stylesheet stays untouched.
  This file only contains responsive refinements for small screens.
*/

@media (max-width: 820px) {
  main {
    padding: 112px 0 56px;
  }

  .container {
    width: 100%;
    max-width: none;
    padding: 0 1.5rem;
  }

  .hero-grid {
    gap: 2rem;
  }

  .hero-copy {
    max-width: 100%;
  }

  .hero-copy p {
    margin-top: 0.75rem;
    margin-bottom: 1.5rem;
    max-width: 100%;
  }

  .hero-points {
    gap: 0.8rem;
    margin: 0 0 1.75rem;
  }

  .hero-points span,
  .panel-list span {
    min-height: 46px;
    padding: 0.8rem 1.2rem;
    font-size: 0.95rem;
    line-height: 1.25;
  }

  .hero-actions {
    margin-bottom: 2.5rem;
  }

  .hero-actions .btn,
  .functions-cta .btn {
    width: 100%;
    min-height: 58px;
    font-size: 1.05rem;
  }

  .functions-section {
    padding-top: 2.75rem;
  }

  .section-head {
    max-width: 100%;
    margin-bottom: 1.5rem;
  }

  .section-head span {
    margin-bottom: 0.85rem;
  }

  .section-head h2 {
    font-size: clamp(2.25rem, 9vw, 3.2rem);
    line-height: 1.02;
    margin-bottom: 1rem;
  }

  .section-head p,
  .functions-cta p,
  .function-card p {
    font-size: 1.02rem;
    line-height: 1.82;
  }

  .functions-panel {
    padding: 1.5rem;
    border-radius: 28px;
  }

  .panel-top {
    margin-bottom: 1.1rem;
  }

  .panel-top strong {
    font-size: 1.15rem;
  }

  .panel-list {
    gap: 0.8rem;
    margin-bottom: 1.35rem;
  }

  .function-grid {
    gap: 0.95rem;
  }

  .function-card {
    padding: 1.15rem;
    border-radius: 22px;
  }

  .functions-cta {
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
  }
}

@media (max-width: 640px) {
  nav {
    padding: 0 1.5rem;
  }

  .logo-img {
    height: 48px;
  }

  .hamburger {
    width: 40px;
    height: 40px;
  }

  .container {
    padding: 0 1.25rem;
  }

  .hero-grid {
    gap: 1.75rem;
  }

  .hero-copy h1 {
    font-size: clamp(2.8rem, 16vw, 4.3rem);
    line-height: 0.94;
    letter-spacing: -0.045em;
    margin-bottom: 1rem;
  }

  .hero-copy p {
    font-size: 1rem;
    line-height: 1.8;
    margin-bottom: 1.35rem;
  }

  .hero-points {
    gap: 0.75rem;
    margin-bottom: 1.5rem;
  }

  .hero-points span,
  .panel-list span {
    width: fit-content;
    max-width: 100%;
    min-height: 44px;
    padding: 0.78rem 1.12rem;
    font-size: 0.92rem;
  }

  .hero-actions {
    margin-bottom: 2.25rem;
  }

  .functions-section {
    padding-top: 2.5rem;
  }

  .section-head h2 {
    font-size: clamp(2rem, 12vw, 2.9rem);
  }

  .section-head p,
  .functions-cta p,
  .function-card p {
    font-size: 0.98rem;
    line-height: 1.76;
  }

  .functions-panel {
    padding: 1.25rem;
    border-radius: 24px;
  }

  .panel-list {
    gap: 0.7rem;
    margin-bottom: 1.15rem;
  }

  .function-card {
    padding: 1.05rem;
    border-radius: 20px;
  }
}

@media (max-width: 420px) {
  nav {
    padding: 0 1.1rem;
  }

  .container {
    padding: 0 1rem;
  }

  .hero-copy h1 {
    font-size: clamp(2.45rem, 15vw, 3.4rem);
  }

  .hero-copy p {
    font-size: 0.96rem;
    line-height: 1.72;
  }

  .hero-points span,
  .panel-list span {
    min-height: 42px;
    padding: 0.74rem 1rem;
    font-size: 0.9rem;
  }

  .hero-actions .btn,
  .functions-cta .btn {
    min-height: 56px;
    font-size: 1rem;
  }

  .functions-section {
    padding-top: 2.25rem;
  }

  .section-head h2 {
    font-size: clamp(1.9rem, 11vw, 2.45rem);
  }

  .functions-panel {
    padding: 1.1rem;
    border-radius: 22px;
  }
}
