#bg-line {
  width: 100vw;
  height: 100vh;
  box-sizing: border-box;
  border: 10px #DFECF2 solid;
  transition: opacity 4.5s;
  position: fixed;
  z-index: 11;
  pointer-events: none; }

#bg-line-under {
  width: 100vw;
  height: 100vh;
  box-sizing: border-box;
  border: 10px #fff solid;
  position: fixed;
  z-index: 10;
  pointer-events: none; }

#bg-container {
  width: 100vw;
  height: 100vh;
  box-sizing: border-box;
  position: fixed; }
  #bg-container #bg-circle {
    transition: opacity 4.5s, border-width 3s, width 3s, height 3s;
    border-color: #DFECF2;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    border-radius: 50%; }

.back0 #bg-circle {
  border: solid 80px #DFECF2; }

.back6 .bg-page6 {
  position: fixed;
  width: calc(100vw - 20px);
  height: calc(100vh - 20px);
  top: 0;
  box-sizing: border-box;
  background-color: #DFECF2;
  margin: 10px; }

.back1 #bg-circle {
  border: solid 7.2px #DFECF2;
  width: 170.4px;
  height: 170.4px; }

.back2 #bg-circle {
  border: solid 37.2px #DFECF2;
  width: 155.4px;
  height: 155.4px; }

.back3 #bg-circle {
  border: solid 30px #DFECF2;
  width: 159px;
  height: 159px; }

.back4 #bg-circle {
  border: solid 12px #DFECF2;
  width: 168px;
  height: 168px; }

.back5 #bg-circle {
  border: solid 24px #DFECF2;
  width: 162px;
  height: 162px; }

@media screen and (min-width: 321px) and (min-height: 321px) {
  .back1 #bg-circle {
    border: solid 7.92px #DFECF2;
    width: 187.44px;
    height: 187.44px; }
  .back2 #bg-circle {
    border: solid 40.92px #DFECF2;
    width: 170.94px;
    height: 170.94px; }
  .back3 #bg-circle {
    border: solid 33px #DFECF2;
    width: 174.9px;
    height: 174.9px; }
  .back4 #bg-circle {
    border: solid 13.2px #DFECF2;
    width: 184.8px;
    height: 184.8px; }
  .back5 #bg-circle {
    border: solid 26.4px #DFECF2;
    width: 178.2px;
    height: 178.2px; } }

@media screen and (min-width: 510px) and (min-height: 510px) {
  .back1 #bg-circle {
    border: solid 12px #DFECF2;
    width: 284px;
    height: 284px; }
  .back2 #bg-circle {
    border: solid 62px #DFECF2;
    width: 259px;
    height: 259px; }
  .back3 #bg-circle {
    border: solid 50px #DFECF2;
    width: 265px;
    height: 265px; }
  .back4 #bg-circle {
    border: solid 20px #DFECF2;
    width: 280px;
    height: 280px; }
  .back5 #bg-circle {
    border: solid 40px #DFECF2;
    width: 270px;
    height: 270px; } }

@media screen and (min-width: 850px) and (min-height: 850px) {
  .back1 #bg-circle {
    border: solid 24px #DFECF2;
    width: 568px;
    height: 568px; }
  .back2 #bg-circle {
    border: solid 124px #DFECF2;
    width: 518px;
    height: 518px; }
  .back3 #bg-circle {
    border: solid 100px #DFECF2;
    width: 530px;
    height: 530px; }
  .back4 #bg-circle {
    border: solid 40px #DFECF2;
    width: 560px;
    height: 560px; }
  .back5 #bg-circle {
    border: solid 80px #DFECF2;
    width: 540px;
    height: 540px; } }

.not-selected {
  display: none; }

.hidden {
  opacity: 0;
  visibility: hidden;
  transition: 2s; }

body {
  -webkit-text-size-adjust: 100%;
  writing-mode: horizontal-tb;
  -webkit-writing-mode: horizontal-tb;
  -ms-writing-mode: horizontal-tb;
  font-family: ryo-text-plusn, serif;
  font-weight: 300;
  font-style: normal;
  line-height: 1.5em;
  letter-spacing: 0.1em; }
  body a {
    color: #000;
    text-decoration: none; }

*::-webkit-scrollbar {
  display: none; }

