/* original style css 2202 */

html {
  font-size: 62.5%;
}

/* common */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Noto Sans JP', sans-serif;
  background: #fffffd;
}

body {
  display: flex;
  flex-direction: column;
  letter-spacing: 0.1rem;
  font-size: 1.6rem;
  color: #0F0E17;
}

.color_orange {
  color: #FB8C00;
}

.color_white {
  color: #FFFFFE;
}

.color_gray {
  color: #cccccc;
}

.back_color_orange {
  background-color: #FB8C00;
}

.back_color_white {
  background-color: #FFFFFE;
}

.back_color_gray {
  background-color: #F5F5F5;
}

.back_color_orgra {
  background: rgb(251,140,0);
  background: linear-gradient(180deg, rgba(251,140,0,1) 0%, rgba(222,124,0,1) 100%);
}

a {
  text-decoration: none;
}

a:hover {
  color: #FB8C00;
}

.align_center {
  text-align: center;
}

.align_right {
  text-align: right;
}

/* header */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  padding:0;
}

nav{
  width: 100%;
  height: auto;
  position: relative;
}

.header_drawer{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  position: relative;
  padding: 2rem 0;
}

.header_logo {
  font-size: 2rem;
  background: #fffffd;
  padding: 0 2rem;
}

.header_logo a {
  color: #FB8C00;
  font-weight: 300;
  letter-spacing: 0.4rem;
}
  
.logo_link {
  display: flex;
  align-items: center;
}

.logo_link span {
}

.header_logo img {
  width: 150px;
  display: inline-block;
}

.header_menu{
  text-align:center;
  /*transition: 0.5s ease;
  -webkit-transform: translateX(-100%);/*画面より100%外へ押し出し非表示にさせる*/
  display: none;
}

.header_menu.open {
  /*-webkit-transform: translateX(0%);
  transform: translateX(0%);/*メニューを元の位置へ戻す*/
}

.header_menu_list {
  list-style: none;
  background: rgba(255, 255, 255, 0.8);
}

.header_menu_list li a {
  display:block;
  padding: 2em;
  border-bottom: 1px dotted #CCC;
  font-weight: 500;
  color: #FB8C00;
}

/*トグルボタンのスタイルを指定*/
.Toggle {
  display: block;
  position: fixed;    /* bodyに対しての絶対位置指定 */
  width: 42px;
  height: 42px;
  cursor: pointer;
  z-index: 3;
  top:25px;
  right:15px;
}
 
.Toggle span {
  display: block;
  position: absolute;
  width: 40px;
  border-bottom: solid 2px #FB8C00;
  -webkit-transition: .35s ease-in-out;	/*変化の速度を指定*/
  -moz-transition: .35s ease-in-out;		/*変化の速度を指定*/
  transition: .35s ease-in-out;			/*変化の速度を指定*/
 
}
 /*各ボーダー少しずつずらす*/
