@media (max-width: 768px) {
  .display-5 {
    font-size: 1.8rem;
  }

  .display-6 {
    font-size: 2rem;
  }

  .icon-circle {
    width: 75px;
    height: 75px;
  }

  .icon-circle .fa-3x {
    font-size: 2em;
  }

  .compatibilidad-circle {
    width: 110px;
    height: 110px;
  }

  .likert-btn {
    min-height: 65px;
    padding: 8px 6px;
  }

  .likert-btn small {
    font-size: 0.65rem;
    line-height: 1.1;
  }

  .likert-btn .fw-bold {
    font-size: 1.1rem;
  }

  .btn-lg {
    font-size: 0.95rem;
    padding: 12px 20px;
  }

  .card-body {
    padding: 1.25rem !important;
  }

  .navbar-brand {
    font-size: 1.2rem;
  }

  h1 {
    font-size: 1.6rem;
  }

  h2 {
    font-size: 1.3rem;
  }

  h4 {
    font-size: 1.1rem;
  }

  .progresoText {
    font-size: 0.8rem;
    padding: 4px 10px;
  }

  #detalleRecomendacion .col-md-4 {
    margin-bottom: 8px;
  }

  canvas {
    max-height: 220px;
  }

  .table {
    font-size: 0.85rem;
  }

  .table th {
    font-size: 0.75rem;
  }

  .table td {
    padding: 0.5rem;
  }

  .row.g-3 > [class*="col-"] {
    margin-bottom: 12px;
  }

  .container {
    padding-left: 12px;
    padding-right: 12px;
  }
}

@media (max-width: 576px) {
  .likert-btn {
    min-height: 58px;
    padding: 6px 4px;
  }

  .likert-btn small {
    display: none;
  }

  .likert-btn .fw-bold {
    font-size: 1.3rem;
  }

  .btn-lg {
    font-size: 0.9rem;
    padding: 10px 16px;
  }

  .compatibilidad-circle {
    width: 100px;
    height: 100px;
  }

  .compatibilidad-circle .display-6 {
    font-size: 1.5rem;
  }

  .badges .badge {
    font-size: 0.7rem;
    padding: 4px 8px;
  }

  .progress {
    height: 6px !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .likert-btn {
    min-height: 75px;
  }

  .container {
    max-width: 960px;
  }
}

@media (min-width: 1025px) {
  .container {
    max-width: 900px;
  }

  .likert-btn:hover small {
    display: block !important;
  }
}

@media (display-mode: standalone) {
  body {
    padding-top: env(safe-area-inset-top, 0);
    padding-bottom: env(safe-area-inset-bottom, 0);
  }

  .navbar {
    padding-top: calc(0.5rem + env(safe-area-inset-top, 0));
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

@media print {
  .navbar, footer, .btn {
    display: none !important;
  }

  .card {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
  }

  body {
    background: white !important;
  }
}
