body {
  font-family: 'Montserrat', sans-serif;
  color: #333;
  font-weight: 400; }

img {
  max-width: 100%;
  height: auto; }

a {
  color: #f01418;
  text-decoration: none; }

a:hover {
  color: #666; }

abbr[title] {
  text-decoration: none; }

.container {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  overflow: hidden; }

.overlay {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  background: rgba(51, 51, 51, 0.3);
  opacity: 1;
  transition: all 0.6s; }

.top-menu {
  font-weight: 600; }
  .top-menu ul {
    padding: 0;
    margin: 0;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row;
    justify-content: center;
    list-style: none;
    flex-wrap: wrap;
    align-content: space-around; }
  .top-menu a {
    padding: 0 1rem; }

footer {
  overflow: hidden;
  background: #333;
  color: #fff; }
  footer a {
    color: #fff; }
  footer a:hover {
    color: #fff;
    text-decoration: underline; }

.copyright {
  font-size: 0.8em;
  text-align: center; }

/* front page */
.front-header {
  background: #333;
  overflow: hidden;
  position: relative; }
  .front-header .container {
    position: relative;
    z-index: 2; }

.front-grid {
  position: relative; }
  .front-grid a {
    text-decoration: none;
    color: #fff; }
  .front-grid img {
    position: relative;
    z-index: 1; }

.front-grid:hover .overlay {
  opacity: 0; }

.front-label {
  color: #fff;
  z-index: 4;
  position: absolute;
  margin: 0;
  font-size: 1.4rem;
  text-transform: lowercase;
  font-weight: normal; }

.journalist {
  right: 10.5rem;
  bottom: 1rem; }

.speaker {
  left: 10.5rem;
  bottom: 1rem; }

.musician {
  right: 10.5rem;
  top: 1rem; }

.author {
  left: 10.5rem;
  top: 1rem; }

.front-title {
  background: #333;
  color: #fff;
  text-align: center;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  position: absolute;
  z-index: 5;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  right: 0;
  margin: auto;
  padding: 1.2rem;
  width: 15rem;
  font-size: 2.5rem; }

/* inside pages */
.inside-logo {
  border: 2px solid #333;
  text-transform: uppercase;
  text-align: center;
  font-size: 2rem;
  padding: 1.2rem;
  color: #333; }

nav {
  text-transform: lowercase;
  font-weight: 400; }
  nav ul {
    padding: 0;
    text-align: right; }
  nav li.current-menu-item a {
    color: #f01418; }
  nav a {
    color: #666; }
  nav a:hover {
    color: #f01418; }

/* blog */
.entry-title a {
  color: #666; }

.entry-title a:hover {
  color: #f01418; }

/* other classes */
.button {
  display: inline-block;
  background: #666;
  border: none;
  border-radius: 0.5em;
  color: #fff;
  text-transform: uppercase;
  font-weight: bold;
  padding: 0.7em 1em; }

.button:hover {
  background: #f01418;
  color: #fff; }

.clear {
  clear: both; }

img.alignleft {
  float: left;
  margin-right: 15px;
  margin-bottom: 5px; }

img.alignright {
  float: right;
  margin-left: 15px;
  margin-bottom: 5px; }

img.aligncenter {
  display: block;
  margin: 0 auto; }

.wp-caption {
  border: none;
  text-align: left;
  background: none;
  padding: 0;
  margin: 1em auto; }

.wp-caption-text {
  font-size: 0.9em;
  font-style: italic; }

/* mobile styles */
@media screen and (max-width: 800px) {
  .inside-logo {
    font-size: 1.6rem; } }

@media screen and (max-width: 700px) {
  .front-title {
    width: 11rem;
    font-size: 2rem; } }

@media screen and (max-width: 480px) {
  .front-title {
    position: relative;
    top: 0;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0);
    font-size: 1.6rem;
    width: 100%; }
  .front-label {
    font-size: 1rem; }
  .journalist, .musician {
    right: 1rem; }
  .speaker, .author {
    left: 1rem; }
  .inside-image {
    width: 60%; }
  nav {
    width: 40%;
    float: right; }
    nav ul {
      margin-top: 0;
      text-align: left;
      margin-left: 1rem; }
  .page-title {
    margin-top: 0; } }