.Toggle span:nth-child(1) { top:5px; }
.Toggle span:nth-child(2) { top: 18px; }
.Toggle span:nth-child(3) { top: 32px; }
.Toggle.active span:nth-child(1) {
  top: 18px;
  /* 1番目のspanをマイナス45度に */
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
 
/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
  top: 18px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (min-width: 600px) {
/*  nav {
    display: flex;
    height: auto;
  }

  .header_drawer{
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    position: relative;
    height: auto;
  }

  h1.header_logo {
    padding: 2rem 3rem;
    width: 400px;
    font-size: 2.2rem;
  }
  
  .logo_link {
    display: flex;
    align-items: center;
  }
  
  .logo_link span {
    padding-top: 1rem;
  }

  .header_logo img {
    width: 50px;
    display: inline-block;
  }
  
  .Toggle {
    display: none;
  }
  
  .header_menu {
    width: 100%;
    background-color: transparent;
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  
  .header_menu_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    background: transparent;
    margin: 0;
  }

  .header_menu_list li a {
    padding: 0 2rem;
    border-bottom: none;
  }
  
  .header_menu_list li a:last-child {
    padding-right: 3rem;
  }
  
  .header_menu_list li.contact_head_btn a {
    color: #fff;
  }*/
}

.container {
  padding: 0;
}

.section {
  padding: 10rem 5rem;
  margin: 0;
  position: relative;
}

@media only screen and (max-width: 599px) {
  .container {
    margin-top: 10rem;
    padding: 0 0rem;
  }
  .section {
    padding: 5rem 1rem;
  }
  .sp-br {
    display: block;
  }
}

/*Title*/

.section_title_contents {
  padding: 5rem 3rem;
  font-family: 'Cormorant', serif;
}

.section-no {
  font-size: 4rem;
}

.section-title-l {
  font-size: 14rem;
  line-height: 13rem;
}

.section-title-m {
  font-size: 9rem;
  line-height: 8rem;
}

@media only screen and (max-width: 599px) {
  .section-title-l {
    font-size: 8rem;
    line-height: 7rem;
  }
  
  .section-title-ls {
    font-size: 6.5rem;
    line-height: 5rem;
  }

  .section-title-m {
    font-size: 5rem;
    line-height: 4rem;
  }
}

.number-left {
  display: inline-block;
  padding-right: 5rem;
}

.section_sub_undertitle {
  font-size: 2rem;
  padding-left: 8.7rem;
}

.section_sub_undertitle_in {
  font-size: 2rem;
  padding-left: 0.5rem;
  padding-top: 2rem;
}

.left_title_box {
  position: absolute;
  top: 0;
  left: 0;
  padding: 1.2rem 6rem;
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.4rem;
}

.right_title_box {
  position: absolute;
  top: 0;
  right: 0;
  padding: 1.2rem 6rem;
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.4rem;
}

.right_title_box_sed {
  position: absolute;
  top: 130px;
  right: 0;
  padding: 1.2rem 6rem;
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.4rem;
}

.right_title_box_tre {
  position: absolute;
  top: 330px;
  right: 0;
  padding: 1.2rem 6rem;
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.4rem;
}

.top_title_box {
  position: absolute;
  top: 0;
  left: calc(50% - 10rem);
  padding: 1.2rem 6rem;
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.4rem;
}

.min_title_m {
  font-family: 'Shippori Mincho', serif;
  font-size: 2.6rem;
  letter-spacing: 0.3rem;
}

/*BTN*/



/*Page*/

.contents_box {
  position: relative;
  padding: 5rem 20rem;
}

.contents_box_left {
  padding-left: 30rem;
}

.flex_bet_box {
  display: flex;
  justify-content: space-around;
}

@media only screen and (max-width: 599px) {
  .contents_box {
    padding: 5rem 2rem;
  }
  .contents_box_left {
    padding-left: 1rem;
  }
  .flex_bet_box {
    flex-flow:column;
    justify-content: center;
  }
}

.top {
  min-height: 650px;
  margin: 0 8rem;
  background: url('/images/main_img.jpg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.top_catch {
  padding-top: 5rem;
}

.top_catch_txt_e {
  font-size: 15rem;
  letter-spacing: 0.5rem;
  color: rgba(255, 255, 253, 0.45);
  padding: 10rem 2rem 5rem;
  font-weight: 700;
  line-height: 10rem;
}

.top_catch_txt_j {
  font-size: 4rem;
  letter-spacing: 0.5rem;
  color: rgba(255, 255, 253, 0.95);
  font-weight: 500;
  padding: 2rem 5rem;
}

@media only screen and (max-width: 599px) {
  .top {
    min-height: 650px;
    margin: 0 1rem;
  }
  .top_catch_txt_e {
   font-size: 6rem;
    line-height: 4rem;
  }
}

/*--------top_aboutus--------*/

.top_aboutus_mes {
  padding: 5rem 0;
  letter-spacing: 0.2rem;
}

.top_aboutus_mes p {
  padding: 1.3rem 0;
  line-height: 3rem;
}

.top_aboutus_boeder {
  position: absolute;
  top: 67px;
  left: 25px;
  width: 250px;
  height: 3px;
  background: #fb8c00;
}

@media only screen and (max-width: 599px) {
  .top_aboutus_boeder {
    top:20px;
    left: 0;
  }
}

.top_aboutus_company {
  padding: 5rem 0;
  letter-spacing: 0.2rem;
}

.top_list_company {
  list-style: none;
  margin: 0;
  padding: 0;
}

.top_list_company li {
  display: flex;
  border-bottom: 1px solid #ccc;
  padding: 3rem 0;
}

.top_list_company li:first-child {
  border-top: 1px solid #ccc;
}

.c-title {
  width: 30%;
  font-size: 1.4rem;
  color: #666;
}

.bor-o-t, .bor-o-b {
  position: relative;
}

.bor-o-t::before {
  content: "";
  position: absolute;
  left: 0;
  top: -3rem;
  width: 100%;
  border-top: 1px solid #fb8c00;
}

.bor-o-b::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3rem;
  width: 100%;
  border-bottom: 1px solid #fb8c00;
}

.top_aboutus_atten {
  padding: 2rem 5rem;
  background: #f1f1f1;
  font-size: 1.2rem;
  line-height: 2rem;
  font-weight: 300;
}

.top_aboutus_atten p {
  padding: 0.5rem 0;
}

/*--------top_aboutus--------*/

/*--------top_service--------*/
.top_service_box {
  background: rgb(251,140,0);
  background: linear-gradient(180deg, rgba(251,140,0,1) 0%, rgba(222,124,0,1) 100%);
}

.top_service_box_w {
  background: #fffffd;
}

.top_service_box_b {
  border-top: 10px solid rgba(255, 255, 255, 0.5);
  background: rgb(251,140,0);
  background: linear-gradient(180deg, rgba(251,140,0,1) 0%, rgba(222,124,0,1) 100%);
}

.top_service_inner {
  padding: 5rem 10rem 10rem;
}

.top_service_inner_all {
  padding: 0;
}

.top_service_inner_b {
  padding: 10rem 10rem;
}

.top_service_inner_s{
  padding: 10rem 5rem 10rem 0;
}

.top_service_title {
  display: flex;
  color: #fffffd;
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: 0.4rem;
}

.service_name span {
  margin-left: 1rem;
  padding: 0 1rem;
}

.service_num {
  font-size: 8rem;
  line-height: 2rem;
  font-family: 'Sora', sans-serif;
  font-weight: 500;
  padding-right: 2rem;
}

.service_content {
  position: relative;
  background: #fffffd;
  border: 3px solid #fb8c00;
  padding: 3rem;
  margin: 5rem 1rem;
  flex-grow: 1;
  width: 300px;
}

.service_sub_name {
  color: #fb8c00;
  font-size: 2.8rem;
  letter-spacing: 0.4rem;
  padding-bottom: 3rem;
}

.service_sub_name_o {
  font-size: 2.8rem;
  letter-spacing: 0.4rem;
  padding: 2rem 1rem;
  color: #fff;
  background: #fb8c00;
}

.service_sub_txt {
  min-height: 150px;
}

.service_sub_name span {
  font-size: 2.4rem;
}

.service_sub_list {
  padding: 3rem 0;
  font-size: 1.4rem;
  line-height: 3rem;
  font-weight: 300;
}

.numone {
  position: absolute;
  bottom: 0;
  right: 0;
  color: #F5F5F5;
  font-family: 'Sora', sans-serif;
  font-weight: 500;
  font-size: 20rem;
  line-height: 14.5rem;
}

.top_service_flex {
  display: flex;
  justify-content: space-between;
}

.top_service_left {
  padding: 10rem 0 5rem 10rem;
  width: 50%;
}

.top_service_right {
  width: 50%;
  /*border-top: 10px solid rgba(255, 255, 255, 0.5);*/
  background: #fb8c00;
}

.top_service_left_w {
  padding: 10rem 0 5rem 10rem;
  width: 50%;
}

.top_service_figure {
  margin-top: 10rem;
}

.top_service_figure_in {
  display: flex;
  justify-content: center;
  padding: 3rem 0;
}

.figure_box {
  background: #fffffd;
  color: #fb8c00;
  padding: 1.5rem 5rem;
  margin: 0 3rem;
}

.top_service_sec_txt {
  padding: 5rem 3rem 5rem 0;
  line-height: 3rem;
}

.top_list_service_box {
  padding: 3rem;
  background: rgba(255, 255, 255, 0.9);
}

.img_box {
  width: 200px;
}

.img_small {
  width: 100px;
}

.service_box_flex {
  display: block;
  align-content: center;
  justify-content: center;
}

.service_box_m {
  display: flex;
  align-items: center;
  border: 1px dotted #fb8c00;
  padding: 3rem;
  font-size: 2rem;
  color: #fb8c00;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 599px) {
  .top_service_inner {
    padding: 5rem 1rem;
  }
  
  .top_service_inner_b {
    padding: 10rem 2rem 5rem;
  }

  .top_service_inner_s{
    padding: 10rem 2rem;
  }

  
  .top_service_title {
    font-size: 2.8rem;
  }
  
  .service_name span {
    margin-left: 0;
  }
  
  .service_num{
    font-size: 6rem;
  }
  
  .service_content {
    width: calc(100% - 3rem);
    margin: 5rem 1rem 0;
  }
  
  .service_sub_name {
    font-size: 2.2rem;
  }
  
  .service_sub_name_o {
    font-size: 2.2rem;
  }
  
  .service_sub_txt {
    min-height: 100%;
    padding-bottom: 2rem;
  }
  
  .top_service_flex {
    flex-flow: column;
    justify-content: center;
  }
  
  .top_service_left {
    padding: 10rem 2rem;
    width: 100%;
  }

  .top_service_right {
    width: 100%;
    background: #fffffd;
  }
  
  .top_service_figure {
    margin-top: 1rem;
    margin-bottom: 2rem;
  }

  .top_service_figure_in {
    display: flex;
    justify-content: center;
    padding: 2rem 0;
  }

  .figure_box {
    background: #fb8c00;
    color: #fffffd;
    padding: 1.5rem 1rem;
    margin: 0 3rem;
  }
  
  .top_service_sec_txt {
    padding: 5rem 0;
    line-height: 3rem;
  }
}

.top_list_service {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  font-weight: 300;
}

.top_list_service li {
  display: flex;
  border-bottom: 1px solid #ccc;
  padding: 2rem 0;
}

.top_list_service li:first-child {
  border-top: 1px solid #ccc;
}

.s-title {
  width: 30%;
  font-size: 1.2rem;
}

/*vision*/

.top_vision_mes {
  padding: 5rem 10rem;
  font-size: 1.8rem;
  letter-spacing: 0.4rem;
  line-height: 5rem;
}

@media only screen and (max-width: 599px) {
  .top_vision_mes {
    padding: 5rem 2rem;
    font-size: 1.6rem;
    line-height: 3rem;
  }
}

.top_vision_mes p {
  padding: 2rem 0;
}

.top_vision_delimiter {
  position: relative;
  background: #fb8c00;
  height: 30px;
  margin: 5rem 0 0;
}

.top_vision_delimiter::after {
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  border-left: 10px solid rgb(222, 43, 43);
  border-right: 10px solid rgb(222, 43, 43);
}

.top_am_section {
  position: relative;
  background-color: #F5F5F5;
  top:-0;
  left: 0;
  width: 100%;
  display: block;
  padding-top: 20rem;
}

.section_title_ab {
  position: absolute;
  top:-180px;
  left: 0;
}

.section_title_ab_s {
  position: absolute;
  top:200px;
  right: 0;
  z-index: 99;
}

.top_am_box, .top_am_box_r {
  display: block;
  position: relative;
  padding: 5rem;
  background: #fffffd;
  width: 60%;
}

.top_am_box::after, .top_am_box_r::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 200px;
  height: 5px;
  background: #fb8c00;
}

