@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
html, body, div, span, object, iframe, a,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1.6;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

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

ol, ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
  margin: 0;
}

/*-----------メディアクエリ----------------------*/
body {
  font-size: 16px;
  webkit-text-size-adjust: 100%;
  line-height: 1.6;
  font-family: "Noto Sans JP", sans-serif;
  color: #3E3E3E;
  word-break: break-all;
  overflow-x: hidden;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

a {
  text-decoration: none;
  color: inherit;
}

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

.inner {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .inner {
    padding: 0 30px;
  }
}
@media (max-width: 767px) {
  .inner {
    padding: 0 16px;
  }
}

section {
  padding: 80px 0 100px;
}
@media (max-width: 767px) {
  section {
    padding: 30px 0;
  }
}

.section_title {
  font-family: "Noto Sans JP", sans-serif;
  color: #F3F3F3;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 767px) {
  .section_title {
    margin-bottom: 20px;
  }
}
.section_title h2 {
  font-size: 36px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .section_title h2 {
    font-size: 20px;
  }
}

.title-circle {
  display: inline-block;
  padding: 65px;
  position: relative;
  z-index: 1;
}
@media (max-width: 767px) {
  .title-circle {
    padding: 40px;
  }
}
.title-circle::before {
  position: absolute;
  content: "";
  width: 180px;
  height: 180px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #514646;
  border-radius: 35%;
  z-index: -1;
}
@media (max-width: 767px) {
  .title-circle::before {
    width: 100px;
    height: 100px;
  }
}

.btn {
  margin-top: 45px;
  text-align: center;
}
@media (max-width: 767px) {
  .btn {
    margin-top: 15px;
  }
}
.btn a {
  display: inline-block;
  padding: 1em 2.5em;
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: 0.45px;
  color: #fff;
  background-color: #FFAA3B;
  border-radius: 10px;
}
.btn a:hover {
  background-color: #fa940e;
}
@media (max-width: 767px) {
  .btn a {
    padding: 1em;
    font-size: 16px;
  }
}

table {
  word-wrap: break-word;
}

/*------------header---------------------------*/
.header {
  width: 100%;
  max-width: 100%;
}

.header_content {
  height: 80px;
  line-height: 80px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .header_content {
    display: block;
    height: 68px;
    line-height: 68px;
  }
}

.header_title {
  display: flex;
  align-items: center;
  font-size: 24px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .header_title img {
    width: 68px;
  }
}

.header_nav {
  font-weight: bold;
  display: flex;
  font-size: 23px;
}
@media (max-width: 767px) {
  .header_nav {
    display: none;
  }
}
.header_nav li:not(:first-child) {
  margin-left: 28px;
}
.header_nav li a {
  display: inline-block;
  position: relative;
}
.header_nav li a::after {
  position: absolute;
  content: "";
  bottom: 20px;
  left: 0;
  height: 2px;
  width: 100%;
  background-color: transparent;
  transition: all 0.3s ease 0s;
  transform: scale(0, 1);
  transform-origin: center top;
  transition: transform 0.3s;
}
.header_nav li a:hover::after {
  background-color: #3E3E3E;
  transform: scale(1, 1);
}

.drawer_icon {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 300;
  transition: transform 0.4s ease 0s;
  display: none;
}
.drawer_icon.is-active {
  transform: translate(-300px);
}
@media (max-width: 767px) {
  .drawer_icon {
    display: block;
  }
}
.drawer_icon.is-active .drawer_icon-bar1 {
  transform: rotate(-45deg);
  top: 8px;
}
.drawer_icon.is-active .drawer_icon-bar2 {
  display: none;
}
.drawer_icon.is-active .drawer_icon-bar3 {
  transform: rotate(45deg);
  top: 8px;
}

.drawer_icon-bars {
  width: 26px;
  height: 20px;
  display: block;
  position: relative;
}

.drawer_icon-bar1,
.drawer_icon-bar2,
.drawer_icon-bar3 {
  position: absolute;
  width: 26px;
  height: 2px;
  background-color: #2e2d2d;
  top: 0;
  left: 0;
}

.drawer_icon-bar1 {
  top: 0;
}

.drawer_icon-bar2 {
  top: 9px;
}

.drawer_icon-bar3 {
  top: 18px;
}

.drawer_content {
  width: 300px;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  background: #fff;
  z-index: 299;
  transform: translateX(105%);
  transition: transform 0.3s ease 0s;
}
.drawer_content.is-active {
  transform: translateX(0px);
}
.drawer_content.is-active .drawer_icon-bar1 {
  transform: rotate(-45deg);
  top: 9px;
}
.drawer_content.is-active .drawer_icon-bar2 {
  display: none;
}
.drawer_content.is-active .drawer_icon-bar3 {
  transform: rotate(45deg);
  top: 9px;
}

.drawer_content-items {
  padding-top: 160px;
  padding-bottom: 160px;
}

.drawer_content-item:not(:first-child) {
  margin-top: 32px;
}
.drawer_content-item a {
  text-align: center;
  display: block;
  color: #3E3E3E;
  font-size: 18px;
}

.drawer_background {
  background-color: #3E3E3E;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 298;
  opacity: 0.7;
  display: none;
}
.drawer_background.is-active {
  display: block;
}

/*-----------------footer--------------------------*/
.footer {
  background-color: #3E3E3E;
  text-align: center;
  padding: 20px 30px;
}
@media (max-width: 767px) {
  .footer {
    padding: 15px 20px;
  }
}

.footer_copy {
  font-size: 16px;
  letter-spacing: 0.3px;
  color: #fff;
  text-align: center;
  opacity: 0.6;
}

.totop {
  position: fixed;
  right: 40px;
  bottom: 40px;
  height: 50px;
  width: 50px;
  background-color: #FFAA3B;
  display: none;
  transition: all 0.3s ease 0s;
}
@media (max-width: 767px) {
  .totop {
    right: 16px;
    bottom: 16px;
    height: 50px;
    width: 50px;
  }
}
.totop a {
  display: block;
  transition: all 0.3s ease 0s;
  opacity: 0.6;
}
.totop a:hover {
  opacity: 1;
}
.totop a img {
  width: 70px;
}
@media (max-width: 767px) {
  .totop a img {
    width: 49px;
  }
}

/*!
Animate.css - http://daneden.me/animate
Licensed under the MIT license

Copyright (c) 2013 Daniel Eden

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.animated.hinge {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

@-webkit-keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-30px);
  }
  60% {
    transform: translateY(-15px);
  }
}
@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-30px);
  }
  60% {
    transform: translateY(-15px);
  }
}
.bounce {
  -webkit-animation-name: bounce;
  animation-name: bounce;
}

@-webkit-keyframes flash {
  0%, 50%, 100% {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
@keyframes flash {
  0%, 50%, 100% {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
}

@-webkit-keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-10px);
  }
  20%, 40%, 60%, 80% {
    transform: translateX(10px);
  }
}
@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-10px);
  }
  20%, 40%, 60%, 80% {
    transform: translateX(10px);
  }
}
.shake {
  -webkit-animation-name: shake;
  animation-name: shake;
}

@-webkit-keyframes swing {
  20% {
    transform: rotate(15deg);
  }
  40% {
    transform: rotate(-10deg);
  }
  60% {
    transform: rotate(5deg);
  }
  80% {
    transform: rotate(-5deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@keyframes swing {
  20% {
    transform: rotate(15deg);
  }
  40% {
    transform: rotate(-10deg);
  }
  60% {
    transform: rotate(5deg);
  }
  80% {
    transform: rotate(-5deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
.swing {
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing;
}

@-webkit-keyframes tada {
  0% {
    transform: scale(1);
  }
  10%, 20% {
    transform: scale(0.9) rotate(-3deg);
  }
  30%, 50%, 70%, 90% {
    transform: scale(1.1) rotate(3deg);
  }
  40%, 60%, 80% {
    transform: scale(1.1) rotate(-3deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
@keyframes tada {
  0% {
    transform: scale(1);
  }
  10%, 20% {
    transform: scale(0.9) rotate(-3deg);
  }
  30%, 50%, 70%, 90% {
    transform: scale(1.1) rotate(3deg);
  }
  40%, 60%, 80% {
    transform: scale(1.1) rotate(-3deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes wobble {
  0% {
    transform: translateX(0%);
  }
  15% {
    transform: translateX(-25%) rotate(-5deg);
  }
  30% {
    transform: translateX(20%) rotate(3deg);
  }
  45% {
    transform: translateX(-15%) rotate(-3deg);
  }
  60% {
    transform: translateX(10%) rotate(2deg);
  }
  75% {
    transform: translateX(-5%) rotate(-1deg);
  }
  100% {
    transform: translateX(0%);
  }
}
@keyframes wobble {
  0% {
    transform: translateX(0%);
  }
  15% {
    transform: translateX(-25%) rotate(-5deg);
  }
  30% {
    transform: translateX(20%) rotate(3deg);
  }
  45% {
    transform: translateX(-15%) rotate(-3deg);
  }
  60% {
    transform: translateX(10%) rotate(2deg);
  }
  75% {
    transform: translateX(-5%) rotate(-1deg);
  }
  100% {
    transform: translateX(0%);
  }
}
.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble;
}

@-webkit-keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.3);
  }
  50% {
    opacity: 1;
    transform: scale(1.05);
  }
  70% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.3);
  }
  50% {
    opacity: 1;
    transform: scale(1.05);
  }
  70% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(1);
  }
}
.bounceIn {
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn;
}

@-webkit-keyframes bounceInDown {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  60% {
    opacity: 1;
    transform: translateY(30px);
  }
  80% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes bounceInDown {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  60% {
    opacity: 1;
    transform: translateY(30px);
  }
  80% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}
.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown;
}

@-webkit-keyframes bounceInLeft {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  60% {
    opacity: 1;
    transform: translateX(30px);
  }
  80% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes bounceInLeft {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  60% {
    opacity: 1;
    transform: translateX(30px);
  }
  80% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
  }
}
.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft;
}

@-webkit-keyframes bounceInRight {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  60% {
    opacity: 1;
    transform: translateX(-30px);
  }
  80% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes bounceInRight {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  60% {
    opacity: 1;
    transform: translateX(-30px);
  }
  80% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
  }
}
.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight;
}

@-webkit-keyframes bounceInUp {
  0% {
    opacity: 0;
    transform: translateY(2000px);
  }
  60% {
    opacity: 1;
    transform: translateY(-30px);
  }
  80% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes bounceInUp {
  0% {
    opacity: 0;
    transform: translateY(2000px);
  }
  60% {
    opacity: 1;
    transform: translateY(-30px);
  }
  80% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp;
}

@-webkit-keyframes bounceOut {
  0% {
    transform: scale(1);
  }
  25% {
    transform: scale(0.95);
  }
  50% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 0;
    transform: scale(0.3);
  }
}
@keyframes bounceOut {
  0% {
    transform: scale(1);
  }
  25% {
    transform: scale(0.95);
  }
  50% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 0;
    transform: scale(0.3);
  }
}
.bounceOut {
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut;
}

@-webkit-keyframes bounceOutDown {
  0% {
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(-20px);
  }
  100% {
    opacity: 0;
    transform: translateY(2000px);
  }
}
@keyframes bounceOutDown {
  0% {
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(-20px);
  }
  100% {
    opacity: 0;
    transform: translateY(2000px);
  }
}
.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown;
}

@-webkit-keyframes bounceOutLeft {
  0% {
    transform: translateX(0);
  }
  20% {
    opacity: 1;
    transform: translateX(20px);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
@keyframes bounceOutLeft {
  0% {
    transform: translateX(0);
  }
  20% {
    opacity: 1;
    transform: translateX(20px);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft;
}

@-webkit-keyframes bounceOutRight {
  0% {
    transform: translateX(0);
  }
  20% {
    opacity: 1;
    transform: translateX(-20px);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
@keyframes bounceOutRight {
  0% {
    transform: translateX(0);
  }
  20% {
    opacity: 1;
    transform: translateX(-20px);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight;
}

@-webkit-keyframes bounceOutUp {
  0% {
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(20px);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
@keyframes bounceOutUp {
  0% {
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(20px);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

@-webkit-keyframes fadeInDown {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInDown {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDownBig {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInDownBig {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig;
}

@-webkit-keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(-20px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(-20px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInLeftBig {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadeInLeftBig {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig;
}

@-webkit-keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
}

@-webkit-keyframes fadeInRightBig {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadeInRightBig {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig;
}

@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUpBig {
  0% {
    opacity: 0;
    transform: translateY(2000px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInUpBig {
  0% {
    opacity: 0;
    transform: translateY(2000px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig;
}

@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOutDown {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(20px);
  }
}
@keyframes fadeOutDown {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(20px);
  }
}
.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown;
}

@-webkit-keyframes fadeOutDownBig {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(2000px);
  }
}
@keyframes fadeOutDownBig {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(2000px);
  }
}
.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig;
}

@-webkit-keyframes fadeOutLeft {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-20px);
  }
}
@keyframes fadeOutLeft {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-20px);
  }
}
.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft;
}

@-webkit-keyframes fadeOutLeftBig {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
@keyframes fadeOutLeftBig {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig;
}

@-webkit-keyframes fadeOutRight {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(20px);
  }
}
@keyframes fadeOutRight {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(20px);
  }
}
.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight;
}

@-webkit-keyframes fadeOutRightBig {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
@keyframes fadeOutRightBig {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig;
}

@-webkit-keyframes fadeOutUp {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-20px);
  }
}
@keyframes fadeOutUp {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-20px);
  }
}
.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp;
}

@-webkit-keyframes fadeOutUpBig {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
@keyframes fadeOutUpBig {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig;
}

@-webkit-keyframes flip {
  0% {
    transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    transform: perspective(400px) translateZ(0) rotateY(360deg) scale(0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  100% {
    transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}
@keyframes flip {
  0% {
    transform: perspective(400px) translateZ(0) rotateY(0) scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    transform: perspective(400px) translateZ(150px) rotateY(170deg) scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    transform: perspective(400px) translateZ(150px) rotateY(190deg) scale(1);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    transform: perspective(400px) translateZ(0) rotateY(360deg) scale(0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  100% {
    transform: perspective(400px) translateZ(0) rotateY(360deg) scale(1);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}
.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  -webkit-animation-name: flip;
  animation-name: flip;
}

@-webkit-keyframes flipInX {
  0% {
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateX(-10deg);
  }
  70% {
    transform: perspective(400px) rotateX(10deg);
  }
  100% {
    transform: perspective(400px) rotateX(0deg);
    opacity: 1;
  }
}
@keyframes flipInX {
  0% {
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateX(-10deg);
  }
  70% {
    transform: perspective(400px) rotateX(10deg);
  }
  100% {
    transform: perspective(400px) rotateX(0deg);
    opacity: 1;
  }
}
.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  animation-name: flipInX;
}

@-webkit-keyframes flipInY {
  0% {
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateY(-10deg);
  }
  70% {
    transform: perspective(400px) rotateY(10deg);
  }
  100% {
    transform: perspective(400px) rotateY(0deg);
    opacity: 1;
  }
}
@keyframes flipInY {
  0% {
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateY(-10deg);
  }
  70% {
    transform: perspective(400px) rotateY(10deg);
  }
  100% {
    transform: perspective(400px) rotateY(0deg);
    opacity: 1;
  }
}
.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInY;
  animation-name: flipInY;
}

@-webkit-keyframes flipOutX {
  0% {
    transform: perspective(400px) rotateX(0deg);
    opacity: 1;
  }
  100% {
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
}
@keyframes flipOutX {
  0% {
    transform: perspective(400px) rotateX(0deg);
    opacity: 1;
  }
  100% {
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
}
.flipOutX {
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipOutY {
  0% {
    transform: perspective(400px) rotateY(0deg);
    opacity: 1;
  }
  100% {
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
}
@keyframes flipOutY {
  0% {
    transform: perspective(400px) rotateY(0deg);
    opacity: 1;
  }
  100% {
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
}
.flipOutY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY;
}

@-webkit-keyframes lightSpeedIn {
  0% {
    transform: translateX(100%) skewX(-30deg);
    opacity: 0;
  }
  60% {
    transform: translateX(-20%) skewX(30deg);
    opacity: 1;
  }
  80% {
    transform: translateX(0%) skewX(-15deg);
    opacity: 1;
  }
  100% {
    transform: translateX(0%) skewX(0deg);
    opacity: 1;
  }
}
@keyframes lightSpeedIn {
  0% {
    transform: translateX(100%) skewX(-30deg);
    opacity: 0;
  }
  60% {
    transform: translateX(-20%) skewX(30deg);
    opacity: 1;
  }
  80% {
    transform: translateX(0%) skewX(-15deg);
    opacity: 1;
  }
  100% {
    transform: translateX(0%) skewX(0deg);
    opacity: 1;
  }
}
.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes lightSpeedOut {
  0% {
    transform: translateX(0%) skewX(0deg);
    opacity: 1;
  }
  100% {
    transform: translateX(100%) skewX(-30deg);
    opacity: 0;
  }
}
@keyframes lightSpeedOut {
  0% {
    transform: translateX(0%) skewX(0deg);
    opacity: 1;
  }
  100% {
    transform: translateX(100%) skewX(-30deg);
    opacity: 0;
  }
}
.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
}

@-webkit-keyframes rotateIn {
  0% {
    transform-origin: center center;
    transform: rotate(-200deg);
    opacity: 0;
  }
  100% {
    transform-origin: center center;
    transform: rotate(0);
    opacity: 1;
  }
}
@keyframes rotateIn {
  0% {
    transform-origin: center center;
    transform: rotate(-200deg);
    opacity: 0;
  }
  100% {
    transform-origin: center center;
    transform: rotate(0);
    opacity: 1;
  }
}
.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn;
}

@-webkit-keyframes rotateInDownLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
@keyframes rotateInDownLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft;
}

@-webkit-keyframes rotateInDownRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
@keyframes rotateInDownRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight;
}

@-webkit-keyframes rotateInUpLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
@keyframes rotateInUpLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft;
}

@-webkit-keyframes rotateInUpRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
@keyframes rotateInUpRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
}
.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight;
}

@-webkit-keyframes rotateOut {
  0% {
    transform-origin: center center;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: center center;
    transform: rotate(200deg);
    opacity: 0;
  }
}
@keyframes rotateOut {
  0% {
    transform-origin: center center;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: center center;
    transform: rotate(200deg);
    opacity: 0;
  }
}
.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@-webkit-keyframes rotateOutDownLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
}
@keyframes rotateOutDownLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
}
.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft;
}

@-webkit-keyframes rotateOutDownRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
}
@keyframes rotateOutDownRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
}
.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight;
}

@-webkit-keyframes rotateOutUpLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
}
@keyframes rotateOutUpLeft {
  0% {
    transform-origin: left bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: left bottom;
    transform: rotate(-90deg);
    opacity: 0;
  }
}
.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft;
}

@-webkit-keyframes rotateOutUpRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
}
@keyframes rotateOutUpRight {
  0% {
    transform-origin: right bottom;
    transform: rotate(0);
    opacity: 1;
  }
  100% {
    transform-origin: right bottom;
    transform: rotate(90deg);
    opacity: 0;
  }
}
.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight;
}

@-webkit-keyframes slideInDown {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slideInDown {
  0% {
    opacity: 0;
    transform: translateY(-2000px);
  }
  100% {
    transform: translateY(0);
  }
}
.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown;
}

@-webkit-keyframes slideInLeft {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slideInLeft {
  0% {
    opacity: 0;
    transform: translateX(-2000px);
  }
  100% {
    transform: translateX(0);
  }
}
.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slideInRight {
  0% {
    opacity: 0;
    transform: translateX(2000px);
  }
  100% {
    transform: translateX(0);
  }
}
.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}

@-webkit-keyframes slideOutLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
@keyframes slideOutLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-2000px);
  }
}
.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft;
}

@-webkit-keyframes slideOutRight {
  0% {
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
@keyframes slideOutRight {
  0% {
    transform: translateX(0);
  }
  100% {
    opacity: 0;
    transform: translateX(2000px);
  }
}
.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight;
}

@-webkit-keyframes slideOutUp {
  0% {
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
@keyframes slideOutUp {
  0% {
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-2000px);
  }
}
.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp;
}

@-webkit-keyframes hinge {
  0% {
    transform: rotate(0);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  20%, 60% {
    transform: rotate(80deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  40% {
    transform: rotate(60deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  80% {
    transform: rotate(60deg) translateY(0);
    opacity: 1;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  100% {
    transform: translateY(700px);
    opacity: 0;
  }
}
@keyframes hinge {
  0% {
    transform: rotate(0);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  20%, 60% {
    transform: rotate(80deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  40% {
    transform: rotate(60deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  80% {
    transform: rotate(60deg) translateY(0);
    opacity: 1;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  100% {
    transform: translateY(700px);
    opacity: 0;
  }
}
.hinge {
  -webkit-animation-name: hinge;
  animation-name: hinge;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes rollIn {
  0% {
    opacity: 0;
    transform: translateX(-100%) rotate(-120deg);
  }
  100% {
    opacity: 1;
    transform: translateX(0px) rotate(0deg);
  }
}
@keyframes rollIn {
  0% {
    opacity: 0;
    transform: translateX(-100%) rotate(-120deg);
  }
  100% {
    opacity: 1;
    transform: translateX(0px) rotate(0deg);
  }
}
.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes rollOut {
  0% {
    opacity: 1;
    transform: translateX(0px) rotate(0deg);
  }
  100% {
    opacity: 0;
    transform: translateX(100%) rotate(120deg);
  }
}
@keyframes rollOut {
  0% {
    opacity: 1;
    transform: translateX(0px) rotate(0deg);
  }
  100% {
    opacity: 0;
    transform: translateX(100%) rotate(120deg);
  }
}
.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut;
}

/*---------------body--------------------------------*/
/*----------top-------------------------*/
.top {
  background: url(../img/fv-img.jpg) no-repeat;
  background-size: cover;
  aspect-ratio: 3800/2100;
  position: relative;
}
@media (max-width: 767px) {
  .top {
    background: url(../img/fvsp-img.jpg) no-repeat;
    background-size: cover;
    aspect-ratio: 2200/2100;
  }
}

.top_texts {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
}
@media (min-width: 768px) and (max-width: 1199px) {
  .top_texts {
    top: 32%;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 767px) {
  .top_texts {
    top: 32%;
    left: 50%;
    transform: translateX(-50%);
  }
}

.top_text {
  font-size: 4rem;
  font-weight: bold;
  color: #514646;
  font-family: "Noto Sans JP", sans-serif;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .top_text {
    font-size: 2.5rem;
  }
}
@media (max-width: 767px) {
  .top_text {
    font-size: 1.75rem;
  }
}

.typing {
  font: 900 4rem/1 "JetBrains Mono";
  width: 16ch;
  overflow: hidden;
  white-space: nowrap;
  -webkit-animation: typing 1.5s steps(16) 1 alternate;
          animation: typing 1.5s steps(16) 1 alternate;
}
@media (max-width: 767px) {
  .typing {
    font: 900 20px/1 "JetBrains Mono";
  }
}

@-webkit-keyframes typing {
  from {
    width: 0ch;
  }
}

@keyframes typing {
  from {
    width: 0ch;
  }
}
.top_btn {
  text-align: left;
}

.about {
  background-color: #707070;
}

.about_content {
  display: flex;
  align-items: center;
  gap: 2%;
  justify-content: center;
  position: relative;
}
@media (max-width: 767px) {
  .about_content {
    flex-direction: column-reverse;
  }
}

.about_left {
  flex: 1;
}
@media (max-width: 767px) {
  .about_left {
    margin-top: 32px;
    width: 100%;
  }
}

.about_left-img {
  margin-inline: auto;
}
.about_left-img img {
  aspect-ratio: 366/488;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 50%;
}
@media (max-width: 767px) {
  .about_left-img img {
    border-radius: 10px;
  }
}

.about_left-item {
  margin-top: 13px;
}
@media (max-width: 767px) {
  .about_left-item {
    margin-top: 8px;
    text-align: center;
  }
}
.about_left-item h3 {
  font-size: 24px;
  color: #fff;
  text-align: center;
}
@media (max-width: 767px) {
  .about_left-item h3 {
    font-size: 18px;
  }
}
.about_left-item p {
  text-align: center;
  color: #fff;
}

.about_right {
  flex: 2;
  font-size: 20px;
  padding: 50px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1607843137);
  border-radius: 5px;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .about_right {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .about_right {
    padding: 36px 20px;
    font-size: 14px;
  }
}
.about_right p:not(:first-child) {
  margin-top: 24px;
}

/*-----------works----------------*/
.works_content {
  display: grid;
  grid-template-columns: repeat(2, minmax(350px, 1fr));
  gap: 50px;
}
@media (max-width: 767px) {
  .works_content {
    grid-template-columns: repeat(1, minmax(250px, 1fr));
    gap: 50px 0;
  }
}

.works_item img {
  -o-object-fit: contain;
     object-fit: contain;
}

.works_item-title {
  font-size: 24px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .works_item-title {
    font-size: 14px;
  }
}

.more {
  margin-top: 50px;
  text-align: center;
  font-size: 22px;
  position: relative;
}
.more :hover {
  opacity: 0.7;
}
@media (max-width: 767px) {
  .more {
    margin-top: 20px;
  }
}
.more ::after {
  content: "→";
  position: absolute;
  top: 2px;
  margin-left: 5px;
}

/*---skill------------------------------------*/
.skill {
  background-color: #707070;
}

.skill_table {
  border: 2px solid #FFAA3B;
  border-collapse: collapse;
  table-layout: fixed;
  width: 960px;
  max-width: 100%;
  background-color: #ffffff;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .skill_table {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .skill_table tr {
    display: flex;
    flex-direction: column;
  }
}
.skill_table th,
.skill_table td {
  border: 2px solid #FFAA3B;
  vertical-align: middle;
  padding: 0.5em;
  height: 60px;
  font-size: 24px;
  font-weight: bold;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .skill_table th,
.skill_table td {
    height: 58px;
  }
}
@media (max-width: 767px) {
  .skill_table th,
.skill_table td {
    height: auto;
    font-size: 13px;
  }
}
.skill_table th {
  color: #ffffff;
  background-color: #FFAA3B;
  width: 262px;
}
@media (max-width: 767px) {
  .skill_table th {
    min-width: 100%;
    max-width: 100%;
  }
}
.skill_table tr:not(:last-of-type) th {
  border-bottom: 2px solid #fff;
}
@media (max-width: 767px) {
  .skill_table tr:not(:last-of-type) th {
    border-bottom: none;
  }
}
.skill_table td {
  padding-left: 0.5em;
  letter-spacing: 1px;
}
@media (max-width: 767px) {
  .skill_table td {
    width: 100%;
  }
}

.service_list {
  margin-inline: auto;
  background-color: #fff;
  max-width: 100%;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .service_list {
    display: block;
  }
}

.service_item {
  width: calc(33% - 30px);
  max-width: 100%;
  background-color: #ffffff;
}
@media (max-width: 767px) {
  .service_item {
    width: 100%;
  }
  .service_item:not(:first-child) {
    margin-top: 34px;
  }
}

.service_item-img {
  text-align: center;
  overflow: hidden;
}
.service_item-img img {
  width: 100%;
  transition: all 0.3s ease 0s;
}
.service_item-img img:hover {
  transform: scale(1.1);
}

.service_item-text h3 {
  text-align: center;
  font-size: 26px;
  height: 84px;
  letter-spacing: 5.5px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 767px) {
  .service_item-text h3 {
    height: 67px;
    font-size: 23px;
    letter-spacing: 4px;
  }
}
.service_item-text p {
  margin-top: 13px;
  line-height: 1.7142857143;
  font-size: 20px;
}
@media (max-width: 767px) {
  .service_item-text p {
    font-size: 18px;
    margin-top: 0;
  }
}

/*price------------------------------------*/
.price {
  background-color: #707070;
}

.price_content {
  width: 960px;
  max-width: 100%;
  margin-inline: auto;
}
@media (max-width: 767px) {
  .price_content {
    width: 100%;
  }
}

.price_table {
  border: 1px solid #707070;
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
  max-width: 100%;
  background-color: #ffffff;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .price_table tr {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
.price_table th,
.price_table td {
  border: 1px solid #707070;
  vertical-align: middle;
  padding: 0.5em;
  font-size: 24px;
  font-weight: bold;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .price_table th,
.price_table td {
    height: 58px;
  }
}
@media (max-width: 767px) {
  .price_table th,
.price_table td {
    font-size: 16px;
    min-width: 100%;
    max-width: 100%;
  }
}
.price_table th {
  color: #ffffff;
  background-color: #3E3E3E;
  width: 260px;
}
@media (max-width: 767px) {
  .price_table th {
    width: 100px;
  }
}
.price_table td {
  padding-left: 40px;
  width: calc(100% - 260px);
  letter-spacing: 1px;
}
@media (max-width: 767px) {
  .price_table td {
    width: 100%;
    padding-left: 20px;
    text-align: center;
  }
}

.price_attention {
  font-size: 16px;
  margin-top: 7px;
  color: #fff;
}
@media (max-width: 767px) {
  .price_attention {
    margin-top: 8px;
    text-align: center;
  }
}

.qa {
  background: url(/img/top.jpg) no-repeat top center/cover;
  z-index: 1;
  background-attachment: fixed;
}

.qa_item {
  border-radius: 4px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1607843137);
}
.qa_item:nth-child(n+2) {
  margin-top: 32px;
}
@media (max-width: 767px) {
  .qa_item:nth-child(n+2) {
    margin-top: 22px;
  }
}

.qa_box {
  padding: 1.5em;
  background-color: #fff;
  font-size: 24px;
}
@media (max-width: 767px) {
  .qa_box {
    padding: 1em;
  }
}

.qa_box-q {
  padding-left: 40px;
  font-weight: bold;
  position: relative;
}
@media (max-width: 767px) {
  .qa_box-q {
    font-size: 16px;
    padding-right: 20px;
  }
}
.qa_box-q::before {
  content: "Q";
  position: absolute;
  width: 24px;
  height: 24px;
  line-height: 24px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
  left: 0px;
  background-color: #FFAA3B;
  border-radius: 50%;
  color: #fff;
}

.qa_box-icon {
  width: 17px;
  height: 17px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.qa_box-icon.is-open .qa_box-bar2 {
  transform: rotate(90deg);
}

.qa_box-bar1 {
  width: 17px;
  height: 2px;
  background: #FFAA3B;
  border-radius: 20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}

.qa_box-bar2 {
  width: 2px;
  height: 17px;
  background: #FFAA3B;
  border-radius: 20px;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  left: 50%;
  transition: all 0.3s ease 0s;
}

.qa_box-a {
  background-color: rgba(222, 203, 96, 0.2);
  border-radius: 4px;
  line-height: 1.5;
  padding: 8px 16px;
  margin-top: 19px;
  display: none;
}
@media (max-width: 767px) {
  .qa_box-a {
    font-size: 14px;
    line-height: 1.4285714286;
    padding: 9px 12px;
    margin-top: 15px;
  }
}

.contact {
  background-color: #707070;
  padding: 60px;
}
@media (max-width: 767px) {
  .contact {
    padding: 40px 16px;
  }
}
.contact input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px #fff inset;
}
.contact input[type=checkbox] {
  display: none;
}

.contact_content {
  width: 960px;
  max-width: 100%;
  margin: 0 auto;
}

.contact_title {
  margin-bottom: 0;
  border-radius: 12px 12px 0 0;
  background: url(/img/contact.png) no-repeat center center/cover;
  padding-top: 56px;
  padding-bottom: 56px;
}
@media (max-width: 767px) {
  .contact_title {
    padding: 36px 10px 35px;
  }
}
.contact_title h2 {
  text-align: center;
  color: #F3F3F3;
}
@media (max-width: 767px) {
  .contact_title h2 {
    font-size: 30px;
  }
}

.contact-form {
  background-color: #fff;
  border-radius: 0 0 12px 12px;
  padding: 60px 120px;
}
@media (max-width: 767px) {
  .contact-form {
    padding: 30px 15px;
  }
}

.contact-form-row {
  display: flex;
}
.contact-form-row:not(:first-child) {
  margin-top: 22px;
}
@media (max-width: 767px) {
  .contact-form-row:not(:first-child) {
    margin-top: 17px;
  }
}
@media (max-width: 767px) {
  .contact-form-row {
    display: block;
  }
}

.contact-form-label {
  width: 190px;
  height: 40px;
  line-height: 40px;
}
@media (max-width: 767px) {
  .contact-form-label {
    width: 100%;
    height: 20px;
  }
}

.contact-form-label-required label {
  position: relative;
}
.contact-form-label-required label::after {
  position: absolute;
  display: inline-block;
  content: "必須";
  top: 50%;
  transform: translateY(-50%);
  left: calc(100% + 12px);
  width: 40px;
  height: 16px;
  line-height: 16px;
  font-size: 12px;
  text-align: center;
  color: #fff;
  background-color: #FF4646;
  border-radius: 2px;
}
@media (max-width: 767px) {
  .contact-form-label-required label::after {
    left: calc(100% + 20px);
  }
}

.contact-form-input {
  width: calc(100% - 200px);
}
@media (max-width: 767px) {
  .contact-form-input {
    width: 100%;
    margin-top: 20px;
  }
}
.contact-form-input [type=text],
.contact-form-input [type=email] {
  border: none;
  border-bottom: 1px solid #3E3E3E;
  border-radius: 0;
  font-size: 20px;
  font-weight: 400;
  font-family: inherit;
  padding: 0.2rem 0.5rem;
  position: relative;
  width: 100%;
  color: #3E3E3E;
  background-color: #ffffff;
  opacity: 0.7;
}
@media (max-width: 767px) {
  .contact-form-input [type=text],
.contact-form-input [type=email] {
    padding: 0;
    height: 20px;
  }
}
.contact-form-input select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  border: 1px solid #3e3e3e;
  border-radius: 0;
  color: #3E3E3E;
  font-size: 16px;
  font-family: inherit;
  font-weight: 500;
  height: 40px;
  line-height: 40px;
  outline: none;
  padding: 0.2em 0.5em;
  transition: box-shadow 0.2s;
  opacity: 0.7;
  box-shadow: none;
  width: 178px;
  position: relative;
}
@media (max-width: 767px) {
  .contact-form-input select {
    width: 100%;
  }
  .contact-form-input select:hover {
    box-shadow: 0 0 4px #4973ff;
  }
}

