@charset "UTF-8";
@import url("destyle.css");
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP&display=swap&subset=japanese");
html, body {
  width: 100%;
}

body {
  font-family: "メイリオ", "Meiryo", "ＭＳ ゴシック", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}

b, strong, .bold {
  font-family: "メイリオ", "Meiryo", "ＭＳ ゴシック", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}

/* IEだけに適応 */
_:lang(x)::-ms-backdrop, .selector {
  font-family: "メイリオ", "Meiryo", "ＭＳ ゴシック", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: #ffffff;
}

a:visited, a:link {
  text-decoration: underline;
}

a:hover {
  text-decoration: none;
}

*, *::before, *::after {
  box-sizing: border-box;
}

/*
	project style
===================================================*/
html, body {
  margin: 0;
  padding: 0;
  background: #efefef;
  letter-spacing: 0.8px;
  font-size: 16px;
  line-height: 1;
  font-feature-settings: "palt";
}

/* IEだけに適応 */
html {
  height: 100vh;
  scroll-behavior: smooth;
}

a:visited, a:link {
  color: #000000;
  transition: 0.5s;
}

a:hover {
  color: #808080;
  transition: 0.5s;
}

img {
  width: 100%;
  height: auto;
}

.icon img {
  width: auto;
  height: 1em;
}

/* ==============================================
variables
============================================== */
/* color */
/* path */
/* width */
header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  header {
    align-items: flex-start;
    text-align: left;
    padding-left: 1rem;
  }
}
header .logo {
  margin: 0 auto;
  padding: 2rem 0 2rem;
  width: 480px;
}
header .logo + .copy {
  margin-bottom: 3rem;
  line-height: 1.6;
}
@media only screen and (max-width: 768px) {
  header .logo {
    margin: 0 auto 0 0;
    padding: 2rem 0 2rem;
    width: 300px;
  }
}
header .score {
  display: table;
  flex-direction: row;
  margin: 1rem auto 0;
  padding: 0.75rem 2rem 0.5rem;
  min-height: auto;
  width: auto;
  line-height: 1;
}
header .score .scoretxt {
  margin-right: 2rem;
}
header nav {
  margin-bottom: 2rem;
}
header nav ul {
  display: flex;
  justify-content: center;
}
header nav ul li {
  margin: 0 0.5rem;
}
header nav ul li a {
  padding: 10px;
  text-decoration: none;
  font-size: 4vw;
}
header nav ul li a:hover, header nav ul li a.current {
  position: relative;
  color: #ffffff;
}
header nav ul li a:hover:after, header nav ul li a.current:after {
  position: absolute;
  top: -10px;
  left: calc(50% - 3px);
  display: inline-block;
  width: 6px;
  height: 6px;
  background-color: #ffffff;
  content: "";
}

.lower header {
  display: flex;
  align-items: baseline;
  padding: 3vw;
  width: 94vw;
}
.lower header .logo {
  margin: 0;
  padding: 0;
  width: 24vw;
}
.lower header .logo + .copy {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 768px) {
  .lower header .logo {
    width: 21vw;
  }
}
.lower header nav {
  margin-bottom: 3rem;
}
.lower header nav ul {
  display: flex;
  justify-content: center;
}
.lower header nav ul li {
  margin: 0 0.5rem;
}
.lower header nav ul li a {
  padding: 10px;
  text-decoration: none;
  font-size: 5vw;
}
.lower header nav ul li a:hover, .lower header nav ul li a.current {
  position: relative;
  color: #ffffff;
}
.lower header nav ul li a:hover:after, .lower header nav ul li a.current:after {
  position: absolute;
  top: -10px;
  left: calc(50% - 3px);
  display: inline-block;
  width: 6px;
  height: 6px;
  background-color: #ffffff;
  content: "";
}

.l-footer {
  margin-top: 5em;
}
.l-footer__cont_inr {
  margin: 0 auto;
  width: 1024px;
}
.l-footer__nav {
  margin-bottom: 0.625em;
}
.l-footer__nav ul {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
}
.l-footer__nav ul:after {
  display: inline-block;
  margin-left: 1.25em;
  width: 1px;
  height: 1em;
  background-color: #000000;
  content: "";
  font-size: 0.875em;
}
.l-footer__nav ul li {
  position: relative;
  display: flex;
  align-items: center;
  line-height: 1;
}
.l-footer__nav ul li:before {
  display: inline-block;
  margin-right: 1.25em;
  margin-left: 1.25em;
  width: 1px;
  height: 1em;
  background-color: #000000;
  content: "";
  font-size: 0.875em;
}
.l-footer__nav ul li a span {
  font-size: 0.875em;
  line-height: 1;
}
.l-footer__copy {
  background-color: #000000;
}
.l-footer__copy_inr {
  margin: 0 auto;
  padding: 1.125em 0;
  width: 1024px;
  text-align: center;
}
.l-footer__copy p small {
  color: #ffffff;
  font-weight: 300;
  font-size: 0.75em;
  line-height: 1;
}

.sidebar {
  display: flex;
  flex-direction: column;
}
.sidebar h2 {
  margin-bottom: 1rem;
  text-align: center;
}
.sidebar h2 span {
  font-weight: bold;
  font-size: 1.25rem;
}
.sidebar .loginsideform {
  margin-bottom: 0.5rem;
  padding: 1.5em;
  background-color: #f1f1f1;
}
.sidebar .loginsideform .input-title {
  display: inline-block;
  margin-bottom: 0.5em;
  font-weight: normal;
  font-size: 0.875rem;
}
.sidebar .loginsideform form {
  display: flex;
  flex-direction: column;
}
.sidebar .loginsideform form input[type=text], .sidebar .loginsideform form input[type=password] {
  margin-bottom: 1.5rem;
  border: none;
  border-radius: 0;
}
.sidebar .loginsideform form .loginbtn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 1.25em 0rem;
  background-color: #004c8a;
  color: #ffffff;
  text-align: center;
  font-size: 0.875rem;
  transition: 0.3s;
}
.sidebar .loginsideform form .loginbtn :hover {
  background-color: #0068bd;
  transition: 0.3s;
}
.sidebar .loginsideform form .loginbtn input {
  margin: 0;
  padding: 1rem 1rem 1rem 2em;
}
.sidebar .loginsideform form .loginbtn .c-icon {
  position: absolute;
  left: 3.25rem;
}
.sidebar .loginsideform form .loginbtn + .login-caption {
  margin: 0.3125em 0 2.5em 0;
  text-align: center;
}
.sidebar .loginsideform form .loginbtn + .login-caption a {
  text-decoration: underline;
}
.sidebar .loginsideform form .loginbtn + .login-caption a span {
  font-size: 0.75em;
}
.sidebar .loginsideform form .registbtn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 1.25em;
  background-color: #e82145;
  color: #ffffff;
  text-align: center;
  text-decoration: none;
  font-size: 0.875rem;
  transition: 0.3s;
}
.sidebar .loginsideform form .registbtn:hover {
  background-color: #ed4f6c;
  transition: 0.3s;
}
.sidebar .loginsideform form .registbtn .c-icon {
  position: absolute;
  margin-right: 10em;
}
.sidebar .loginsideform form .registbtn span {
  display: inline-block;
  margin: 0 0 0;
  padding: 1rem 1rem 1rem 2.5rem;
}
.sidebar .sidebtn {
  position: relative;
  display: flex;
  margin-bottom: -1px;
  width: 100%;
  font-weight: 600;
}
.sidebar .sidebtn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25em;
  width: 100%;
  border: 1px solid #004b9e;
  background-color: #ffffff;
  color: #004b9e;
  text-decoration: none;
  transition: all 0.3s ease 0s;
}
.sidebar .sidebtn a span {
  margin-left: 0.5rem;
  font-size: 0.875rem;
}
.sidebar .sidebtn a .icon {
  width: 16px;
  box-shadow: none;
  transition: all 0.3s ease 0s;
}
.sidebar .sidebtn a .icon path {
  transition: all 0.3s ease 0s;
  fill: #004b9e;
}
.sidebar .sidebtn a:hover {
  border: 1px solid #004b9e;
  background-color: #004b9e;
  color: #ffffff;
  transition: all 0.3s ease 0s;
}
.sidebar .sidebtn a:hover .icon path {
  transition: all 0.3s ease 0s;
  fill: #ffffff;
}
.sidebar .sidebtn.imp {
  position: relative;
  display: flex;
  margin-top: 0.75rem;
  width: 100%;
}
.sidebar .sidebtn.imp a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5em;
  width: 100%;
  border: 1px solid #fe5353;
  background-color: #ffffff;
  color: #fe5353;
}
.sidebar .sidebtn.imp a .icon path {
  transition: all 0.3s ease 0s;
  fill: #fe5353;
}
.sidebar .sidebtn.imp a span {
  font-size: 0.875em;
}
.sidebar .sidebtn.imp a:hover {
  border: 1px solid #fe5353;
  background-color: #fe5353;
  color: #ffffff;
  transition: all 0.3s ease 0s;
}
.sidebar .sidebtn.imp a:hover .icon path {
  transition: all 0.3s ease 0s;
  fill: #ffffff;
}
.sidebar figure.company_guide a img {
  width: 100%;
}