.top_am_in_r {
  display: flex;
  justify-content: flex-end;
}

.top_am_box::before {
  position: absolute;
  right: -100px;
  bottom: 0;
  content: "";
  border-top: 100px solid transparent;
  border-left: 50px solid #fb8c00;
  border-right: 50px solid transparent;
  border-bottom: 100px solid #fb8c00;
}

.top_am_box_r::before {
  position: absolute;
  left: -100px;
  bottom: 0;
  content: "";
  border-top: 100px solid transparent;
  border-left: 50px solid transparent;
  border-right: 50px solid #fb8c00;
  border-bottom: 100px solid #fb8c00;
}

@media only screen and (max-width: 599px) {
  .top_am_box, .top_am_box_r {
    width: 90%;
  }
  
  .top_am_box::before {
    right: -40px;
    bottom: 0;
    content: "";
    border-top: 50px solid transparent;
    border-left: 20px solid #fb8c00;
    border-right: 20px solid transparent;
    border-bottom: 50px solid #fb8c00;
  }
  
  .top_am_box_r::before {
    left: -40px;
    bottom: 0;
    content: "";
    border-top: 50px solid transparent;
    border-left: 20px solid transparent;
    border-right: 20px solid #fb8c00;
    border-bottom: 50px solid #fb8c00;
  }
}

