#fsproblemfinder {
  padding: 28px;
}
#fsproblemfinder .is-hidden { display: none !important; }
#fsproblemfinder h3,
#fsproblemfinder h4,
#fsproblemfinder h5 { margin-top: 0; }

#fsproblemfinder .fspf-hero {
  display:flex;
  justify-content:center;
  margin: 6px 0 22px;
}
#fsproblemfinder .fspf-hero-card-wrap {
  position: relative;
  width: 100%;
}

#fsproblemfinder .fspf-hero-card-wrap--desktop { display:block !important; }
#fsproblemfinder .fspf-hero-card-wrap--mobile { display:none !important; }
#fsproblemfinder.is-mobile-hero .fspf-hero-card-wrap--desktop { display:none !important; }
#fsproblemfinder.is-mobile-hero .fspf-hero-card-wrap--mobile { display:block !important; }
#fsproblemfinder.is-desktop-hero .fspf-hero-card-wrap--desktop { display:block !important; }
#fsproblemfinder.is-desktop-hero .fspf-hero-card-wrap--mobile { display:none !important; }
#fsproblemfinder .fspf-hero-card-image {
  display:block;
  width:100%;
  height:auto;
  border-radius: 18px;
}
#fsproblemfinder .fspf-hero-hotspot {
  position:absolute;
  border:0;
  padding:0;
  margin:0;
  background: transparent;
  cursor: pointer;
  z-index: 5;
}
#fsproblemfinder .fspf-hero-hotspot--desktop {
  top: 64.8%;
  left: 74.8%;
  width: 24.8%;
  height: 12.2%;
  transform: translate(-50%, -50%);
}
#fsproblemfinder .fspf-hero-hotspot--mobile {
  top: 38.2%;
  left: 49.8%;
  width: 59%;
  height: 7.2%;
  transform: translate(-50%, -50%);
}
#fsproblemfinder .fspf-hero-hotspot:focus {
  outline: 2px solid rgba(41, 86, 180, 0.35);
  outline-offset: 4px;
  border-radius: 12px;
}
#fsproblemfinder .fspf-hero-hotspot:hover {
  box-shadow: 0 0 0 2px rgba(41, 86, 180, 0.15) inset;
  border-radius: 12px;
}
#fsproblemfinder .fspf-hero p { color: #666; margin-bottom: 18px; }
#fsproblemfinder .fspf-progress { color: #666; font-size: 14px; margin-bottom: 0; }
#fsproblemfinder .fspf-breadcrumb {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin: 0 0 18px;
}
#fsproblemfinder .fspf-crumb {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  background:#f5f7fb;
  border:1px solid #d8dff3;
  border-radius:999px;
  font-size:13px;
  color:#2f365f;
}
#fsproblemfinder .fspf-crumb-thumb { width:28px; height:28px; border-radius:50%; object-fit:cover; border:1px solid #d8dff3; }

#fsproblemfinder .fspf-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
#fsproblemfinder .fspf-back-btn {
  flex: 0 0 auto;
}
#fsproblemfinder .fspf-back-btn[disabled] {
  opacity: .5;
  pointer-events: none;
}
#fsproblemfinder .fspf-more {
  margin-top: 18px;
}

#fsproblemfinder .fspf-step-description {
  margin: 0 0 16px;
  color: #5a6473;
}
#fsproblemfinder .fspf-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 14px;
}
#fsproblemfinder .fspf-card {
  border: 1px solid #d9d9d9;
  background: #fff;
  border-radius: 18px;
  padding: 10px;
  cursor: pointer;
  transition: all .18s ease;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  text-align:left;
  min-height: 170px;
  overflow:hidden;
}
#fsproblemfinder .fspf-card-media {
  display:block;
  border-radius: 14px;
  overflow:hidden;
  background:#eef2f6;
  aspect-ratio: 4 / 3;
}
#fsproblemfinder .fspf-card-image {
  width:100%; height:100%; object-fit:cover; display:block;
}
#fsproblemfinder .fspf-card-text { font-weight:600; color:#253041; }
#fsproblemfinder .fspf-card:hover { transform: translateY(-1px); box-shadow:0 10px 24px rgba(25,34,56,0.08); border-color:#bcc8d6; }
#fsproblemfinder .fspf-card.is-selected { border-color: #272a88; box-shadow:0 0 0 2px rgba(39,42,136,0.12); }
#fsproblemfinder .fspf-card.is-selected .fspf-card-text { color:#272a88; }
#fsproblemfinder .fspf-card--big { min-width: 180px; }
#fsproblemfinder .fspf-step { display: none; }
#fsproblemfinder .fspf-step.is-active { display: block; }
#fsproblemfinder .fspf-actions { margin-top: 20px; }
#fsproblemfinder .fspf-results-wrap { margin-top: 24px; }
#fsproblemfinder .fspf-results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
}
#fsproblemfinder .fspf-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid #e4e4e4;
  border-radius: 10px;
  padding: 16px;
  align-items: stretch;
  height: 100%;
}
#fsproblemfinder .fspf-item img {
  width: 100%;
  height: 220px;
  object-fit: contain;
  border-radius: 8px;
  flex: 0 0 auto;
  background: #f3f3f3;
}
#fsproblemfinder .fspf-item.fspf-no-image .fspf-image-wrap {
  min-height: 220px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f3f3f3;
  border-radius:8px;
}
#fsproblemfinder .fspf-item.fspf-no-image .fspf-image-wrap::before {
  content:'📦';
  font-size:42px;
}
#fsproblemfinder .fspf-content { display:flex; flex-direction:column; flex:1 1 auto; }
#fsproblemfinder .fspf-content h5 { min-height: 56px; margin-bottom:8px; }
#fsproblemfinder .fspf-content p { margin-bottom: 10px; }
#fsproblemfinder .fspf-content .btn { margin-top:auto; align-self:flex-start; }
#fsproblemfinder .fspf-summary {
  color: #666;
  font-size: 13px;
}
#fsproblemfinder .fspf-contact-box,
#fsproblemfinder .fspf-contact {
  margin-top: 20px;
  padding: 18px;
  border: 1px solid #ececec;
  border-radius: 10px;
  background: #fafafa;
}
#fsproblemfinder .fspf-feedback {
  margin-top: 12px;
  font-size: 14px;
}
#fsproblemfinder .fspf-debug {
  margin-top: 10px;
  background: #f7f7f9;
  font-size: 11px;
  padding: 8px;
  border: 1px dashed #c0c0c0;
  white-space: pre-wrap;
}
@media (max-width: 991px) {
  #fsproblemfinder .fspf-results { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 767px) {
  #fsproblemfinder { padding: 20px; }
  #fsproblemfinder .fspf-hero-card-wrap--desktop { display: none !important; }
  #fsproblemfinder .fspf-hero-card-wrap--mobile { display: block !important; }
  #fsproblemfinder .fspf-hero { margin: 0 0 18px; }
  #fsproblemfinder .fspf-results { grid-template-columns: 1fr; }
  #fsproblemfinder .fspf-item img { width: 100%; height: auto; max-height: 220px; }
}

#fsproblemfinder .fspf-contact-intro {
  margin: 0 0 18px;
  color: #5a6473;
}
#fsproblemfinder .fspf-contact .form-group {
  margin-bottom: 14px;
}
#fsproblemfinder .fspf-label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  color: #253041;
}