* {
  -ms-overflow-style: none; }

#log {
  position: fixed;
  display: none; }

.vertical {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl; }

.sp {
  position: static;
  width: 100vw; }
  .sp .pc-visible {
    visibility: hidden !important; }
  .sp .sp-visible {
    visibility: visible !important; }
  .sp .pc-block {
    display: none !important; }
  .sp .sp-block {
    display: block !important; }
  .sp .pc-inline {
    display: none !important; }
  .sp .sp-inline {
    display: inline-block !important; }
  .sp #nav__spmenu {
    z-index: 100;
    position: fixed;
    width: calc(100vw - 20px);
    margin: 10px;
    height: 30px;
    padding: 10px 20px 0;
    box-sizing: border-box;
    background-color: #fff; }
    .sp #nav__spmenu .header-logo {
      width: 140px;
      vertical-align: top;
      z-index: 2;
      position: relative; }
    .sp #nav__spmenu #spmenu-open {
      width: 19px;
      z-index: 2;
      cursor: pointer;
      position: absolute;
      right: 16px;
      top: 10px; }
    .sp #nav__spmenu #spmenu-close {
      width: 19px;
      z-index: 2;
      cursor: pointer;
      position: absolute;
      right: 16px;
      top: 10px; }
    .sp #nav__spmenu #spmenu {
      position: fixed;
      z-index: 1;
      background-color: rgba(255, 255, 255, 0.95);
      width: 100vw;
      height: 100vh;
      top: 0;
      left: 0; }
      .sp #nav__spmenu #spmenu ul {
        list-style-image: url(./img/list-img.png);
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        -o-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
      .sp #nav__spmenu #spmenu li {
        cursor: pointer;
        height: max-content;
        font-size: 20px;
        line-height: 2.5em; }
  .sp #nav__bottom {
    position: absolute;
    top: 620px;
    left: 49.7%;
    height: 15px; }
  .sp #nav__top li {
    top: 120px;
    font-size: 11px;
    line-height: 3.7em; }
  .sp .page {
    display: block;
    position: relative;
    padding-top: 50px;
    margin-bottom: 140px; }
  .sp #page1 {
    padding-top: 190px; }
  .sp #page2 {
    padding-left: 25px;
    padding-right: 25px;
    text-align: left; }
    .sp #page2 .page__inner {
      width: auto; }
  .sp #page3 .page__inner {
    width: auto; }
  .sp #page3 h2 {
    margin-bottom: 20px;
    text-align: center; }
  .sp #page3 p {
    font-size: 13px; }
  .sp #page3 .border {
    display: block;
    width: auto;
    margin: 0 25px 50px;
    height: 0px;
    border: 1px solid #000; }
  .sp #page3 .page3-service {
    width: auto;
    display: block;
    padding: 0 25px 35px; }
  .sp #page4 {
    padding-left: 25px;
    padding-right: 25px;
    margin-bottom: 740px; }
    .sp #page4 #page4-list-container {
      width: auto; }
    .sp #page4 #page4-index {
      margin-bottom: 80px; }
      .sp #page4 #page4-index p {
        text-align: center;
        margin-bottom: 30px; }
      .sp #page4 #page4-index .border {
        display: block;
        width: auto;
        margin-bottom: 30px;
        height: 0px;
        border: 1px solid #000; }
    .sp #page4 #page4-right {
      display: none; }
    .sp #page4 #page4-left {
      width: auto;
      padding: 0;
      text-align: left; }
    .sp #page4 #page4__btns .page4__btn {
      top: auto; }
    .sp #page4 #page4__btns .left.top {
      left: 20px; }
    .sp #page4 #page4__btns .right.top {
      right: 20px; }
    .sp #page4 #page4__btns .left.bottom {
      bottom: -640px;
      left: 140px; }
    .sp #page4 #page4__btns .right.bottom {
      bottom: -640px;
      right: 140px; }
    .sp #page4 #page4-1 h3 {
      letter-spacing: 0.04em; }
    .sp #page4 .page4-main {
      width: 100% !important; }
    .sp #page4 .page4-maintext {
      position: static;
      width: 100%;
      top: auto; }
      .sp #page4 .page4-maintext h3 {
        margin-left: 0;
        padding: 0 25px; }
      .sp #page4 .page4-maintext p {
        padding: 0 25px; }
    .sp #page4 .sp-selected {
      color: #000; }
  .sp #page5 {
    width: 100%; }
    .sp #page5 .page__inner {
      width: auto; }
    .sp #page5 .page5-left {
      width: auto;
      display: block;
      box-sizing: border-box;
      padding: 25px;
      text-align: center;
      margin-bottom: 60px; }
    .sp #page5 .page5-right {
      width: auto;
      display: block;
      box-sizing: border-box;
      padding: 25px; }
      .sp #page5 .page5-right .logo {
        width: 230px; }
      .sp #page5 .page5-right .sign-img {
        width: 150px; }
  .sp #page6 {
    margin: 10px;
    padding-top: 30px;
    background-color: #DFECF2; }
    .sp #page6 .page__inner {
      width: auto; }
    .sp #page6 .page6-left {
      width: auto;
      display: block;
      padding: 0 15px;
      box-sizing: border-box; }
    .sp #page6 .page6-right {
      width: auto;
      display: block;
      padding: 0 15px;
      box-sizing: border-box; }
    .sp #page6 .page6-nav ul {
      height: 100%; }
    .sp #page6 .page6-nav ul li {
      line-height: 3em !important;
      height: 200px; }
    .sp #page6 img {
      width: 100%;
      box-sizing: border-box; }
    .sp #page6 .sp-copyright {
      font-size: 11px;
      padding: 15px; }
    .sp #page6 .map {
      height: 150px; }

