/* wanderers */

/* fonts */
@font-face {
  font-family: "Bebas Neue";
  src: url('../fonts/Bebas_Neue/BebasNeue-Regular.ttf') format('truetype');
}

@font-face {
  font-family: "Jost";
  src: url('../fonts/Jost/Jost-VariableFont_wght.ttf') format('truetype');
}

:root {
  --color-scheme: dark;
  --font-family: system-ui;
  --color-orange: hsl(28, 94%, 49%); /* #F27407 */
  --color-oranger: hsl(21, 100%, 50%); /* #FF5A00 */
  --color-orangest: hsl(18, 94%, 49%); /* #F24D07 */

  --color-outerspace: hsl(191, 8%, 28%); /* #708090 */
  --color-metal: hsl(200, 15%, 19%); /* #2A3439 */
  --color-jet-black: hsl(240, 7%, 6%); /* #0E0E10 */
  --color-black: hsl(0, 0%, 0%); /* #000000 */
  --color-eigengrau: hsl(240, 14%, 10%); /* #16161D */
  --color-brightlight: hsl(60, 31%, 94%); /* #F4F4EA */

  --color-selective-yellow: hsl(42, 100%, 50%); /* #FFB101 */
  --color-sunglow: hsl(42, 100%, 60%); /* #FFC134 */

  --color-sundance-shade: hsl(50, 38%, 42%); /* #938642 */
  --color-sundance: hsl(50, 48%, 56%); /* #C5B358 */
  --color-sundance-tint: hsl(50, 48%, 77%); /* #E1D8A9 */

  /* https://pagefind.app/docs/ui-usage/#customising-the-styles */
  --pagefind-ui-scale: 1;
  --pagefind-ui-primary: var(--color-brightlight);
  --pagefind-ui-text: var(--color-brightlight);
  --pagefind-ui-background: var(--color-jet-black);
  --pagefind-ui-border: var(--color-eigengrau);
  --pagefind-ui-border: var(--color-eigengrau);
  --custom-pagefind-width: 500px;
}
/* keep Pagefind UI a fixed width (but not wider than the viewport) */
#search,
#search .pagefind-ui,
#search .pagefind-ui__header,
#search .pagefind-ui__input {
  width: var(--custom-pagefind-width);
  max-width: 100%;
  box-sizing: border-box;
}
/* make the input fill its container so it doesn't trigger auto-resize */
#search .pagefind-ui__input input {
  width: 100%;
  min-width: 0;
}
/* make results/dropdown match the container width */
#search .pagefind-ui__results,
#search .pagefind-ui__sub-results {
  width: 100%;
  min-width: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  color-scheme: var(--color-scheme);
  /* Prevent font size inflation */
  text-size-adjust: none;
  color-scheme: dark;
  color: var(--color-brightlight);
}

body {
  line-height: 1.5;
  font-family: "Jost", sans-serif;
  font-weight: 400;
  background-color: var(--color-black);
  color: var(--color-brightlight);
  max-width: 1024px;
  margin: 0em auto;
  min-height: 100vh;
  /* box-shadow: 0px 0px 100px 50px var(--color-jet-black); */
}

hr {
  margin: 1rem;
  background-image: linear-gradient(
    90deg,
    transparent,
    var(--color-eigengrau),
    transparent
  );
  border: 0;
  height: 1px;
}

q {
  font-style: italic;
  border-left: 5px solid var(--color-outerspace);
  padding-left: 5px;
}

p {
  text-indent: 1rem;
}