input[type=text]:hover, input[type=text]:focus {
  border-color: #4973ff;
  outline: none;
}
input[type=email]:hover, input[type=email]:focus {
  border-color: #4973ff;
  outline: none;
}
input[type=text]:hover + .contact-focusLine, input[type=text]:focus + .contact-focusLine {
  opacity: 1;
}
input[type=email]:hover + .contact-focusLine, input[type=email]:focus + .contact-focusLine {
  opacity: 1;
}

.contact-form-message {
  margin-top: 10px;
}

.contact-form-textarea textarea {
  width: 718px;
  max-width: 100%;
  min-height: 195px;
  resize: vertical;
  font-size: 16px;
  padding: 0.2rem;
  color: #3E3E3E;
  font-family: inherit;
  background-color: #ffffff;
}
@media (max-width: 767px) {
  .contact-form-textarea textarea {
    min-height: 160px;
    margin-top: 23px;
  }
  .contact-form-textarea textarea:hover {
    border-color: #4973ff;
    box-shadow: 0 0 4px #4973ff;
  }
}
.contact-form-textarea textarea:focus {
  border-color: #4973ff;
  box-shadow: 0 0 4px #4973ff;
}

.select-box {
  width: 178px;
  position: relative;
}
@media (max-width: 767px) {
  .select-box {
    width: 100%;
  }
}
.select-box::before {
  content: "";
  position: absolute;
  display: inline-block;
  width: 12px;
  height: 12px;
  top: 25%;
  transform: translateY(-50%);
  right: 12px;
  border-left: 1px solid #707070;
  border-bottom: 1px solid #707070;
  transform: rotate(-45deg);
  pointer-events: none;
}