@media screen and (min-width: 350px) {
  .sp #page4 {
    margin-bottom: 680px; }
  .sp #page4 #page4__btns .right.bottom {
    bottom: -585px; }
  .sp #page4 #page4__btns .left.bottom {
    bottom: -585px; } }

@media screen and (min-width: 400px) {
  .sp #page4 {
    margin-bottom: 640px; }
  .sp #page4 #page4__btns .right.bottom {
    bottom: -560px; }
  .sp #page4 #page4__btns .left.bottom {
    bottom: -560px; } }

@media screen and (min-width: 450px) {
  .sp #page4 {
    margin-bottom: 600px; }
  .sp #page4 #page4__btns .right.bottom {
    bottom: -505px; }
  .sp #page4 #page4__btns .left.bottom {
    bottom: -505px; } }

@media screen and (min-width: 540px) {
  .sp #page4 {
    margin-bottom: 560px; }
  .sp #page4 #page4__btns .right.bottom {
    bottom: -475px; }
  .sp #page4 #page4__btns .left.bottom {
    bottom: -475px; } }

@media screen and (min-width: 735px) {
  .sp #page4 {
    margin-bottom: 520px; }
  .sp #page4 #page4__btns .right.bottom {
    bottom: -430px; }
  .sp #page4 #page4__btns .left.bottom {
    bottom: -430px; } }

.pc {
  position: fixed;
  width: 100vw;
  height: 100vh; }
  .pc .pc-visible {
    visibility: visible !important; }
  .pc .sp-visible {
    visibility: none !important; }
  .pc .pc-block {
    display: block !important; }
  .pc .sp-block {
    display: none !important; }
  .pc .pc-inline {
    display: inline-block !important; }
  .pc .sp-inline {
    display: none !important; }
  .pc #nav__spmenu {
    display: none !important; }
  .pc .page {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: 2s;
    opacity: 0;
    pointer-events: none; }
  .pc .page--init {
    transition: 0s; }
  .pc .page.on {
    pointer-events: auto;
    top: 52%;
    z-index: 100;
    transition-delay: 0s;
    opacity: 1;
    display: block; }
  .pc #page4 .page4-main {
    top: 0;
    left: 50% !important;
    -webkit-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    transform: translate(-50%, 0); }
  .pc #page4 .page4-maintext {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-align: left;
    position: absolute;
    height: 380px;
    width: auto;
    top: 75px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    transform: translate(-50%, 0); }
    .pc #page4 .page4-maintext p {
      font-size: 14px;
      letter-spacing: 0.23em; }
  .pc #page4 #page4__backbtn {
    transition-duration: 2s;
    position: absolute;
    left: 160px;
    bottom: -140px;
    font-size: 13px;
    -webkit-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    cursor: pointer;
    text-decoration: underline; }
    .pc #page4 #page4__backbtn:hover {
      text-decoration: none; }
  .pc #page4 .next:hover {
    color: #000;
    cursor: pointer; }
  .pc #page4 .prev:hover {
    color: #000;
    cursor: pointer; }
  .pc #page4 #page4__leftbtn2 {
    left: 110px !important; }
  .pc #page4 #page4__rightbtn2 {
    right: 110px !important; }
  .pc .page6-right img {
    width: 334px; }