img,
picture {
  /* Make images easier to work with */
  font-style: italic;
  text-align: center;
  max-width: 100%;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

img,
.infobox {
  /* corner-only frame */
  --border: 5px;
  --color: transparent 25%, var(--color-jet-black) 0;
  padding: 10px;
  background: conic-gradient(
        from 90deg at top var(--border) left var(--border),
        var(--color)
      )
      0 0,
    conic-gradient(
        from 180deg at top var(--border) right var(--border),
        var(--color)
      )
      100% 0,
    conic-gradient(
        from 0deg at bottom var(--border) left var(--border),
        var(--color)
      )
      0 100%,
    conic-gradient(
        from -90deg at bottom var(--border) right var(--border),
        var(--color)
      )
      100% 100%;
  background-size: 25px 25px;
  background-repeat: no-repeat;
}

figcaption {
  text-align: center;
  font-family: monospace;
}

li {
  list-style-type: square;
  margin-left: 1rem;
}

a {
  color: var(--color-orange);
}
a:hover {
  color: var(--color-oranger);
}
a:visited {
  color: var(--color-orangest);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-transform: uppercase;
  font-family: "Bebas Neue", sans-serif;
  font-weight: 200;
  font-size: clamp(1rem, 5vw + 1rem, 3rem);
  border-bottom: 3px solid var(--color-eigengrau);
  margin-bottom: 1rem;
}

h1 {
  font-weight: 500;
  font-size: clamp(1rem, 5vw + 1rem, 4rem);
  text-align: center;
  background-color: var(--color-eigengrau);
}

h2 {
  font-family: "Jost", sans-serif;
}

main {
  padding: 1rem;
}

.infobox {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  max-width: max-content;
  margin: auto;
}

dl {
  text-align: center;
  background-color: var(--color-outerspace);
  border-right: 1px solid var(--color-jet-black);
}

dl:last-child {
  border-right: none;
}

dt {
  text-transform: uppercase;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.25rem;
  background-color: var(--color-metal);
  padding: 0.5rem;
}

dd {
  font-family: "Bebas Neue", sans-serif;
  padding: 0.5rem;
  text-align: center;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.logo-container {
  display: flex;
  justify-content: center;
}

.nav-flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.header {
  background-color: var(--color-black);
  position: relative;
  border-bottom: 5px solid var(--color-eigengrau);
}

.header .logo {
  padding-top: 1rem;
}

.header .nav {
  padding: 1rem;
  background-color: var(--color-jet-black);
  margin-bottom: 1rem;
}

.header .logo a {
  font-size: clamp(3rem, 5vw + 1rem, 5rem);
  color: var(--color-brightlight);
  font-family: "Bebas Neue", sans-serif;
  text-transform: uppercase;
  transition: all 0.5s ease 0s;
}

.header .logo a:hover {
  color: var(--color-orangest);
}

.header .nav ul li {
  display: inline-block;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

.header .nav ul li a {
  display: block;
  font-size: 1.5rem;
  color: var(--color-brightlight);
  text-transform: uppercase;
  text-align: center;
  font-family: "Bebas Neue", sans-serif;
  transition: all 0.25s ease 0s;
  padding-top: 0.5rem;
  padding-right: 1.75rem;
  padding-bottom: 0.5rem;
  padding-left: 1.75rem;
}

.header .nav ul li a:hover {
  color: var(--color-orange);
  background-color: var(--color-eigengrau);
}

.header .nav ul li a.active {
  color: var(--color-brightlight);
  background-color: var(--color-oranger);
}
.header .nav ul li a.active:hover {
  background-color: var(--color-orangest);
}

.header #nav-check {
  position: absolute;
  opacity: 0; /* hide the tickbox */
  pointer-events: none;
}

.nav-toggler {
  height: 2.75rem;
  width: 3rem;
  background-color: var(--color-eigengrau);
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
}

/* ≡ (hamburger) icon */
.nav-toggler span {
  /* center line */
  display: block;
  height: 0.125rem;
  width: 1.25rem;
  background-color: var(--color-brightlight);
  position: relative;
}

.nav-toggler span::before,
.nav-toggler span::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: var(--color-brightlight);
  left: 0;
}

.nav-toggler span::before {
  top: -0.45rem;
}

.nav-toggler span::after {
  top: 0.45rem;
}

.cta {
  background-color: var(--color-sundance-shade) !important;
  color: var(--color-sundance) !important;
  background: linear-gradient(
      90deg,
      var(--color-sundance-shade),
      var(--color-sundance)
    ),
    linear-gradient(
      90deg,
      var(--color-sundance-shade),
      var(--color-sundance),
      var(--color-sundance-tint)
    );
  background-size: 100% 5px, 0 5px;
  background-position: 100% 100%, 0 100%;
  background-repeat: no-repeat;
  transition: background-size 500ms;
}

.cta:hover {
  color: var(--color-sundance-tint) !important;
  background-size: 0 5px, 100% 5px;
}

.logo-container .logo a,
.nav-flex .nav ul li a {
  text-decoration: none;
}

footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-top: 5px solid var(--color-eigengrau);
  padding-top: 1rem;
  padding-bottom: 1rem;
}

footer li {
  font-family: "Bebas Neue", sans-serif;
  text-transform: uppercase;
  display: inline;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  margin: 0;
  color: var(--color-orange);
  border-right: 1px solid var(--color-outerspace);
}

footer li:last-child {
  border-right: none;
}

footer li a:hover,
footer p a:hover {
  text-decoration: underline;
  color: var(--color-oranger);
}

footer a,
footer li a {
  color: var(--color-orange);
}

footer a:visited,
footer li a:visited,
footer li:visited,
footer p a:visited {
  color: var(--color-orangest);
}

footer div p {
  text-align: center;
}

