@charset "UTF-8";

/*----------
   Common
----------*/
html{
    font-size: 62.5%;
}
body{
    color: #282828;
    font-size: 1.6rem;
    line-height: 1.8;
    font-family: gothic;
}
img{
    max-width: 100%;
    height: auto;
}
section{
    padding: 40px 0 60px;
}
.all_wrap{
    overflow: hidden;
}
a:hover {
    opacity: inherit;
}
/* .inner{
    padding: 0 4%;
} */

/* top */
.sec-top {
    background-image: url(../imges/mv-example.png);
    width: 100%;
    height: 50vh;
    background-repeat: no-repeat;
    position: relative;
    top: 100px;
    background-size: cover;
}
.sec-top_mv {
    background-color: black;
    opacity: 20%;
    border: solid 3px #fff;
    width: 90%;
    height: 100%;
    margin: 0 auto;
    position: relative;
}
.sec-top_logo {
    width:80%;
}
.sec-top_logo h2 {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    color: #fff;
    top: 47%;
}
.sec-top_logo h2::after {
    border-bottom: solid 3px #fff;
}
.sec-top_logo img {
    position: absolute;
    top: 150px;
     left: 0;
     right: 0;
     bottom: 0;
     margin: auto;
}
.sec-top_asirai {
    position: absolute;
    top: 0px;
}
.sec-top_yama{
    position: absolute;
    bottom: 0px;
    right: 0px;
}
.sec-top_contact{
    position: absolute;
    top: 68%;
    left: 6%;
}
/* floting-button */
.floating {
	position: fixed;
	right: 8px;
	bottom: 8px;
	display: none;
}
.floating a {
	display: block;
	padding: 10px;
	text-decoration: none;
}
.floating a:hover {
	opacity: 1;
}
.sec-top-toi {
    background-image: url(../imges/mv-work2.png);
    width: 100%;
    height: 50vh;
    background-repeat: no-repeat;
    position: relative;
    top: 100px;
    background-size: cover;
}
@media screen and (max-width: 1370px){
    .sec-top {
        top: 100px;
      }
    }
@media screen and (max-width: 767px){
.sec-top {
    background-image: url(../imges/mv-example-sp.png);
    transform: translateY(-30px);
    background-size: cover;
    top: 100px;
  }
  .sec-top_asirai {
    width: 70%;
    position: absolute;
    top: 30px;
}
.sec-top_yama{
    width: 30%;
    position: absolute;
}
.sec-top_contact{
    display: none;
}
 .sec-top_mv {
    transform: translateY(20px);
    max-width: 90%;
    height: 100%;
 }
 .sec-top-toi {
    background-image: url(../imges/mv-work2-sp.png);
    transform: translateY(-30px);
    background-size: cover;
    top: 100px;
}
}
@media screen and (max-width: 480px){
    .sec-top {
        top: 40px;
    }
    .sec-top_asirai {
        height: 43px;
    }
    .sec-top_logo img {
        width: 30%;
    }
    .sec-top-toi {
    top: 40px;
    }
  }

