@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  list-style-type: none;
  border: none;
  box-sizing: border-box;
}

/* iOSのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  box-sizing: border-box;
}
input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}
input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

/* iOSサファリで発生する部分的な文字の拡大表示の抑制 */
html {
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

a:link {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

a:visited {
  text-decoration: none;
}

img {
  width: 100%;
  display: block;
  border: none;
  -webkit-backface-visibility: hidden; /*クロームの画像ぼけ防止*/
  image-rendering: -webkit-optimize-contrast; /*クロームの画像ぼけ防止*/
}

button {
  border: 0;
  outline: none;
  font-size: 0;
  color: transparent;
  line-height: 0;
  background-color: transparent;
}

main {
  position: relative;
}
@media screen and (max-width: 768px) {
  main {
    padding: 130px 0 0 0;
  }
}

article {
  padding: 20px 0 50px 0;
  background-color: #e9e4d8;
}
@media screen and (max-width: 768px) {
  article {
    padding: 20px 0 20px 0;
  }
}

.icon {
  padding: 20px 0;
  background-color: #fff;
}
.icon img {
  width: 10%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .icon img {
    width: 30%;
  }
}

.title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1rem, 0.464rem + 2.68vw, 1.75rem);
  color: #231815;
  text-align: center;
  padding: 0 0 20px 0;
  background-color: #fff;
}

.headline {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0.75rem, 0.214rem + 2.68vw, 1.5rem);
  font-weight: 500;
  color: #fff;
  text-align: center;
  line-height: 1;
  padding: 10px;
  margin: 0 0 30px 0;
  background: linear-gradient(90deg, #0089bb, #003d73);
}

.category div {
  margin: 0 auto 20px auto;
}
.category p {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0.75rem, 0.393rem + 1.79vw, 1.25rem);
  color: #231815;
  text-align: center;
  line-height: 1.5;
}

footer {
  width: 100%;
  padding: 30px 20px;
  background-color: #dcdedf;
  position: fixed;
  left: 0;
  bottom: 28px;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  footer {
    display: none;
  }
}
footer div {
  width: 1050px;
  margin: 0 auto 20px auto;
  display: flex;
  justify-content: space-between;
}
footer div #footernav_1 {
  width: 680px;
}
footer div #footernav_1 ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 20px;
  -moz-column-gap: 30px;
       column-gap: 30px;
}
footer div #footernav_1 ul li {
  border-radius: 10px;
  background-color: #1eaa39;
}
footer div #footernav_1 ul li a {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1;
  padding: 20px 0;
  display: block;
}
footer div #footernav_1 ul li a span {
  padding: 0 30px 0 0;
  background-image: url(../../images/common/icon.png);
  background-size: 25px 25px;
  background-position: center right;
  background-repeat: no-repeat;
}
footer div #footernav_2 {
  width: 330px;
}
footer div #footernav_2 ul {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 20px;
}
footer div #footernav_2 ul li {
  border-radius: 10px;
  background-color: #036eb8;
}
footer div #footernav_2 ul li a {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1;
  padding: 20px 0;
  display: block;
}
footer div #footernav_2 ul li a span {
  padding: 0 30px 0 0;
  background-image: url(../../images/common/icon.png);
  background-size: 25px 25px;
  background-position: center right;
  background-repeat: no-repeat;
}

#credit {
  width: 100%;
  font-size: 14px;
  color: #000;
  text-align: center;
  background-color: #dcdedf;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  #credit {
    font-size: 8px;
    position: relative;
  }
}

#return {
  width: 50px;
  height: 50px;
  position: fixed;
  bottom: -100px;
  right: 10px;
  cursor: pointer;
  transition: 0.3s;
  visibility: hidden;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  #return {
    width: 30px;
    height: 30px;
  }
}
#return.active {
  bottom: 30px;
  visibility: visible;
}/*# sourceMappingURL=common.css.map */