.top_am_box_title {
  font-size: 2.6rem;
  letter-spacing: 0.4rem;
  padding-bottom: 2rem;
}

.top_am_box_title_em {
  font-size: 3rem;
}

.top_am_box_txt {
  font-weight: 300;
  letter-spacing: 0.3rem;
  font-size: 1.5rem;
}

.news_content_box {
  padding: 5rem 20rem;
}

.news_content {
  display: flex;
  border-bottom: 1px solid #ccc;
  padding: 2rem 0;
}

.news_date {
  text-align: center;
  padding: 0 2rem;
  margin-right: 5rem;
}

@media only screen and (max-width: 599px) {
  .news_content_box {
    padding: 5rem 2rem;
  }
  
  .news_date {
    margin-right: 2rem;
  }
}

.news_month {
  display: block;
}

.news_day {
  display: block;
  color: #fb8c00;
  font-size: 3rem;
}

.news_txt {
  
}

.news_tag {
  display: block;
  width: 150px;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 300;
  padding: 1rem 3rem;
  background: #f1f1f1;
  margin-bottom: 1rem;
}

.contact_info {
  text-align: center;
  color: #fffffd;
}

.privacy-text {
  font-weight: 300;
}

.accsess-text {
  text-align: right;
  padding: 0 0 3rem;
}

