/* ==============================================================
   SEARCH OVERLAY
   ============================================================== */

/* Container — Stimulus controller root, invisible in the DOM */
.fusion-search-container {
  display: contents;
}

/* ========================
   Backdrop
   ======================== */

.fusion-search-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(34, 34, 34, 0.45);
  z-index: 9998;
  display: none;
  cursor: default;
}

@keyframes fadeInBackdrop {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.fusion-search-container.active .fusion-search-backdrop {
  display: block;
  animation: fadeInBackdrop 0.2s ease;
}

/* ========================
   Panel
   ======================== */

.fusion-search-overlay {
  position: fixed;
  top: 116px; /* 80px header + 36px gap */
  left: 50%;
  transform: translateX(-50%);
  width: calc(100vw - 80px); /* 40px margin each side */
  max-width: 1440px;
  bottom: 40px;
  z-index: 9999;
  background: var(--color-bg-primary);
  border-radius: var(--border-radius-lg);
  box-shadow: 0 8px 48px rgba(0, 0, 0, 0.12), 0 2px 12px rgba(0, 0, 0, 0.06);
  display: none;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

@keyframes slideInOverlay {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

.fusion-search-container.active .fusion-search-overlay {
  display: flex;
  animation: slideInOverlay 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Has-results: snap header to top, fill space with results */
.fusion-search-overlay.has-results {
  justify-content: flex-start;
}

/* ========================
   Header / search bar
   ======================== */

.fusion-search-header {
  padding: var(--space-48) var(--space-40) var(--space-32);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
  transition: padding 0.25s ease, border-color 0.25s ease;
}

.fusion-search-overlay.has-results .fusion-search-header {
  padding: var(--space-24) var(--space-40);
  border-bottom: 1px solid var(--color-gray-very-light);
}

.fusion-search-hint {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-small);
  color: var(--color-gray-light);
  text-align: center;
  margin: 0;
  letter-spacing: 0.01em;
}

.fusion-search-overlay.has-results .fusion-search-hint {
  display: none;
}

.fusion-search-form {
  width: 100%;
  max-width: 640px;
}

.fusion-search-input-container {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
}

img.fusion-search-icon {
  position: absolute;
  left: var(--space-18);
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  opacity: 0.4;
  pointer-events: none;
  z-index: 2;
}

.fusion-search-input {
  width: 100%;
  height: 60px;
  padding: 0 var(--space-48) 0 var(--space-48);
  border: 1.5px solid var(--color-gray-very-light);
  border-radius: var(--border-radius-special);
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-h3);
  font-weight: var(--font-light);
  background: var(--color-bg-primary);
  box-sizing: border-box;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
  color: var(--color-black);
  line-height: 1;
  text-align: left;
}

.fusion-search-input:focus {
  outline: none;
  border-color: var(--color-gray-dark);
  box-shadow: 0 0 0 3px rgba(98, 92, 75, 0.1);
}

.fusion-search-input::placeholder {
  color: var(--color-gray-light);
  font-weight: var(--font-light);
  text-align: left;
  opacity: 1;
}

.fusion-search-input-clear {
  position: absolute;
  right: var(--space-12);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-8);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius-circle);
  transition: background-color 0.15s;
}

.fusion-search-input-clear:hover {
  background-color: var(--color-gray-very-light);
}

.fusion-search-input-clear img {
  width: 14px;
  height: 14px;
  opacity: 0.4;
  transition: opacity 0.15s;
  display: block;
}

.fusion-search-input-clear:hover img {
  opacity: 0.75;
}

/* ========================
   Loading spinner
   ======================== */

.fusion-search-loading {
  display: none;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.fusion-search-container.loading .fusion-search-loading {
  display: flex;
}

.fusion-search-spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--color-gray-very-light);
  border-top-color: var(--color-gray-dark);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ========================
   Results area
   ======================== */

.fusion-search-results {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-32) var(--space-40) var(--space-60);
  display: none;
}

.fusion-search-overlay.has-results .fusion-search-results {
  display: block;
}

.fusion-search-container.loading .fusion-search-results {
  display: none;
}

.fusion-search-results::-webkit-scrollbar {
  width: 5px;
}

.fusion-search-results::-webkit-scrollbar-track {
  background: transparent;
}

.fusion-search-results::-webkit-scrollbar-thumb {
  background: var(--color-gray-very-light);
  border-radius: var(--border-radius-sm);
}

.fusion-search-results::-webkit-scrollbar-thumb:hover {
  background: var(--color-border-light);
}