#wrapper {
  width: 100vw;
  height: 4800px;
  position: relative;
  z-index: 1; }

.wrapper-sp {
  height: auto !important; }

#nav__top {
  z-index: 11;
  cursor: pointer;
  position: absolute;
  left: 50%;
  top: 110px;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }
  #nav__top li {
    list-style-type: none;
    background-image: url(./img/list-img.png);
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 8px;
    font-size: 12px;
    line-height: 43px;
    letter-spacing: 0.2em;
    opacity: 0.5;
    height: 160px; }
    #nav__top li:hover {
      opacity: 0.75; }
  #nav__top .selected {
    opacity: 1; }

#nav__left {
  position: absolute;
  left: 55px;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }
  #nav__left img {
    width: 13px; }

#nav__right {
  position: absolute;
  right: 55px;
  top: 50%;
  -webkit-transform: translate(50%, -50%);
  -moz-transform: translate(50%, -50%);
  -ms-transform: translate(50%, -50%);
  -o-transform: translate(50%, -50%);
  transform: translate(50%, -50%); }

#nav__bottom .border {
  position: absolute;
  bottom: 25px;
  left: 50%;
  -webkit-transform: translate(50%, 0);
  -moz-transform: translate(50%, 0);
  -ms-transform: translate(50%, 0);
  -o-transform: translate(50%, 0);
  transform: translate(50%, 0);
  background-color: #000;
  width: 1px;
  height: 35px; }

#nav__bottom .border.white {
  height: 10px;
  bottom: 60px;
  background-color: #fff; }

.white-top {
  bottom: 60px !important; }

.white-bottom {
  bottom: 15px !important;
  transition: 1s; }

#nav__copyright {
  font-size: 12px;
  position: absolute;
  bottom: 25px;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -moz-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  -o-transform: translate(-50%, 0);
  transform: translate(-50%, 0); }

.page__title {
  font-size: 13px;
  margin-bottom: 60px;
  letter-spacing: 0.4em; }

h2 {
  font-size: 18px;
  margin-bottom: 30px; }

p {
  font-size: 14px;
  font-weight: 300;
  width: auto; }

sub {
  vertical-align: sub;
  font-size: smaller; }

.page__title {
  text-align: center;
  font-weight: bold; }

.page__inner {
  width: max-content; }

.width {
  width: 100%;
  display: inline; }

#page1 h1 {
  text-align: center; }

#page1 h1 img {
  width: 21px; }

#page2 {
  text-align: center; }

#page3 {
  text-align: center; }
  #page3 .page__inner {
    width: 796px; }
  #page3 .border {
    display: inline-block;
    background-color: #000;
    border: solid #000 1px;
    height: 290px;
    margin-top: -10px; }
  #page3 .page3-service {
    text-align: left;
    display: inline-block;
    width: 280px;
    vertical-align: top;
    padding: 0 55px; }

#page4 #page4-index {
  color: #000;
  transition-duration: 2s; }

#page4 .border {
  display: inline-block;
  background-color: #000;
  border: solid #000 1px;
  height: 290px;
  vertical-align: middle; }

#page4 #page4-list-container {
  width: 796px; }

#page4 #page4-left {
  text-align: right;
  list-style-type: none;
  vertical-align: middle;
  display: inline-block;
  width: 280px;
  padding: 0 55px;
  color: #ccc; }
  #page4 #page4-left li {
    cursor: pointer;
    line-height: 2em; }
  #page4 #page4-left li:hover {
    color: #000; }

#page4 #page4-right {
  vertical-align: middle;
  display: inline-block;
  width: 280px;
  padding: 0 55px; }

