:root {
  --responsive-width-xl: calc(30px + 1.5vw);
  --responsive-width-lg: calc(20px + 1.5vw);
  --responsive-width-md: calc(10px + 1.5vw);
  --responsive-width-sm: calc(5px + 1.5vw);
  --utf-yellow: rgba(197, 184, 82, 1);
  --bf6-orange: rgb(232 55 0);
  --bf2046-teal: rgba(38, 255, 222);
}

@font-face {
  font-family: bf-bold;
  src: url(../fonts/BF_Modernista-Bold.ttf);
}

@font-face {
  font-family: bf-heading;
  font-weight: 700;
  src: url('../fonts/BF_SUB_HEADLINE_BOLD.ttf') format('truetype');
}

@font-face {
  font-family: bf-display;
  font-weight: 700;
  src: url('../fonts/BF_HEADLINE_NARROW-BOLD.ttf') format('truetype');
}

@font-face {
  font-family: bf-body;
  font-weight: 400;
  src: url('../fonts/BF_TEXT_REGULAR.ttf') format('truetype');
}

@font-face {
  font-family: bf-utility;
  font-weight: 350;
  src: url('../fonts/BF_MONO_BOOK.ttf') format('truetype');
}

body,
html {
  height: 100%;
  color: #ccc;
}

main {
  position: relative;
  background-color: #2E2E2E;
  box-shadow: 0px -2rem 2rem .5rem rgba(0,0,0,0.35);
  z-index: 1;
}

footer {
  position: relative;
  background-color: #2E2E2E;
  z-index: 1;
}

#intro {
  position: relative;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: url(https://cdnjs.cloudflare.com/ajax/libs/vegas/2.3.1/overlays/03.png);
}

#hero-vid {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-height: 100%;
  min-width: 100%;
  width: auto;
  height: auto;
  z-index: -10;
}

#hero-container {
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin-top: 1rem;
  padding-left: 1rem;
  padding-right: 1rem;
  margin-bottom: 1rem;
}

.hero-text h2 {
  margin-bottom: 0;
}

.hero-text h1 {
  text-transform: uppercase;
  background: linear-gradient(to bottom, rgba(197,184,82,1) 0%, rgba(90,76,26,1) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

nav#menu {
  margin: 0;
  padding: 0 var(--responsive-width-xl);
}

nav#menu .navbar-collapse,
nav#menu .navbar-collapse .dropdown-menu {
  text-align: right;
}

nav#menu .navbar-brand,
nav#menu .nav-link {
  font-family: 'utf-menu', sans-serif;
  font-size: 20px;
  text-decoration: none;
  text-transform: uppercase;
  color: #515A5F;
}

nav#menu.sticky-menu {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030;
}

@media(min-width: 768px) {
  nav#menu .navbar-collapse,
  nav#menu .navbar-collapse .dropdown-menu {
    text-align: left;
  }
}

article .section-heading {
  font-family: 'utf-menu', sans-serif;
  padding: 2rem 0;
  text-align: center;
}

article .section-media {
  margin: 2rem 0;
  padding: 0 2rem;
  flex: 1 0;
  min-height: 300px;
}

article .section-desc {
  margin: 2rem 0;
  padding: 2rem;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
  border: 0;
  border-radius: .25rem;
}

article .frame-container {
  margin: 1rem 2rem;
}

section.parallax {
  margin: 0 -.75rem;
  padding: 4rem var(--responsive-width-xl);
  min-height: 200px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: inset 0px 2rem 2rem -.50rem rgba(0,0,0,0.35),
              inset 0px -2rem 2rem -.50rem rgba(0,0,0,0.35);
}

section .section-content {
  display: flex;
  margin: auto;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  max-width: 95ch;
}

footer {
  color: rgba(197,184,82,1);
}

footer a,
footer a:hover,
footer a:visited,
footer a:active {
  color: rgba(197,184,82,1);
  text-decoration: none;
}

footer a:hover  {
  text-decoration: underline;
}


/* Page: Battlefield */

#hero-bf-branding {
  margin: 1rem;
}

.hero-bf-title {
  font-family: bf-bold;
  font-size: 2.5rem;
  color: var(--utf-yellow);
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: rgba(0, 0, 0, 0.75);
  text-shadow: rgba(0, 0, 0, 0.50) 0px 0px 5px;
  white-space: nowrap;
  line-height: 1.25;
}

#hero-bf-cta {
  margin: 1rem;
  color: #fff;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: rgba(0, 0, 0, 0.75);
  text-shadow: rgba(0, 0, 0, 0.50) 0px 0px 5px;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
}

a.hero-bf-button {
  display: inline-block;
  text-align: center;
  text-decoration: none;
  padding: .5rem 1.5rem;
  color: var(--utf-yellow);
  border-width: .125rem;
  border-style: solid;
  border-color: var(--utf-yellow);
  border-radius: 999em;
  background-color: rgba(0, 0, 0, .25);
  font-size: 1.5rem;
  font-weight: 700;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: rgba(0, 0, 0, 0.75);
}

