/* Homepage content: full-width layout, showcase cards, navigation boxes. */

body.bd-index-page .bd-main {
  flex: 1 1 100%;
  max-width: 100%;
}

body.bd-index-page .bd-main > .bd-content {
  width: 100%;
  max-width: 100% !important;
  margin: 0;
  padding: 0;
}

body.bd-index-page .bd-article-container,
body.bd-index-page .bd-article-container .bd-article {
  width: 100% !important;
  max-width: 100% !important;
}

body.bd-index-page .bd-sidebar-secondary,
body.bd-index-page #pst-secondary-sidebar,
body.bd-index-page .bd-breadcrumbs,
body.bd-index-page article.bd-article > section:first-of-type > h1:first-of-type {
  display: none !important;
}

body.bd-index-page article.bd-article > section {
  width: 100%;
  max-width: var(--ld-content);
  margin: 0 auto;
  padding: 3.2rem 1.5rem 0;
}

body.bd-index-page article.bd-article > section:last-of-type {
  padding-bottom: 2rem;
}

body.bd-index-page article.bd-article > section > h1 {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  width: 100%;
  margin: 0 0 1.2rem;
  border: 0;
  color: var(--pst-color-text-base, var(--ld-ink));
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  font-weight: 800;
  letter-spacing: 0;
}

body.bd-index-page article.bd-article > section > h1::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--pst-color-border, var(--ld-border)), transparent);
}

.showcase-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 16.5rem), 1fr));
  gap: 1rem;
}

.showcase-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 21rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--pst-color-border, var(--ld-border)) 86%, transparent);
  border-radius: var(--ld-radius);
  background: color-mix(in srgb, var(--pst-color-background, var(--ld-card)) 96%, #2563eb 4%);
  box-shadow: 0 12px 30px rgba(28, 45, 74, 0.07);
  color: inherit;
  text-decoration: none !important;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.showcase-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(145deg, rgba(37, 99, 235, 0.07), transparent 42%);
  opacity: 0;
  transition: opacity 0.18s ease;
}

.showcase-card:hover {
  border-color: color-mix(in srgb, var(--pst-color-primary, var(--ld-blue)) 70%, var(--ld-border));
  box-shadow: 0 20px 48px rgba(28, 45, 74, 0.12);
  color: inherit;
  transform: translateY(-4px);
}

.showcase-card:hover::before {
  opacity: 1;
}

.showcase-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 8.8rem;
  padding: 1.25rem;
  border-bottom: 1px solid var(--pst-color-border, var(--ld-border));
  background: transparent;
}

.showcase-card__media img {
  width: auto;
  max-width: min(82%, 12rem);
  max-height: 6.4rem;
  object-fit: contain;
  background: transparent !important;
  filter: drop-shadow(0 12px 20px rgba(28, 45, 74, 0.14));
}

html[data-bs-theme="dark"] .showcase-card,
html[data-theme="dark"] .showcase-card {
  background: color-mix(in srgb, var(--pst-color-background, #0f1217) 88%, #7db7ff 12%);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.34);
}

html[data-bs-theme="dark"] .showcase-card__media,
html[data-theme="dark"] .showcase-card__media {
  background: transparent;
}

html[data-bs-theme="dark"] .showcase-card__media img,
html[data-theme="dark"] .showcase-card__media img {
  filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.32));
}

.showcase-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.2rem;
  height: 4.2rem;
  border-radius: 8px;
  background: #fff;
  color: var(--pst-color-primary, var(--ld-blue));
  font-size: 1.75rem;
  box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.16);
}

html[data-bs-theme="dark"] .showcase-card__icon,
html[data-theme="dark"] .showcase-card__icon {
  background: rgba(255, 255, 255, 0.08);
}

.showcase-card__body {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 1.15rem 1.2rem 1.2rem;
}

.showcase-card__tag,
.showcase-card__more {
  display: inline-flex;
  align-items: center;
  width: fit-content;
}

.showcase-card__tag {
  min-height: 1.55rem;
  margin-bottom: 0.55rem;
  padding: 0.12rem 0.55rem;
  border: 1px solid color-mix(in srgb, var(--pst-color-primary, var(--ld-blue)) 22%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--pst-color-primary, var(--ld-blue)) 10%, transparent);
  color: var(--pst-color-primary, var(--ld-blue));
  font-size: 0.72rem;
  font-weight: 750;
}

.showcase-card__title {
  color: var(--pst-color-text-base, var(--ld-ink));
  font-size: 1.03rem;
  font-weight: 800;
  line-height: 1.35;
}

.showcase-card__desc {
  margin-top: 0.48rem;
  color: var(--pst-color-text-muted, var(--ld-muted));
  font-size: 0.9rem;
  line-height: 1.68;
}

.showcase-card__more {
  gap: 0.38rem;
  margin-top: auto;
  padding-top: 0.85rem;
  color: var(--pst-color-primary, var(--ld-blue));
  font-size: 0.82rem;
  font-weight: 800;
}

.showcase-card__more i {
  font-size: 0.75rem;
  transition: transform 0.18s ease;
}

.showcase-card:hover .showcase-card__more i {
  transform: translateX(3px);
}

body.bd-index-page article.bd-article > section:nth-of-type(2) {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  padding-top: 2.4rem;
}

body.bd-index-page article.bd-article > section:nth-of-type(2) > h1 {
  grid-column: 1 / -1;
  margin-bottom: 0.2rem;
}

@media (min-width: 760px) {
  body.bd-index-page article.bd-article > section:nth-of-type(2) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

body.bd-index-page article.bd-article .toctree-wrapper {
  height: 100%;
  margin: 0;
  padding: 1.15rem 1.2rem;
  border: 1px solid var(--pst-color-border, var(--ld-border));
  border-radius: var(--ld-radius);
  background: var(--pst-color-surface, var(--ld-surface));
  box-shadow: var(--ld-shadow-sm);
}

body.bd-index-page article.bd-article .toctree-wrapper p.caption {
  display: flex;
  align-items: center;
  gap: 0.42rem;
  margin: 0 0 0.65rem;
  color: var(--pst-color-primary, var(--ld-blue));
  font-size: 0.76rem;
  font-weight: 850;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.bd-index-page article.bd-article .toctree-wrapper p.caption::before {
  content: "\f02d";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  letter-spacing: 0;
}

body.bd-index-page article.bd-article .toctree-wrapper ul {
  margin-bottom: 0;
}

body.bd-index-page article.bd-article .toctree-wrapper li {
  margin: 0.08rem 0;
}

body.bd-index-page article.bd-article .toctree-wrapper li > a {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.34rem 0.45rem;
  border-radius: 6px;
  color: var(--pst-color-text-base, var(--ld-ink));
  text-decoration: none;
}

body.bd-index-page article.bd-article .toctree-wrapper li > a::before {
  content: "\f105";
  color: var(--pst-color-text-muted, var(--ld-muted));
  font-family: "Font Awesome 6 Free";
  font-size: 0.72rem;
  font-weight: 900;
}

body.bd-index-page article.bd-article .toctree-wrapper li > a:hover {
  background: color-mix(in srgb, var(--pst-color-primary, var(--ld-blue)) 10%, transparent);
  color: var(--pst-color-primary, var(--ld-blue));
}

@media (max-width: 640px) {
  body.bd-index-page article.bd-article > section {
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .showcase-card {
    min-height: 0;
  }

  .showcase-card__media {
    min-height: 7rem;
  }
}