.p-title{
  font-weight: 400;
  padding: 2rem 0;
}

.btn_long_w {
  display: block;
  padding: 3rem 6rem;
  width: 300px;
  margin: 5rem auto;
  color: #fb8c00;
  background: #fffffd;
  cursor: pointer;
}

.btn_long_w:hover {
  background: #e5e1de;
}

.gray-btn {
  display: block;
  background: #ECE8E4;
  padding: 1rem 2rem;
  text-align: center;
  letter-spacing: 0.4rem;
  color: #0f0e17;
  border-left: 5px solid #E5E1DE;
  border-right: 5px solid #E5E1DE;
}

.btn_allow_basic {
  display: flex;
  justify-content: flex-end;
}

.btn_allow_basic a {
  position: relative;
  display: block;
  padding: 5rem 0 2.5rem;
  width: 300px;
  color: #fff;
  transition: 0.3s;
}

.btn_allow_basic a::before {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translateY(calc(-50% - 2px)) rotate(45deg);
  width: 12px;
  height: 2px;
  background-color: #fff;
  transition: 0.3s;
}

.btn_allow_basic a::after {
  content: '';
  position: absolute;
  bottom: -0.2rem;
  right: 0.5px;
  transform: translateY(-50%);
  width: 100%;
  height: 2px;
  background-color: #fff;
  transition: 0.3s;
}

