/*==============================================================*/
/*     R E S E T     */
/*==============================================================*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
}

html, body {
  height: 100%;
}

abbr[title] {
  border-bottom: 1px dotted #888 !important;
  cursor: help;
}

*:focus {
  outline: 0;
}

ul {
  list-style-type: none;
}

/* Apply a natural box layout model to all elements */
*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/*==============================================================*/
/*     F O N T S     */
/*==============================================================*/
@font-face {
  font-family: "AmericanGroteskBlack";
  src: url(../fonts/AmericanGrotesk-Black.woff2) format("woff2");
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: "KometWeb";
  src: url(../fonts/Komet-Light.woff2) format("woff2"), url(../fonts/Komet-Light.woff) format("woff");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "KometWeb";
  src: url(../fonts/Komet-Regular.woff2) format("woff2"), url(../fonts/Komet-Regular.woff) format("woff");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "KometWeb";
  src: url(../fonts/Komet-Medium.woff2) format("woff2"), url(../fonts/Komet-Medium.woff) format("woff");
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: "KometWeb";
  src: url(../fonts/Komet-Bold.woff2) format("woff2"), url(../fonts/Komet-Bold.woff) format("woff");
  font-weight: 700;
  font-style: normal;
}
#breakpoints:after {
  position: fixed;
  font-size: 10px;
  line-height: 12px;
  bottom: 0;
  left: 0;
  z-index: 10000;
  content: "0";
  color: black;
  font-weight: 700;
}
@media only screen and (min-width: 480px) {
  #breakpoints:after {
    content: "1";
  }
}
@media only screen and (min-width: 640px) {
  #breakpoints:after {
    content: "2";
  }
}
@media only screen and (min-width: 780px) {
  #breakpoints:after {
    content: "3";
  }
}
@media only screen and (min-width: 900px) {
  #breakpoints:after {
    content: "4";
  }
}
@media only screen and (min-width: 1030px) {
  #breakpoints:after {
    content: "5";
  }
}
@media only screen and (min-width: 1340px) {
  #breakpoints:after {
    content: "6";
  }
}

/*==================================================================================*/
/*==================================================================================*/
/*     T Y P E     */
/*==================================================================================*/
/*==================================================================================*/
html {
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: 0.04rem;
  word-spacing: 0.08rem;
}
@media only screen and (min-width: 480px) {
  html {
    font-size: 20px;
  }
}
@media only screen and (min-width: 900px) {
  html {
    font-size: 22px;
  }
}
@media only screen and (min-width: 1340px) {
  html {
    font-size: 24px;
  }
}

body {
  font-family: AmericanGroteskBlack, Arial Black, sans-serif;
  font-weight: 900;
  color: hsl(0, 0%, 0%);
  background: hsl(53, 100%, 91%);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}

h1 {
  color: hsl(153, 28%, 41%);
}

a {
  color: hsl(0, 0%, 0%);
  text-decoration: none;
}
a:hover {
  color: hsl(153, 28%, 41%);
}
a.link-primary {
  color: hsl(153, 28%, 41%);
}
a.link-primary:hover {
  color: hsl(0, 0%, 0%);
}

.container {
  display: flex;
  flex-direction: column;
  height: 100dvh;
}
.container header {
  border-bottom: 2px solid hsl(153, 28%, 41%);
}
.container main {
  flex-grow: 1;
  border-bottom: 2px solid hsl(153, 28%, 41%);
}
.container main .row {
  height: 100%;
}

.row {
  display: flex;
  flex-direction: column;
  padding: 1rem;
}
.row .col-main {
  text-transform: uppercase;
  font-feature-settings: "case" 1;
}
.row .col-sub {
  text-transform: uppercase;
  font-feature-settings: "case" 1;
}
@media only screen and (min-width: 780px) {
  .row {
    flex-direction: row;
  }
  .row .col-main {
    flex-grow: 1;
  }
  .row .col-sub {
    text-align: right;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

.exhibit-info {
  font-size: 6vw;
  letter-spacing: 0;
  word-spacing: 0;
  padding: 1rem 0;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: center;
}
.exhibit-info p.info-primary {
  color: hsl(153, 28%, 41%);
}
@media only screen and (min-width: 780px) {
  .exhibit-info {
    font-size: 5vw;
  }
}
@media only screen and (min-width: 1340px) {
  .exhibit-info {
    font-size: 72px;
  }
}

.sub-links {
  margin-top: 1rem;
}
.sub-links li {
  float: left;
}
.sub-links li:first-of-type {
  margin-right: 1rem;
}
@media only screen and (min-width: 780px) {
  .sub-links {
    margin-top: 0;
  }
  .sub-links li {
    float: none;
  }
  .sub-links li:first-of-type {
    margin-right: 0;
  }
}