#article-features {
  margin: 0 -.75rem;
  padding: 0 .75rem;
  background: url(https://cdnjs.cloudflare.com/ajax/libs/vegas/2.3.1/overlays/08.png) left top repeat,
              linear-gradient( rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25) ),
              url("../media/battlefield_basejump.jpg") center center/cover no-repeat;
  color: #fff;
  box-shadow: inset 0px 1rem 1rem -0.5rem rgb(0 0 0 / 35%),
              inset 0px -1rem 1rem -0.5rem rgb(0 0 0 / 35%);
}

#article-features .section-heading {
  text-align: center;
  background-color: #2E2E2E;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
}

#article-features .section-heading h1 {
  margin: 0;
  font-size: 2.5rem;
  font-family: bf-bold;
  font-weight: 600;
  line-height: 1;
  color: var(--utf-yellow);  
}

#article-features .section-content {
  align-items: stretch;
  align-content: stretch;
}

#article-features .feature {
  flex-grow: 1;
  margin: 1rem;
  padding: 1rem 3rem;
  background-color: rgba(0, 0, 0, .80);
  border: 1px solid var(--utf-yellow);
  border-radius: .25rem;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
}

#article-features .feature h2 {
  text-transform: uppercase;
  color: var(--utf-yellow);
  font-family: bf-bold;
}

#article-features .feature div {
  margin: 0 auto;
  padding: 1rem 0;
}

#article-modes {
  margin: 0 -.75rem;
  padding: 0 1rem 1rem 1rem;
  background: url(https://cdnjs.cloudflare.com/ajax/libs/vegas/2.3.1/overlays/08.png) left top repeat,
              linear-gradient( rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5) ),
              url("../media/battlefield_wingsuit.jpg") center center/cover no-repeat;
  box-shadow: inset 0px 1rem 1rem -0.5rem rgb(0 0 0 / 35%),
              inset 0px -1rem 1rem -0.5rem rgb(0 0 0 / 35%);
  z-index: -100;
}

#article-modes .section-heading {
  margin: -1rem -1rem 0 -1rem;
  background-color: #2E2E2E;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
}

#article-modes .section-heading h1 {
  margin: 0;
  font-size: 2.5rem;
  font-family: bf-bold;
  font-weight: 600;
  line-height: 1;
  color: var(--bf6-orange);  
}

#article-modes .section-body {
  margin: 2rem auto;
  padding: 1rem 2rem;
  color: #ddd;
  background-image: linear-gradient(85deg, rgba(34, 34, 39, .90), rgba(38, 38, 43, .90));
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
  border: 0;
  border-radius: .5rem;
  max-width: 120ch;
}

#article-modes .mode-info {
  margin: 0 auto;
  text-align: justify;
  max-width: 50ch;
}

#article-modes .mode-video-bf {
  margin: auto 0;
}

#article-reviews {
  margin: 0 -.75rem;
  padding: 0 .75rem;
  background: url(https://cdnjs.cloudflare.com/ajax/libs/vegas/2.3.1/overlays/08.png) left top repeat,
              linear-gradient( rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5) ),
              url("../media/battlefield_basejump.jpg") center center/cover no-repeat;
  color: #fff;
  box-shadow: inset 0px 1rem 1rem -0.5rem rgb(0 0 0 / 35%),
              inset 0px -1rem 1rem -0.5rem rgb(0 0 0 / 35%);
}

#article-reviews .section-heading {
  text-align: center;
  background-color: #2E2E2E;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
}

#article-reviews .review-block {
  display: flex;
  flex-direction:column;
  flex-grow: 1;
  margin: 1rem;
  padding: 1rem 2rem;;
  text-align: justify;
  background-color: rgba(0, 0, 0, .80);
  border: 1px solid var(--bf6-orange);;
  border-radius: .25rem;
  box-shadow: 0 .25rem .50rem 0 rgba(0,0,0,.16),
              0 .25rem 1rem 0 rgba(0,0,0,.12);
}

#article-reviews img.opencritic-outlet {
  width: 48px;
  height: 48px;
  border-radius: 100%;
  border-style: none;
  vertical-align: middle;
}

.bf-heading {
  font-family: bf-heading;
}

.bf-display {
  font-family: bf-bold;
}

.bf-text-teal {
  color: var(--bf2046-teal);
}

.bf-text-orange {
  color: var(--bf6-orange);
}

.bf-text-stroke-dark {
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: black;
}

.bf-bg-teal {
  background-color: var(--bf2042-teal);
}

.bf-bg-orange {
  background-color: var(--bf6-orange);
}

.btn-bf6 {
  color: #000;
  background-color: var(--bf6-orange);
  font-size: 1rem;
  font-family: bf-heading;
  font-weight: 600;
}