@font-face {
  font-family: "Helvetica Neue";
  src:
    local("Helvetica Neue"),
    url("HelveNeuGre.ttf") format("truetype");
}
@font-face {
  font-family: "Helvetica Neue Light";
  src:
    local("Helvetica Neue Light"),
    url("HelveNeuGreLig.ttf") format("truetype");
}
:root {
  --background-color: #fff;
  --border-color: #000;
  --color: initial;
  --placeholder-color: #b0b0b0;
  --cyan: #00a0d7;
  --yellow: #fff037;
}
html {
  background: var(--background-color);
  color: var(--color);
  font: 16px/1.25 "Helvetica Neue Light", sans-serif;
  height: 100%;
  min-height: 100%;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  height: 100%;
  margin: 0;
}
blockquote,
section,
main,
aside,
footer {
  box-sizing: border-box;
  margin: auto;
  max-width: 100rem;
  padding: 3rem;
}
[aria-hidden] {
 left: -5000px;
 position: absolute;
}
sup {
  line-height: 1;
  vertical-align: top;
}
hr {
  border: 0;
  border-top: 1px solid var(--border-color);
  margin: 0;
}
a {
  color: inherit;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
  text-decoration-thickness: 1px;
}
a:focus {
  outline: 0;
}
svg {
  display: block;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font: inherit;
  margin: 0;
}
h1 {
  font-size: 3rem;
  text-transform: uppercase;
}
h1 a:hover {
  text-decoration: none;
}
h1 + span {
  font-size: 1.5rem;
}
h2 {
  font-family: "Helvetica Neue";
  font-size: 1.4375rem;
}
h3 {
  font-family: "Helvetica Neue";
  font-size: 1.25rem;
  margin: 1rem 0 0.5rem;
}
h4 {
  font-family: "Helvetica Neue";
  font-size: 1.25rem;
  margin: 1rem 0 0;
  text-decoration: underline;
  text-decoration-color: var(--yellow);
}
figure {
  margin: 0;
}
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
p {
  margin: 0;
}
iframe {
  height: auto;
  object-fit: cover;
  width: 100%;
}
video {
  height: auto;
  object-fit: cover;
  max-width: 100%;
}
img {
  background: #f0f0f0;
  font-size: 0.75rem;
  height: auto;
  object-fit: cover;
  max-width: 100%;
}
form {
  margin: 0;
}
input {
  background: none;
  border: 1px solid transparent;
  border-width: 1px 0;
  border-radius: 0;
  font: inherit;
}
input::placeholder {
  color: var(--placeholder-color);
}
input:focus {
  outline: 1px dotted var(--border-color);
  outline-offset: 1px;
}
input[type="email"] {
  border-bottom-color: var(--border-color);
  line-height: 1;
  margin: 0;
  max-width: 8rem;
  padding: 0;
  width: 100%;
}
input[type="submit"] {
  color: inherit;
  line-height: 1.25;
  margin-top: -1px;
  padding: 0 0.2rem;
}
address {
  font-style: normal;
}
blockquote {
  font-size: 2.125rem;
  text-transform: uppercase;
}
blockquote p {
  max-width: 33.75rem;
}
blockquote span {
  text-decoration: underline;
}
blockquote span:first-of-type {
  text-decoration-color: var(--yellow);
}
blockquote span:last-of-type {
  text-decoration-color: var(--cyan);
}
aside {
  display: grid;
  font-size: 1.3125rem;
  gap: 0.75rem;
}
aside:empty {
  aspect-ratio: 4 / 1;
  background: url("banner.svg") no-repeat;
  background-position: center;
  background-size: 100% auto;
}
footer {
  display: grid;
  font-family: "Helvetica Neue";
  line-height: 1.5;
  gap: 1.5rem;
}
header {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  margin: auto;
  max-width: 100rem;
  padding: 1.5rem 3rem;
  position: relative;
}
header h1::selection,
header h1 a::selection {
  background: none;
}
header ul {
  background: var(--background-color);
  border-bottom: 1px solid var(--border-color);
  box-sizing: border-box;
  font-size: 2.125rem;
  left: 0;
  padding: 1.5rem 3rem;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
header li a {
  display: inline-block;
  padding: 0.125em;
}
header label {
  align-self: end;
  background: url("sprite.svg#off") no-repeat;
  background-size: 100% 100%;
  cursor: pointer;
  display: block;
  padding: 1rem;
  position: absolute;
  right: 3rem;
  top: 50%;
  transform: translate(0, -50%);
  z-index: 2;
}
header input {
  left: 0;
  margin: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transform: translate(-100%, -100%);
}
header input:checked + label {
  background: var(--background-color) url("sprite.svg#on") no-repeat;
  background-size: 100% 100%;
}
header input:checked ~ h1 {
  visibility: hidden;
}
header input:checked ~ ul {
  display: initial;
}
main header {
  padding: 0;
  margin-bottom: 1.5rem;
}
main ul {
  font-size: 1.75rem;
}
main figcaption {
  font-size: 0.875rem;
}
main figure {
  margin-bottom: 2.25rem;
}
main figure + p {
  text-align: right;
}
section {
  display: grid;
  gap: 1rem;
}
section figure {
  aspect-ratio: 5 / 3;
  order: 1;
}
section ul {
  font-size: 1.125rem;
  order: 2;
}
.gallery a {
  display: block;
}
.gallery a:hover,
.gallery a.pick {
  text-decoration: underline;
  text-decoration-thickness: 3px;
  text-decoration-color: var(--yellow);
}
.gallery img:not(.pick) {
  display: none;
}
@media screen and (max-width: 640px) {
  h1 {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 640px) {
  address {
    text-align: right;
  }
  aside {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }
  header span {
    justify-self: end;
  }
  figcaption {
    flex: 0 0 100%;
  }
  figure {
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: space-between;
  }
  figure figure {
    margin-bottom: 0;
    max-width: 50%;
  }
  section ul {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 720px) {
  blockquote,
  section,
  main,
  aside,
  footer {
    padding: 2.25rem;
  }
  footer p {
    font-size: 0.875rem;
  }
  header {
    padding: 1rem 2.25rem;
  }
  header label {
    right: 2.25rem;
  }
  header ul {
    padding: 1rem 2.25rem;
  }
}
@media screen and (min-width: 720px) {
  input[type="email"] {
    margin: 0 0.5rem;
    width: calc(100% - 1rem);
  }
  header ul {
    border-bottom: 0;
    top: 50%;
    transform: translate(0, -50%);
  }
  header li {
    display: inline-block;
  }
  footer p {
    font-style: italic;
    order: 1;
  }
  footer figure {
    align-content: space-between;
    order: 2;
  }
  footer nav {
    order: 3;
  }
  footer figcaption,
  footer label {
    font-style: italic;
  }
  footer form {
    align-items: flex-start;
    display: flex;
    order: 4;
  }
  footer {
    display: flex;
    justify-content: space-between;
  }
  section ul {
    font-size: 1rem;
    grid-area: 1 / 1;
    order: initial;
    position: relative;
  }
  section ul:last-child {
    text-align: right;
  }
  section ul:last-child span {
    margin-left: calc(60% + 1rem);
  }
  section ul:first-child span {
    margin-right: calc(60% + 1rem);
  }
  section figure {
    aspect-ratio: 4 / 3;
    grid-area: 1 / 1;
    order: initial;
    width: 59%;
  }
  section figure:last-child {
    margin-left: auto;
  }
  section {
    align-items: center;
    display: grid;
  }
}
@media screen and (max-width: 800px) {
  label {
    display: block;
  }
}
@media screen and (min-width: 800px) {
  section ul {
    font-size: 1.125rem;
  }
}
@media screen and (min-width: 880px) {
  section ul {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 960px) {
  section ul {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1280px) {
  html {
   font-size: 25px;
  }
  section ul {
    font-size: 1.75rem;
  }
}
@media (prefers-color-scheme: dark) {
  :root {
    --background-color: #1e1e1e;
    --color: #efefef;
    --border-color: #666;
    --placeholder-color: #444;
  }
  img {
    background: #222;
    opacity: 0.8;
  }
  aside:empty {
    background: url("banner-light.svg") no-repeat;
  }
  header label {
    background: url("sprite-light.svg#off") no-repeat;
    background-size: 100% 100%;
  }
  header input:checked + label {
    background: var(--background-color) url("sprite-light.svg#on") no-repeat;
    background-size: 100% 100%;
  }
}