.hero {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 500px;
  font-family: "Bebas Neue", sans-serif;
  background: rgb(22, 59, 182);
  background: linear-gradient(
    12deg,
    rgba(22, 59, 182, 1) 0%,
    rgba(55, 9, 121, 1) 35%,
    rgba(69, 31, 166, 1) 68%,
    rgba(57, 0, 255, 1) 100%
  );
  padding: 1rem;
}
.hero h1 {
  background-color: unset;
  border-bottom: unset;
  padding: 1rem;
  text-transform: unset;
}

.featured-card-container {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: nowrap;
}

.index-card-container {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-direction: row;
  flex-wrap: wrap;
}

.card {
  text-align: center;
  margin: 1rem;
  padding: 1rem;
  background-color: var(--color-jet-black);
  border: 5px solid var(--color-eigengrau);
}
.card h3 {
  font-size: 1.5rem;
}

.card p {
    width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: auto;
}

/*
  Responsive
*/

@media (max-width: 1024px) {
  .nav-toggler {
    display: flex;
  }
  .header .nav {
    position: absolute;
    left: 0;
    top: 100%;
    width: 100%;
    background-color: var(--color-jet-black);
    border-top: 1px solid var(--color-eigengrau);
    opacity: 0;
    visibility: hidden;
    z-index: 1000;
  }
  /* stack header children vertically so the Pagefind search box doesn't float next to the hamburger */
  .header {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding-bottom: 1rem;
  }

  /* make search occupy full width and sit beneath the toggler/logo */
  #search {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  .header .nav ul li {
    display: block;
    margin: 0;
  }
  .header #nav-check:checked ~ .nav {
    opacity: 1;
    visibility: visible;
  }
  .header #nav-check:focus ~ .nav-toggler {
    box-shadow: 0 0 15px var(--color-brightlight);
  }
  /* convert the ≡ (hamburger) into a "X" */
  /* hide the center line and rotate ::before and ::after to form the shape */
  .header #nav-check:checked ~ .nav-toggler span {
    background-color: transparent;
  }
  .header #nav-check:checked ~ .nav-toggler span::before {
    top: 0;
    transform: rotate(45deg);
  }
  .header #nav-check:checked ~ .nav-toggler span::after {
    top: 0;
    transform: rotate(-45deg);
  }

  .header .nav ul li a {
    padding-top: 1.25rem;
    padding-right: 1.75rem;
    padding-bottom: 1.25rem;
    padding-left: 1.75rem;
  }

  .infobox {
    flex-direction: column;
    max-width: 100%;
  }

  .infobox dl {
    margin: 0;
    border-right: none;
    border-bottom: 1px solid var(--color-jet-black);
  }

  .featured-card-container {
    flex-direction: column;
  }

  .index-card-container {
    flex-direction: column;
  }

  .card p {
    width: unset;
  }

  section p {
    word-wrap: break-word;
  }

}

/* Pagefind result text */
.pagefind-ui__result-title a {
  color: var(--color-orange) !important;
}
.pagefind-ui__result-title a:hover {
  color: var(--color-orangest) !important;
}
.pagefind-ui__result-excerpt {
  color: var(--color-outerspace);
}
/* Pagefind summary / message (e.g. "3 results for ...") */
.pagefind-ui__message,
.pagefind-ui__message * {
  color: var(--color-selective-yellow) !important;
}
/* target Pagefind's <mark> used in result excerpts */
.pagefind-ui__result-excerpt mark,
.pagefind-ui mark,
.pagefind-ui .pagefind-ui__result-excerpt mark {
  background: var(--color-selective-yellow) !important;
  color: var(--color-jet-black) !important;
}

/* keeps Pagefind search visually consistent with the nav */
#search {
  padding: 1rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* make the Pagefind UI fill the padded area while respecting our fixed width */
#search .pagefind-ui,
#search .pagefind-ui__header {
  width: 100%;
  max-width: var(--custom-pagefind-width);
  box-sizing: border-box;
  background: transparent;
}

/* customize Pagefind input focus ring */
#search .pagefind-ui__search-input {
  outline: none;
  border: 3px solid var(--color-eigengrau);
}

/* visible focus style (for keyboard users) */
#search .pagefind-ui__search-input:focus-visible {
  outline: none;
  border-color: var(--color-orange);
}

/* fallback for browsers that don't support :focus-visible */
#search .pagefind-ui__search-input:focus {
  outline: none;
  border-color: var(--color-orange);
}

/* Section heading anchors styling */
.heading-anchor {
  margin-inline-start: 0.25em;
  color: var(--color-brightlight) !important;
  text-decoration: none;
  opacity: 0.5;
  transition: all 0.25s ease 0s;
}

/* show anchor more prominently on heading hover */
:is(h2, h3, h4, h5, h6):hover .heading-anchor,
.heading-anchor:hover,
.heading-anchor:focus {
  opacity: 1;
}