.belowsidenav li {
  border-bottom: 1px solid #cccccc;
}
.belowsidenav li a {
  position: relative;
  display: block;
  padding: 0.75rem;
  text-decoration: none;
  transition: 0.3s;
}
.belowsidenav li a span {
  margin-left: 1.5rem;
  font-size: 0.8125rem;
}
.belowsidenav li a:hover, .belowsidenav li a.current {
  padding-left: 1.3rem;
  background: #004b9e;
  color: #ffffff;
  transition: 0.3s;
}
.belowsidenav li a:hover::before, .belowsidenav li a.current::before {
  border-color: #ffffff;
}
.belowsidenav li a:hover::after, .belowsidenav li a.current::after {
  border-left-color: #ffffff;
}
.belowsidenav li a::before {
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  box-sizing: border-box;
  margin: auto;
  width: 12px;
  height: 12px;
  border: 1px solid #004b9e;
  border-radius: 25%;
  content: "";
  vertical-align: middle;
}
.belowsidenav li a::after {
  position: absolute;
  top: 0;
  right: 11px;
  bottom: 0;
  box-sizing: border-box;
  margin: auto;
  width: 3px;
  height: 3px;
  border: 3px solid transparent;
  border-left: 3px solid #004b9e;
  content: "";
  vertical-align: middle;
}