/* ========================
   Section headers
   ======================== */

/* Stand-alone section header (brands only — carousels have their own title row) */
.search-section-header {
  display: flex;
  align-items: baseline;
  margin-bottom: var(--space-12);
  margin-top: var(--space-32);
}

.search-section-header:first-child {
  margin-top: 0;
}

/* Shared title style used both in .search-section-header and carousel title rows */
.search-section-title {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-tiny);
  font-weight: var(--font-semibold);
  color: var(--color-gray-light);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0;
}

/* Spacing between consecutive carousels */
.fusion-search-overlay div[data-controller="fusion--carousel"] + div[data-controller="fusion--carousel"] {
  margin-top: var(--space-48);
}


/* ========================
   Brand grid
   ======================== */

.search-brand-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-32);
  align-items: center;
  margin-bottom: var(--space-48);
}

.search-brand-logo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 60px;
  padding: 0;
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.15s;
}

.search-brand-logo-link:hover {
  opacity: 0.65;
}

.search-brand-logo-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.search-brand-name {
  color: var(--color-gray-dark);
  font-size: var(--fs-small);
  font-family: "DM Sans", sans-serif;
  font-weight: var(--font-medium);
  text-align: center;
}

/* ========================
   No-results / empty state
   ======================== */

.search-no-results {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  padding: var(--space-72) var(--space-40);
  text-align: center;
}

.fusion-search-placeholder {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-body-lg);
  font-weight: var(--font-normal);
  color: var(--color-gray-dark);
  margin: 0;
}

.search-no-results-label {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-body-lg);
  color: var(--color-gray-dark);
  font-weight: var(--font-normal);
  margin: 0;
}

.search-no-results-sub {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-body);
  font-weight: var(--font-light);
  color: var(--color-gray-light);
  margin: 0;
}

/* ========================
   Carousel overrides — strip page-level margins
   ======================== */

.fusion-search-overlay div[data-controller="fusion--carousel"] {
  margin-top: 0;
  padding: 0;
}

/* Zero out the 80px page indent on header row and track wrapper.
   Needs !important — carousel.css uses :is() which has higher specificity. */
.fusion-search-overlay div[data-controller="fusion--carousel"] > div:first-child,
.fusion-search-overlay div[data-controller="fusion--carousel"] > div:last-child {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Section title row inside carousel */
.fusion-search-overlay div[data-controller="fusion--carousel"] > div:first-child {
  margin-bottom: var(--space-12);
}

/* Track: remove right padding (overlay edge handles overflow) */
.fusion-search-overlay div[data-controller="fusion--carousel"] > div:last-child > div[data-fusion--carousel-target="track"] {
  padding-right: var(--space-40);
  padding-bottom: var(--space-16);
}

/* ========================
   Card overrides — compact in search context
   ======================== */

/* Card backgrounds inside search overlay — match overlay background */
.fusion-search-overlay div.course-card,
.fusion-search-overlay div.photo-card,
.fusion-search-overlay div.video-card,
.fusion-search-overlay .article-card,
.fusion-search-overlay .resource {
  background: var(--color-bg-primary);
}

/* ========================
   Responsive
   ======================== */

@media (max-width: 1024px) {
  .fusion-search-overlay {
    width: calc(100vw - 32px);
    top: 108px;
    bottom: var(--space-24);
  }

  .fusion-search-header {
    padding: var(--space-36) var(--space-24) var(--space-24);
  }

  .fusion-search-overlay.has-results .fusion-search-header {
    padding: var(--space-20) var(--space-24);
  }

  .fusion-search-results {
    padding: var(--space-24) var(--space-24) var(--space-48);
  }

}

@media (max-width: 768px) {
  .fusion-search-overlay {
    width: calc(100vw - 16px);
    top: 96px;
    bottom: var(--space-12);
  }

  .fusion-search-input {
    height: 52px;
    font-size: var(--fs-body);
  }

  .search-brand-grid {
    gap: var(--space-20);
  }

  .search-brand-logo-link {
    width: 80px;
    height: 48px;
  }
}

@media (max-width: 480px) {
  .fusion-search-overlay {
    width: 100vw;
    top: 80px;
    bottom: 0;
    border-radius: 0;
  }

  .fusion-search-header {
    padding: var(--space-24) var(--space-16) var(--space-20);
  }

  .fusion-search-overlay.has-results .fusion-search-header {
    padding: var(--space-16) var(--space-16);
  }

  .fusion-search-results {
    padding: var(--space-20) var(--space-16) var(--space-36);
  }

}
