@charset "utf-8";

html {
  scroll-behavior: smooth;
}

/* Loading背景画面設定　*/
#splash {
  /*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 999;
  background: #333;
  text-align: center;
  color: #fff;
}

/* Loading画像中央配置　*/
#splash_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#splash_logo img {
  width: 100px;
}

/* fadeUpをするアイコンの動き */
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

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

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

@media(min-width:1040px) {
  #splash_logo img {
    width: 260px;
  }
}

.top {
  background-image: url("../images/main.png");
  background-position: 50% 60%;
  background-size: cover;
  background-repeat: no-repeat;
  height: 320px;
  position: relative;
}

.intro1,
.intro2 {
  color: #FFF;
  font-weight: 600;
}

.intro1 {
  font-size: 1.1rem;
  padding: 20px 0;
  text-shadow: 2px 2px 1px #819752;
}

.intro2 {
  font-size: 3.0rem;
  text-shadow: 2px 2px 1px #819752;
}

@media(min-width:1040px) {
  .top {
    background-image: url("../images/test.png");
    height: calc(100vh - 84px);
  }

  .intro1 {
    font-size: 2.4rem;
    padding: 70px 0 70px;
    text-shadow: 3px 3px 1px #819752;
  }

  .intro2 {
    font-size: 4.8rem;
    text-shadow: 3px 3px 1px #819752;
  }
}

.about {
  margin: 20px;
}

.about img {
  width: 50px;
}

.kazari1 {
  text-align: right;
}

.kazari2 {
  text-align: left;
}

.top_title {
  margin: 15px 0;
  font-size: 3.6rem;
  font-family: "valion";
  font-weight: 200;
  letter-spacing: 0.05em;
}

.subtitle {
  font-size: 1.2rem;
}

.title_description {
  margin: 40px auto;
}

.title_description_paragraph {
  font-size: 1.2rem;
  line-height: 2.0rem;
  text-align: center;
  font-weight: 400;
}

.about_button {
  display: flex;
  justify-content: center;
  align-items:center;
  width: 140px;
  height:45px;
  margin: 40px auto 0;
  border: 1px solid #333;
  border-radius: 50px;
  color: #333;
  text-decoration: none;
  font-size: 1.2rem;
}

.about_button i::before {
  padding-left: 15px;
}

.about_button:hover {
  background-color: #333;
  color: #FFF;
  opacity: 1.0;
}

@media(min-width:1040px) {
  .about {
    margin: 50px 70px;
  }

  .about img {
    width: 100px;
  }

  .about_main {
    display: flex;
  }

  .title_box {
    margin: auto;
    flex: 1;
  }

  .top_title {
    font-size: 6.4rem;
    margin-bottom: 40px;
  }

  .subtitle {
    font-size: 2.4rem;
  }

  .title_description {
    flex: 1;
    margin: 60px auto 0;
  }

  .title_description_paragraph {
    font-size: 2.0rem;
    line-height: 3.0rem;
  }

  .about_button {
    margin: 60px auto 0;
    width:240px;
    height:80px;
    border: 2px solid #333;
    font-size: 2.2rem;
  }

  .about_button i::before {
    padding-left: 20px;
  }
}

.service {
  background-color: #f2f2f2;
}
.service img {
  width: 50px;
}

.top_title2 {
  margin: 80px 0 10px 0;
  font-size: 4.0rem;
  font-family: "valion";
  font-weight: 200;
  letter-spacing: 0.05em;
}

.communication_image img {
  margin-top: 50px;
  width: 100%;
  max-width: 550px;
}

.kazari3 img {
  display: none;
}

.communication_description {
  max-width: 600px;
  margin:0 auto;
}

.communication_description h3 {
  margin: 30px 0 20px 30px;
  font-size: 2.6rem;
  text-align: left;
}

.communication_description p {
  margin-left: 30px;
  font-size: 1.4rem;
  line-height: 2.0rem;
  text-align: left;
  font-weight: 400;
}



@media(min-width:1040px) {
  .service img {
  width: 120px;
}
  .top_title2 {
    font-size: 8.0rem;
    margin: 100px 0 60px 0;
  }

  .communication_head {
    display: flex;
    justify-content: flex-start;
    margin-top: 100px;
  }

  .communication_image {
    flex-grow: 1;
    text-align: left;
  }

  .communication_image img {
    height: 460px;
    width: 100%;
    max-width: 770px;
    margin-top: 0px;
  }

  .communication_description {
    position: relative;
    flex-grow: 1;
  }

  .kazari3 img {
    display: block;
    position: absolute;
    top: 0;
    right: 70px;
    width: 100px;
  }

  .communication_description h3 {
    margin: 120px 0px 60px 80px;
    font-size: 4.6rem;
  }

  .communication_description p {
    margin-left: 80px;
    font-size: 2.0rem;
    line-height: 3.0rem;
  }
}

.communication_contents {
  padding: 0 50px 0;
}

.phone,
.consul,
.staff {
  margin: 70px auto 60px;
  padding: 40px 50px 40px 50px;
  background-color: #FFF;
  border-radius: 70px;
  box-shadow: 20px 20px 10px #d1dcba;
  max-width: 280px;
}