.c-icon {
  position: relative;
}
.c-icon::after {
  display: inline-block;
  margin-top: -0.1em;
  width: 1em;
  height: 1em;
  background-size: 100%;
  content: "";
  vertical-align: middle;
}
.c-icon--tel {
  margin-right: 0.40625em;
}
.c-icon--tel::after {
  margin-top: -0.1em;
  width: 1.0625em;
  height: 0.8125em;
  background: url(../images/common/icon_tel.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--contact {
  margin-right: 0.40625em;
}
.c-icon--contact::after {
  margin-top: -0.1em;
  width: 1.0625em;
  height: 0.8125em;
  background: url(../images/common/icon_contact.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--arrow {
  position: absolute;
  top: 50%;
  right: 0;
  margin-right: 0.625em;
  transform: translateY(-50%);
}
.c-icon--arrow::after {
  margin-top: -0.1em;
  width: 1.125em;
  height: 1.125em;
  background: url(../images/common/icon_arrow-forward.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--arrow.rev {
  top: 49%;
  right: inherit;
  left: 0;
  margin-right: 0;
  margin-left: 0.625em;
}
.c-icon--arrow.rev::after {
  transform: rotate(180deg);
}
.c-icon--pdf {
  margin-right: 0.40625em;
}
.c-icon--pdf::after {
  margin-top: -0.1em;
  width: 1em;
  height: 1.375em;
  background: url(../images/common/icon_pdf.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--pdf-file {
  margin-right: 0.40625em;
}
.c-icon--pdf-file::after {
  margin-top: -0.1em;
  width: 1.0625em;
  height: 0.9375em;
  background: url(../images/common/icon_pdf-file.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--calendar {
  margin-right: 0.8125em;
}
.c-icon--calendar::after {
  margin-top: -0.4em;
  width: 1.0625rem;
  height: 1.21875rem;
  background: url(../images/common/icon_calendar.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--calendarimg {
  margin-top: -0.4em;
  margin-right: 0.8125em;
  width: 1.0625rem;
  height: 1.21875rem;
}
.c-icon--globe {
  margin-right: 0.40625em;
}
.c-icon--globe::after {
  margin-top: -0.1em;
  width: 0.8125em;
  height: 0.8125em;
  background: url(../images/common/icon_globe.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--handshake {
  margin-right: 0.8125em;
}
.c-icon--handshake::after {
  margin-top: -0.25rem;
  width: 1.375rem;
  height: 1.09375rem;
  background: url(../images/common/icon_handshake.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--account-login {
  margin-right: 0.40625em;
}
.c-icon--account-login::after {
  width: 1.125em;
  height: 1em;
  background: url(../images/common/icon_account-login.svg) center center no-repeat;
  background-size: cover;
}
.c-icon--user-plus {
  margin-right: 0.40625em;
}
.c-icon--user-plus::after {
  margin-top: -0.1em;
  width: 1.375em;
  height: 1.25em;
  background: url(../images/common/icon_user-plus.svg) center center no-repeat;
  background-size: 100%;
}
.c-icon--warehouse {
  margin-right: 0.8125em;
}
.c-icon--warehouse::after {
  margin-top: -0.35em;
  width: 1.21875rem;
  height: 0.96875rem;
  background: url(../images/common/icon_warehouse.svg) center center no-repeat;
  background-size: 100%;
}

.sidebtn a .icon {
  margin-top: -0.2rem;
}
.sidebtn a .icon.icon_cal {
  width: 17px;
  height: 19.5px;
}
.sidebtn a .icon.icon_handshake {
  width: 22px;
  height: 17.5px;
}
.sidebtn a .icon.icon_warehouse {
  width: 19.5px;
  height: 15.5px;
}

.caution {
  color: #ff0000;
}

.c-header {
  margin-bottom: 3rem;
}
.c-header h3 {
  margin-bottom: 0.5rem;
  font-weight: 700;
}
.c-header p {
  font-size: 0.8125rem;
  line-height: 1.6;
}

.l-content p.fs-11 {
  font-size: 0.6875rem;
}

.l-main {
  color: #333333;
}
.l-main h2 {
  text-align: center;
}
.l-main h2 span {
  display: inline-block;
  margin: 0px auto 40px;
  padding: 0 1rem;
  min-width: 250px;
  color: #000000;
  text-align: center;
  font-weight: bold;
  font-size: 1.25em;
}
.l-main h2 span::after {
  display: block;
  margin: 0 -1rem;
  margin-top: 0.5rem;
  height: 1px;
  background: linear-gradient(to right, #68b0ff 0%, #262a2d 100%);
  content: "";
}
.l-main .title {
  margin-bottom: 1rem;
  color: #004d8c;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.6;
}
.l-main .mid-title {
  margin-bottom: 1rem;
  color: #004d8c;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.6;
}

.result-location, .result-paginate {
  padding: 2rem 0;
}

.txt {
  margin-bottom: 1.6em;
  font-size: 0.8125rem;
}

.result-location b {
  padding: 0 0.3em;
  color: #e82044;
  font-weight: normal;
}

.result-paginate {
  float: right;
}
.result-paginate li {
  float: left;
  margin-left: 4px;
  font-size: 0.75rem;
}
.result-paginate li a {
  display: inline-block;
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  border: 1px solid #d5d5d5;
  border-radius: 3px;
  background-color: #ffffff;
  color: #d5d5d5;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  line-height: 24px;
}
.result-paginate li.cur a {
  border: 0;
  background-color: #004d8c;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) inset;
  color: #ffffff;
}

.herowarp {
  width: 100%;
  background: url(../images/top/hero@2x.png);
  background-position: center top;
  background-size: 1294px 490px;
  background-repeat: no-repeat;
}
.herowarp .hero {
  position: relative;
  margin: 0 auto;
  width: 1024px;
  height: 490px;
}
.herowarp .hero .l1 {
  position: absolute;
  top: 50px;
  left: -30px;
}
.herowarp .hero .l2 {
  position: absolute;
  top: 160px;
  left: 0;
}
.herowarp .hero .l2 ul li {
  position: relative;
  margin-bottom: 7px;
  padding: 1.0625rem 0;
  width: 340px;
  text-align: center;
  line-height: 1.4;
}
.herowarp .hero .l2 ul li:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  background: linear-gradient(to right, rgba(0, 75, 158, 0.8) 0%, rgba(0, 38, 79, 0.8) 100%);
  content: "";
  mix-blend-mode: multiply;
}
.herowarp .hero .l2 ul li .text {
  position: relative;
  z-index: 2;
  color: #ffffff;
  font-weight: 600;
  font-size: 1.0625rem;
  mix-blend-mode: normal;
}
.service_route {
  padding: 20px;
  padding-bottom: 0px;
  background: #d1e7f0;
}
.service_route .service_route-inner {
  margin: 0 auto;
  width: 1024px;
  text-align: center;
}
.service_route .service_route-inner h2 {
  margin-bottom: 0.8125rem;
  color: #004b9e;
  font-weight: 700;
  font-size: 1.25rem;
}
.service_route .service_route-inner ul {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
.service_route .service_route-inner ul li {
  margin-right: 20px;
  margin-bottom: 20px;
  padding: 1rem;
  width: 185px;
  background: #ffffff;
  color: #004b9e;
  transition: 0.2s;
}
.service_route .service_route-inner ul li:nth-child(5n) {
  margin-right: 0;
}
.service_route .service_route-inner ul li a span.jp {
  position: relative;
  display: block;
  margin-bottom: 0.4375rem;
  padding-bottom: 0.4375rem;
  font-weight: 700;
  font-size: 1rem;
}
.service_route .service_route-inner ul li a span.jp:after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #004b9e;
  content: "";
}
.service_route .service_route-inner ul li a span.en {
  display: block;
  font-size: 0.75rem;
  font-family: "Times New Roman", Times, serif;
}
.service_route .service_route-inner ul li:hover {
  background-color: #004b9e;
  color: #ffffff;
  transition: 0.3s;
}
.service_route .service_route-inner ul li:hover a {
  transition: 0.1s;
}
.service_route .service_route-inner ul li:hover a span:after {
  background: #ffffff;
}

.basicbtnlist {
  margin: 0 0 70px -30px;
  padding: 30px;
  padding-bottom: calc(30px - 1rem);
  background-color: #004b9e;
}
.basicbtnlist ul {
  display: flex;
  align-items: start;
  flex-wrap: wrap;
}
.basicbtnlist ul li {
  position: relative;
  margin-right: 12px;
  margin-bottom: 12px;
  padding: 1rem;
  width: 220px;
  border: 1px solid #004b9e;
  background: #ffffff;
  color: #004b9e;
  text-align: center;
  transition: 0.2s;
}
.basicbtnlist ul li:nth-child(3n) {
  margin-right: 0;
}
.basicbtnlist ul li a span {
  display: block;
}
.basicbtnlist ul li a span svg {
  margin-bottom: 5px;
}
.basicbtnlist ul li a span.text {
  position: relative;
  display: block;
  font-weight: 700;
  font-size: 0.875rem;
}
.basicbtnlist ul li a span.icon-arrow {
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -9px;
}
.basicbtnlist ul li:hover {
  width: 220px;
  border: 1px solid #ffffff;
  background-color: #004b9e;
  color: #ffffff;
  transition: 0.3s;
}
.basicbtnlist ul li:hover a .icon-arrow svg path {
  transition: 0.3s;
  fill: #ffffff;
}
.basicbtnlist ul li:hover a span svg g {
  transition: 0.3s;
  fill: #ffffff;
}
.basicbtnlist ul li:hover a span:after {
  background: #ffffff;
}

.btn-box {
  text-align: center;
}
.btn-box .btn {
  position: relative;
  display: inline-block;
  margin: 1rem auto 0;
  min-width: 130px;
  border: 0;
  background-color: #004d8c;
  color: #ffffff !important;
  text-align: center;
  text-decoration: none;
  font-size: 1rem;
  cursor: pointer;
  transition: opacity 0.3s;
}
.btn-box .btn.c1 {
  background-color: #343435;
}
.btn-box .btn.c1 a {
  text-decoration: none;
}
.btn-box .btn.c1 a .icon-arrow_lt {
  position: relative;
  display: inline-block;
  padding: 0 0 0 16px;
  vertical-align: middle;
  text-decoration: none;
  font-size: 15px;
}
.btn-box .btn.c1 a .icon-arrow_lt:after {
  display: inline-block;
  margin: auto;
  margin-top: -4px;
  margin-left: 0.5rem;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  content: "";
  vertical-align: middle;
  transform: rotate(45deg);
}
.btn-box .btn.c2 {
  background-color: #848484;
}
.btn-box .btn.ssz {
  min-width: 100px;
  width: 100px;
}
.btn-box .btn a {
  display: inline-block;
  margin: 0;
  padding: 1rem 1rem 1rem 1rem;
  text-decoration: none;
}
.btn-box .btn a span {
  color: #ffffff;
}

.l-content p {
  margin-bottom: 1em;
  font-size: 0.9375rem;
  line-height: 2;
}

.tar {
  text-align: right;
}

.tac {
  text-align: center;
}

.tal {
  text-align: left;
}

table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
}
table th {
  white-space: nowrap;
}
table th span {
  display: block;
  color: #999999;
  font-size: smaller;
}
table th, table td {
  padding: 1em;
  border-bottom: 1px solid #d0d0d0;
  text-align: left;
  font-weight: normal;
  font-size: 0.9375rem;
  line-height: 1.5;
}
table td .en {
  display: block;
  margin-top: 0.5rem;
  color: #333333;
  font-size: smaller;
}

dt, dd {
  line-height: 1.5;
}

.borderBox {
  margin-bottom: 3rem;
}
.borderBox .l-box-inner {
  position: relative;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px dotted #cccccc;
}
.borderBox .l-box-inner a.mappop {
  top: 0;
  right: 0;
}
.borderBox .l-box-inner:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
.borderBox .l-box-inner p {
  font-size: 0.8125rem;
  line-height: 1.8;
}
.borderBox .l-box-inner p:last-child {
  margin-bottom: 0;
}

a.mappop {
  display: inline-block;
  margin-left: 1rem;
  padding: 0.3125rem 0.5rem 0.2rem;
  border-radius: 6px;
  background-color: #e96a21;
  color: #ffffff !important;
  line-height: 1;
  cursor: pointer;
  transition: 0.3s;
}
a.mappop:hover {
  background-color: #ac4a11;
  transition: 0.3s;
}

.borderBox {
  position: relative;
  margin-bottom: 2.4em;
  padding: 10px 18px;
  border: 4px solid #e0e0e0;
  font-size: 0.8125rem;
}
.borderBox:after {
  display: block;
  clear: both;
  content: "";
}
.borderBox a.mappop {
  position: absolute;
  top: 10px;
  right: 18px;
  line-height: 1;
}
.borderBox h2 {
  margin: 0 -18px 15px;
  padding: 0 18px 10px;
  border-bottom: 3px double #e0e0e0;
  color: #004d8c;
  text-align: left;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.6;
}
.borderBox h2 + p {
  line-height: 1.6;
}
.borderBox table {
  float: right;
  margin-top: 1rem;
  width: auto;
}
.borderBox table th, .borderBox table td {
  padding: 0.5rem;
  font-size: 0.8125rem;
}

.profile th, .profile td {
  border: none;
  font-size: 0.8125rem;
}
.profile th {
  position: relative;
  padding-right: 2rem;
}
.profile th:before {
  position: absolute;
  top: 1rem;
  right: 0;
  bottom: 1rem;
  width: 1px;
  background: #999999;
  content: "";
}
.profile td {
  padding-left: 2rem;
}

.message p {
  padding: 3rem 0;
  border: 2px dotted #fe5353;
  border-width: 2px 0;
  color: #fe5353;
  text-align: center;
  font-weight: 700;
  font-size: 1.25rem;
}

.tac {
  text-align: center;
}

.btn-search {
  justify-content: center;
  margin: 0;
  border-radius: 4px;
  background: #004c8a url(../images/common/icon_search.svg) 60px center no-repeat;
  color: #ffffff;
  text-align: center;
  transition: 0.3s;
}
.btn-search:hover {
  background-color: #0068bd;
  transition: 0.3s;
}
.btn-search input[type=submit] {
  padding: 0.5rem;
  font-size: 1rem;
}

.box-title {
  margin: 0 -18px 15px;
  margin-bottom: 0.5rem;
  padding: 0 18px 10px;
  border-bottom: 3px double #e0e0e0;
  color: #666666;
  font-weight: 700;
  font-size: 1rem;
}
.box-title span {
  display: inline-block;
  margin-right: 0.5rem;
  color: #004d8c;
}

.nes-btn.is-warning {
  border-width: 4px;
  border-style: solid;
  background-color: #f7d51d;
  color: #212529;
  transform: scale(0.65);
}

.nes-btn.is-contact {
  border-width: 4px;
  border-style: solid;
  border-radius: 0;
  background-color: #fe5353;
  color: #ffffff;
  font-weight: 700;
  font-family: "numberf", "dotf";
  line-height: 1;
}

.nes-btn {
  position: relative;
  display: inline-block;
  margin: 4px;
  padding: 6px 8px;
  border-image-source: url('data:image/svg+xml;utf8,<?xml version="1.0" encoding="UTF-8" ?><svg version="1.1" width="5" height="5" xmlns="http://www.w3.org/2000/svg"><path d="M2 1 h1 v1 h-1 z M1 2 h1 v1 h-1 z M3 2 h1 v1 h-1 z M2 3 h1 v1 h-1 z" fill="rgb(33,37,41)" /></svg>');
  border-image-slice: 2;
  border-image-width: 2;
  border-image-outset: 2;
  border-image-repeat: stretch;
  background-color: #ffffff;
  color: #212529;
  vertical-align: middle;
  text-align: center;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.nes-btn.is-warning::after {
  position: absolute;
  top: -4px;
  right: -4px;
  bottom: -4px;
  left: -4px;
  box-shadow: inset -4px -4px #e59400;
  content: "";
}

.tglbtn {
  position: relative;
  display: inline-block;
  margin: 30px;
  padding: 14px 14px 14px 20px;
  color: #333333;
  font-weight: 500;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
}
.tglbtn a {
  position: relative;
  text-decoration: none;
}
.tglbtn a:hover:before {
  left: 100%;
  transform: translate(-90%, -25%);
}
.tglbtn a:hover:after {
  left: 100%;
  transform: translate(-95%, -17%);
}
.tglbtn a:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  width: 4rem;
  height: 2rem;
  border-radius: 2rem;
  background-color: #ffffff;
  content: "";
  transition: 0.4s cubic-bezier(0.6, 0.01, 0.4, 1);
  transform: translate(-20%, -25%);
}
.tglbtn a:after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: -2;
  width: 4rem;
  height: 2rem;
  border-radius: 2rem;
  background-color: #e82044;
  content: "";
  transition: 0.5s cubic-bezier(0.6, 0.01, 0.4, 1);
  transform: translate(-25%, -17%);
}
.tglbtn a span {
  position: relative;
  z-index: 2;
}

.fbc {
  margin: 0 auto 30px;
}

.postlist {
  z-index: 99999;
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  padding: 20px;
  max-width: 1280px;
  border-radius: 20px;
  background-color: #fafafa;
}
.postlist article {
  font-family: "A1ゴシック R JIS2004";
}
.postlist article .title {
  color: inherit;
  font-weight: normal;
}
.postlist article .title .entry-title {
  text-align: left;
}

.bookstand {
  position: relative;
  z-index: 999;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
  margin-top: 3rem;
  max-width: 820px;
}
.bookstand .item {
  margin-bottom: 3rem;
}

.book {
  position: relative;
  margin: 0 auto;
  width: 220px;
  height: 337px;
}
.book:hover {
  position: relative;
  z-index: 999;
  transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg);
  transform-style: preserve-3d;
}
.book:hover .book-wrap {
  position: relative;
  z-index: 1;
  margin: 0px 16px;
  transform: rotateX(0deg) rotateZ(0deg);
}
.book .book-wrap {
  position: relative;
  width: 220px;
  height: 337px;
  transition: 0.3s;
  transform: rotateX(-16deg) rotateY(-30deg) rotateZ(0deg);
  transform-style: preserve-3d;
}
.book .book-wrap .jacket {
  position: relative;
  top: 0px;
  z-index: 1;
  width: 186px;
  height: 337px;
  line-height: 1.6;
  transform: translate3d(0, 0, 0);
  transform-style: preserve-3d;
}
.book .book-wrap .jacket .postmeta {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  padding: 20px;
  height: 100%;
  color: #ffffff;
  text-decoration: none;
}
.book .book-wrap .jacket .title {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  color: #ffffff;
  text-decoration: none;
}
.book .book-wrap .jacket .title h2, .book .book-wrap .jacket .title h1 {
  width: 186px;
}
.book .book-wrap .jacket figure {
  overflow: hidden;
  width: 186px;
}
.book .book-wrap .jacket figure img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -3;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.book .book-wrap .jacket:after, .book .book-wrap .jacket:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.book .book-wrap .jacket::before {
  left: 136px;
  width: 50px;
  content: "";
  transform: rotateY(-90deg);
  transform-origin: right center;
}
.book .book-wrap .jacket::after {
  top: 0;
  bottom: auto;
  height: 50px;
  background-position: top center;
  content: "";
  transform: rotateX(-90deg);
  transform-origin: top center;
}
.book .book-wrap .jacket.normal {
  z-index: 99999;
  background: #ffffff;
  transform: translate3d(0, 0, 0);
}
.book .book-wrap .jacket.normal::before {
  background: #cccccc;
}
.book .book-wrap .jacket.normal::after {
  background: #ffffff;
}

.sushi {
  display: none;
  margin: 0 auto;
  width: 80px;
  height: 160px;
}

.sushi-wrap {
  position: relative;
  width: 80px;
  height: 160px;
  transform: rotateX(60deg) rotateZ(30deg);
  transform-style: preserve-3d;
}

.neta {
  position: absolute;
  top: 0px;
  z-index: 10;
  width: 76px;
  height: 160px;
  transform-style: preserve-3d;
}
.neta:after, .neta:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.neta::before {
  left: 56px;
  width: 20px;
  content: "";
  transform: rotateY(-90deg);
  transform-origin: right center;
}
.neta::after {
  top: auto;
  bottom: 0;
  height: 20px;
  background-position: bottom center;
  content: "";
  transform: rotateX(90deg);
  transform-origin: bottom center;
}
.neta.magro {
  background: #d03636;
}
.neta.magro::before {
  background: #d03636;
}
.neta.magro::after {
  background: #d03636;
}

.shari {
  position: absolute;
  top: 0px;
  z-index: -10;
  width: 68px;
  height: 152px;
  background: #f1f1f1;
  transform-style: preserve-3d;
}
.shari:before, .shari:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #f7f7f7;
  content: "";
}
.shari:before {
  left: 8px;
  width: 60px;
  border-radius: 8px 0 0 0;
  transform: rotateY(-90deg);
  transform-origin: right center;
}
.shari:after {
  top: auto;
  bottom: 0;
  height: 60px;
  border-radius: 8px 0 0 0;
  transform: rotateX(90deg);
  transform-origin: bottom center;
}

form {
  width: 100%;
}

button, input, select, textarea {
  margin: 0;
  border: 1px solid #cccccc;
  border-radius: 4px;
  font-size: 100%;
  font-size: 1rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
}
button[type=text], button[type=password], button[type=tel], button[type=email], button[type=reset], input[type=text], input[type=password], input[type=tel], input[type=email], input[type=reset], select[type=text], select[type=password], select[type=tel], select[type=email], select[type=reset], textarea[type=text], textarea[type=password], textarea[type=tel], textarea[type=email], textarea[type=reset] {
  display: inline-block;
  box-sizing: border-box;
  padding: 0.5rem 0.75rem;
  width: 100%;
  height: fit-content;
  border: 1px solid #cccccc;
  border-radius: 4px;
  background: #ffffff;
  color: inherit;
  line-height: 1;
}
button[type=text]#tel, button[type=text]#fax, button[type=password]#tel, button[type=password]#fax, button[type=tel]#tel, button[type=tel]#fax, button[type=email]#tel, button[type=email]#fax, button[type=reset]#tel, button[type=reset]#fax, input[type=text]#tel, input[type=text]#fax, input[type=password]#tel, input[type=password]#fax, input[type=tel]#tel, input[type=tel]#fax, input[type=email]#tel, input[type=email]#fax, input[type=reset]#tel, input[type=reset]#fax, select[type=text]#tel, select[type=text]#fax, select[type=password]#tel, select[type=password]#fax, select[type=tel]#tel, select[type=tel]#fax, select[type=email]#tel, select[type=email]#fax, select[type=reset]#tel, select[type=reset]#fax, textarea[type=text]#tel, textarea[type=text]#fax, textarea[type=password]#tel, textarea[type=password]#fax, textarea[type=tel]#tel, textarea[type=tel]#fax, textarea[type=email]#tel, textarea[type=email]#fax, textarea[type=reset]#tel, textarea[type=reset]#fax {
  width: 50%;
}
button[type=text]::placeholder, button[type=password]::placeholder, button[type=tel]::placeholder, button[type=email]::placeholder, button[type=reset]::placeholder, input[type=text]::placeholder, input[type=password]::placeholder, input[type=tel]::placeholder, input[type=email]::placeholder, input[type=reset]::placeholder, select[type=text]::placeholder, select[type=password]::placeholder, select[type=tel]::placeholder, select[type=email]::placeholder, select[type=reset]::placeholder, textarea[type=text]::placeholder, textarea[type=password]::placeholder, textarea[type=tel]::placeholder, textarea[type=email]::placeholder, textarea[type=reset]::placeholder {
  color: #999999;
}
button[type=radio], input[type=radio], select[type=radio], textarea[type=radio] {
  display: none;
}
button[type=radio] + .radio_icon, input[type=radio] + .radio_icon, select[type=radio] + .radio_icon, textarea[type=radio] + .radio_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.5em;
  width: 1em;
  height: 1em;
  border: 1px solid #cccccc;
  border-radius: 999em;
  background-color: #ffffff;
  line-height: 1em;
}
button[type=radio] + .radio_icon:before, input[type=radio] + .radio_icon:before, select[type=radio] + .radio_icon:before, textarea[type=radio] + .radio_icon:before {
  display: block;
  visibility: hidden;
  width: 0.625rem;
  height: 0.625rem;
  border-radius: inherit;
  background-color: #259899;
  content: "";
  line-height: inherit;
}
button[type=radio]:checked + .radio_icon:before, input[type=radio]:checked + .radio_icon:before, select[type=radio]:checked + .radio_icon:before, textarea[type=radio]:checked + .radio_icon:before {
  visibility: visible;
}

input[type=button], input[type=submit], input[type=reset] {
  margin: 0.5rem 0;
  padding: 0.5rem 1rem;
  max-width: 100%;
  width: 100%;
  border: none;
}

textarea {
  padding: 0 0 0 5px;
  max-width: 493px;
  width: 493px;
  height: 107px;
  border: 1px solid #999999;
  background: #ffffff;
}

.captcha {
  float: left;
}
.captcha input {
  float: right;
}
.captcha input[name=question] {
  padding-right: 0;
  width: 4rem;
  text-align: right;
}
.captcha [name=captcha] {
  padding-left: 0.5rem;
  width: 5rem;
}
.captcha [name=captcha]::placeholder {
  text-align: center;
}

.modSubmitBotton {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding: 40px 0 0;
  width: 350px;
  text-align: center;
  justify-items: center;
}
.modSubmitBotton .submitBottonInner {
  margin: 0;
}
.modSubmitBotton .submitBottonInner .submit {
  display: inline-block;
  padding: 0;
  width: 165px;
  height: 44px;
  border: none;
  background: #d59500;
  color: #ffffff;
  line-height: 1;
  transition: 0.3s;
}
.modSubmitBotton .submitBottonInner .submit:hover {
  background-color: #a27100;
  transition: 0.3s;
}
.modSubmitBotton .submitBottonInner .reset {
  display: inline-block;
  padding: 0;
  width: 165px;
  height: 44px;
  border: none;
  background: #848484;
  color: #ffffff;
  line-height: 1;
  transition: 0.3s;
}
.modSubmitBotton .submitBottonInner .reset:hover {
  background-color: #6b6b6b;
  transition: 0.3s;
}

/* --- form set box - flow list */
.flowList {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 0 5rem;
  padding: 0;
  width: 100%;
}
.flowList li {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 1rem;
  width: 280px;
  height: 66px;
  background: #ffffff url("../images/common/mc_flowstep.svg");
  background-size: contain;
  background-repeat: no-repeat;
  color: #b0d7e8;
}
.flowList li.current {
  background: #ffffff url("../images/common/mc_flowstep_on.svg");
  color: #ffffff;
}
.flowList li:last-child {
  width: 242px;
  background: #ffffff url("../images/common/mc_flowstep_last.svg");
}
.flowList li:last-child.current {
  background: #ffffff url("../images/common/mc_flowstep_last_on.svg");
  color: #ffffff;
}
.flowList p {
  position: relative;
  margin: 0;
  vertical-align: middle;
  text-align: center;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1;
}

/* --- form set box */
.formSetBox {
  position: relative;
}
.formSetBox .caution {
  margin-left: 1rem;
  padding: 0 0.25rem;
  border-radius: 5px;
  background-color: #ff0000;
  color: #ffffff;
  font-size: 0.625rem;
}
.formSetBox .formSetList {
  width: 100%;
}
.formSetBox .formSetList li {
  margin-bottom: 2rem;
  font-size: 0.875rem;
}
.formSetBox .formSetList li.mb05 {
  margin-bottom: 0.5rem;
}
.formSetBox .formSetList li dl {
  display: flex;
  align-items: center;
}
.formSetBox .formSetList li dl dt {
  width: 250px;
  font-size: 0.875rem;
}
.formSetBox .formSetList li dl dt label {
  display: flex;
  align-items: center;
}
.formSetBox .formSetList li dl dd {
  display: flex;
  align-items: center;
  width: 100%;
}
.formSetBox .formSetList li ul.inline {
  display: flex;
  align-items: center;
}
.formSetBox .formSetList li ul.inline li {
  margin-bottom: 0;
}
.formSetBox .formSetList li ul.inline label {
  display: flex;
  align-items: center;
  margin-right: 3rem;
  font-weight: 700;
  font-size: 0.875rem;
}

/* width */
/* ==============================================
spacing
============================================== */
.u-mt0 {
  margin-top: 0px !important;
}

.u-mr0 {
  margin-right: 0px !important;
}

.u-mb0 {
  margin-bottom: 0px !important;
}

.u-ml0 {
  margin-left: 0px !important;
}

.u-pt0 {
  padding-top: 0px !important;
}

.u-pr0 {
  padding-right: 0px !important;
}

.u-pb0 {
  padding-bottom: 0px !important;
}

.u-pl0 {
  padding-left: 0px !important;
}

.u-mt5 {
  margin-top: 5px !important;
}

.u-mr5 {
  margin-right: 5px !important;
}

.u-mb5 {
  margin-bottom: 5px !important;
}

.u-ml5 {
  margin-left: 5px !important;
}

.u-pt5 {
  padding-top: 5px !important;
}

.u-pr5 {
  padding-right: 5px !important;
}

.u-pb5 {
  padding-bottom: 5px !important;
}

.u-pl5 {
  padding-left: 5px !important;
}

.u-mt10 {
  margin-top: 10px !important;
}

.u-mr10 {
  margin-right: 10px !important;
}

.u-mb10 {
  margin-bottom: 10px !important;
}

.u-ml10 {
  margin-left: 10px !important;
}

.u-pt10 {
  padding-top: 10px !important;
}

.u-pr10 {
  padding-right: 10px !important;
}

.u-pb10 {
  padding-bottom: 10px !important;
}

.u-pl10 {
  padding-left: 10px !important;
}

.u-mt15 {
  margin-top: 15px !important;
}

.u-mr15 {
  margin-right: 15px !important;
}

.u-mb15 {
  margin-bottom: 15px !important;
}

.u-ml15 {
  margin-left: 15px !important;
}

.u-pt15 {
  padding-top: 15px !important;
}

.u-pr15 {
  padding-right: 15px !important;
}

.u-pb15 {
  padding-bottom: 15px !important;
}

.u-pl15 {
  padding-left: 15px !important;
}

.u-mt20 {
  margin-top: 20px !important;
}

.u-mr20 {
  margin-right: 20px !important;
}

.u-mb20 {
  margin-bottom: 20px !important;
}

.u-ml20 {
  margin-left: 20px !important;
}

.u-pt20 {
  padding-top: 20px !important;
}

.u-pr20 {
  padding-right: 20px !important;
}

.u-pb20 {
  padding-bottom: 20px !important;
}

.u-pl20 {
  padding-left: 20px !important;
}

.u-mt25 {
  margin-top: 25px !important;
}

.u-mr25 {
  margin-right: 25px !important;
}

.u-mb25 {
  margin-bottom: 25px !important;
}

.u-ml25 {
  margin-left: 25px !important;
}

.u-pt25 {
  padding-top: 25px !important;
}

.u-pr25 {
  padding-right: 25px !important;
}

.u-pb25 {
  padding-bottom: 25px !important;
}

.u-pl25 {
  padding-left: 25px !important;
}

.u-mt30 {
  margin-top: 30px !important;
}

.u-mr30 {
  margin-right: 30px !important;
}

.u-mb30 {
  margin-bottom: 30px !important;
}

.u-ml30 {
  margin-left: 30px !important;
}

.u-pt30 {
  padding-top: 30px !important;
}

.u-pr30 {
  padding-right: 30px !important;
}

.u-pb30 {
  padding-bottom: 30px !important;
}

.u-pl30 {
  padding-left: 30px !important;
}

.u-mt35 {
  margin-top: 35px !important;
}

.u-mr35 {
  margin-right: 35px !important;
}

.u-mb35 {
  margin-bottom: 35px !important;
}

.u-ml35 {
  margin-left: 35px !important;
}

.u-pt35 {
  padding-top: 35px !important;
}

.u-pr35 {
  padding-right: 35px !important;
}

.u-pb35 {
  padding-bottom: 35px !important;
}

.u-pl35 {
  padding-left: 35px !important;
}

.u-mt40 {
  margin-top: 40px !important;
}

.u-mr40 {
  margin-right: 40px !important;
}

.u-mb40 {
  margin-bottom: 40px !important;
}

.u-ml40 {
  margin-left: 40px !important;
}

.u-pt40 {
  padding-top: 40px !important;
}

.u-pr40 {
  padding-right: 40px !important;
}

.u-pb40 {
  padding-bottom: 40px !important;
}

.u-pl40 {
  padding-left: 40px !important;
}

.u-mt45 {
  margin-top: 45px !important;
}

.u-mr45 {
  margin-right: 45px !important;
}

.u-mb45 {
  margin-bottom: 45px !important;
}

.u-ml45 {
  margin-left: 45px !important;
}

.u-pt45 {
  padding-top: 45px !important;
}

.u-pr45 {
  padding-right: 45px !important;
}

.u-pb45 {
  padding-bottom: 45px !important;
}

.u-pl45 {
  padding-left: 45px !important;
}

.u-mt50 {
  margin-top: 50px !important;
}

.u-mr50 {
  margin-right: 50px !important;
}

.u-mb50 {
  margin-bottom: 50px !important;
}

.u-ml50 {
  margin-left: 50px !important;
}

.u-pt50 {
  padding-top: 50px !important;
}

.u-pr50 {
  padding-right: 50px !important;
}

.u-pb50 {
  padding-bottom: 50px !important;
}

.u-pl50 {
  padding-left: 50px !important;
}

.u-mt55 {
  margin-top: 55px !important;
}

.u-mr55 {
  margin-right: 55px !important;
}

.u-mb55 {
  margin-bottom: 55px !important;
}

.u-ml55 {
  margin-left: 55px !important;
}

.u-pt55 {
  padding-top: 55px !important;
}

.u-pr55 {
  padding-right: 55px !important;
}

.u-pb55 {
  padding-bottom: 55px !important;
}

.u-pl55 {
  padding-left: 55px !important;
}

.u-mt60 {
  margin-top: 60px !important;
}

.u-mr60 {
  margin-right: 60px !important;
}

.u-mb60 {
  margin-bottom: 60px !important;
}

.u-ml60 {
  margin-left: 60px !important;
}

.u-pt60 {
  padding-top: 60px !important;
}

.u-pr60 {
  padding-right: 60px !important;
}

.u-pb60 {
  padding-bottom: 60px !important;
}

.u-pl60 {
  padding-left: 60px !important;
}

.u-mt65 {
  margin-top: 65px !important;
}

.u-mr65 {
  margin-right: 65px !important;
}

.u-mb65 {
  margin-bottom: 65px !important;
}

.u-ml65 {
  margin-left: 65px !important;
}

.u-pt65 {
  padding-top: 65px !important;
}

.u-pr65 {
  padding-right: 65px !important;
}

.u-pb65 {
  padding-bottom: 65px !important;
}

.u-pl65 {
  padding-left: 65px !important;
}

.u-mt70 {
  margin-top: 70px !important;
}

.u-mr70 {
  margin-right: 70px !important;
}

.u-mb70 {
  margin-bottom: 70px !important;
}

.u-ml70 {
  margin-left: 70px !important;
}

.u-pt70 {
  padding-top: 70px !important;
}

.u-pr70 {
  padding-right: 70px !important;
}

.u-pb70 {
  padding-bottom: 70px !important;
}

.u-pl70 {
  padding-left: 70px !important;
}

.u-mt75 {
  margin-top: 75px !important;
}

.u-mr75 {
  margin-right: 75px !important;
}

.u-mb75 {
  margin-bottom: 75px !important;
}

.u-ml75 {
  margin-left: 75px !important;
}

.u-pt75 {
  padding-top: 75px !important;
}

.u-pr75 {
  padding-right: 75px !important;
}

.u-pb75 {
  padding-bottom: 75px !important;
}

.u-pl75 {
  padding-left: 75px !important;
}

.u-mt80 {
  margin-top: 80px !important;
}

.u-mr80 {
  margin-right: 80px !important;
}

.u-mb80 {
  margin-bottom: 80px !important;
}

.u-ml80 {
  margin-left: 80px !important;
}

.u-pt80 {
  padding-top: 80px !important;
}

.u-pr80 {
  padding-right: 80px !important;
}

.u-pb80 {
  padding-bottom: 80px !important;
}

.u-pl80 {
  padding-left: 80px !important;
}

.u-mt85 {
  margin-top: 85px !important;
}

.u-mr85 {
  margin-right: 85px !important;
}

.u-mb85 {
  margin-bottom: 85px !important;
}

.u-ml85 {
  margin-left: 85px !important;
}

.u-pt85 {
  padding-top: 85px !important;
}

.u-pr85 {
  padding-right: 85px !important;
}

.u-pb85 {
  padding-bottom: 85px !important;
}

.u-pl85 {
  padding-left: 85px !important;
}

.u-mt90 {
  margin-top: 90px !important;
}

.u-mr90 {
  margin-right: 90px !important;
}

.u-mb90 {
  margin-bottom: 90px !important;
}

.u-ml90 {
  margin-left: 90px !important;
}

.u-pt90 {
  padding-top: 90px !important;
}

.u-pr90 {
  padding-right: 90px !important;
}

.u-pb90 {
  padding-bottom: 90px !important;
}

.u-pl90 {
  padding-left: 90px !important;
}

.u-mt95 {
  margin-top: 95px !important;
}

.u-mr95 {
  margin-right: 95px !important;
}

.u-mb95 {
  margin-bottom: 95px !important;
}

.u-ml95 {
  margin-left: 95px !important;
}

.u-pt95 {
  padding-top: 95px !important;
}

.u-pr95 {
  padding-right: 95px !important;
}

.u-pb95 {
  padding-bottom: 95px !important;
}

.u-pl95 {
  padding-left: 95px !important;
}

.u-mt100 {
  margin-top: 100px !important;
}

.u-mr100 {
  margin-right: 100px !important;
}

.u-mb100 {
  margin-bottom: 100px !important;
}

.u-ml100 {
  margin-left: 100px !important;
}

.u-pt100 {
  padding-top: 100px !important;
}

.u-pr100 {
  padding-right: 100px !important;
}

.u-pb100 {
  padding-bottom: 100px !important;
}

.u-pl100 {
  padding-left: 100px !important;
}

@media only screen and (max-width: 767px) {
  .u-mt0-sp {
    margin-top: 0px !important;
  }
  .u-mr0-sp {
    margin-right: 0px !important;
  }
  .u-mb0-sp {
    margin-bottom: 0px !important;
  }
  .u-ml0-sp {
    margin-left: 0px !important;
  }
  .u-pt0-sp {
    padding-top: 0px !important;
  }
  .u-pr0-sp {
    padding-right: 0px !important;
  }
  .u-pb0-sp {
    padding-bottom: 0px !important;
  }
  .u-pl0-sp {
    padding-left: 0px !important;
  }
  .u-mt5-sp {
    margin-top: 5px !important;
  }
  .u-mr5-sp {
    margin-right: 5px !important;
  }
  .u-mb5-sp {
    margin-bottom: 5px !important;
  }
  .u-ml5-sp {
    margin-left: 5px !important;
  }
  .u-pt5-sp {
    padding-top: 5px !important;
  }
  .u-pr5-sp {
    padding-right: 5px !important;
  }
  .u-pb5-sp {
    padding-bottom: 5px !important;
  }
  .u-pl5-sp {
    padding-left: 5px !important;
  }
  .u-mt10-sp {
    margin-top: 10px !important;
  }
  .u-mr10-sp {
    margin-right: 10px !important;
  }
  .u-mb10-sp {
    margin-bottom: 10px !important;
  }
  .u-ml10-sp {
    margin-left: 10px !important;
  }
  .u-pt10-sp {
    padding-top: 10px !important;
  }
  .u-pr10-sp {
    padding-right: 10px !important;
  }
  .u-pb10-sp {
    padding-bottom: 10px !important;
  }
  .u-pl10-sp {
    padding-left: 10px !important;
  }
  .u-mt15-sp {
    margin-top: 15px !important;
  }
  .u-mr15-sp {
    margin-right: 15px !important;
  }
  .u-mb15-sp {
    margin-bottom: 15px !important;
  }
  .u-ml15-sp {
    margin-left: 15px !important;
  }
  .u-pt15-sp {
    padding-top: 15px !important;
  }
  .u-pr15-sp {
    padding-right: 15px !important;
  }
  .u-pb15-sp {
    padding-bottom: 15px !important;
  }
  .u-pl15-sp {
    padding-left: 15px !important;
  }
  .u-mt20-sp {
    margin-top: 20px !important;
  }
  .u-mr20-sp {
    margin-right: 20px !important;
  }
  .u-mb20-sp {
    margin-bottom: 20px !important;
  }
  .u-ml20-sp {
    margin-left: 20px !important;
  }
  .u-pt20-sp {
    padding-top: 20px !important;
  }
  .u-pr20-sp {
    padding-right: 20px !important;
  }
  .u-pb20-sp {
    padding-bottom: 20px !important;
  }
  .u-pl20-sp {
    padding-left: 20px !important;
  }
  .u-mt25-sp {
    margin-top: 25px !important;
  }
  .u-mr25-sp {
    margin-right: 25px !important;
  }
  .u-mb25-sp {
    margin-bottom: 25px !important;
  }
  .u-ml25-sp {
    margin-left: 25px !important;
  }
  .u-pt25-sp {
    padding-top: 25px !important;
  }
  .u-pr25-sp {
    padding-right: 25px !important;
  }
  .u-pb25-sp {
    padding-bottom: 25px !important;
  }
  .u-pl25-sp {
    padding-left: 25px !important;
  }
  .u-mt30-sp {
    margin-top: 30px !important;
  }
  .u-mr30-sp {
    margin-right: 30px !important;
  }
  .u-mb30-sp {
    margin-bottom: 30px !important;
  }
  .u-ml30-sp {
    margin-left: 30px !important;
  }
  .u-pt30-sp {
    padding-top: 30px !important;
  }
  .u-pr30-sp {
    padding-right: 30px !important;
  }
  .u-pb30-sp {
    padding-bottom: 30px !important;
  }
  .u-pl30-sp {
    padding-left: 30px !important;
  }
  .u-mt35-sp {
    margin-top: 35px !important;
  }
  .u-mr35-sp {
    margin-right: 35px !important;
  }
  .u-mb35-sp {
    margin-bottom: 35px !important;
  }
  .u-ml35-sp {
    margin-left: 35px !important;
  }
  .u-pt35-sp {
    padding-top: 35px !important;
  }
  .u-pr35-sp {
    padding-right: 35px !important;
  }
  .u-pb35-sp {
    padding-bottom: 35px !important;
  }
  .u-pl35-sp {
    padding-left: 35px !important;
  }
  .u-mt40-sp {
    margin-top: 40px !important;
  }
  .u-mr40-sp {
    margin-right: 40px !important;
  }
  .u-mb40-sp {
    margin-bottom: 40px !important;
  }
  .u-ml40-sp {
    margin-left: 40px !important;
  }
  .u-pt40-sp {
    padding-top: 40px !important;
  }
  .u-pr40-sp {
    padding-right: 40px !important;
  }
  .u-pb40-sp {
    padding-bottom: 40px !important;
  }
  .u-pl40-sp {
    padding-left: 40px !important;
  }
  .u-mt45-sp {
    margin-top: 45px !important;
  }
  .u-mr45-sp {
    margin-right: 45px !important;
  }
  .u-mb45-sp {
    margin-bottom: 45px !important;
  }
  .u-ml45-sp {
    margin-left: 45px !important;
  }
  .u-pt45-sp {
    padding-top: 45px !important;
  }
  .u-pr45-sp {
    padding-right: 45px !important;
  }
  .u-pb45-sp {
    padding-bottom: 45px !important;
  }
  .u-pl45-sp {
    padding-left: 45px !important;
  }
  .u-mt50-sp {
    margin-top: 50px !important;
  }
  .u-mr50-sp {
    margin-right: 50px !important;
  }
  .u-mb50-sp {
    margin-bottom: 50px !important;
  }
  .u-ml50-sp {
    margin-left: 50px !important;
  }
  .u-pt50-sp {
    padding-top: 50px !important;
  }
  .u-pr50-sp {
    padding-right: 50px !important;
  }
  .u-pb50-sp {
    padding-bottom: 50px !important;
  }
  .u-pl50-sp {
    padding-left: 50px !important;
  }
  .u-mt55-sp {
    margin-top: 55px !important;
  }
  .u-mr55-sp {
    margin-right: 55px !important;
  }
  .u-mb55-sp {
    margin-bottom: 55px !important;
  }
  .u-ml55-sp {
    margin-left: 55px !important;
  }
  .u-pt55-sp {
    padding-top: 55px !important;
  }
  .u-pr55-sp {
    padding-right: 55px !important;
  }
  .u-pb55-sp {
    padding-bottom: 55px !important;
  }
  .u-pl55-sp {
    padding-left: 55px !important;
  }
  .u-mt60-sp {
    margin-top: 60px !important;
  }
  .u-mr60-sp {
    margin-right: 60px !important;
  }
  .u-mb60-sp {
    margin-bottom: 60px !important;
  }
  .u-ml60-sp {
    margin-left: 60px !important;
  }
  .u-pt60-sp {
    padding-top: 60px !important;
  }
  .u-pr60-sp {
    padding-right: 60px !important;
  }
  .u-pb60-sp {
    padding-bottom: 60px !important;
  }
  .u-pl60-sp {
    padding-left: 60px !important;
  }
  .u-mt65-sp {
    margin-top: 65px !important;
  }
  .u-mr65-sp {
    margin-right: 65px !important;
  }
  .u-mb65-sp {
    margin-bottom: 65px !important;
  }
  .u-ml65-sp {
    margin-left: 65px !important;
  }
  .u-pt65-sp {
    padding-top: 65px !important;
  }
  .u-pr65-sp {
    padding-right: 65px !important;
  }
  .u-pb65-sp {
    padding-bottom: 65px !important;
  }
  .u-pl65-sp {
    padding-left: 65px !important;
  }
  .u-mt70-sp {
    margin-top: 70px !important;
  }
  .u-mr70-sp {
    margin-right: 70px !important;
  }
  .u-mb70-sp {
    margin-bottom: 70px !important;
  }
  .u-ml70-sp {
    margin-left: 70px !important;
  }
  .u-pt70-sp {
    padding-top: 70px !important;
  }
  .u-pr70-sp {
    padding-right: 70px !important;
  }
  .u-pb70-sp {
    padding-bottom: 70px !important;
  }
  .u-pl70-sp {
    padding-left: 70px !important;
  }
  .u-mt75-sp {
    margin-top: 75px !important;
  }
  .u-mr75-sp {
    margin-right: 75px !important;
  }
  .u-mb75-sp {
    margin-bottom: 75px !important;
  }
  .u-ml75-sp {
    margin-left: 75px !important;
  }
  .u-pt75-sp {
    padding-top: 75px !important;
  }
  .u-pr75-sp {
    padding-right: 75px !important;
  }
  .u-pb75-sp {
    padding-bottom: 75px !important;
  }
  .u-pl75-sp {
    padding-left: 75px !important;
  }
  .u-mt80-sp {
    margin-top: 80px !important;
  }
  .u-mr80-sp {
    margin-right: 80px !important;
  }
  .u-mb80-sp {
    margin-bottom: 80px !important;
  }
  .u-ml80-sp {
    margin-left: 80px !important;
  }
  .u-pt80-sp {
    padding-top: 80px !important;
  }
  .u-pr80-sp {
    padding-right: 80px !important;
  }
  .u-pb80-sp {
    padding-bottom: 80px !important;
  }
  .u-pl80-sp {
    padding-left: 80px !important;
  }
  .u-mt85-sp {
    margin-top: 85px !important;
  }
  .u-mr85-sp {
    margin-right: 85px !important;
  }
  .u-mb85-sp {
    margin-bottom: 85px !important;
  }
  .u-ml85-sp {
    margin-left: 85px !important;
  }
  .u-pt85-sp {
    padding-top: 85px !important;
  }
  .u-pr85-sp {
    padding-right: 85px !important;
  }
  .u-pb85-sp {
    padding-bottom: 85px !important;
  }
  .u-pl85-sp {
    padding-left: 85px !important;
  }
  .u-mt90-sp {
    margin-top: 90px !important;
  }
  .u-mr90-sp {
    margin-right: 90px !important;
  }
  .u-mb90-sp {
    margin-bottom: 90px !important;
  }
  .u-ml90-sp {
    margin-left: 90px !important;
  }
  .u-pt90-sp {
    padding-top: 90px !important;
  }
  .u-pr90-sp {
    padding-right: 90px !important;
  }
  .u-pb90-sp {
    padding-bottom: 90px !important;
  }
  .u-pl90-sp {
    padding-left: 90px !important;
  }
  .u-mt95-sp {
    margin-top: 95px !important;
  }
  .u-mr95-sp {
    margin-right: 95px !important;
  }
  .u-mb95-sp {
    margin-bottom: 95px !important;
  }
  .u-ml95-sp {
    margin-left: 95px !important;
  }
  .u-pt95-sp {
    padding-top: 95px !important;
  }
  .u-pr95-sp {
    padding-right: 95px !important;
  }
  .u-pb95-sp {
    padding-bottom: 95px !important;
  }
  .u-pl95-sp {
    padding-left: 95px !important;
  }
  .u-mt100-sp {
    margin-top: 100px !important;
  }
  .u-mr100-sp {
    margin-right: 100px !important;
  }
  .u-mb100-sp {
    margin-bottom: 100px !important;
  }
  .u-ml100-sp {
    margin-left: 100px !important;
  }
  .u-pt100-sp {
    padding-top: 100px !important;
  }
  .u-pr100-sp {
    padding-right: 100px !important;
  }
  .u-pb100-sp {
    padding-bottom: 100px !important;
  }
  .u-pl100-sp {
    padding-left: 100px !important;
  }
}
.u-anchor {
  display: block;
  margin-top: -100px;
  padding-top: 100px;
}

img {
  vertical-align: bottom;
}

html {
  scrollbar-gutter: stable;
}

body {
  align-items: center;
  flex-flow: column;
  min-height: 100vh;
}

.wrap {
  flex: 1;
}

footer {
  width: 100%;
}

picture {
  display: block;
}
picture source {
  display: block;
}

*:focus {
  outline: none !important;
}

.wrap {
  position: relative;
  display: flex;
  justify-content: flex-end;
  margin: 2.5rem auto 0;
  width: 1024px;
}
.wrap.single .l-main {
  margin: 0 auto;
  width: 860px;
}
.wrap .l-main {
  padding: 0 0 0 30px;
  width: 744px;
}
.wrap .l-main .l-section {
  min-height: 600px;
}
.wrap .l-main .l-section .l-content {
  padding: 0.625rem;
  padding-left: 0;
}
.wrap .sidebar {
  position: absolute;
  left: 0;
  width: 280px;
}

@font-face {
  font-family: "dotf";
  src: url("../fonts/PixelMplus10-Regular.eot?") format("oldIE"), url("../fonts/PixelMplus10-Regular.woff") format("woff"), url("../fonts/PixelMplus10-Regular.ttf") format("truetype");
  unicode-range: U+0080-FFFF;
}
@font-face {
  font-family: "numberf";
  src: url("../fonts/NuKinakoMochiFwCt-Square-1.eot?") format("oldIE"), url("../fonts/NuKinakoMochiFwCt-Square-1.woff") format("woff"), url("../fonts/NuKinakoMochiFwCt-Square-1.ttf") format("truetype");
}
body {
  background-color: #5f97fb;
  font-family: "numberf", "dotf";
}

a, button, .slick-slider, .btn, footer {
  position: relative;
  z-index: 9999;
}

.sponly {
  display: none;
}
@media only screen and (max-width: 768px) {
  .sponly {
    display: block;
  }
}

.pconly {
  display: block;
}
@media only screen and (max-width: 768px) {
  .pconly {
    display: none;
  }
}

.content-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  width: 100%;
  position: relative;
  z-index: 20;
  background-image: url("../images/dev/bg2.png"), url("../images/dev/bg1.png");
  animation: cloudMove 20s linear infinite;
  will-change: background-position;
}
.content-wrapper:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 5;
  flex-direction: column;
  width: 100%;
  background-image: url("../images/dev/bg2.png"), url("../images/dev/bg1.png");
  content: "";
  animation: cloudMove2 50s linear infinite;
  will-change: background-position;
  pointer-events: none;
}
.content-wrapper .l-main {
  padding: 0 0 2rem;
}

body.contact .content-wrapper::after {
  z-index: -1;
}

section {
  min-height: 100px;
}

.topocs-board, .about-board {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  margin: 0 auto 60px;
  padding: 1.5rem;
  min-height: 120px;
  width: 640px;
  border: 2px solid #000000;
  border-radius: 5px;
  background-color: rgba(0, 0, 0, 0.8);
  box-shadow: 0 0 0 4px #ffffff inset;
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.8;
}
@media only screen and (max-width: 768px) {
  .topocs-board, .about-board {
    margin-bottom: 5vw;
    padding: 3vw;
    width: 94vw;
  }
}
.topocs-board .p-title, .about-board .p-title {
  display: block;
  margin-bottom: 0.25rem;
  padding: 0;
  width: 100%;
  text-align: left;
  letter-spacing: -4px;
  font-size: 1.25rem;
}
.topocs-board .p-title.jp, .about-board .p-title.jp {
  letter-spacing: 0;
}
.topocs-board .text, .about-board .text {
  overflow: hidden;
  width: 100%;
}
.topocs-board .text time, .about-board .text time {
  display: block;
  letter-spacing: -2px;
}
.topocs-board dl, .about-board dl {
  display: flex;
  text-align: left;
}
.topocs-board dl dt, .about-board dl dt {
  padding-right: 1rem;
}
@media only screen and (max-width: 768px) {
  .topocs-board dl dt, .about-board dl dt {
    padding-right: 0;
    white-space: nowrap;
    font-size: 0.75rem;
    opacity: 0.75;
  }
}
.topocs-board dl dd, .about-board dl dd {
  margin-bottom: 0.5rem;
}
.topocs-board dl:last-child dd, .about-board dl:last-child dd {
  margin-bottom: 0;
}
@media only screen and (max-width: 768px) {
  .topocs-board dl, .about-board dl {
    flex-direction: column;
    margin-bottom: 0.75rem;
  }
  .topocs-board dl:last-child, .about-board dl:last-child {
    margin-bottom: 0;
  }
}
.topocs-board ul li, .about-board ul li {
  position: relative;
}
.topocs-board ul li:before, .about-board ul li:before {
  display: inline-block;
  margin: calc(1rem - 2px);
  width: 2px;
  height: 2px;
  background-color: #ffffff;
  content: "";
  vertical-align: middle;
  line-height: 1;
}

.contact_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 2rem 0;
}

.icon {
  margin-right: 0.5rem;
}
.icon img {
  height: 1em;
  vertical-align: middle;
}

.slick-slide div div a {
  outline: none;
  border: none;
}
.slick-slide div div a img {
  max-height: 140px;
  height: auto;
  outline: none;
  border: none;
  object-fit: cover;
}

.tab-hidden * {
  animation-play-state: paused !important;
}

#curtain {
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 999998;
  pointer-events: none;
  overflow: hidden;
}
#curtain #curtain-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Arial Black", "Helvetica Neue", Arial, sans-serif;
  font-weight: 900;
  color: #000;
  line-height: 1;
  letter-spacing: -0.03em;
  white-space: nowrap;
  user-select: none;
  font-size: 19vw;
}

.content-main {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .content-main {
    justify-content: flex-start;
  }
}

footer {
  width: 100%;
}
footer .footer-inner {
  position: relative;
  padding: 2rem;
  height: 70px;
  background: url(../images/dev/ground.png);
  background-size: contain;
  text-align: center;
  cursor: pointer;
}
footer .footer-inner small {
  display: inline-block;
  color: #ffffff;
  letter-spacing: -4px;
  font-size: 1rem;
}

.btn_text_star {
  display: inline-block;
  font-weight: bold;
}
.btn_text_star:hover {
  animation: color-star 0.3s linear infinite;
}

.buruburu {
  display: inline-block;
  animation: hurueru 0.1s infinite;
}

.buruburu2 {
  display: inline-block;
  animation: hurueru 1s infinite;
}

@keyframes hurueru {
  0% {
    transform: translate(0px, 0px) rotateZ(0deg);
  }
  25% {
    transform: translate(2px, 2px) rotateZ(1deg);
  }
  50% {
    transform: translate(0px, 2px) rotateZ(0deg);
  }
  75% {
    transform: translate(2px, 0px) rotateZ(-1deg);
  }
  100% {
    transform: translate(0px, 0px) rotateZ(0deg);
  }
}
.fluffy {
  margin: 100px;
  width: 100px;
  height: 100px;
  background: #000000;
  animation: fluffy1 3s ease infinite;
}

@keyframes fluffy1 {
  0% {
    transform: translateY(0);
  }
  5% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(0);
  }
  20% {
    transform: translateY(-15px);
  }
  25% {
    transform: translateY(0);
  }
  30% {
    transform: translateY(-15px);
  }
  50% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}
.jump.btn {
  position: absolute;
  top: 130px;
  right: -0.4rem;
  display: inline-block;
  cursor: pointer;
  transform: rotate(-90deg);
}
.jump.btn button {
  font-family: "numberf", "dotf";
}
@media only screen and (max-width: 768px) {
  .jump.btn {
    top: 120px;
    right: -2rem;
  }
}

#rocket-btn {
  position: absolute;
  top: 20px;
  right: 35px;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  z-index: 99999;
  /* 上下は 2.3s、左右は 3.7s — 周期が異なるため組み合わせが非周期的でランダムに見える */
  animation: rocket-float-y 2.3s ease-in-out infinite;
}
@media only screen and (max-width: 768px) {
  #rocket-btn {
    right: 15px;
  }
}
#rocket-btn.in-flight {
  position: fixed;
}
#rocket-btn .rocket-wrap {
  display: block;
  animation: rocket-float-x 3.7s ease-in-out infinite;
}
#rocket-btn img {
  width: 50px;
  height: auto;
  display: block;
}
#rocket-btn.launching {
  animation: rocket-launch 5s linear forwards;
  pointer-events: none;
}
#rocket-btn.launching .rocket-wrap {
  animation: none;
}
#rocket-btn.landing {
  animation: rocket-land 3.5s linear forwards;
  pointer-events: none;
}
#rocket-btn.landing .rocket-wrap {
  animation: none;
}

