/* === STRUCTURE ============================================================ */
body {
  font-family: 'Cairo','Helvetica Neue',Arial,sans-serif;
  webkit-tap-highlight-color: #222;
  background-color: var(--color-bg-secondary);
}

main > article {
  margin: 20px 0 10px 0;
  padding: 10px 15px;
}

article > h1 {
  margin: 1rem 0;
  padding: 1rem;
}

section {
  margin: 5px 0 25px 0;
}

h1 {
  margin: 1.5rem 0;
  font-family: 'Metal Mania';
}

h2 {
  font-family: 'Metal Mania';
  margin-top: 1rem 0;
  padding-bottom: 8px;
  color: var(--color-text-emphasize);
  border-bottom: 1px solid #989898;
}

h2.with-notice {
  display: inline-flex;
  justify-content: space-between;
  width: 100%;
}
h2.with-notice .notice {
  font-size: 0.5em;
  align-self: flex-end;
}

h4 {
  font-size: 1.2rem;
}

@media (max-width: 768px) {
  main > article {
    margin: 0;
  }

  article > h1 {
    padding: 0;
  }

  h2 {
    color: var(--color-bg-secondary);
    background-color: var(--color-text-emphasize);

    margin: 0 -15px;
    padding: 5px 10px;
    margin-bottom: 20px;
  }
}

.container-md {
  color: var(--color-text-primary);
  background-color: var(--color-bg-primary);
  padding: 0;
}

@media (max-width: 768px) {
  article > section {
    margin-top: 0;
  }
}


/* === CONTENT ============================================================== */

span.primary {
  color: var(--color-text-emphasize);
}
span.strong {
  font-weight: bold;
}

a, a:visited, a:hover, a:active {
  color: white;
}

/* === ICONS ================================================================ */

.icon-primary {
  fill: var(--color-text-emphasize);
}

.icon-secondary {
  fill: var(--color-text);
}

/* === FOOTER =============================================================== */

footer.footer {
  margin-top: 20px;
  margin-bottom: 20px;
  padding-top: 10px;
}

footer a, footer a:visited {
  color: var(--color-text-primary);
  text-decoration: none;
}
footer ul {
  text-align: left;
}

footer ul li {
  list-style: none;
}

footer > div .social-media {
  margin-top: 5px;
}
footer > div .social-media a,
footer > div .social-media a:hover {
  text-decoration: none;
  margin: 0 5px;
}
footer > div .social-media a img {
  height: 2rem;
  background-color: var(--color-text-emphasize);
}


@media (max-width: 768px) {
  footer ul {
    text-align: center;
    margin: 0;
    padding: 0;
  }
  footer .row {
    margin: 0;
  }
  footer .row > div {
    margin: 5px 0;
  }
}

/* === SNIPPETS / Carousel ================================================== */

.carousel-indicators {
  background-color: #989898;
}
