h3.svelte-easguy {
  font-size: 1.25rem;
  font-weight: 500;
  max-width: 100%;
  flex-shrink: 1;
  line-height: 1.1;
  margin-bottom: 0.25rem;
}

.iconoir-map-pin.svelte-easguy {
  margin-top: 0.5rem;
}

.profile.svelte-easguy {
  position: absolute;
  background: white;
  padding: 0.75rem;
  width: 8rem;
  height: 8rem;
  object-fit: contain;
  left: 0.75rem;
  top: 0.75rem;
  border-radius: 0.75rem;
  border: 1px solid var(--neutral-warm-300);
  user-select: none;
  pointer-events: none;
}
.profile.profile-icon.svelte-easguy {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--neutral-warm-300);
}
.profile.profile-icon.svelte-easguy i:where(.svelte-easguy) {
  font-size: 4rem;
  margin: 0;
}
.profile.profile-icon.svelte-easguy i:where(.svelte-easguy)::before {
  font-size: 4rem;
}

.banner.svelte-easguy {
  height: 7.5rem;
  background: var(--neutral-warm-300);
  width: 100%;
}
.banner.has-image.svelte-easguy img:where(.svelte-easguy) {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 30%;
  user-select: none;
  pointer-events: none;
}

i.svelte-easguy {
  font-size: 1rem;
  display: flex;
  gap: 0.25rem;
  align-items: center;
  font-style: normal;
  margin-bottom: 1rem;
}
i.svelte-easguy::before {
  font-size: 1.5rem; /* Icon-Size */
}

.content.svelte-easguy {
  padding: 2rem 1rem 1rem;
}
.content.svelte-easguy p:where(.svelte-easguy) {
  min-height: 3rem;
}