.btn_allow_basic a:hover {
  text-decoration: none;
}

.btn_allow_basic a:hover::before,
.btn_allow_basic a:hover::after {
  right: 0.5em;
}

.btn_allow_basic_l {
  display: flex;
  justify-content: flex-start;
}

.btn_allow_basic_l a {
  position: relative;
  display: block;
  padding: 5rem 0 2.5rem;
  width: 300px;
  color: #fb8c00;
  transition: 0.3s;
}

.btn_allow_basic_l a::before {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translateY(calc(-50% - 2px)) rotate(45deg);
  width: 12px;
  height: 2px;
  background-color: #fb8c00;
  transition: 0.3s;
}

.btn_allow_basic_l a::after {
  content: '';
  position: absolute;
  bottom: -0.2rem;
  right: 0.5px;
  transform: translateY(-50%);
  width: 100%;
  height: 2px;
  background-color: #fb8c00;
  transition: 0.3s;
}

.btn_allow_basic_l a:hover {
  text-decoration: none;
}

.btn_allow_basic_l a:hover::before,
.btn_allow_basic_l a:hover::after {
  right: 0.5em;
}

/*--------top_service--------*/


/* footer */
footer {
  margin-top: auto;
  padding: 0;
  color: #FB8C00;
  font-weight: 300;
}
.footer {
  opacity: 1;
  padding: 3rem 2rem;
  position: relative;
}
.copyright {
  text-align: right;
  font-size: 1.4rem;
  padding-right: 70px;
}
.f_sub_menu {
  font-size: 1.4rem;
  color: #0f0e17;
}

@media only screen and (max-width: 599px) {
  .footer {
    padding: 3rem 2rem;
    position: relative;
  }
  .copyright {
    text-align: center;
    font-size: 0.8rem;
    padding-right: 0;
    padding-top: 3rem;
  }
}

/*スクロールダウン全体の場所*/
.scrolldown {
  /*描画位置*/
  position:absolute;
  bottom:0;
  right:10%;
}

