/* ========== ZONA PRIVADA · SOLO MÓVIL ========== */
/* Extraído desde zonaprivada.css para mantener separado el responsive móvil. */

@media (max-width: 767px) {
  /* Chatbot oculto en móvil */
  #botonIA,
  #chatIA,
  #botonEnviarIA {
    display: none !important;
  }

  /* Oculta el sidebar completamente */
  #sidebarMenu {
    display: none !important;
  }
  /* El contenido ocupa todo el ancho sin dejar margen lateral */
  main {
    margin-left: 0 !important;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  /* Navbar más compacto y limpio */
  .navbar {
    padding: 0.4rem 1rem;
  }
  .navbar-brand,
  .navbar .h6 {
    font-size: 0.95rem;
  }
  .navbar .btn {
    padding: 0.3rem 0.7rem;
    font-size: 0.9rem;
  }
  .navbar .fa-wifi {
    font-size: 1rem;
    margin-right: 0.3rem;
  }
  /* Tarjetas de cursos y estadísticas más compactas */
  .course-card {
    font-size: 0.95rem;
  }
  .course-card .card-body {
    padding: 1rem;
  }
  .course-card i {
    font-size: 2.2rem;
  }
  .section-title {
    font-size: 1.2rem;
    text-align: center;
  }
  /* Ajustes para las cards de estadísticas */
  .card .fw-bold {
    font-size: 1.3rem;
  }
  /* Ajuste en los botones de descarga y acciones */
  .btn-sm {
    font-size: 0.85rem;
    padding: 0.35rem 0.7rem;
  }
  /* El acordeón ocupa más espacio visual */
  .accordion-button {
    font-size: 0.95rem;
    padding: 0.75rem 1rem;
  }
  .accordion-body {
    font-size: 0.9rem;
  }
  /* Footer centrado y compacto */
  footer {
    font-size: 0.75rem;
    padding: 1rem;
  }
  #sugerenciasDropdown .list-group-item {
    cursor: pointer;
    font-size: 0.9rem;
    padding: 0.45rem 1rem;
  }
  #sugerenciasDropdown .list-group-item:hover {
    background-color: #eaf6ff;
  }
  .navbar-gradient {
    background: linear-gradient(90deg, #007bff, #0056b3);
  }
  #sugerenciasDropdown {
    font-size: 0.85rem;
  }
}

@media (max-width: 767px) {
  #stats-impacto {
    padding: 2rem 0;
  }

  .stats-card {
    padding: 1.25rem 1rem !important;
    border-radius: 16px !important;
  }

  .stats-card .stats-icon {
    width: 50px !important;
    height: 50px !important;
    font-size: 1.2rem !important;
  }

  .stats-card h3 {
    font-size: 1.75rem !important;
  }

  .stats-card p.text-muted {
    font-size: 0.65rem !important;
  }
}

@media (max-width: 767px) {
  .alert {
    padding: 0.875rem 1rem !important;
    font-size: 0.85rem !important;
    border-radius: 10px !important;
  }

  .alert i {
    font-size: 1rem;
  }
}

@media (max-width: 767px) {
  .card, .course-card, .tech-card {
    border-radius: 12px !important;
  }
  .tech-grid .card {
    min-height: 120px !important;
    padding: 1rem 0.75rem !important;
  }
  .tech-grid .card i[class*="devicon"] {
    font-size: 2.2rem !important;
  }
  .ut-icon {
    width: 34px !important;
    height: 34px !important;
  }
}

@media (max-width: 767px) {
  :root {
    --text-4xl: 1.75rem;
    --text-3xl: 1.5rem;
    --text-2xl: 1.25rem;
    --text-xl: 1.125rem;
  }

  body {
    font-size: 0.9375rem;
  }

  h1, .h1 {
    letter-spacing: -0.02em;
  }

  p {
    line-height: 1.65;
  }
}

@media (max-width: 767px) {
  .accordion-item {
    border-radius: 10px !important;
  }

  .accordion-button {
    padding: 0.875rem 1rem !important;
    font-size: 0.9rem !important;
    border-radius: 9px !important;
  }

  .accordion .accordion-body {
    padding: 1rem !important;
  }
}

