/*
Theme Name: ichimi
*/


@charset "UTF-8";

html {
  font-size: 62.5%;
  /*16px × 62.5%=10px*/
}

body {
  font-family: 'Noto Sans JP', 'Josefin Sans', "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  color: #393939;
  font-size: 1.6rem;
  line-height: 1.85;
  letter-spacing: 0.05em;
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

.text-center {
  text-align: center;
}

.inner {
  max-width: 980px;
  margin: 0 auto;
}

a {
  color: #393939;
}

a:hover {
  cursor: pointer;
}

.sp {
  display: none;
}

.flex {
  display: flex;
}

.upper {
  text-transform: uppercase;
}


.delay-time03 {
  animation-delay: 0.3s;
}


.delay-time05 {
  animation-delay: 0.5s;
}

.delay-time1 {
  animation-delay: 1s;
}

.delay-time15 {
  animation-delay: 1.5s;
}

.delay-time2 {
  animation-delay: 2s;
}

.delay-time25 {
  animation-delay: 2.5s;
}

.opacity {
  opacity: 0;
}

/* ------------

共通

--------------*/

h2 {
  display: inline-block;
  font-size: 3.0rem;
  color: #A0A0A0;
  font-family: 'Josefin Sans', sans-serif;
  text-transform: uppercase;
  font-weight: bold;
  border-bottom: solid 4px #707070;
  line-height: 1;
  margin-bottom: 20px;
}

.h2_accent {
  font-size: 6.0rem;
  color: #505050;
  font-family: 'Josefin Sans', sans-serif;
  text-transform: uppercase;
  font-weight: bold;

}

.section_header {
  padding-top: 80px;
  margin-bottom: 44px;
}

.section_body {
  padding-bottom: 44px;
}


/* ------------

////共通

--------------*/



/* ------------

fadeIn

-------------*/


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

@keyframes fadeInAnime {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* ------------

////fadeIn

-------------*/

/* ------------

fadeUp

-------------*/

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

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

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

/* ------------

////////fadeUp

-------------*/

/* ------------

トップへ戻るボタン

-------------*/

#page_top {
  width: 64px;
  position: fixed;
  right: 36px;
  bottom: 48px;
  opacity: 1;
  z-index: 100;
  box-shadow: 0px 0px 2px #fff;
}

/* ------------

///トップへ戻るボタン

-------------*/

/* ---------

ヘッダー

-----------*/

.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 50;
  width: 100%;
  padding: 22px 24px;
  background-color: #fff;
  opacity: 0.95;
}

.header_inner {
  width: 90%;
  margin: 0 auto;
}

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

.under_logo {
  width: 110px;

}


.header_list {
  display: flex;
  font-size: 1.8rem;
  font-family: 'Josefin Sans', sans-serif;
}

.header_nav_btn {
  margin-left: 80px;

}


.nav .header_nav_btn {
  position: relative;
}