.phone img,
.consul img,
.staff img {
  max-width: 260px;
  width: 100%;
}

.phone h4,
.consul h4,
.staff h4 {
  text-align: left;
  font-size: 1.8rem;
  margin: 20px auto 15px;
}

.phone p,
.consul p,
.staff p {
  text-align: left;
  font-size: 1.2rem;
  line-height: 1.8rem;
  font-weight: 400;
}

.communication_contents {
  margin-bottom: 130px;
  transition: 1.0s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
}

.communication_contents.on {
  transform: translateY(0);
  opacity: 1.0;
}

@media(min-width:1040px) {
  .communication_contents {
    display: flex;
    margin: 100px 70px 200px;
  }

  .phone,
  .consul,
  .staff {
    flex: 1;
    max-width: 340px;
    box-sizing: border-box;
    padding: 50px 50px 50px 50px;
    margin: 50px auto 0;
  }

  .phone img,
  .consul img,
  .staff img {
    max-width: 260px;
  }

  .phone h4,
  .consul h4,
  .staff h4 {
    font-size: 2.4rem;
    line-height: 3.4rem;
    margin-top: 20px;
  }

  .phone p,
  .consul p,
  .staff p {
    font-size: 1.6rem;
    line-height: 2.6rem;
    font-weight: 400;
  }
}

.digital_image img {
  margin-top: 50px;
  width: 100%;
  max-width: 550px;
}

.kazari4 img {
  display: none;
}
.digital_description {
  max-width: 600px;
  margin:0 auto;
}

.digital_description h3 {
  margin: 30px 0 20px 30px;
  font-size: 2.6rem;
  text-align: left;
}

.digital_description p {
  margin-left: 30px;
  font-size: 1.4rem;
  line-height: 2.0rem;
  text-align: left;
  font-weight: 400;
}

@media(min-width:1040px) {
  .digital_head {
    display: flex;
    flex-flow: row-reverse;
    justify-content: flex-end;
    margin-top: 0px;
  }

  .digital_image {
    flex-grow: 1;
    text-align: right;
  }

  .digital_image img {
    height: 460px;
    width: 100%;
    max-width: 770px;
    margin-top: 0px;
  }

  .digital_description {
    position: relative;
    flex-grow: 1;
  }

  .kazari4 img {
    display: block;
    position: absolute;
    width: 100px;
    top: 0;
    left: 70px;
  }

  .digital_description h3 {
    margin: 120px 80px 30px 170px;
    font-size: 4.6rem;
    line-height: 6.0rem;
  }

  .digital_description p {
    margin-left: 170px;
    font-size: 2.0rem;
    line-height: 3.0rem;
  }
}

.movie,
.photo,
.sns {
  margin: 70px auto 60px;
  padding: 40px 50px 40px 50px;
  background-color: #FFF;
  border-radius: 70px;
  box-shadow: 20px 20px 10px #b5cfde;
  max-width: 280px;
}

.movie img,
.photo img,
.sns img {
  max-width: 260px;
  width: 100%;
}

.movie h4,
.photo h4,
.sns h4 {
  text-align: left;
  font-size: 1.8rem;
  margin: 20px auto 15px;
}

.movie p,
.photo p,
.sns p {
  text-align: left;
  font-size: 1.2rem;
  line-height: 1.8rem;
  font-weight: 400;
}

.digital {
  margin-bottom: 100px;
}

.digital_contents {
  transition: 1.0s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
  padding: 0 50px 0;
}

.digital_contents.on {
  transform: translateY(0);
  opacity: 1.0;
}

@media(min-width:1040px) {
  .digital_contents {
    display: flex;
    margin: 100px 70px 150px;
  }

  .movie,
  .photo,
  .sns {
    flex: 1;
    max-width: 340px;
    box-sizing: border-box;
    padding: 50px 50px 50px 50px;
    margin: 50px auto 0;
  }

  .movie img,
  .photo img,
  .sns img {
    max-width: 260px;
  }

  .movie h4,
  .photo h4,
  .sns h4 {
    font-size: 2.4rem;
    line-height: 3.4rem;
    margin-top: 20px;
  }

  .movie p,
  .photo p,
  .sns p {
    font-size: 1.6rem;
    line-height: 2.6rem;
    font-weight: 400;
  }
}

.works {
  padding: 0 30px 100px;
}

.works h3 {
  font-size: 3.6rem;
  font-family: "valion";
  margin-bottom: 10px;
  font-weight: 200;
  letter-spacing: 0.05em;
}

.works_subtitle{
  font-size:1.2rem;
}

.works_contents {
  margin: 30px auto 0px;
  padding: 60px 30px;
  background-color: #FFF;
  border-radius: 40px;
  box-shadow: 20px 20px 10px #b5cfde;
  transition: 1.0s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
  max-width: 500px;
}

.works_contents.on {
  transform: translateY(0);
  opacity: 1.0;
}