.contact-form-check {
  margin-top: 35px;
  display: inline-block;
}
@media (max-width: 767px) {
  .contact-form-check {
    margin-top: 21px;
  }
}

.contact-privacyLabel {
  display: block;
  font-size: 18px;
  padding-left: 38px;
  cursor: pointer;
  position: relative;
  font-weight: 700;
}
.contact-privacyLabel:before {
  background: #fff;
  border: solid 1px #3e3e3e;
  content: "";
  display: block;
  height: 16px;
  left: 12px;
  position: absolute;
  top: 5px;
  transition: 0.2s;
  width: 16px;
}
.contact-privacyLabel:hover::before {
  border-color: #4973ff;
  box-shadow: 0 0 4px #4973ff;
}
.contact-privacyLabel:active::before {
  background-color: rgba(73, 115, 255, 0.2);
  box-shadow: none;
}
.contact-privacyLabel:after {
  border-bottom: solid 2px #4973ff;
  border-left: solid 2px #4973ff;
  content: "";
  display: block;
  height: 6px;
  left: 14px;
  opacity: 0;
  position: absolute;
  top: 8px;
  transform: rotate(-45deg);
  transition: 0.2s;
  width: 12px;
}
@media (max-width: 767px) {
  .contact-privacyLabel:after {
    left: 14px;
  }
}

