﻿html,
button,
input,
select,
textarea,
.pure-g [class*="pure-u"] {
  font-family: "Noto Sans JP", sans-serif !important;
}

.site-header {
  height: calc(100vh - 0px);
  width: 100%;
}

.site-header > div.container {
  height: 100%;
  max-width: 100%;
  background: radial-gradient(rgba(0,0,0,0.17) 40%, rgba(0,0,0,0.2) 90%);
  background-size: 5px 5px;
  background-repeat: repeat;
  z-index: 10;
  position: relative;
  padding: 0;
}

.site-header__content {
  height: 100%;
  display: flex !important;
  flex-direction: column;
}

@media (min-width: 769px) {
  .global-nav {
    margin-top: auto;
    height: 6rem;
  }
}

.site-header .custom-logo {
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  position: absolute;
  width: 50%;
  max-width: 20rem;
  color: transparent;
}

#landing-background > div {
  width: 100%; height: 100%;
  position: absolute; top: 0;
  transition: opacity 2s ease 0s;
}

#landing-background > div img {
  width: 100%; height: 100%;
  object-fit: cover;
  color: transparent;
}

.site-content {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.site-content > div.container {
  max-width: 100%;
  padding: 0;
}

/* === Summary === */
#summary {
  background-color: #5a6a62;
  width: 100%;
  padding-bottom: 2rem;
}
#summary > div {
  padding: 2.5rem;
  max-width: 1536px;
  margin: auto;
}
#summary h2 {
  font-size: 1.7rem;
  font-weight: 900;
  color: white;
  margin-top: 1rem !important;
  padding-bottom: 1rem;
}
#summary h3 {
  font-size: 1.3rem;
  font-weight: 700;
  color: rgba(253,230,138,1);
  text-align: right;
  margin-top: 1rem !important;
  padding-bottom: 1rem;
}
#summary figure > img {
  width: 100%;
  object-fit: cover;
  border-radius: 0.25rem;
}
#summary-text {
  color: white;
  font-weight: 300;
}
@media screen and (min-width: 64em) {
  #summary h2 { font-size: 2.5rem; }
  #summary h3 { font-size: 2rem; }
  #summary figure { padding-right: 3rem; }
  #summary-text { padding-top: 2rem; }
}

/* === Info === */
#info {
  background: #e6ebe9;
  padding-top: 4rem;
  padding-bottom: 4rem;
}
#info > div {
  max-width: 1536px;
  margin: auto;
  padding-left: 2.5em;
  padding-right: 2.5em;
}
#info h2 {
  font-size: 1.7rem;
  font-weight: 100;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 1rem;
  padding-bottom: 1rem;
}
#info-card-wrapper {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 2rem;
  padding-bottom: 1rem;
}
.info-card {
  height: 100%;
  overflow: hidden;
  text-decoration: none;
}
.info-card:hover { text-decoration: none; }
.info-card-image {
  position: relative;
  padding-top: 70%;
}
.info-card-image > img {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.info-card-date {
  font-weight: 100;
  text-align: right;
  margin-top: 0; margin-bottom: 0;
  color: #000000;
}
.info-card-title {
  text-align: right;
  margin-top: 0; margin-bottom: 0;
  color: #374151;
}
@media screen and (min-width: 48em) {
  #info h2 { font-size: 2rem; }
  #info-card-wrapper { grid-template-columns: repeat(5, 1fr); }
}

/* === Access === */
#access { background: #f5f3ef; }
#access > div {
  max-width: 1536px;
  margin: auto;
  padding-left: 2.5em;
  padding-right: 2.5em;
}
#access h2 {
  font-size: 2rem;
  font-weight: 100;
  text-align: center;
  margin: auto;
  padding-bottom: 2rem;
}
#access-wrapper {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
#access-wrapper > div {
  margin-top: auto;
  margin-bottom: auto;
}
.access-content {
  padding-bottom: 1rem;
  margin-left: 1rem;
  margin-right: 1rem;
}
.access-content-title {
  border-color: rgba(75,85,99,1);
  border-bottom: 1px solid;
  font-weight: 700;
  font-size: 1.25em;
  margin-bottom: 0.5rem;
}
.access-content p {
  font-size: 0.9em;
  margin: 0;
}
@media screen and (min-width: 64em) {
  #access {
    background: linear-gradient(90deg, #f5f3ef 0%, #f5f3ef 70%, white 70%, white 100%);
  }
  #access > div {
    background: linear-gradient(90deg, #f5f3ef 0%, #f5f3ef 90%, white 90%, white 100%);
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
  #access h2 {
    font-size: 2.2rem;
    writing-mode: vertical-rl;
    letter-spacing: 0.6em;
    padding: 0;
  }
  .access-content {
    margin-left: 1rem;
    margin-right: 4rem;
  }
}