#return-btn {
  position: absolute;
  top: 80px;
  right: 23px;
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s;
}
@media only screen and (max-width: 768px) {
  #return-btn {
    right: -5px;
  }
}
#return-btn.in-flight {
  position: fixed;
  opacity: 1;
  pointer-events: auto;
}

@keyframes rocket-float-y {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}
@keyframes rocket-float-x {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  30% {
    transform: translateX(-4px) rotate(-2deg);
  }
  65% {
    transform: translateX(3px) rotate(1.5deg);
  }
  100% {
    transform: translateX(0) rotate(0deg);
  }
}
@keyframes rocket-land {
  /* 地球へ向かってダイブ */
  0% {
    transform: translateY(0);
    opacity: 1;
    animation-timing-function: ease-in;
  }
  18% {
    transform: translateY(110vh);
    opacity: 1;
  }
  22% {
    transform: translateY(130vh);
    opacity: 0;
  }
  /* スカイスペース収縮中は画面外で待機（約3s） */
  87% {
    transform: translateY(130vh);
    opacity: 0;
  }
  /* 定位置すぐ上にテレポートして着地バウンド */
  88% {
    transform: translateY(-15px);
    opacity: 0;
  }
  93% {
    transform: translateY(-15px);
    opacity: 1;
  }
  97% {
    transform: translateY(6px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes rocket-launch {
  /* Phase1: 発射〜画面外（ease-in で加速） */
  0% {
    transform: translateY(0);
    opacity: 1;
    animation-timing-function: ease-in;
  }
  16% {
    transform: translateY(-110vh);
    opacity: 1;
  }
  /* 画面外でフェードアウト後テレポート */
  20% {
    transform: translateY(-130vh);
    opacity: 0;
  }
  21% {
    transform: translateY(115vh);
    opacity: 0;
  }
  /* Phase2: 画面下から徐々に加速しながら上昇 */
  33% {
    transform: translateY(102vh);
    opacity: 1;
  }
  50% {
    transform: translateY(80vh);
  }
  67% {
    transform: translateY(42vh);
  }
  /* Phase3: 元位置へ ease-out で減速停止 */
  80% {
    transform: translateY(10vh);
    animation-timing-function: ease-out;
  }
  100% {
    transform: translateY(0);
  }
}
.underground {
  position: relative;
  z-index: 99999;
  overflow: hidden;
  height: 0;
  background-color: #653323;
}
.underground::after {
  position: absolute;
  top: 0;
  width: 100%;
  height: 20px;
  background: linear-gradient(45deg, #000000 10px, transparent 0%) 0 10px, linear-gradient(-45deg, #000000 10px, #653323 0%) 0 10px;
  background-position: left bottom;
  background-size: 30px 40px;
  background-repeat: repeat-x;
  content: "";
}
.underground .downbelow {
  position: relative;
  height: 100%;
  background-color: #653323;
}
.underground .downbelow .downbelow-inner {
  padding-top: 3rem;
  height: 500px;
  background-color: #000000;
  color: #ffffff;
}
.underground .downbelow .downbelow-inner .downbelow-content {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.underground .downbelow .downbelow-inner .downbelow-content-inner .topocs-board.about-board {
  margin: 0;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .underground .downbelow .downbelow-inner .downbelow-content-inner {
    padding-left: 2vw;
  }
  .underground .downbelow .downbelow-inner .downbelow-content-inner .topocs-board.about-board {
    margin: 0;
    width: 100%;
  }
}
.underground .secretbtn {
  display: inline-block;
  margin-bottom: 2rem;
  padding: 0.5rem 1rem;
  width: auto;
  border-radius: 4px;
  background-color: #7a51b8;
  cursor: pointer;
  transition: 0.3s;
}
.underground .secretbtn:hover {
  background-color: #4b2f74;
  transition: 0.3s;
}
.underground .escapebtn {
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  background-color: #7a51b8;
  cursor: pointer;
  transition: 0.3s;
}
.underground .escapebtn:hover {
  background-color: #4b2f74;
  transition: 0.3s;
}

.skyspace {
  position: relative;
  overflow: hidden;
}
.skyspace .skyspace-inner {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  padding-top: 3rem;
  height: 60000px;
  background: linear-gradient(to top, rgb(255, 255, 255) 0%, rgba(55, 81, 133, 0.35) 20%, rgb(150, 117, 199) 30%, rgba(55, 81, 133, 0.95) 35%, rgba(17, 61, 52, 0.9) 42%, rgba(6, 34, 64, 0.8) 54%, rgb(0, 0, 0) 80%, rgb(0, 0, 0) 100%);
  color: #ffffff;
}
.skyspace .skyspace-content {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .skyspace .skyspace-content-inner {
    padding-right: 80px;
    padding-left: 2vw;
  }
  .skyspace .skyspace-content-inner .topocs-board.about-board {
    width: 100%;
  }
}
.skyspace .skyspace-content .secretbtn {
  display: inline-block;
  margin-bottom: 2rem;
  padding: 0.5rem 1rem;
  width: auto;
  border-radius: 4px;
  background-color: #7a51b8;
  cursor: pointer;
  transition: 0.3s;
}
.skyspace .skyspace-content .secretbtn:hover {
  background-color: #4b2f74;
  transition: 0.3s;
}
.skyspace .skyspace-content .reversebtn {
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  background-color: #7a51b8;
  cursor: pointer;
  transition: 0.3s;
}
.skyspace .skyspace-content .reversebtn:hover {
  background-color: #4b2f74;
  transition: 0.3s;
}

@keyframes clouds-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.stars, .twinkling, .clouds {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  height: 12300px;
}

.stars {
  z-index: 0;
  width: 100%;
  height: 40000px;
  background: transparent url(../images/dev/stars.png) repeat top center;
  -webkit-mask-image: -webkit-gradient(linear, left 90%, left bottom, from(rgb(0, 0, 0)), to(rgba(0, 0, 0, 0)));
}

.clouds {
  z-index: 3;
  width: 200%;
  background: transparent url(../images/dev/clouds.png) repeat top center;
  animation: clouds-slide 160s linear infinite;
  will-change: transform;
}

@keyframes shake {
  from {
    transform: translateX(-5px) translateY(0px);
  }
  20% {
    transform: translateX(5px) translateY(0px);
  }
  40% {
    transform: translateX(-10px) translateY(-3px);
  }
  60% {
    transform: translateX(10px) translateY(0px);
  }
  80% {
    transform: translateX(-10px) translateY(0px);
  }
  to {
    transform: translateX(-5px) translateY(0px);
  }
}
@keyframes cloudMove {
  0% {
    background-position: 0 0, 0 0;
  }
  100% {
    background-position: 852px 0, 974px 0;
  }
}
@keyframes cloudMove2 {
  0% {
    background-position: -200px -200px, -200px -200px;
  }
  100% {
    background-position: 652px -200px, 774px -200px;
  }
}
@keyframes color-star {
  0%, 100% {
    color: #ff031a;
  }
  25% {
    color: #ff7622;
  }
  50% {
    color: #ffff37;
  }
  75% {
    color: #00ff30;
  }
  90% {
    color: #00fffe;
  }
}