/*Scrollテキストの描写*/
.scrolldown span{
  /*描画位置*/
  position: absolute;
  left:10px;
  bottom:10px;
  /*テキストの形状*/
  color: #fff;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}

/* 丸の描写 */
.scrolldown:before {
  content: "";
  position: absolute;
  bottom:0;
  left:-4px;
  width:10px;
  height:10px;
  border-radius: 50%;
  background:#fff;
  /*丸の動き1.6秒かけて透過し、永遠にループ*/
  animation:
    circlemove 1.6s ease-in-out infinite,
    cirlemovehide 1.6s ease-out infinite;
}

/*下からの距離が変化して丸の全体が上から下に動く*/
@keyframes circlemove {
  0%{bottom:45px;}
  100%{bottom:-5px;}
 }

/*上から下にかけて丸が透過→不透明→透過する*/
@keyframes cirlemovehide{
      0%{opacity:0}
     50%{opacity:1;}
    80%{opacity:0.9;}
	100%{opacity:0;}
 }

/* 線の描写 */
.scrolldown:after{
  content:"";
  position: absolute;
  bottom:0;
  left:0;
  width:2px;
  height: 50px;
  background:#fff;
}

/*==================================================
ふわっ
===================================*/

/* その場で */
.fadeIn{
animation-name:fadeInAnime;
animation-duration:1s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* 下から */

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:1s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

/* 上から */

.fadeDown{
animation-name:fadeDownAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeDownAnime{
  from {
    opacity: 0;
  transform: translateY(-100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

/* 左から */

.fadeLeft{
animation-name:fadeLeftAnime;
animation-duration:0.8s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeLeftAnime{
  from {
    opacity: 0;
  transform: translateX(-100px);
  }

  to {
    opacity: 1;
  transform: translateX(0);
  }
}

/* 右から */

.fadeRight{
animation-name:fadeRightAnime;
animation-duration:0.8s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeRightAnime{
  from {
    opacity: 0;
  transform: translateX(100px);
  }

  to {
    opacity: 1;
  transform: translateX(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeInTrigger,
.fadeUpTrigger,
.fadeDownTrigger,
.fadeLeftTrigger,
.fadeRightTrigger{
    opacity: 0;
}

/*==================================================
ボンッ
===================================*/

/* 拡大 */
.zoomIn{
  animation-name:zoomInAnime;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
  from {
  transform: scale(0.6);
  }

  to {
      transform: scale(1);
  }
}


/*==================================================
シャッ（背景色が伸びて出現）
===================================*/

/*背景色が伸びて出現（共通）*/
.bgextend{
  animation-name:bgextendAnimeBase;
  animation-duration:1s;
  animation-fill-mode:forwards;
  position: relative;
  overflow: hidden;/*　はみ出た色要素を隠す　*/
  opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;
}
}

/*中の要素*/
.bgappear{
  animation-name:bgextendAnimeSecond;
  animation-duration:1s;
  animation-delay: 0.6s;
  animation-fill-mode:forwards;
  opacity: 0;
}

@keyframes bgextendAnimeSecond{
  0% {
  opacity: 0;
  }
  100% {
  opacity: 1;
}
}

/*左から*/
.bgLRextend::before{
  animation-name:bgLRextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #2356A7;/*伸びる背景色の設定*/
}
@keyframes bgLRextendAnime{
  0% {
    transform-origin:left;
    transform:scaleX(0);
  }
  50% {
    transform-origin:left;
    transform:scaleX(1);
  }
  50.001% {
    transform-origin:right;
  }
  100% {
    transform-origin:right;
    transform:scaleX(0);
  }
}

/*右から*/
.bgRLextend::before{
  animation-name:bgRLextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgRLextendAnime{
  0% {
    transform-origin:right;
    transform:scaleX(0);
  }
  50% {
    transform-origin:right;
    transform:scaleX(1);
  }
  50.001% {
    transform-origin:left;
  }
  100% {
    transform-origin:left;
    transform:scaleX(0);
  }
}

/*下から*/
.bgDUextend::before{
  animation-name:bgDUextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgDUextendAnime{
  0% {
    transform-origin:bottom;
    transform:scaleY(0);
  }
  50% {
    transform-origin:bottom;
    transform:scaleY(1);
  }
  50.001% {
    transform-origin:top;
  }
  100% {
    transform-origin:top;
    transform:scaleY(0);
  }
}

/*上から*/
.bgUDextend::before{
  animation-name:bgUDextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgUDextendAnime{
  0% {
    transform-origin:top;
    transform:scaleY(0);
  }
  50% {
    transform-origin:top;
    transform:scaleY(1);
  }
  50.001% {
    transform-origin:bottom;
  }
  100% {
    transform-origin:bottom;
    transform:scaleY(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgUDextendTrigger,
.bgDUextendTrigger,
.bgRLextendTrigger,
.bgLRextendTrigger{
    opacity: 0;
}

.slide-in {
  overflow: hidden;
  display: inline-block;
}

.slide-in_inner {
  display: inline-block;

}

/*左右のアニメーション*/
.leftAnime{
  opacity: 0;/*事前に透過0にして消しておく*/
}

.slideAnimeLeftRight {
  animation-name:slideTextX100;
  animation-duration:1.5s;
  animation-fill-mode:forwards;
  opacity: 0;
}

@keyframes slideTextX100 {
  from {
    transform: translateX(-100%); /*要素を左の枠外に移動*/
    opacity: 0;
  }

  to {
    transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}

.slideAnimeRightLeft {
  animation-name:slideTextX-100;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  opacity: 0;
}


@keyframes slideTextX-100 {
  from {
    transform: translateX(100%);/*要素を右の枠外に移動*/
    opacity: 0;
  }

  to {
    transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}

.eachTextAnime span{opacity: 0;}
.eachTextAnime.appeartext span{ animation:text_anime_on 1s ease-out forwards; }
@keyframes text_anime_on {
	0% {opacity:0;}
	100% {opacity:1;}
}