/* --- Inter font (variable, self-hosted) --- */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../fonts/inter/InterVariable.woff2") format("woff2");
}

@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url("../fonts/inter/InterVariable-Italic.woff2") format("woff2");
}

/* --- JetBrains Mono font (self-hosted) --- */
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/jetbrains-mono/JetBrainsMono-Regular.woff2") format("woff2");
}

@font-face {
  font-family: "JetBrains Mono";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/jetbrains-mono/JetBrainsMono-Italic.woff2") format("woff2");
}

@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/jetbrains-mono/JetBrainsMono-Bold.woff2") format("woff2");
}

@font-face {
  font-family: "JetBrains Mono";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/jetbrains-mono/JetBrainsMono-BoldItalic.woff2") format("woff2");
}

/* --- DHI theme defaults --- */
:root {
  --md-text-font: "Inter", Arial, sans-serif;
  --md-code-font: "JetBrains Mono", monospace;
}

[data-md-color-primary="custom"] {
  --md-primary-fg-color: #2146a4;
  --md-primary-fg-color--light: #4a6bb8;
  --md-primary-fg-color--dark: #193580;
  --md-accent-fg-color: #0098DB;
  --md-typeset-a-color: #004165;
}

/* Dark mode overrides */
[data-md-color-scheme="slate"][data-md-color-primary="custom"] {
  --md-typeset-a-color: #4a9fd4;
  --md-accent-fg-color: #0098DB;
}

/* Links: hover color */
.md-typeset a:hover {
  color: #0098DB;
}

/* --- Banner: full-width, no padding --- */
.md-banner__inner.md-grid {
  max-width: none;
  padding: 0;
  margin: 0;
}

/* --- Scrollbar: hidden for page --- */
html {
  scrollbar-width: none;
}
html::-webkit-scrollbar {
  display: none;
}

/* --- Footer --- */
.md-footer {
  background-color: var(--md-primary-fg-color);
}
.md-footer__link {
  margin-top: .2rem;
  margin-bottom: .2rem;
}
.md-footer-meta {
  background-color: #1c3a86;
}
.md-footer-meta .md-social {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.md-footer-meta .md-social .dhi-build-info {
  display: flex;
  gap: 1rem;
  width: 100%;
  justify-content: flex-end;
  color: rgba(255, 255, 255, .45);
  font-size: .55rem;
  font-family: var(--md-text-font);
}

/* --- Announcement Banner --- */
.dhi-banner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 3rem;
  padding: .6rem 2.5rem;
  background-color: var(--md-primary-fg-color);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff;
  overflow: hidden;
  box-sizing: border-box;
}
.dhi-banner__text {
  font-size: .8rem;
  font-weight: 600;
  font-family: var(--md-text-font);
  color: #fff;
  text-decoration: none;
  text-align: center;
  z-index: 1;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .3);
}
a.dhi-banner__text:hover {
  text-decoration: underline;
  color: #fff;
}
.dhi-banner__dismiss {
  position: absolute;
  right: .6rem;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: #fff;
  font-size: 1.2rem;
  cursor: pointer;
  padding: .2rem .4rem;
  line-height: 1;
  opacity: .7;
  z-index: 1;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .3);
}
.dhi-banner__dismiss:hover {
  opacity: 1;
}

/* Full-width banner inner (remove Material grid constraints) */
.md-header__button.md-logo img {
  vertical-align: middle;
}

/* --- Version selector dropdown --- */
.dhi-version-selector {
  position: relative;
  display: flex;
  align-items: center;
  margin-left: .4rem;
  margin-right: .4rem;
  flex-shrink: 0;
}
.dhi-version-selector__button {
  display: flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .6rem;
  font-size: .7rem;
  font-family: var(--md-text-font);
  color: var(--md-primary-bg-color);
  background: transparent;
  border: 1px solid rgba(255, 255, 255, .3);
  border-radius: .2rem;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.6;
}
.dhi-version-selector__button:hover {
  border-color: rgba(255, 255, 255, .6);
}
.dhi-version-selector__button::after {
  content: "";
  display: inline-block;
  border-left: .25rem solid transparent;
  border-right: .25rem solid transparent;
  border-top: .3rem solid currentColor;
  margin-left: .2rem;
}
.dhi-version-selector--open .dhi-version-selector__button::after {
  border-top: none;
  border-bottom: .3rem solid currentColor;
}
.dhi-version-selector__list {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  margin: .2rem 0 0;
  padding: .3rem 0;
  list-style: none;
  background: var(--md-default-bg-color);
  border-radius: .2rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .2);
  min-width: 100%;
  z-index: 10;
}
.dhi-version-selector--open .dhi-version-selector__list {
  display: block;
}
.dhi-version-selector__item a {
  display: block;
  padding: .3rem .8rem;
  font-size: .7rem;
  color: var(--md-default-fg-color);
  text-decoration: none;
  white-space: nowrap;
}
.dhi-version-selector__item a:hover {
  background: var(--md-accent-fg-color--transparent, rgba(0, 152, 219, .1));
  color: var(--md-accent-fg-color);
}
.dhi-version-selector__item--active a {
  font-weight: 700;
  color: var(--md-accent-fg-color);
}