/* mv */
.works_mv{
    background-image: url(../imges/example_mv_sp.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-bottom: 56.4%;
    width: 100%;
    position: relative;
}
.works_mv .mv_ttl{
    font-size: 2.2rem;
    color: #fff;
    position:absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    display: block;
}
.mv_ttl h2{
    text-align: center;
    position: relative;
}
.mv_ttl h2::after{
    position:absolute;
    content: "";
    background-color: #fff;
    height: 3px;
    bottom: -5px;
    width: 40px;
    left: calc(50% - 20px);
}
.mv_ttl span{
    font-family: 'Nothing You Could Do', cursive;
    font-size: 1.6rem;
    margin: 5px 0 0 0;
    display: block;
    text-align: center;
}
.job_example{
    padding: 50px 0;
    margin-top: 0px;
}
.job_description {
    margin: 80px 0;

}
.consultation{
    position: relative;
}
.consultation::before,.consultation::after{
    position:absolute;
    content: "";
    background-image: url(../imges/kawara_illust.png);
    display: inline-block;
    width: 160px;
    height: 50px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 5%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.consultation::after{
    top: 105%;
}
.consultation p{
    text-align: center;
    padding: 40px 0;
    font-weight: 600;
}
.content{
    position: relative;
    text-align: center;
    max-width: 350px;
    margin: 0 auto;
    margin-top: 30px;
}
.content p{
    border:#7c8a97 3px solid ;
    padding: 20px 40px;
    display: inline-block;
    font-weight: 600;
    background-color: #fff;
}
.content::after{
    position:absolute;
    content: "";
    background:#7c8a97;
    opacity: 0.2;
    width: 300px;
    height: 84px;
    z-index: -1;
    top: 30px;
    right: 10px;
}
.content span{
    display: block;
    font-weight: 600;
    padding: 20px 4%;
    font-size: 1.4rem;
}
/* work_explanation  */
.work_explanation{
    position: relative;
    background: #f2f2f2;
    text-align:center;
}
.work_explanation::before{
    position:absolute;
    content: "";
    background-image: url(../imges/naname_g.png);
    display: inline-block;
    width: 160px;
    height: 50px;
    background-size: contain;
    background-repeat: no-repeat;
    top: -8px;
    left: 0;
}
.work_explanation .inner{
    padding: 0 4%;
}
/* .job_description{
    padding-bottom: 10px;
} */
.diamond{
    width: 10px;
    height: 10px;
    background: #5a7b79;
    transform: rotate(45deg);
    display: inline-block;
    margin-right: 10px;
}
.work_explanation p{
    font-weight: 600;
    padding-bottom: 100px;
}
.work_imgbox p{
    text-align: left;
    font-size: 1.4rem;
}
.work_imgbox p:last-of-type{
    font-weight: normal;
}
.work_imgbox p span{
    font-size: 1.6rem;
}
.work_imgbox p span:last-of-type{
    font-size: 1.4rem;
    font-weight: 600;
}




/*tabの形状*/
.tab{
	display: flex;
	flex-wrap: wrap;
    max-width: 1040px;
    margin: 0 auto;
    list-style: none;
}
.tab li a{
    font-size: 150%;
	display: block;
	background:#fff;
	margin:0 2px;
	padding:10px 20px;
    color: #282828;
}
/*liにactiveクラスがついた時の形状*/
.tab li.active a{
	background:#f2f2f2;
}


/*エリアの表示非表示と形状*/
.area {
	display: none;/*はじめは非表示*/
	opacity: 0;/*透過0*/
	background: #f2f2f2;
	padding:50px 20px;
}

/*areaにis-activeというクラスがついた時の形状*/
.area.is-active {
    display: block;/*表示*/
    animation-name: displayAnime;/*ふわっと表示させるためのアニメーション*/
    animation-duration: 2s;
    animation-fill-mode: forwards;
}

@keyframes displayAnime{
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}


.works-price {
    text-align: center;
}
.works-price h2 {
    font-size: 2.4rem;
    margin-top: 80px;
    margin-bottom: 100px;
}
.works-price h2::after {
    display: block;
    content: "";
    border-bottom: solid 3px #333;
    width: 50px;
    margin: 0 auto;
    padding-top: 20px;
}
.works-price ul {
    max-width: 1040px;
    margin: 0 auto;
}
.works-price ul li {
    list-style: none;
}
.price-flex {
    display: flex;
}
.works-price ul li span {
    display: block;
    text-align: center;
}
.works-price ul li {
    margin-bottom: 80px;
}
.works-price ul li:first-child {
    margin-right: 40px;
}
.works-price2 h2 {
    font-size: 2.4rem;
    margin-top: 80px;
    margin-bottom: 100px;
}
.works-price2 h2::after {
    display: block;
    content: "";
    border-bottom: solid 3px #333;
    width: 50px;
    margin: 0 auto;
    padding-top: 20px;
}
.works-price2 ul li {
  margin-bottom: 80px;
  list-style: none;
}
.toi-span {
  display: block;
}
.opacity {
    opacity: 0;
}
@media (max-width:768px) {
    .price-flex {
        display: block;
    }
    .works-price ul li:first-child {
        margin-right: 0px;
    }
    .opacity {
        display: none;
    }
}
@media (max-width:480px) {
    .tab li a {
        font-size: 100%;
    }
    .work_explanation p {
        text-align: left;
    }
}

@media (min-width:480px){
    .job_example {
        margin-top: 70px;
        padding: 40px 0px;
    }
}
/* PC */
@media (min-width:769px){
    .works_mv{
        background-image: url(../imges/example_mv.png);
        padding-bottom: 33.1%;
    }
    .works_mv .mv_ttl,.mv_ttl span{
        font-size: 4.2rem;
    }
    .job_example{
        padding: 60px 0;
        margin-top: 0px;
    }
    .consultation{
        margin-bottom: 30px;
        margin-top: 140px;
    }
    .consultation::before,.consultation::after{
        width: 240px;
        height: 80px;
        top: 3%;
    }
    .consultation::after{
        top: 105%;
    }
    .consultation p{
        font-size: 3.0rem;
    }
    .content{
        max-width: 1100px;
    }
    .content p{
        font-size: 3.6rem;
        padding:40px 80px;
        line-height: 1.4;
    }
    .content::after{
        width: 640px;
        height: 168px;
        top: 40px;
        right: 20px;
    }
    .content span{
        padding: 40px 4%;
    }
    .work_explanation::before{
        width: 320px;
    }
    .work_explanation .inner{
        max-width: 1100px;
        margin: 0 auto;
    }
    .job_description h2{
        font-size: 2.6rem;
    }
    .diamond{
        width: 20px;
        height: 20px;
    }
    .work_explanation p{
        font-size: 1.6rem;
        padding-bottom: 90px;
    }
    .work_imgbox p{
        font-size: 1.6rem;
        padding-bottom: 15px;
    }
}
@media(min-width:1100px){
    .content::after{
        right: 100px;
    }
}