.nav .header_nav_btn::after {
  position: absolute;
  left: 0;
  bottom: -12px;
  display: block;
  content: "";
  width: 0%;
  height: 2px;
  background: #393939;
  transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.nav .header_nav_btn:hover::after {
  width: 100%;
}

.home .under_logo {
  opacity: 0;
}

.home .top_none {
  display: none;
}

.single .under_none {
  display: none;
}

.archive .under_none {
  display: none;
}

.page .under_none {
  display: none;
}






/* ---------

////ヘッダー

-----------*/


/* ---------

トップビュー

-----------*/

.topview {
  height: 700px;
  position: relative;
}



.topview_sclool {
  position: absolute;
  bottom: 0%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 72px;

}

.topview_sclool:before {
  content: "";
  position: absolute;
  left: 24px;
  top: 102%;
  transition: all 0.2s ease-in-out;
  display: block;
  width: 8px;
  height: 8px;
  border-top: solid 2px #4b4b4b;
  border-right: solid 2px #4b4b4b;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}


/* ---------

///トップビュー

-----------*/

/* ---------

導入

-----------*/

.introduction_p {
  padding-top: 114px;
  padding-bottom: 120px;
}

.intro_inner {
  width: 316px;
  margin: 0 auto;
}

.intro_text01 {
  font-size: 1.4rem;
  line-height: 3.5;


}


.intro_text02 {
  font-size: 1.4rem;
  line-height: 3.5;
  padding-top: 56px;
  margin-left: 110px;
  margin-bottom: 172px;


}

.intro_text03 p {
  font-size: 2.0rem;
}

/* ---------

///導入

-----------*/

/* ---------

ニュース

-----------*/

.news {
  background-color: #F2F2F2;
}

.news_inner {
  max-width: 820px;
  margin: 0 auto;
}

.news_title {
  font-size: 2.2rem;
  border-bottom: solid 2px #707070;

}

.news_accent {
  font-size: 3.0rem;
  font-weight: bold;
  color: #505050;

}

.news_item {
  display: flex;
  align-items: center;
  margin-bottom: 8px;
}

.news_item p {
  font-family: 'Josefin Sans', "メイリオ", sans-serif;
  font-size: 1.8rem;
}

.news_item span {
  display: block;
  margin-left: 28px;
  margin-top: -4px;
}

.news_all {
  text-align: right;
}

.news_btn {
  position: relative;
  transition: all 0.5s;
}

.news_btn:hover {
  color: #9d9d9d;
}

.news_btn::before {
  content: '';
  position: absolute;
  width: 98px;
  height: 1px;
  background: #707070;
  right: -44px;
  top: 127%;

}

.news_btn::after {
  content: "";
  position: absolute;
  top: 22px;
  right: -42px;
  width: 16px;
  height: 16px;
  border-top: 1px solid #707070;
  transform: rotate(45deg);
}

/* ---------

///ニュース

-----------*/

/* ---------

サービス

-----------*/

.service_contents {
  background-image: url(../images/bg01@2x.png);
  background-size: cover;
  padding: 20px 0 118px 0;
  margin-bottom: 120px;
}

.service_contents_2 {
  background-image: url(../images/bg02@2x.png);
  background-size: cover;
  padding: 20px 0 118px 0;
  margin-bottom: 96px;
}

.service_box {
  position: relative;
}

.number {
  font-family: 'Josefin Sans', "メイリオ", sans-serif;
  position: absolute;
  top: -74px;
  left: 20px;
  font-size: 11.4rem;
  color: #C6C6C6;
  font-weight: bold;
  line-height: 1;
}

.number_2 {
  font-family: 'Josefin Sans', "メイリオ", sans-serif;
  position: absolute;
  top: -74px;
  right: 20px;
  font-size: 11.4rem;
  color: #C6C6C6;
  font-weight: bold;
  line-height: 1;

}

.service_img {
  max-width: 493px;
}

.service_img_2 {
  max-width: 493px;
  margin: 0 0 0 auto;

}

.flow_text {
  position: absolute;
  top: 20px;
  right: 60px;
  width: 420px;
  padding: 30px;
  background-color: #fff;
  box-shadow: 1px 1px 2px rgb(162, 162, 162);
  margin-left: -40px;
  margin-top: 180px;
  display: inline-block;
}

.flow_text_2 {
  position: absolute;
  top: 20px;
  left: 60px;
  width: 420px;
  padding: 30px;
  background-color: #fff;
  box-shadow: 1px 1px 2px rgb(162, 162, 162);
  margin-left: -40px;
  margin-top: 180px;
  display: inline-block;

}


.flow_title {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 12px;
}

/* ---------

///サービス

-----------*/

/* ---------

会社

-----------*/

.company {
  padding-top: 20px;
  padding-bottom: 80px;
  background-color: #F2F2F2;
}

.company_info_inner {
  max-width: 720px;
  margin: 0 auto 154px;
}

.info_data {
  margin-bottom: 40px;
}

.info_item {
  display: flex;
  padding: 20px 0;
  border-bottom: solid 1px #C6C6C6;
}

.info_title {
  width: 20%;
}

.info_detail {
  width: 80%;
  margin-left: 20px;
}

.info_data_en {
  font-family: 'Josefin Sans', "メイリオ", sans-serif;
  font-size: 1.6rem;
}



.info_item_en {
  display: flex;
  padding: 12px 0;
}
.info_title_en {
	width: 30%;  
}
@media screen and (max-width:481px) { 
	.info_item_en {
		flex-direction: column;
	}
	.info_title_en{
		width: 100%;
	}
}

.info_detail_en {
  width: 70%;
  margin-left: 20px;
}

.company_greeting_inner {
  max-width: 700px;
  margin: 0 auto;
}

.greeting {
  padding-top: 80px;
  padding-bottom: 120px;
}

.greeting_title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 56px;
}

.greeting_catch {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 40px;
}

.greeting_box {
  margin-bottom: 48px;
}


.greeting_text {
  margin-bottom: 28px;
  line-height: 1.8;

}

.greeting_name {
  text-align: right;
}

/* ---------

///会社

-----------*/

/* ---------

お問い合わせ

-----------*/

.contact_inner {
  width: 720px;
  margin: 0 auto;
  padding-top: 28px;
  padding-bottom: 108px;
}

.form_item {
  display: flex;
  width: 100%;
  margin-bottom: 44px;
}

.form_title {
  width: 200px;
  padding: 10px 0;
  text-align: right;
}

.caution {
  background-color: #A48BDD;
  color: #fff;
  padding: 2px 12px;
  border-radius: 4px;
  margin-left: 12px;
}


.form_detail {
  width: 400px;
  margin-left: 42px;
}

.posit {
  text-align: center;
  margin-left: 20px;
}


.form_text_detail {
  width: 400px;
  margin-left: 40px;
  padding-top: 12px;
}

.form_parts {
  display: inline-block;
  width: 100%;
  line-height: 2.0;
}

.form_parts_text {
  width: 100%;
}

.submit_button {
  padding-top: 40px;
}

.submit_btn {
  display: block;
  width: 224px;
  margin: 0 auto;
  padding: 10px 0px;
  background-color: #fff;
  border: solid 1px #9c9c9c;
  transition: all 0.5s ease;
}

.submit_btn:hover {
  background-color: rgb(219, 219, 219);
  border: solid 1px rgb(219, 219, 219);
}

/* ---------

///お問い合わせ

-----------*/

/* ---------

フッター

-----------*/

.footer_bg {
  background-color: #4D4D4D;
  padding-top: 54px;
  padding-bottom: 12px;
}

.footer_inner {
  max-width: 500px;
  margin: 0 auto;
}


.footer_list {
  color: #fff;
  display: flex;
  font-size: 1.8rem;
  font-family: 'Josefin Sans', sans-serif;
  justify-content: space-between;
  margin-bottom: 96px;

}

.nav_btn {
  color: #fff;
}

.copyright {
  color: #fff;
  font-size: 1.4rem;
}

/* ---------

///フッター

-----------*/


/* ---------

下層ページ（新着一覧）

-----------*/

.under_section_header {
  padding-top: 164px;
  width: 780px;
  margin: 0 auto 56px;

}


.under_news_title {
  margin-bottom: 8px;
  color: #393939;
  border-bottom: solid 4px #393939;

}


.under_news_inner {
  width: 780px;
  margin: 0 auto 56px;
  display: flex;
}

.under_section_body {
  padding-bottom: 120px;
}

.under_news_contents {
  width: 100%;
}


.under_news_item {
  display: flex;
  align-items: center;
  margin-bottom: 44px;
}

.under_news_item p {
  font-family: 'Josefin Sans', "メイリオ", sans-serif;
  font-size: 1.8rem;
}

.under_news_item span {
  display: block;
  margin-left: 28px;
  margin-top: -4px;
}

.under_contents {
  width: 640px;
}

.under_contents_date {

  margin-bottom: 40px;
}

.under_news_all {
  text-align: right;
}

.side_content {
  padding-left: 60px;
  margin-left: 60px;
  border-left: solid 1px #707070;
  width: 130px;
}

.side_content p {
  margin-bottom: 32px;
}

.side_content li {
  margin-bottom: 20px;
}

.under_contents_title {
  font-size: 1.8rem;
  padding-bottom: 8px;
  border-bottom: solid 1px #707070;
  margin-bottom: 8px;

}

.under_news_all {
  text-align: right;
  margin-right: 56px;
}

.under_contents_text {
  max-width: 800px;
  margin-bottom: 72px;
}

/* ---------

///下層ページ（新着一覧）

-----------*/









@media screen and (max-width:767px) {
  /* スマホ向け */


  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  h2 {
    font-size: 2.4rem;
    margin-bottom: 8px;
  }

  .h2_accent {
    font-size: 4.0rem;
  }

  .section_header {
    padding-top: 48px;
  }

  #page_top {
    width: 64px;
    right: 0px;
    bottom: 57px;
  }

  .under_logo {
    display: none;
  }

  /* ---------

ヘッダー

-----------*/

  .header_inner {
    width: 86%;
  }

  .nav {
    width: 100%;
  }

  .header_list {
    justify-content: space-between;
  }


  .header {
    bottom: 0;
    left: 0;
    top: initial;
    z-index: 50;
    width: 100%;
    padding: 12px 0px;
    opacity: 1;
    box-shadow: 0 0 2px rgb(81, 81, 81);
  }

  .header_nav_btn {
    margin-left: 0px;
    font-size: 1.6rem;

  }

  .nav .header_nav_btn:hover::after {
    width: 0%;
  }

  /* ---------

///ヘッダー

-----------*/




  /* ---------

イントロ

-----------*/

  .intro_inner {
    width: 270px;
  }

  .intro_text02 {
    font-size: 1.4rem;
    line-height: 3.5;
    padding-top: 44px;
    margin-left: 64px;
    margin-bottom: 144px;
  }

  /* ---------

///イントロ

-----------*/

  /* ---------

ニュース

-----------*/

  .news_title {
    margin-bottom: 40px;
  }

  .news_inner {
    width: 90%;
    margin: 0 auto;
  }

  .news_item {
    display: block;
    margin-bottom: 24px;
  }

  .news_item span {
    margin-left: 0px;
    margin-top: 0px;
  }

  /* ---------

///ニュース

-----------*/

  /* ---------

サービス

-----------*/

  .service {
    padding-bottom: 80px;
  }


  .service_contents:first-of-type {
    margin-top: 20px;
  }

  .service_contents {
    margin-top: 184px;
    background-image: url(../images/bg01_sp@2x.png);
    background-size: contain;
    padding: 20px 0 118px 0;
    margin-bottom: 120px;
  }

  .service_contents_2 {
    margin-top: 184px;
    background-image: url(../images/bg02_sp@2x.png);
    background-size: contain;
    padding: 20px 0 118px 0;
    margin-bottom: 120px;
  }



  .number {
    top: -54px;
    left: 20px;
    font-size: 8.4rem;
  }

  .number_2 {
    top: -54px;
    right: 20px;
    font-size: 8.4rem;
  }

  .flow_text {
    position: absolute;
    top: 260px;
    right: 0;
    width: 94%;
    box-sizing: border-box;
    margin-left: 0px;
    margin-top: 0px;
  }

  .flow_text_2 {
    position: absolute;
    top: 260px;
    left: 0;
    width: 94%;
    box-sizing: border-box;
    margin-left: 0px;
    margin-top: 0px;
  }

  /* ---------

///サービス

-----------*/


  /* ---------

トップビュー

-----------*/


  .topview {
    height: 580px;
  }

  /* ---------

///トップビュー

-----------*/

  /* ---------

お知らせ

-----------*/

  .news_all {
    text-align: left;
    margin-left: 200px;
  }

  .news_all {
    text-align: left;
    margin-left: 260px;
  }

  .news_btn::before {
    width: 88px;
    right: -32px;
    top: 127%;
  }

  .news_btn::after {
    right: -30px;
  }


  /* ---------

///お知らせ

-----------*/

  /* ---------

会社概要

-----------*/

  .company_info_inner {
    width: 90%;
    margin: 0 auto 154px;
  }

  .info_title {
    width: 22%;
  }

  .greeting {
    width: 90%;
    margin: 0 auto;
  }

  /* ---------

///会社概要

-----------*/
  /* ---------

お問い合わせ

-----------*/

  .contact_inner {
    width: 90%;
  }

  .form_item {
    display: block;
  }

  .form_title {
    text-align: left;
  }

  .form_detail {
    width: 340px;
    margin-left: 0;
  }

  .form_text_detail {
    width: 340px;
    margin-left: 0px;
  }

  .submit_btn {
    padding: 20px 0px;
  }

  /* ---------

 ///お問い合わせ

-----------*/

  /* ----------

下層

-------------*/

  .sp_under_header {
    width: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 50;
    width: 100%;
    padding: 12px 24px;

  }

  .under_logo_width {
    width: 88px;
  }


  .under_news_inner {
    width: 90%;
    display: block;
  }

  .under_section_header {
    padding-top: 96px;
    width: 90%;
    margin: 0 auto 56px;
  }

  .under_section_body {
    padding-bottom: 36px;
  }

  .under_news_item {
    display: block;
  }

  .under_news_item span {
    display: block;
    margin-left: 0px;
    margin-top: 0px;
  }

  .side_content {
    padding-left: 0px;
    margin-left: 0px;
    border-left: solid 0px #707070;
    border-top: solid 1px #707070;
    padding-top: 28px;
    width: 100%;
  }

  .footer_nav {
    margin-bottom: 40px;
  }

  .footer_list {
    display: block;
    justify-content: space-between;
    margin-bottom: 96px;
    width: 100px;
    margin: 0 auto;
    text-align: center;
  }

  .footer_list li {
    margin-bottom: 20px;
  }


  .footer_bg {
    padding-top: 34px;
    padding-bottom: 80px;
  }

  .under_news_all {
    margin-bottom: 40px;
  }


  /* ----------

///下層

-------------*/



}

@media screen and (min-width:768px) and (max-width:1024px) {
  /* タブレット向け */

}

@media screen and (min-width:1024px) {
  /* PC向け */

}