@charset "UTF-8";
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

.clearfix:before {
  content: " ";
  display: table;
}
.clearfix:after {
  content: " ";
  display: table;
  clear: both;
}

@media screen\0  {
  #content {
    font-family: "メイリオ", Meiryo, sans-serif;
  }
}
body {
  margin: 0;
  padding: 0;
  width: 100%;
  /*overflow-x: hidden;*/
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  margin: 0;
}

#header {
  width: 100%;
  text-align: center;
}
#header img {
  max-width: 100%;
  height: auto;
}

/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#container {
  width: 100%;
  box-sizing: border-box;
  color: #333;
}
#container p {
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: 0.025em;
}
#container img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
#container a {
  text-decoration: none;
  transition: 0.4s;
}
#container .head {
  width: 100%;
  position: relative;
  width: 100%;
  margin: auto;
}
#container .head_wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 86vw;
}
#container .head_wrap .headImg {
  width: 100%;
  height: 100%;
  background: url(./head-img.jpg);
  background-repeat: no-repeat;
  background-size: 130%;
  background-position: 42% 75%;
}
#container .head_inner {
  position: relative;
  padding-top: 86%;
}
#container .head h1 {
  width: 90%;
  display: flex;
  flex-direction: column;
  background: #e0301e;
  padding: 5%;
}
#container .head h1 img.sub {
  padding-bottom: 5%;
  margin-bottom: 5%;
  border-bottom: 1px dashed #fff;
}
#container .lead {
  position: relative;
  margin: 30px auto 50px;
  padding: 30px 0;
  width: min(94%, 860px);
  background: #fff;
  border: solid 1px #e0301e;
}
#container .lead::before {
  content: "";
  position: absolute;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  top: 0;
  left: 0;
  border: solid 8px #eee;
}
#container .lead p {
  width: min(80%, 680px);
  margin: auto;
  font-size: 17px;
  color: #000;
}
#container .lead p span {
  letter-spacing: -0.12em;
}
#container section {
  width: min(90%, 820px);
  margin: auto;
  padding-bottom: 50px;
}
#container section p.solo {
  text-indent: 1em;
}
#container section p span {
  color: #e0301e;
  font-weight: 700;
  margin-right: 1em;
}
#container section p.leader span {
  letter-spacing: -0.12em;
  margin-right: 5px;
  color: #333;
}
#container section p.note {
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 3em;
}
#container section p + p {
  margin-top: 1.5em;
}
#container h2 {
  position: relative;
  width: min(100%, 594px);
  font-size: 0.8em;
  margin: 0 auto 30px;
  padding-bottom: 1em;
}
#container h2::after {
  content: "";
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  border-bottom: dashed 1px #e0301e;
}
#container .flexWrap {
  margin: 40px auto 1.5em;
}
#container .prof_box {
  position: relative;
  margin: 0 auto 40px;
  padding: 20px 0;
  width: min(94%, 392px);
  background: #fff;
  border: solid 1px #e0301e;
}
#container .prof_box::before {
  content: "";
  position: absolute;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  top: 0;
  left: 0;
  border: solid 8px #eee;
}
#container .prof_box img, #container .prof_box p {
  width: 86%;
  margin: auto;
  display: block;
}
#container .prof_box p {
  margin-top: 1em;
  font-size: 14px;
  line-height: 1.4;
  color: #e0301e;
}
#container .prof_box p span {
  font-size: 120%;
  margin-right: 5px;
}
#container .photoBox {
  margin: 40px 0 20px;
}
#container .next_link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #eee;
  border: solid 1px #e0301e;
}
#container .next_link div {
  padding: 10px 0;
  text-align: center;
  transition: 0.4s;
}
#container .next_link div:nth-of-type(1) {
  width: 100%;
  border-bottom: solid 1px #e0301e;
}
#container .next_link div:nth-of-type(1) span {
  position: relative;
}
#container .next_link div:nth-of-type(1) span::before, #container .next_link div:nth-of-type(1) span::after {
  content: "";
  width: 5px;
  height: 5px;
  border-top: solid 1px #333;
  border-right: solid 1px #333;
  position: absolute;
  right: -10px;
  top: 5px;
  transform: rotate(45deg);
}
#container .next_link div:nth-of-type(1) span::after {
  right: -16px;
}
#container .next_link div:nth-of-type(2) {
  background: #fff;
  margin: 8px;
}
#container .next_link div:nth-of-type(2) img {
  width: 94%;
}
#container .next_link div:nth-of-type(2) a {
  display: block;
}
#container .next_link div:nth-of-type(2):hover {
  background: none;
}
#container .next_link div:nth-of-type(2):hover a {
  filter: drop-shadow(0 0 8px #fff) drop-shadow(0 0 4px #fff) drop-shadow(0 0 2px #fff);
}
#container .paging {
  width: 60%;
  display: flex;
  justify-content: space-around;
  margin: 0 auto 40px;
}
#container .paging a, #container .paging .active {
  position: relative;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eee;
}
#container .paging a {
  transition: 0.4s;
  border: solid 1px #eee;
  color: #808080;
}
#container .paging a:hover {
  background: #e0301e;
  color: #fff;
}
#container .paging a.arrow {
  background: none;
  border: none;
}
#container .paging a.arrow::before {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 1px #808080;
  border-right: solid 1px #808080;
  position: absolute;
  left: 8px;
  top: 12px;
  transform: rotate(45deg);
  transition: 0.4s;
}
#container .paging a.arrow:hover::before {
  border-top: solid 1px #e0301e;
  border-right: solid 1px #e0301e;
}
#container .paging .active {
  border: solid 1px #e0301e;
  color: #e0301e;
  background: #fff;
}
#container .paging .active::before {
  content: "";
  width: calc(100% - 6px);
  height: calc(100% - 6px);
  position: absolute;
  top: 0;
  left: 0;
  border: solid 3px #eee;
}
#container.page2 section:nth-of-type(1) {
  padding-top: 50px;
}
#container.page2 .linkWrap a {
  display: block;
}
#container.page2 .btn {
  position: relative;
  width: min(100%, 580px);
  background: #e0301e;
  border: solid 1px #e0301e;
  border-radius: 50px;
  text-align: center;
  padding: 5px 0;
}
#container.page2 .btn span {
  color: #fff;
  font-weight: 700;
  font-size: min(4.4vw, 18px);
  line-height: 1.4;
}
#container.page2 .btn::before {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}
#container.page2 .btn.btn2 {
  background: #464646;
  border: solid 1px #464646;
}
#container.page2 .banner {
  margin: 40px 0;
  border: solid 1px #eee;
}
#container.page2 a.logo {
  margin: 60px auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #e0301e;
}
#container.page2 a.logo img {
  width: min(40%, 180px);
  margin: 0 auto 50px;
  display: block;
  transition: 0.4s;
}
#container.page2 .paging .arrow::before {
  transform: rotate(-135deg);
}