.company-card.svelte-easguy {
  min-width: 20rem;
  flex: 1;
  position: relative;
  display: flex;
  overflow: hidden;
  flex-direction: column;
  background: var(--neutral-warm-50);
  border-radius: 1rem;
  border: 2px solid var(--neutral-warm-100);
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.company-card.svelte-easguy:hover {
  border-color: var(--neutral-warm-300);
}

@media (max-width: 700px) {
  .banner.svelte-easguy {
    height: 12rem;
  }
  .profile.svelte-easguy {
    top: 5rem;
  }
  .content.svelte-easguy {
    padding-bottom: 3rem;
  }
}.iconoir.svelte-qnmhgp {
  font-size: 1.5rem;
  font-weight: 700;
}

h3.svelte-qnmhgp {
  font-weight: 500;
  margin-bottom: 0.25rem;
}

.student-deco-image.svelte-qnmhgp {
  position: absolute;
  left: 4rem;
  bottom: -2rem;
  height: 100%;
  max-height: 280px;
}

@media (max-width: 1520px) {
  .student-deco-image.svelte-qnmhgp {
    left: 2rem;
    bottom: -2rem;
    height: 90%;
  }
}
@media (max-width: 1420px) {
  .student-deco-image.svelte-qnmhgp {
    left: 1rem;
    bottom: -2rem;
    height: 80%;
  }
}
@media (max-width: 1320px) {
  .student-deco-image.svelte-qnmhgp {
    display: none;
  }
}
.search.svelte-qnmhgp {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 3rem 1rem;
  position: relative;
  background: var(--neutral-warm-100);
}

.search-form.svelte-qnmhgp {
  width: 100%;
  max-width: 50rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
}

.search-input-wrapper.svelte-qnmhgp {
  position: relative;
  display: flex;
  align-items: flex-end;
  width: 100%;
  border-radius: 1.5rem;
  border: 1px solid var(--neutral-warm-300);
  background-color: var(--white);
  padding: 0.75rem 3rem 0.75rem 1.25rem;
}

.search-input-wrapper.svelte-qnmhgp label:where(.svelte-qnmhgp) {
  position: absolute;
  top: 0.7rem;
  left: 1.5rem;
  font-size: 0.8rem;
  z-index: 10;
  font-weight: 600;
  transition: top 0.2s ease-out, font-size 0.2s ease-out, color 0.2s ease-out;
}

.search-input-wrapper.svelte-qnmhgp label.floating:where(.svelte-qnmhgp) {
  top: 0.25rem;
  font-size: 0.7rem;
  color: var(--neutral-warm-400);
}

.search-input-wrapper.svelte-qnmhgp textarea:where(.svelte-qnmhgp) {
  font-family: Poppins, sans-serif;
  width: 100%;
  border: none;
  outline: none;
  resize: none;
  max-height: 12rem;
  min-height: 1.5rem;
  padding-top: 1.2rem;
  padding-right: 0.75rem;
  font-size: 0.95rem;
  font-weight: 400;
  background: transparent;
  line-height: 1.4;
}

.search-input-wrapper.svelte-qnmhgp textarea:where(.svelte-qnmhgp)::placeholder {
  color: #817e75;
  font-weight: 400;
}

.search-button.svelte-qnmhgp {
  position: absolute;
  right: 0.6rem;
  bottom: 0.55rem;
  padding: 0.45rem;
  aspect-ratio: 1;
  border-radius: 999px;
  background-color: var(--accent-wildberry);
  transition: background-color 0.3s ease-in-out;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.search-button.svelte-qnmhgp:hover {
  background-color: var(--primary-dark);
}

.search-summary.svelte-qnmhgp {
  max-width: var(--content-width-xl);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.prompt-bubble.svelte-qnmhgp {
  max-width: 32rem;
  background: var(--white);
  border-radius: 1rem 1rem 0 1rem;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  line-height: 1.4;
  border: 1px solid var(--neutral-warm-300);
}

.search-response-text.svelte-qnmhgp {
  max-width: 32rem;
  background: var(--neutral-warm-700);
  color: var(--neutral-warm-50);
  border-radius: 1rem 1rem 1rem 0;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  line-height: 1.4;
}

.ai-results.svelte-qnmhgp {
  max-width: var(--content-width-xl);
  margin: 0 auto;
  width: 100%;
  padding: 1.5rem 1rem 0;
}

.no-results.svelte-qnmhgp {
  text-align: center;
  padding: 2rem;
  color: var(--neutral-warm-700);
  font-size: 1.1rem;
  width: 100%;
}

.companies.svelte-qnmhgp {
  max-width: var(--content-width-xl);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-top: 2rem;
  padding-bottom: 2rem;
  background: transparent;
  overflow: visible !important;
}

.companies-header.svelte-qnmhgp {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.filters.svelte-qnmhgp {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.filter-group.svelte-qnmhgp {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 300px;
}
/* (unused) .filter-group label {
  font-size: 0.85rem;
  font-weight: 500;
}*/

.company-wrapper.svelte-qnmhgp {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
  gap: 1rem;
  width: 100%;
  margin-bottom: 1rem;
}
.company-wrapper.svelte-qnmhgp > * {
  max-width: 30rem;
}

.infinite-scroll-trigger.svelte-qnmhgp {
  height: 1px;
  width: 100%;
}

@media (max-width: 600px) {
  .search.svelte-qnmhgp {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
  .search-form.svelte-qnmhgp,
  .search-summary.svelte-qnmhgp {
    max-width: 100%;
  }
  .companies-header.svelte-qnmhgp {
    align-items: flex-start;
  }
  .filters.svelte-qnmhgp {
    width: 100%;
  }
}
.text-warn.svelte-qnmhgp {
  color: var(--warn-500);
  font-weight: 500;
  font-size: 1rem;
  margin-top: 0.25rem;
  padding: 0.5rem;
  border-radius: 0.5rem;
  background: var(--neutral-warm-50);
  border: 1px solid var(--warn-200);
  width: max-content;
}

.tip-text.svelte-qnmhgp {
  position: relative;
  min-height: 1.2rem;
  opacity: 0.6;
}
.tip-text.svelte-qnmhgp span:where(.svelte-qnmhgp) {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  display: inline-block;
}