@media (max-width: 767px) {
  .form-control:not(.navbar .form-control):not(#chat-input),
  .form-select,
  input[type="text"]:not(.form-control):not(.navbar input),
  input[type="email"]:not(.form-control):not(.navbar input),
  textarea:not(.form-control):not(#chat-input) {
    font-size: 16px !important; /* Evita zoom en iOS */
  }
}

@media (max-width: 767px) {
  .dropdown-menu {
    border-radius: 10px !important;
    padding: 0.375rem !important;
  }

  .dropdown-menu .dropdown-item {
    padding: 0.75rem 0.875rem !important;
    font-size: 0.9rem !important;
  }

  /* Full width en móvil para dropdowns del navbar */
  .navbar .dropdown-menu {
    position: fixed !important;
    left: 0.75rem !important;
    right: 0.75rem !important;
    width: calc(100% - 1.5rem) !important;
    max-height: 70vh;
    overflow-y: auto;
  }
}

@media (max-width: 767px) {
  .badge {
    font-size: 0.7rem !important;
    padding: 0.3rem 0.6rem !important;
  }

  .badge.rounded-pill {
    padding: 0.3rem 0.7rem !important;
  }
}

@media (max-width: 767.98px) {
  .preview-modal-dialog {
    width: 100%;
    max-width: 100%;
    height: auto;
    margin: 0;
  }

  .preview-modal-window {
    border-radius: 0 !important;
    min-height: 100vh;
  }

  .preview-modal-header {
    cursor: default;
    padding: 0.95rem 0.9rem;
  }

  .preview-modal-meta {
    gap: 0.4rem;
  }

  .preview-modal-chip--path {
    max-width: calc(100vw - 10rem);
  }

  .preview-modal-body {
    height: calc(100vh - 92px);
  }

  .preview-resize-handle {
    display: none;
  }
}

@media (max-width: 767.98px) {
  body.mobile-practice-mode {
    background:
      radial-gradient(circle at top left, rgba(14, 165, 233, 0.12), transparent 40%),
      linear-gradient(180deg, #eff6ff 0%, #f8fafc 28%, #eef2ff 100%);
  }

  body.mobile-practice-mode .navbar {
    display: none !important;
  }

  body.mobile-practice-mode .navbar .position-relative.flex-grow-1,
  body.mobile-practice-mode #btnAdminNavbar,
  body.mobile-practice-mode #btnNotificacion,
  body.mobile-practice-mode [data-bs-target="#offcanvasSidebar"],
  body.mobile-practice-mode #offcanvasSidebar,
  body.mobile-practice-mode #sidebarMenu,
  body.mobile-practice-mode #btnToggleSidebar,
  body.mobile-practice-mode #botonIA,
  body.mobile-practice-mode #chatIA,
  body.mobile-practice-mode footer {
    display: none !important;
  }

  body.mobile-practice-mode .navbar .dropdown:first-of-type {
    display: none !important;
  }

  body.mobile-practice-mode main {
    width: 100% !important;
    margin-left: 0 !important;
    padding: 0.75rem 0.75rem calc(6.75rem + env(safe-area-inset-bottom)) !important;
  }

  body.mobile-practice-mode main > section:not(.mobile-practice-target) {
    display: none !important;
  }

  body.mobile-practice-mode .mobile-practice-target {
    display: none !important;
    margin-top: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.mobile-practice-mode .mobile-practice-target.mobile-practice-active {
    display: block !important;
  }

  /* Forzar visibilidad de elementos AOS dentro de la sección activa.
     En carga directa en móvil, AOS no detecta elementos ocultos y los deja
     con opacity:0 / transform indefinidamente. Esta regla lo sobreescribe. */
  body.mobile-practice-mode .mobile-practice-target.mobile-practice-active[data-aos],
  body.mobile-practice-mode .mobile-practice-target.mobile-practice-active [data-aos] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  body.mobile-practice-mode .mobile-practice-nav-shell {
    display: block;
    position: fixed;
    left: 0.8rem;
    right: 0.8rem;
    bottom: calc(0.8rem + env(safe-area-inset-bottom));
    z-index: 1090;
    margin: 0;
    padding: 0.5rem;
    background: rgba(15, 23, 42, 0.92);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 1.35rem;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.28);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow: hidden;
  }

  body.mobile-practice-mode .mobile-practice-nav-tabs {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.28rem;
    margin-top: 0;
  }

  body.mobile-practice-mode .mobile-practice-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.22rem;
    min-height: 56px;
    border: 0;
    border-radius: 1rem;
    padding: 0.55rem 0.2rem;
    background: transparent;
    color: rgba(226, 232, 240, 0.74);
    font-size: 0.75rem;
    font-weight: 700;
    box-shadow: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, color 0.18s ease;
  }

  body.mobile-practice-mode .mobile-practice-tab:active {
    transform: scale(0.98);
  }

  body.mobile-practice-mode .mobile-practice-tab.active {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 14px 24px rgba(37, 99, 235, 0.28);
  }

  body.mobile-practice-mode .mobile-practice-tab i {
    font-size: 0.95rem;
  }

  body.mobile-practice-mode .mobile-practice-tab span {
    font-size: 0.62rem;
    letter-spacing: 0.01em;
  }

  body.mobile-practice-mode #web-practica > :not(.mobile-practice-shell),
  body.mobile-practice-mode #java-instrucciones > :not(.mobile-practice-shell),
  body.mobile-practice-mode #swing-instrucciones > :not(.mobile-practice-shell),
  body.mobile-practice-mode #php-instrucciones > :not(.mobile-practice-shell),
  body.mobile-practice-mode #sql-crud > :not(.mobile-practice-shell),
  body.mobile-practice-mode #practica-ia > :not(.mobile-practice-shell) {
    display: none !important;
  }

  body.mobile-practice-mode #python-instrucciones > h2,
  body.mobile-practice-mode #python-instrucciones > .python-intro-grid,
  body.mobile-practice-mode #python-instrucciones > #accordionCursoPython {
    display: none !important;
  }

  body.mobile-practice-mode #python-instrucciones > #accordionPracticaInteractiva {
    display: block !important;
    margin: 0 !important;
  }

  body.mobile-practice-mode .mobile-practice-shell {
    border-radius: 1.15rem !important;
    border: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.08) !important;
    background: #ffffff !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb.mobile-practice-shell {
    background:
      radial-gradient(circle at top right, rgba(34, 211, 238, 0.14), transparent 36%),
      linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
    border-color: rgba(125, 211, 252, 0.8) !important;
  }

  body.mobile-practice-mode #accordionPracticaJavaCurso.mobile-practice-shell {
    background:
      radial-gradient(circle at top right, rgba(248, 113, 113, 0.14), transparent 36%),
      linear-gradient(180deg, #ffffff 0%, #fffaf9 100%) !important;
    border-color: rgba(252, 165, 165, 0.78) !important;
  }

  body.mobile-practice-mode #accordionPracticaSwing.mobile-practice-shell {
    background:
      radial-gradient(circle at top right, rgba(249, 115, 22, 0.14), transparent 36%),
      linear-gradient(180deg, #ffffff 0%, #fffaf5 100%) !important;
    border-color: rgba(253, 186, 116, 0.82) !important;
  }

  body.mobile-practice-mode #accordionPracticaPHP.mobile-practice-shell {
    background:
      radial-gradient(circle at top right, rgba(129, 140, 248, 0.15), transparent 36%),
      linear-gradient(180deg, #ffffff 0%, #fcfcff 100%) !important;
    border-color: rgba(165, 180, 252, 0.82) !important;
  }

  body.mobile-practice-mode #collapsePracticaWeb,
  body.mobile-practice-mode #collapsePracticaJavaCurso,
  body.mobile-practice-mode #collapsePracticaSwing,
  body.mobile-practice-mode #collapsePracticaPHP,
  body.mobile-practice-mode #collapsePracticaInteractiva {
    border-top: 0 !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb > .zona-practica-header,
  body.mobile-practice-mode #accordionPracticaJavaCurso > .zona-practica-header {
    padding: 0.9rem 1rem;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    pointer-events: none;
    cursor: default;
  }

  body.mobile-practice-mode #accordionPracticaWeb > .zona-practica-header {
    background: linear-gradient(135deg, #0f172a 0%, #155e75 100%);
  }

  body.mobile-practice-mode #accordionPracticaJavaCurso > .zona-practica-header {
    background: linear-gradient(135deg, #111827 0%, #991b1b 100%);
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-title h5,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-title h5 {
    margin: 0;
    font-size: 0.98rem;
    color: #fff;
    line-height: 1.15;
  }

  body.mobile-practice-mode .zona-practica-header .zp-title small,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button small,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button .text-muted,
  body.mobile-practice-mode #sql-crud .accordion-button small,
  body.mobile-practice-mode #sql-crud .accordion-button .text-muted {
    display: none !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-actions .btn,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-actions .btn {
    display: none !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb .badge-live,
  body.mobile-practice-mode #accordionPracticaJavaCurso .badge-live {
    background: rgba(255, 255, 255, 0.14) !important;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.12);
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-item {
    border: 0 !important;
    border-radius: inherit !important;
    overflow: hidden;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva.python-mobile-shell {
    background:
      radial-gradient(circle at top right, rgba(59, 130, 246, 0.12), transparent 34%),
      linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
    border-color: rgba(134, 239, 172, 0.85) !important;
  }

  body.mobile-practice-mode #sql-crud .sql-mobile-shell {
    background:
      radial-gradient(circle at top right, rgba(250, 204, 21, 0.16), transparent 32%),
      linear-gradient(180deg, #ffffff 0%, #fffdf5 100%) !important;
    border-color: rgba(250, 204, 21, 0.72) !important;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button {
    padding: 0.95rem 1rem;
    font-size: 0.97rem;
    font-weight: 800;
    color: #0f172a;
    background: linear-gradient(135deg, #ecfdf5 0%, #dbeafe 100%);
    box-shadow: none;
    pointer-events: none;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button:not(.collapsed) {
    color: #0f172a;
    background: linear-gradient(135deg, #eff6ff 0%, #bfdbfe 100%);
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button:focus {
    box-shadow: none;
  }

  body.mobile-practice-mode .python-mobile-intro {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea,
  body.mobile-practice-mode #practicaJavaArea,
  body.mobile-practice-mode #practicaPythonArea,
  body.mobile-practice-mode #practica-ia .mobile-practice-shell {
    padding: 0.9rem !important;
  }

  body.mobile-practice-mode #practicaWebArea > p,
  body.mobile-practice-mode #practicaJavaArea > p,
  body.mobile-practice-mode #practicaPythonArea > p {
    font-size: 0.83rem;
  }

  body.mobile-practice-mode #practicaWebArea > p,
  body.mobile-practice-mode #practicaJavaArea > p {
    display: none !important;
  }

  body.mobile-practice-mode #sql-crud #accordionSqlTeoria,
  body.mobile-practice-mode #sql-crud .sql-mobile-header {
    display: none !important;
  }

  body.mobile-practice-mode #sql-crud {
    scroll-margin-top: 0.5rem;
    margin-left: -0.75rem !important;
    margin-right: -0.75rem !important;
  }

  body.mobile-practice-mode #sql-crud .sql-mobile-shell {
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  body.mobile-practice-mode #sql-crud .sql-platform-embed-card {
    position: relative;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 1.3rem !important;
    border: 1px solid rgba(250, 204, 21, 0.28) !important;
    background:
      radial-gradient(circle at top right, rgba(250, 204, 21, 0.2), transparent 32%),
      linear-gradient(180deg, #fffef7 0%, #fff7db 100%) !important;
    box-shadow: 0 18px 34px rgba(161, 98, 7, 0.12) !important;
    overflow: hidden !important;
  }

  body.mobile-practice-mode #sql-crud .sql-platform-embed-head {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 0 !important;
    padding: 1rem 1rem 1.05rem;
    border-bottom: 0;
    background:
      radial-gradient(circle at top right, rgba(250, 204, 21, 0.08), transparent 35%);
  }

  body.mobile-practice-mode #sql-crud .sql-platform-frame-wrap {
    display: none !important;
  }

  body.mobile-practice-mode #sqlPlatformFrame {
    display: none !important;
  }

  body.mobile-practice-mode #sqlPlatformEmbedCard {
    position: relative;
    isolation: isolate;
  }

  body.mobile-practice-mode #sql-crud .sql-platform-kicker {
    margin-bottom: 0.55rem;
    background: rgba(234, 179, 8, 0.14);
    color: #a16207;
    border: 1px solid rgba(234, 179, 8, 0.16);
  }

  body.mobile-practice-mode #sql-crud .sql-platform-embed-head h3 {
    margin: 0 0 0.32rem;
    font-size: 1.06rem;
    line-height: 1.18;
    color: #111827;
    letter-spacing: -0.02em;
  }

  body.mobile-practice-mode #sql-crud .sql-platform-embed-head p {
    margin: 0;
    max-width: 14rem;
    font-size: 0.8rem;
    line-height: 1.48;
    color: #5b6474;
  }

  body.mobile-practice-mode #sql-crud .sql-platform-open-btn {
    flex: 0 0 auto;
    align-self: center;
    min-height: 46px;
    padding: 0.72rem 1rem;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #facc15 0%, #f59e0b 100%) !important;
    border: 0 !important;
    color: #111827 !important;
    box-shadow: 0 14px 28px rgba(245, 158, 11, 0.34) !important;
    white-space: nowrap;
    font-size: 0.84rem !important;
    font-weight: 900 !important;
    letter-spacing: -0.01em;
  }

  @media (max-width: 420px) {
    body.mobile-practice-mode #sql-crud .sql-platform-embed-head {
      align-items: flex-start;
      flex-direction: column;
    }

    body.mobile-practice-mode #sql-crud .sql-platform-embed-head p {
      max-width: none;
    }

    body.mobile-practice-mode #sql-crud .sql-platform-open-btn {
      width: 100%;
      justify-content: center;
    }
  }

  body.mobile-practice-mode #sql-crud .sql-mobile-intro {
    display: block !important;
    margin-bottom: 0.95rem !important;
    padding: 1rem 1.05rem;
    border-radius: 1rem;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 251, 235, 0.98) 100%);
    border: 1px solid rgba(250, 204, 21, 0.22);
    color: #475569 !important;
    font-size: 0.9rem !important;
    line-height: 1.6;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.05);
  }

  body.mobile-practice-mode #sqlMobileSupport {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.9rem;
  }

  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-card {
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.05);
  }

  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-card h4 {
    margin: 0.2rem 0 0.45rem;
    font-size: 0.98rem;
    line-height: 1.25;
    color: #0f172a;
  }

  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-card p,
  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-card li {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.55;
    color: #64748b;
  }

  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-label {
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.62rem;
    border-radius: 999px;
    background: rgba(59, 130, 246, 0.08);
    color: #1d4ed8;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }

  body.mobile-practice-mode #sqlMobileSupport .sql-mobile-support-list {
    margin: 0;
    padding-left: 1rem;
  }

  body.mobile-practice-mode #practicaPythonArea > p {
    margin-bottom: 0.65rem !important;
    padding: 0.7rem 0.85rem;
    border-radius: 0.8rem;
    background: #f8fafc;
    border: 1px solid rgba(226, 232, 240, 0.9);
    color: #64748b !important;
    font-size: 0.78rem !important;
    line-height: 1.45;
  }

  body.mobile-practice-mode #practicaWebArea > .d-flex.flex-wrap.gap-2.mb-3,
  body.mobile-practice-mode #javaPracticeButtons,
  body.mobile-practice-mode #swingPracticeButtons,
  body.mobile-practice-mode #phpPracticeButtons,
  body.mobile-practice-mode #practicaPythonArea > .d-flex.flex-wrap.gap-2.mb-3 {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    padding-bottom: 0.35rem;
    margin-inline: -0.15rem;
    padding-inline: 0.15rem;
    scrollbar-width: thin;
  }

  body.mobile-practice-mode #practicaWebArea > .d-flex.flex-wrap.gap-2.mb-3 > *,
  body.mobile-practice-mode #javaPracticeButtons > *,
  body.mobile-practice-mode #swingPracticeButtons > *,
  body.mobile-practice-mode #phpPracticeButtons > *,
  body.mobile-practice-mode #practicaPythonArea > .d-flex.flex-wrap.gap-2.mb-3 > * {
    flex: 0 0 auto;
  }

  body.mobile-practice-mode #practicaPythonArea > .d-flex.flex-wrap.gap-2.mb-3 {
    margin-bottom: 0.9rem !important;
    padding-bottom: 0.45rem;
    border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  }

  body.mobile-practice-mode #practicaWebArea > .d-flex.flex-wrap.gap-2.mb-3,
  body.mobile-practice-mode #javaPracticeButtons,
  body.mobile-practice-mode #swingPracticeButtons,
  body.mobile-practice-mode #phpPracticeButtons {
    margin-bottom: 0.9rem !important;
    padding-bottom: 0.45rem;
    border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  }

  body.mobile-practice-mode #practicaWebArea .btn-ut-selector {
    min-height: 44px;
    padding-inline: 0.9rem;
    border-radius: 999px;
    border-color: rgba(186, 230, 253, 0.92) !important;
    background: #fff !important;
    color: #0f172a !important;
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(125, 211, 252, 0.14) !important;
  }

  body.mobile-practice-mode #practicaWebArea .btn-ut-selector.active,
  body.mobile-practice-mode #practicaWebArea .btn-ut-selector.btn-primary {
    background: linear-gradient(135deg, #0ea5e9 0%, #155e75 100%) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 12px 22px rgba(14, 165, 233, 0.26) !important;
  }

  body.mobile-practice-mode #javaPracticeButtons .java-ut-chip {
    min-height: 44px;
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    border-color: rgba(254, 202, 202, 0.95);
    background: #fff;
    color: #334155;
    box-shadow: 0 8px 18px rgba(248, 113, 113, 0.12);
  }

  body.mobile-practice-mode #javaPracticeButtons .java-ut-chip.btn-danger {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
    border-color: transparent;
    box-shadow: 0 12px 22px rgba(220, 38, 38, 0.24);
  }

  body.mobile-practice-mode #javaPracticeButtons .java-ut-chip .java-ut-code {
    padding: 0.18rem 0.5rem;
    font-size: 0.7rem;
  }

  body.mobile-practice-mode #swingPracticeButtons .btn-ut-swing-selector {
    min-height: 44px;
    padding-inline: 0.9rem;
    border-radius: 999px;
    border-color: rgba(253, 186, 116, 0.95) !important;
    background: #fff !important;
    color: #9a3412 !important;
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(249, 115, 22, 0.12) !important;
  }

  body.mobile-practice-mode #swingPracticeButtons .btn-ut-swing-selector.active,
  body.mobile-practice-mode #swingPracticeButtons .btn-ut-swing-selector.btn-warning {
    background: linear-gradient(135deg, #ea580c 0%, #c2410c 100%) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 12px 22px rgba(234, 88, 12, 0.24) !important;
  }

  body.mobile-practice-mode #javaPracticeButtons .java-ut-name {
    font-size: 0.74rem;
  }

  body.mobile-practice-mode #practicaPythonArea .btn-ut-python-selector {
    min-height: 44px;
    padding-inline: 0.9rem;
    border-radius: 999px;
    border-color: rgba(203, 213, 225, 0.9) !important;
    background: #fff !important;
    color: #334155 !important;
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(148, 163, 184, 0.12) !important;
  }

  body.mobile-practice-mode #practicaPythonArea .btn-ut-python-selector.active,
  body.mobile-practice-mode #practicaPythonArea .btn-ut-python-selector.btn-success {
    background: linear-gradient(135deg, #16a34a 0%, #15803d 100%) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 12px 22px rgba(22, 163, 74, 0.24) !important;
  }

  body.mobile-practice-mode #practicaPythonArea .badge.align-self-center {
    display: inline-flex !important;
    align-items: center;
    min-height: 38px;
    padding: 0.45rem 0.85rem !important;
    border-radius: 999px !important;
    font-size: 0.72rem !important;
    white-space: nowrap;
  }

  body.mobile-practice-mode #btnFullscreenPracticaPython {
    display: none !important;
  }

  body.mobile-practice-mode #btnFullscreenPractica {
    display: none !important;
  }

  body.mobile-practice-mode #zonaFaseWeb {
    margin-bottom: 0.95rem !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .fase-wrapper {
    padding: 0.1rem 0;
  }

  body.mobile-practice-mode #zonaFaseWeb .fase-wrapper > .d-flex.align-items-center.flex-wrap.gap-2.mb-3 {
    gap: 0.45rem !important;
    margin-bottom: 0.75rem !important;
    grid-template-columns: 1fr 1fr !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .badge.rounded-pill {
    grid-column: 1 / -1;
    min-height: 38px;
    align-items: center !important;
    border-radius: 999px !important;
    border-color: rgba(186, 230, 253, 0.92) !important;
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%) !important;
    color: #0c4a6e !important;
    font-size: 0.73rem !important;
    padding: 0.45rem 0.75rem !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .badge.rounded-pill strong {
    font-size: 0.78rem;
  }

  body.mobile-practice-mode #zonaFaseWeb #btnToggleCodeUT,
  body.mobile-practice-mode #zonaFaseWeb #btnToggleMdUT {
    background: #fff;
    border-color: rgba(148, 163, 184, 0.35);
    color: #0f172a;
    font-weight: 700;
  }

  body.mobile-practice-mode #zonaFaseWeb #btnLayoutSplitUT,
  body.mobile-practice-mode #zonaFaseWeb #btnLayoutStackUT,
  body.mobile-practice-mode #zonaFaseWeb .fase-wrapper > .d-flex.align-items-center.flex-wrap.gap-2.mb-3 > .btn-group:last-of-type {
    display: none !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .bg-light.p-3.rounded.shadow-sm.h-100.position-relative,
  body.mobile-practice-mode #zonaFaseWeb .bg-white.border-start.border-3.border-success.p-3.rounded.shadow-sm.h-100 {
    border-radius: 1rem !important;
    border: 1px solid rgba(226, 232, 240, 0.95);
    box-shadow: 0 12px 24px rgba(148, 163, 184, 0.12) !important;
    overflow: hidden !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .ut-code-col .bg-light.p-3.rounded.shadow-sm.h-100.position-relative {
    max-height: none !important;
    background: linear-gradient(180deg, #eff6ff 0%, #f8fafc 100%) !important;
  }

  body.mobile-practice-mode #zonaFaseWeb .ut-md-col .bg-white.border-start.border-3.border-success.p-3.rounded.shadow-sm.h-100 {
    max-height: none !important;
  }

  body.mobile-practice-mode #codigoUTWeb {
    max-height: 38vh !important;
    overflow: auto !important;
    border-radius: 0.8rem !important;
    font-size: 0.76rem !important;
    line-height: 1.55;
  }

  body.mobile-practice-mode #guiaUTWeb {
    max-height: 42vh !important;
    overflow: auto !important;
    padding-right: 0.1rem;
    font-size: 0.8rem !important;
    line-height: 1.55;
  }

  body.mobile-practice-mode #guiaUTWeb h1,
  body.mobile-practice-mode #guiaUTWeb h2,
  body.mobile-practice-mode #guiaUTWeb h3 {
    font-size: 1rem !important;
    line-height: 1.2;
    margin-bottom: 0.65rem;
  }

  body.mobile-practice-mode #zonaFasePython {
    margin-bottom: 1rem !important;
  }

  body.mobile-practice-mode #zonaFasePython .alert {
    border-radius: 1rem;
    border: 1px solid rgba(134, 239, 172, 0.55);
    background: linear-gradient(135deg, #ecfdf5 0%, #f0fdf4 100%);
    color: #14532d;
  }

  body.mobile-practice-mode #zonaFasePython .fase-wrapper {
    padding: 0.15rem 0;
  }

  body.mobile-practice-mode #zonaFasePython .fase-wrapper > .d-flex.align-items-center.flex-wrap.gap-2.mb-3 {
    gap: 0.45rem !important;
    margin-bottom: 0.75rem !important;
  }

  body.mobile-practice-mode #zonaFasePython .badge.rounded-pill {
    min-height: 38px;
    align-items: center !important;
    border-radius: 999px !important;
    border-color: rgba(187, 247, 208, 0.8) !important;
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%) !important;
    color: #166534 !important;
    font-size: 0.73rem !important;
    padding: 0.45rem 0.75rem !important;
  }

  body.mobile-practice-mode #zonaFasePython .bg-light.p-3.rounded.shadow-sm.h-100.position-relative,
  body.mobile-practice-mode #zonaFasePython .bg-white.border-start.border-3.border-success.p-3.rounded.shadow-sm.h-100 {
    border-radius: 1rem !important;
    border: 1px solid rgba(226, 232, 240, 0.95);
    box-shadow: 0 12px 24px rgba(148, 163, 184, 0.12) !important;
    overflow: hidden !important;
  }

  body.mobile-practice-mode #zonaFasePython .ut-code-col-python .bg-light.p-3.rounded.shadow-sm.h-100.position-relative {
    max-height: none !important;
  }

  body.mobile-practice-mode #zonaFasePython .ut-md-col-python .bg-white.border-start.border-3.border-success.p-3.rounded.shadow-sm.h-100 {
    max-height: none !important;
  }

  body.mobile-practice-mode #codigoUTPython {
    max-height: 38vh !important;
    overflow: auto !important;
    border-radius: 0.8rem !important;
    font-size: 0.76rem !important;
    line-height: 1.55;
  }

  body.mobile-practice-mode #guiaUTPython {
    max-height: 42vh !important;
    overflow: auto !important;
    padding-right: 0.1rem;
    font-size: 0.8rem !important;
    line-height: 1.55;
  }

  body.mobile-practice-mode #guiaUTPython h1,
  body.mobile-practice-mode #guiaUTPython h2,
  body.mobile-practice-mode #guiaUTPython h3 {
    font-size: 1rem !important;
    line-height: 1.2;
    margin-bottom: 0.65rem;
  }

  body.mobile-practice-mode #zonaFasePython #btnToggleCodePython,
  body.mobile-practice-mode #zonaFasePython #btnToggleMdPython {
    background: #fff;
    border-color: rgba(148, 163, 184, 0.35);
    color: #0f172a;
    font-weight: 700;
  }

  body.mobile-practice-mode #zonaFasePython #btnLayoutSplitPython,
  body.mobile-practice-mode #zonaFasePython #btnLayoutStackPython {
    max-width: 3.1rem;
    padding-inline: 0;
  }

  body.mobile-practice-mode #zonaFasePython .btn-group {
    gap: 0.4rem;
  }

  body.mobile-practice-mode #zonaFasePython .btn-group > .btn {
    border-radius: 0.85rem !important;
  }

  body.mobile-practice-mode #zonaFasePython .ut-code-col-python.d-none,
  body.mobile-practice-mode #zonaFasePython .ut-md-col-python.d-none {
    display: none !important;
  }

  body.mobile-practice-mode #zonaFasePython .ut-code-col-python.d-none + .ut-md-col-python,
  body.mobile-practice-mode #zonaFasePython .ut-code-col-python:not(.d-none):has(+ .ut-md-col-python.d-none) {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  body.mobile-practice-mode #practicaWebArea .btn,
  body.mobile-practice-mode #javaPracticeButtons .btn,
  body.mobile-practice-mode #swingPracticeButtons .btn,
  body.mobile-practice-mode #phpPracticeButtons .btn,
  body.mobile-practice-mode #practicaPythonArea .btn,
  body.mobile-practice-mode .java-practice-toggle-row .btn,
  body.mobile-practice-mode .fase-wrapper .btn {
    min-height: 42px;
    border-radius: 0.85rem;
  }

  body.mobile-practice-mode .java-practice-toggle-row,
  body.mobile-practice-mode .fase-wrapper > .d-flex.align-items-center.flex-wrap.gap-2.mb-3,
  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap {
    display: grid !important;
    gap: 0.55rem !important;
  }

  body.mobile-practice-mode .fase-wrapper .ms-auto,
  body.mobile-practice-mode #practicaWebArea .ms-auto {
    margin-left: 0 !important;
    width: 100%;
    display: grid !important;
    gap: 0.55rem !important;
  }

  body.mobile-practice-mode .fase-wrapper .btn-group,
  body.mobile-practice-mode #practicaWebArea .btn-group {
    width: 100%;
  }

  body.mobile-practice-mode .fase-wrapper .btn-group > .btn,
  body.mobile-practice-mode #practicaWebArea .btn-group > .btn {
    flex: 1 1 0;
  }

  body.mobile-practice-mode .fase-wrapper .ut-content,
  body.mobile-practice-mode .fase-wrapper .ut-content-python {
    gap: 0.85rem !important;
  }

  body.mobile-practice-mode .fase-wrapper .ut-col,
  body.mobile-practice-mode .fase-wrapper .ut-code-col,
  body.mobile-practice-mode .fase-wrapper .ut-md-col,
  body.mobile-practice-mode .fase-wrapper .ut-code-col-python,
  body.mobile-practice-mode .fase-wrapper .ut-md-col-python {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  body.mobile-practice-mode #codigoUTWeb,
  body.mobile-practice-mode #codigoUTPython,
  body.mobile-practice-mode #swingPracticeCode,
  body.mobile-practice-mode #codigoUTPHP,
  body.mobile-practice-mode #javaPracticeCode,
  body.mobile-practice-mode .markdown-lite,
  body.mobile-practice-mode #guiaUTWeb,
  body.mobile-practice-mode #guiaUTPython,
  body.mobile-practice-mode #guiaUTPHP {
    font-size: 0.78rem !important;
    line-height: 1.55;
  }

  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap {
    padding: 0.75rem !important;
    border-radius: 1rem !important;
    border-color: rgba(226, 232, 240, 0.95) !important;
    background: #f8fafc !important;
    margin-bottom: 0.85rem !important;
  }

  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap > .badge.rounded-pill {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea #btnToggleEmbebido {
    width: 100%;
    justify-content: center;
    border-color: rgba(148, 163, 184, 0.35);
    background: #fff;
    color: #0f172a;
    font-weight: 700;
  }

  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap .btn-group[aria-label="Tamaño editor"] {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap .ms-auto button.btn-outline-primary {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea .p-2.rounded.border.bg-light.mb-2.d-flex.align-items-center.gap-3.flex-wrap .ms-auto a.btn {
    width: 100%;
    justify-content: center;
    background: linear-gradient(135deg, #0ea5e9 0%, #0369a1 100%);
    border-color: transparent;
    color: #fff;
    font-weight: 700;
  }

  body.mobile-practice-mode #zonaFaseWeb a[download] {
    display: none !important;
  }

  body.mobile-practice-mode #editorContainer {
    margin-top: 0.25rem !important;
  }

  body.mobile-practice-mode #editorContainer > .bg-light.border.rounded.shadow-sm.p-2.position-relative {
    padding: 0.55rem !important;
    border-radius: 1rem !important;
    background: #0f172a !important;
    border-color: rgba(15, 23, 42, 0.18) !important;
    box-shadow: 0 14px 26px rgba(14, 165, 233, 0.12) !important;
  }

  body.mobile-practice-mode #editorContainer .btn-danger {
    border-radius: 999px !important;
    width: 34px;
    height: 34px;
    padding: 0;
    top: 0.55rem !important;
    right: 0.55rem !important;
  }

  body.mobile-practice-mode #editorContainer iframe,
  body.mobile-practice-mode #editorPythonContainer,
  body.mobile-practice-mode #iframeProgramadorIA {
    min-height: 54vh;
  }

  body.mobile-practice-mode #editorIframe {
    height: 42vh !important;
    min-height: 17.5rem !important;
  }

  body.mobile-practice-mode #editorPythonContainer {
    height: 58vh !important;
  }

  body.mobile-practice-mode .ia-mobile-window {
    padding: 1rem !important;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
  }

  body.mobile-practice-mode .ia-mobile-topbar {
    align-items: flex-start !important;
    gap: 0.75rem !important;
    margin-bottom: 0.9rem !important;
  }

  body.mobile-practice-mode .ia-mobile-topbar .section-title {
    font-size: 1.18rem;
    line-height: 1.05;
    letter-spacing: -0.03em;
  }

  body.mobile-practice-mode .ia-mobile-topbar .text-muted {
    font-size: 0.82rem;
    line-height: 1.45;
  }

  body.mobile-practice-mode #ia-workspace-container {
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
    min-height: 0 !important;
    border-color: rgba(191, 219, 254, 0.9) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
  }

  body.mobile-practice-mode #ia-left-panel,
  body.mobile-practice-mode #ia-right-panel {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.mobile-practice-mode #ia-left-panel {
    border-right: 0 !important;
    border-bottom: 1px solid #e2e8f0 !important;
    background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%) !important;
  }

  body.mobile-practice-mode #ia-right-panel {
    min-height: 60vh;
  }

  body.mobile-practice-mode .ia-mobile-config {
    padding: 1rem !important;
    background: transparent !important;
    box-shadow: none !important;
    border-bottom: 1px solid rgba(191, 219, 254, 0.9) !important;
  }

  body.mobile-practice-mode .ia-mobile-config .form-select,
  body.mobile-practice-mode .ia-mobile-config .form-control {
    min-height: 44px;
    border-radius: 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.22) !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  body.mobile-practice-mode .ia-mobile-config textarea {
    min-height: 96px;
    resize: vertical;
  }

  body.mobile-practice-mode .ia-mobile-brief {
    padding: 1rem !important;
    max-height: 34vh;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.98));
  }

  body.mobile-practice-mode .ia-mobile-right > .p-2.bg-dark {
    padding: 0.7rem 0.85rem !important;
    background: #020617 !important;
    border-bottom-color: rgba(148, 163, 184, 0.2) !important;
  }

  body.mobile-practice-mode .ia-mobile-overlay {
    padding: 1.25rem;
    text-align: center;
    background:
      radial-gradient(circle at top, rgba(37, 99, 235, 0.18), transparent 36%),
      linear-gradient(180deg, #0f172a 0%, #020617 100%) !important;
  }

  body.mobile-practice-mode .ia-mobile-overlay h5 {
    margin-bottom: 0.35rem;
    font-size: 1rem;
  }

  body.mobile-practice-mode .ia-mobile-overlay p {
    max-width: 16rem;
    line-height: 1.5;
  }

  body.mobile-practice-mode #ia-resizer {
    display: none !important;
  }

  body.mobile-practice-mode #ia-left-panel .row.g-2.mb-3 > div,
  body.mobile-practice-mode #ia-left-panel .col-6 {
    width: 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }

  body.mobile-practice-mode .modal-dialog {
    margin: 0.75rem;
  }
}