.movie1 {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.movie1 iframe {
  width: 100%;
  height: 100%;
  margin-bottom: 10px;
}

.movie1 p {
  font-size: 1.2rem;
  font-weight: 500;
}

.movie2 {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.movie2 iframe {
  width: 100%;
  height: 100%;
  margin: 60px 0 10px 0;
}

.movie2 {
  margin-bottom: 40px;
}

.movie2 p {
  font-size: 1.2rem;
  font-weight: 500;
}

.movie_comment p {
  font-size: 1.2rem;
  line-height: 1.8rem;
  font-weight: 400;
}

@media(min-width:1040px) {
  .works {
    padding: 0 100px 200px;
  }

  .works h3 {
    font-size: 4.8rem;
    margin-bottom: 10px;
    display: inline-block;
    line-height: 6.5rem;
  }

.works_subtitle{
  font-size:1.8rem;
}

  .works_contents {
    margin-top: 70px;
    padding: 80px 60px;
    max-width: 1200px;
  }

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

  .movie1 {
    flex-grow: 1;
    margin-right: 20px;
  }

  .movie1 iframe {
    margin: 0px 0 20px 0;
  }

  .movie1 p {
    font-size: 1.8rem;
  }

  .movie2 iframe {
    margin: 0px 0 20px 0;
  }

  .movie2 {
    flex-grow: 1;
    margin-left: 20px;
    margin-bottom: 0px;
  }

  .movie2 p {
    font-size: 1.8rem;
  }

  .movie_comment p {
    font-size: 1.8rem;
    line-height: 2.7rem;
    margin-top: 40px;
  }
}

.recruit {
  padding-bottom: 80px;
}

.recruit img {
  width: 50px;
}

.top_title3 {
  margin: 80px 0 15px;
  font-size: 3.6rem;
  font-family: "valion";
  font-weight: 200;
  letter-spacing: 0.05em;
}

.recruit_contents {
  display: block;
  margin-top: 50px;
}

.recruit_image img {
  width: 100%;
  max-width: 600px;
}

.recruit_description {
  padding: 60px 70px 0;
}

.recruit_description img {
  display: none;
}

.recruit_description_paragraph {
  text-align: center;
  font-size: 1.2rem;
  font-weight: 400;
}

.point {
  font-size: 1.6rem;
  font-weight: 600;
}

.recruit_button {
  display: flex;
  justify-content: center;
  align-items:center;
  width: 140px;
  height:45px;
  margin: 30px auto 0;
  border: 1px solid #333;
  border-radius: 50px;
  color: #333;
  text-decoration: none;
  font-size: 1.2rem;
}

.recruit_button i::before {
  padding-left: 15px;
}

.recruit_button:hover {
  background-color: #333;
  color: #FFF;
  opacity: 1.0;
}

@media(min-width:1040px) {
  .recruit {
    padding-bottom: 150px;
  }

  .recruit img {
    width: 120px;
  }

  .top_title3 {
    margin: 100px 0 40px;
    font-size: 6.4rem;
    font-weight: 200;
    letter-spacing: 0.05em;
  }

  .recruit_contents {
    display: flex;
    margin: 70px 70px 0 0;
  }

  .recruit_image {
    width: 50%;
    align-items: center;
  }

  .recruit_image img {
    width: 100%;
    max-width: 720px;
    height: 460px;
    object-fit: cover;
  }

  .recruit_description {
    width: 50%;
    padding: 0;
    margin-bottom: 60px;
  }

  .recruit_description img {
    display: block;
    margin: 0 0 0 auto;
    width: 100px;
  }

  .recruit_description_paragraph {
    display: inline-block;
    align-items: center;
    margin-top: 60px;
    text-align: left;
    font-size: 2.4rem;
    line-height: 5.0rem;
    font-weight: 400;
  }

  .point {
    font-size: 3.2rem;
    font-weight: 600;
  }

  .recruit_button {
    margin: 60px auto 0;
    width:240px;
    height:80px;
    border: 2px solid #333;
    font-size: 2.2rem;
  }

  .recruit_button i::before {
    padding-left: 20px;
  }
}

.contact {
  background-color: #f2f2f2;
  padding: 0 30px 70px 30px;
}

.contact img {
  width: 50px;
}

.contact p {
  font-size: 1.2rem;
  margin-top: 50px;
  font-weight: 400;
  line-height: 2.0rem;
}

.contact_button {
  display: flex;
  margin: 50px auto 0;
  justify-content: center;
  align-items: center;
  width: 200px;
  height:45px;
  border-radius: 25px;
  border: solid 1px #333;
  background-color: #FFF;
  color: #333;
  text-decoration: none;
  font-size: 1.2rem;
}

.contact_button:hover {
  background-color: #333;
  color: #FFF;
  opacity: 1.0;
}

.contact_button i::before {
  padding-left: 15px;
}

@media(min-width:1040px) {
  .contact {
    padding: 0px 70px 150px;
  }

  .contact img {
    width: 120px;
  }

  .contact p {
    font-size: 1.8rem;
    margin-top: 70px;
  }

  .contact_button {
    margin-top: 70px;
    width: 340px;
    height:80px;
    font-size: 2.0rem;
    border-radius: 50px;
    border: solid 2px #333;
  }

  .contact_button i::before {
    padding-left: 20px;
  }
}