@import "extensions/tabbed.css";

/* Make the main content area, header, and footer extremely wide at all breakpoints */
.md-main__inner,
.md-content__inner,
.md-content,
.md-grid,
.md-header,
.md-footer,
.md-footer-meta,
.md-footer-meta__inner {
  max-width: none !important;
  width: 100vw !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.md-typeset pre,
.md-typeset table {
  max-width: 98vw !important;
}

/* Prevent Material for MkDocs from capping width at large breakpoints */
@media screen and (min-width: 76.25em) {
  .md-sidebar--primary,
  .md-sidebar--secondary {
    max-width: 20vw !important;
  }
  .md-main__inner,
  .md-content__inner,
  .md-content,
  .md-grid,
  .md-header,
  .md-footer,
  .md-footer-meta,
  .md-footer-meta__inner {
    max-width: none !important;
    width: 100vw !important;
  }
}

/* Hero banner parallax-like effect for MkDocs Material */
.mdx-hero {
  position: relative;
  left: 0;
  right: 0;
  width: 100vw;
  min-height: 100vh;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
    url("/assets/images/background_image.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  color: #fff;
  text-align: center;
  z-index: 1;
  --parallax-title: 0px;
  --parallax-subtitle: 0px;
  --parallax-desc: 0px;
}
.mdx-hero__title {
  font-size: 3rem;
  font-weight: bold;
  margin: 0.5em 0 0.2em 0;
  letter-spacing: 0.02em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  transform: translateY(var(--parallax-title, 0px));
}
.mdx-hero__subtitle {
  font-size: 1.5rem;
  font-weight: 400;
  margin-bottom: 1em;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  transition:
    opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  transform: translateY(var(--parallax-subtitle, 0px));
}
.mdx-hero__desc {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  transform: translateY(var(--parallax-desc, 0px));
}
@media (max-width: 600px) {
  .mdx-hero__title {
    font-size: 2rem;
  }
  .mdx-hero__subtitle {
    font-size: 1.1rem;
  }
}

/* Fade-in effect for hero and main content (faster) */
.mdx-hero,
.md-content,
.md-main__inner,
.md-typeset {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.mdx-hero.fade-in,
.md-content.fade-in,
.md-main__inner.fade-in,
.md-typeset.fade-in {
  opacity: 1;
  transform: none;
}

/* Optional: fade in blog post cards, tabs, and images (faster) */
.md-typeset .tabbed-block,
.md-typeset img,
.md-typeset pre,
.md-typeset blockquote {
  opacity: 0;
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.md-typeset .tabbed-block.fade-in,
.md-typeset img.fade-in,
.md-typeset pre.fade-in,
.md-typeset blockquote.fade-in {
  opacity: 1;
}