@media (max-width: 430px) {
  body.mobile-practice-mode main {
    padding: 0.55rem 0.4rem calc(6.75rem + env(safe-area-inset-bottom)) !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb > .zona-practica-header,
  body.mobile-practice-mode #accordionPracticaJavaCurso > .zona-practica-header {
    align-items: flex-start;
    padding: 0.72rem 0.78rem;
  }

  body.mobile-practice-mode .zona-practica-header .zp-title {
    min-width: 0;
  }

  body.mobile-practice-mode .zona-practica-header .zp-title > div:last-child {
    min-width: 0;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-title,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-title {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    min-width: 0;
    flex: 1 1 auto;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-title > div:last-child,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-title > div:last-child {
    min-width: 0;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-icons,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-icons {
    flex: 0 0 auto;
    gap: 0.28rem;
    margin-top: 0.08rem;
  }

  body.mobile-practice-mode .zona-practica-header .zp-title h5,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button h5,
  body.mobile-practice-mode #sql-crud .accordion-button h5 {
    font-size: 0.82rem;
    line-height: 1.08;
    letter-spacing: -0.02em;
    margin: 0;
  }

  body.mobile-practice-mode .zona-practica-header .zp-title small,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button small,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button .text-muted,
  body.mobile-practice-mode #sql-crud .accordion-button small,
  body.mobile-practice-mode #sql-crud .accordion-button .text-muted {
    display: none !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-actions,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-actions {
    width: 100%;
    margin-top: 0.55rem;
    justify-content: flex-start;
    gap: 0.4rem;
  }

  body.mobile-practice-mode #accordionPracticaWeb .zp-actions > .badge:first-child,
  body.mobile-practice-mode #accordionPracticaJavaCurso .zp-actions > .badge:first-child {
    display: none !important;
  }

  body.mobile-practice-mode #accordionPracticaWeb .badge-live,
  body.mobile-practice-mode #accordionPracticaJavaCurso .badge-live {
    font-size: 0 !important;
    padding: 0.38rem 0.65rem !important;
    white-space: nowrap;
  }

  body.mobile-practice-mode #accordionPracticaWeb .badge-live::before,
  body.mobile-practice-mode #accordionPracticaJavaCurso .badge-live::before {
    content: "Completa";
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.01em;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button {
    font-size: 0.82rem !important;
    line-height: 1.14;
    padding: 0.8rem 0.82rem;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button .python-acc-ico {
    margin-top: 0.1rem;
    margin-right: 0.45rem !important;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button::after {
    margin-left: auto;
  }

  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button small,
  body.mobile-practice-mode #accordionPracticaInteractiva .accordion-button .text-muted {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea > .p-4.rounded-4.border.bg-light,
  body.mobile-practice-mode #practicaJavaArea > .p-4.rounded-4.border.bg-light,
  body.mobile-practice-mode #practicaPythonArea > .p-4.rounded-4.border.bg-light {
    padding: 0.82rem !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-4.align-items-start.mb-4 .col-12.col-xl-7 > .badge,
  body.mobile-practice-mode #practicaJavaArea .row.g-4.align-items-start.mb-4 .col-12.col-xl-7 > .badge,
  body.mobile-practice-mode #practicaPythonArea .row.g-4.align-items-start.mb-4 .col-12.col-xl-7 > .badge {
    display: inline-flex;
    max-width: 100%;
    white-space: normal;
    line-height: 1.15;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-4.align-items-start.mb-4 h3,
  body.mobile-practice-mode #practicaJavaArea .row.g-4.align-items-start.mb-4 h3,
  body.mobile-practice-mode #practicaPythonArea .row.g-4.align-items-start.mb-4 h3 {
    font-size: 0.95rem !important;
    line-height: 1.18;
    letter-spacing: -0.02em;
    margin-bottom: 0.55rem !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-3.mb-4,
  body.mobile-practice-mode #practicaJavaArea .row.g-3.mb-4,
  body.mobile-practice-mode #practicaPythonArea .row.g-3.mb-4 {
    margin-bottom: 0 !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-3.mb-4 > :not(:first-child),
  body.mobile-practice-mode #practicaJavaArea .row.g-3.mb-4 > :not(:first-child),
  body.mobile-practice-mode #practicaPythonArea .row.g-3.mb-4 > :not(:first-child) {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-3.mb-4 .rounded-4.border.bg-white.p-3.shadow-sm,
  body.mobile-practice-mode #practicaJavaArea .row.g-3.mb-4 .rounded-4.border.bg-white.p-3.shadow-sm,
  body.mobile-practice-mode #practicaPythonArea .row.g-3.mb-4 .rounded-4.border.bg-white.p-3.shadow-sm {
    padding: 0.78rem 0.82rem !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-3.mb-4 .text-muted.small.mb-0,
  body.mobile-practice-mode #practicaJavaArea .row.g-3.mb-4 .text-muted.small.mb-0,
  body.mobile-practice-mode #practicaPythonArea .row.g-3.mb-4 .text-muted.small.mb-0 {
    display: none !important;
  }

  body.mobile-practice-mode #practicaWebArea .row.g-4.align-items-start.mb-4 .text-muted.mb-3,
  body.mobile-practice-mode #practicaJavaArea .row.g-4.align-items-start.mb-4 .text-muted.mb-3,
  body.mobile-practice-mode #practicaPythonArea .row.g-4.align-items-start.mb-4 .text-muted.mb-3,
  body.mobile-practice-mode #practicaWebArea .row.g-4.align-items-start.mb-4 .d-flex.flex-column.gap-2.small.text-muted,
  body.mobile-practice-mode #practicaJavaArea .row.g-4.align-items-start.mb-4 .d-flex.flex-column.gap-2.small.text-muted,
  body.mobile-practice-mode #practicaPythonArea .row.g-4.align-items-start.mb-4 .d-flex.flex-column.gap-2.small.text-muted {
    display: none !important;
  }

  body.mobile-practice-mode #sql-crud > .mobile-practice-shell {
    padding: 1rem !important;
  }

  body.mobile-practice-mode #sql-crud .row.g-4.align-items-start.mb-4 .d-flex.flex-wrap.align-items-center.gap-2.mb-3 > .badge:not(:first-child) {
    display: none !important;
  }

  body.mobile-practice-mode #sql-crud .row.g-4.align-items-start.mb-4 .section-title {
    font-size: 1.02rem !important;
    line-height: 1.14;
    letter-spacing: -0.02em;
    gap: 0.55rem !important;
    align-items: flex-start !important;
  }

  body.mobile-practice-mode #sql-crud .row.g-4.align-items-start.mb-4 .section-title i {
    font-size: 1.15rem !important;
    margin-top: 0.1rem;
  }

  body.mobile-practice-mode #sql-crud .row.g-4.align-items-start.mb-4 .lead,
  body.mobile-practice-mode #sql-crud .row.g-4.align-items-start.mb-4 .col-12.col-xl-4 {
    display: none !important;
  }

  body.mobile-practice-mode #sql-crud .row.g-3.mb-4 {
    margin-top: 0 !important;
  }

  body.mobile-practice-mode .ia-mobile-topbar {
    margin-bottom: 0.7rem !important;
  }

  body.mobile-practice-mode .ia-mobile-topbar .section-title {
    font-size: 1rem !important;
    line-height: 1.12 !important;
    letter-spacing: -0.02em;
  }

  body.mobile-practice-mode .ia-mobile-topbar .text-muted {
    display: none !important;
  }
}