#page4 #page4__btns {
  transition-duration: 2s; }
  #page4 #page4__btns .page4__btn {
    z-index: 9;
    position: absolute;
    cursor: pointer; }
    #page4 #page4__btns .page4__btn:hover {
      opacity: 0.5; }
  #page4 #page4__btns .top {
    width: 10px;
    top: 3px; }
  #page4 #page4__btns .bottom {
    width: 18px;
    top: 50%; }
  #page4 #page4__btns .left {
    -webkit-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    transform: translate(-50%, 0); }
  #page4 #page4__btns .right {
    -webkit-transform: translate(50%, 0);
    -moz-transform: translate(50%, 0);
    -ms-transform: translate(50%, 0);
    -o-transform: translate(50%, 0);
    transform: translate(50%, 0); }
  #page4 #page4__btns .left.top {
    left: 250px; }
  #page4 #page4__btns .right.top {
    right: 250px; }
  #page4 #page4__btns .left.bottom {
    left: 150px; }
  #page4 #page4__btns .right.bottom {
    right: 150px; }

#page4 .page4-main {
  color: #000;
  position: absolute;
  transition-duration: 2s;
  text-align: center;
  width: 500px;
  height: 400px;
  left: 0; }

#page4 h2 {
  font-size: 13px; }

#page4 .prev {
  font-size: 13px;
  font-weight: bold;
  position: absolute;
  left: 430px;
  color: #ccc;
  width: 300px;
  text-align: left; }

#page4 .next {
  font-size: 13px;
  font-weight: bold;
  position: absolute;
  right: 430px;
  color: #ccc;
  width: 300px;
  text-align: right; }

#page4 .page4-maintext {
  text-align: left; }
  #page4 .page4-maintext h3 {
    font-size: 18px;
    line-height: 1.9em;
    margin-left: 30px; }
  #page4 .page4-maintext p {
    font-size: 13px;
    line-height: 2.1em; }

#page5 .page__inner {
  width: 1108px; }

#page5 .page5-left {
  vertical-align: middle;
  display: inline-block;
  width: 440px;
  padding: 0 55px; }

#page5 .page5-right {
  vertical-align: middle;
  display: inline-block;
  width: 440px;
  padding: 0 55px;
  list-style-position: inside; }
  #page5 .page5-right img {
    width: 280px;
    margin-bottom: 20px; }
  #page5 .page5-right .signiture {
    font-size: 14px; }
    #page5 .page5-right .signiture .title {
      margin-bottom: 10px; }
    #page5 .page5-right .signiture img {
      width: 200px;
      margin-bottom: 5px; }
    #page5 .page5-right .signiture .english {
      margin-bottom: 15px;
      font-size: 12px;
      font-weight: bold;
      letter-spacing: 0.3em; }
    #page5 .page5-right .signiture .positions {
      margin-bottom: 25px; }
    #page5 .page5-right .signiture ul li {
      line-height: 1.8em; }

#page6 .page__inner {
  width: 968px;
  margin-bottom: 40px; }

#page6 .page6-left {
  vertical-align: middle;
  display: inline-block;
  width: 370px;
  padding: 0 55px; }
  #page6 .page6-left .page6-nav {
    height: 200px;
    margin-left: auto;
    margin-right: auto; }
    #page6 .page6-left .page6-nav ul li {
      list-style-image: url(./img/list-img.png);
      cursor: pointer;
      font-size: 16px;
      font-weight: bold;
      line-height: 4em; }
    #page6 .page6-left .page6-nav ul li:hover {
      color: #888; }

#page6 .page6-right {
  vertical-align: top;
  display: inline-block;
  width: 370px;
  padding: 0 55px;
  font-size: 14px; }
  #page6 .page6-right a {
    text-decoration: underline;
    color: #000;
    padding-bottom: 1px; }
    #page6 .page6-right a:hover {
      text-decoration: none; }
  #page6 .page6-right img {
    margin-bottom: 20px; }
  #page6 .page6-right p {
    font-weight: bold;
    margin-bottom: 5px; }
  #page6 .page6-right ul {
    list-style-type: none;
    list-style-position: inside;
    margin-bottom: 20px; }

#page6 .tel {
  text-decoration: underline; }

#page6 .map {
  display: block;
  filter: grayscale(100%); }