input[type=checkbox]:checked + .contact-privacyLabel:after {
  opacity: 1;
}

.contact-form-button {
  text-align: center;
  display: flex;
  justify-content: space-around;
  margin-top: 32px;
}
@media (max-width: 767px) {
  .contact-form-button {
    text-align: center;
    margin-top: 30px;
    display: block;
  }
}
.contact-form-button [type=submit] {
  display: inline-block;
  color: #FFFFFF;
  background-color: #FFAA3B;
  border: none;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
  padding: 11px 50px;
  font-size: 18px;
  border-radius: 10px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-family: inherit;
  letter-spacing: 0.45px;
  transition: all 0.3s ease 0s;
  cursor: pointer;
}
.contact-form-button [type=submit]:disabled {
  background-color: rgb(189, 185, 185);
}
@media (max-width: 767px) {
  .contact-form-button [type=submit] {
    font-size: 16px;
    text-align: center;
  }
}
.contact-form-button [type=reset] {
  display: inline-block;
  color: #FFFFFF;
  background-color: rgb(189, 185, 185);
  border: none;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
  padding: 11px 50px;
  font-size: 18px;
  border-radius: 10px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-family: inherit;
  letter-spacing: 0.45px;
  transition: all 0.3s ease 0s;
  cursor: pointer;
}
@media (max-width: 767px) {
  .contact-form-button [type=reset] {
    font-size: 16px;
    margin-top: 24px;
    text-align: center;
  }
}