@media screen and (min-width: 641px) {
  #container .head {
    width: min(98%, 1350px);
  }
  #container .head_wrap {
    height: min(92%, 596px);
  }
  #container .head_wrap .headImg {
    width: 63.26%;
    background-size: contain;
    background-position: center top;
  }
  #container .head_wrap .headObj {
    position: absolute;
    z-index: -1;
    width: 44%;
    height: 100%;
    top: 0;
    right: 0;
    background: url(./head-obj.png);
    background-size: contain;
    background-repeat: no-repeat;
  }
  #container .head_inner {
    padding-top: min(22%, 300px);
  }
  #container .head h1 {
    width: min(36%, 465px);
    margin: 0 0 0 auto;
    padding: 3% 2%;
  }
  #container .lead {
    margin: 80px auto;
  }
  #container section {
    padding-bottom: 100px;
  }
  #container h2 {
    margin: 0 auto 40px;
    padding-bottom: 1.5em;
  }
  #container .flexWrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  #container .flexWrap.right {
    flex-direction: row-reverse;
  }
  #container .prof_box {
    width: 47.8048780488%;
    margin: 0;
  }
  #container .txt_box {
    width: 43.9024390244%;
  }
  #container .photoBox {
    margin: 60px 0 0;
  }
  #container .next_link {
    width: min(80%, 640px);
    margin: auto;
    flex-direction: row;
    align-items: stretch;
  }
  #container .next_link div:nth-of-type(1) {
    width: 22%;
    border-bottom: 0;
    border-right: solid 1px #e0301e;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  #container .next_link div:nth-of-type(1) span::before, #container .next_link div:nth-of-type(1) span::after {
    top: 9px;
  }
  #container .next_link div:nth-of-type(2) {
    width: 76%;
  }
  #container .paging {
    margin: 0 auto 60px;
    width: 240px;
  }
  #container.page2 .head_wrap {
    height: 100%;
    width: 80%;
  }
  #container.page2 .head_wrap .headImg {
    width: 68%;
    height: 100%;
    background-size: cover;
    background-position: left 25%;
  }
  #container.page2 .head_wrap .headObj {
    width: 32%;
  }
  #container.page2 .head_inner {
    padding-top: min(12%, 150px);
    padding-bottom: min(5%, 30px);
  }
  #container.page2 .head h1 {
    width: min(45%, 600px);
    padding: 2% 3%;
  }
  #container.page2 .head h1 img.sub {
    padding-bottom: 3%;
    margin-bottom: 3%;
  }
  #container.page2 section:nth-of-type(1) {
    padding-top: 80px;
  }
  #container.page2 .btn {
    padding: 0.8em;
    margin: auto;
  }
  #container.page2 .btn::before {
    right: 20px;
  }
  #container.page2 .btn:hover {
    background: #fff;
  }
  #container.page2 .btn:hover span {
    color: #e0301e;
  }
  #container.page2 .btn:hover::before {
    border-top: solid 1px #e0301e;
    border-right: solid 1px #e0301e;
  }
  #container.page2 .btn.btn2:hover {
    background: #fff;
  }
  #container.page2 .btn.btn2:hover span {
    color: #464646;
  }
  #container.page2 .btn.btn2:hover::before {
    border-top: solid 1px #464646;
    border-right: solid 1px #464646;
  }
  #container.page2 .btn br {
    display: none;
  }
  #container.page2 .banner {
    margin: 60px auto;
  }
  #container.page2 .banner:hover {
    opacity: 0.8;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
  }
  #container.page2 a.logo {
    margin: 110px auto 0;
    width: 260px;
  }
  #container.page2 a.logo img {
    width: 180px;
  }
  #container.page2 a.logo span {
    position: relative;
    padding-bottom: 0.3em;
  }
  #container.page2 a.logo span::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 1px;
    background: #e0301e;
    bottom: 0;
    left: 0;
    transform: scale(0, 0);
    transition: 0.3s;
  }
  #container.page2 a.logo:hover img {
    opacity: 0.8;
  }
  #container.page2 a.logo:hover span::before {
    transform: scale(1, 1);
  }
}