/* =========================================================
   bolsaOficios.css
   ✅ Mantiene tu diseño actual y lo vuelve responsive:
   - Desktop (>=1280)
   - Tablet (>=768)
   - Mobile pequeño (<=320) -> logo arriba y título/texto abajo
   ========================================================= */

.at-custom-side-wrapper {
  display: none;
}

/* Fondo (igual a tu style actual) */
body {
  background: radial-gradient(
      1200px 600px at 50% -50%,
      rgba(220, 38, 38, 0.18),
      transparent 60%
    ),
    radial-gradient(
      900px 500px at 0% 10%,
      rgba(239, 68, 68, 0.12),
      transparent 55%
    ),
    #f3f4f6;
}

/* Card (igual a tu style actual) */
.cmic-card {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(229, 231, 235, 0.95);
  box-shadow: 0 22px 60px rgba(15, 23, 42, 0.14);
  background: #fff;
  width: 100%;
  max-width: 1150px; /* ✅ ancho desktop actual */
}

/* Head rojo (igual) */
.cmic-card__head {
  background: linear-gradient(135deg, #b91c1c 0%, #dc2626 45%, #ef4444 100%);
  color: #fff;
}

/* Inputs grandes blindados (igual) */
.input-pro,
.select-pro,
.textarea-pro {
  width: 100% !important;
  font-size: 16px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 18px !important;
  outline: none !important;
  background: #fff !important;
}

/* Altura + padding (igual) */
.input-pro,
.select-pro {
  height: 58px !important;
  padding: 0 18px !important;
}

/* Fix: evitar que estilo.css reduzca anchos (igual) */
.cmic-card form,
.cmic-card form * {
  box-sizing: border-box;
}

.cmic-form-wrap {
  width: 100% !important;
  display: flex;
  justify-content: center; /* centra el contenido dentro del card */
}

.cmic-form {
  width: 100% !important; /* ✅ ocupa todo el ancho del card */
  max-width: 980px; /* ✅ área interna centrada (tu valor actual) */
  margin: 0 auto !important;
}

/* Grid base (igual, 1 columna por default) */
.cmic-grid {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 22px !important;
}

/* Span 2 columnas (igual) */
.cmic-span-2 {
  grid-column: 1 / -1 !important;
}

/* Inputs “más grandes” (igual a tu style actual) */
.input-pro,
.select-pro {
  width: 100% !important;
  height: 66px !important;
  font-size: 18px !important;
  padding: 0 18px !important;
}

.textarea-pro {
  width: 100% !important;
  min-height: 200px !important;
  font-size: 18px !important;
  padding: 14px 18px !important;
}

/* Focus (igual) */
.input-pro:focus,
.select-pro:focus,
.textarea-pro:focus {
  border-color: #2563eb !important;
  box-shadow: 0 0 0 5px rgba(37, 99, 235, 0.18) !important;
}

/* Botón (igual) */
.btn-primary {
  background: #0f172a !important;
  color: #fff !important;
  font-weight: 800 !important;
  border-radius: 18px !important;
  padding: 16px 22px !important;
  font-size: 16px !important;
}

.btn-primary:hover {
  background: #111827 !important;
}
.areas-box {
  border: 1px solid #d1d5db;
  border-radius: 18px;
  padding: 14px;
  display: grid;
  gap: 10px;
  background: #fff;
}
.area-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(229, 231, 235, 0.95);
  background: #f9fafb;
}

.area-item input {
  margin-top: 3px;
  width: 18px;
  height: 18px;
}
/* =========================================================
   ✅ TABLET (>=768px)
   - 2 columnas reales para el formulario
   ========================================================= */
@media (min-width: 768px) {
  .cmic-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 26px !important;
  }
  .areas-box {
    grid-template-columns: 1fr 1fr;
  }
}

/* =========================================================
   ✅ DESKTOP GRANDE (>=1280px)
   - Mantiene tus tamaños actuales (solo seguridad)
   ========================================================= */
@media (min-width: 1280px) {
  .cmic-card {
    max-width: 1150px;
  }
  .cmic-form {
    max-width: 980px;
  }
}

/* =========================================================
   ✅ MOBILE PEQUEÑO (<=320px)
   - Logo arriba y abajo el título + texto
   - Card / paddings / inputs compactos sin romper diseño
   ========================================================= */
@media (max-width: 320px) {
  /* Reduce padding general para que no se corte */
  main .w-full.px-4 {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* Card un poquito más compacta */
  .cmic-card {
    border-radius: 16px;
  }

  /* Cabecera compacta */
  .cmic-card__head {
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-top: 18px !important;
    padding-bottom: 18px !important;
  }

  /* ✅ Fuerza layout vertical SOLO en 320:
     ataca directamente el wrapper del head que trae flex */
  .cmic-card__head > .flex {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 10px !important;
  }

  /* Logo arriba */
  .cmic-card__head img {
    height: 56px !important;
    width: auto !important;
    display: block;
    margin: 0 auto;
  }

  /* Título abajo del logo */
  .cmic-card__head h1 {
    font-size: 18px !important;
    line-height: 1.15 !important;
    margin-top: 2px !important;
  }

  /* Texto descriptivo */
  .cmic-card__head p {
    font-size: 13px !important;
    line-height: 1.35 !important;
    margin-top: 6px !important;
  }

  /* Body del card más compacto (tu body usa px-6 sm:px-10 py-10) */
  .cmic-card > .px-6 {
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-top: 18px !important;
    padding-bottom: 18px !important;
  }

  /* Grid: 1 columna */
  .cmic-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  /* Labels más chicos */
  label {
    font-size: 14px !important;
  }

  /* Inputs compactos pero con tu estilo */
  .input-pro,
  .select-pro {
    height: 54px !important;
    font-size: 15px !important;
    padding: 0 14px !important;
    border-radius: 14px !important;
  }

  .textarea-pro {
    min-height: 140px !important;
    font-size: 15px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
  }

  /* Botón full width */
  .btn-primary {
    width: 100% !important;
    padding: 14px 16px !important;
    font-size: 15px !important;
    border-radius: 14px !important;
  }

  /* Textos ayudita */
  .text-sm {
    font-size: 12px !important;
  }
}
