@charset "UTF-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond&display=swap');




/*■■■共通：基本■■■
---------------------------------------------------------------*/

html{
    font-size: 100%;
    scroll-behavior: smooth;
}

body{
    font-family: "Noto Sans JP", sans-serif;
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.1em;
    color: #4d4d4d;
    margin: 0;
}
div{
    box-sizing: border-box;
}
.wrapper{
    max-width: auto;
    margin: auto;
    padding: 5% 4%;
}
.flex{
    display: flex;
    justify-content: center;
}

a{
    color: #4d4d4d;
    text-decoration: none;
}
a:hover{
    color: #00a3af;
    transition: ease-in-out .6s;
    text-shadow: 1px 1px 6px rgba(158, 214, 216, 1);
}
img{
    /* SPでの長押し禁止 */
    -webkit-touch-callout:none;
    -webkit-user-select:none;
    -moz-touch-callout:none;
    -moz-user-select:none;
    user-select:none;
}



.more{
    text-align: center;
}
.more a{
    border-bottom: 1px #4d4d4d solid;
    width: 100px;
}
.more a:hover{
    border-bottom: 1px #00a3af dotted;
    width: 130px;
    transition: ease-in-out .6s;
}

.fadein{
    animation-name: fadeIn;
    animation-duration:3s;
    animation-fill-mode:forwards;
    opacity:0;
    }
@keyframes fadeIn{
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }


/*■■■jQuery■■■
---------------------------------------------------------------*/
  /*スクロール前*/
.js-fadeup{
    opacity: 0;
    visibility: hidden;
    transform: translateY(80px);
    transition: opacity 1.5s,visibility 1.5s, transform 1.5s;
}
  /*スクロール後*/
.js-scroll{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.js-fadein{
    display: none;
}




/*■■■画像■■■
---------------------------------------------------------------*/
img{
    max-width: auto;
}
.icon{
    width: 20px;
    height: 20px;
}

.flex .img{
    width: 150px;
    height: 150px;
}


/*■■■見出し■■■
---------------------------------------------------------------*/
h1{
    font-family: "Inter", sans-serif;
    font-size: 18px;
    font-weight: 400;
    color: #4d4d4d;
}
.menutitle-box h1{
    color: #9ed6d8;
    width: 900px;
    line-height: 100px;
    font-size: 38px;
    text-align: left;
    letter-spacing: 0.2em;
    padding: 0 4%;
}

.page-title{
    font-size: 64px;
    font-weight: 400;
    line-height: 1.3;
    text-transform: none;
}

h2{
    color: #4d4d4d;
    font-weight: 400;
}
h3{
    text-align: center;
}
.menutitle{
    color: #4d4d4d;
    font-size: 38px;
    font-weight: 400;
    line-height: 1.3;
    text-align: center;
}
.sub-menutitle{
    font-size: 13px;
    text-align: center;
}

.text-title{
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
}

.contents{
    text-align: left;
}

/*■■■ボックス■■■
---------------------------------------------------------------*/
.menutitle-box{
    height: 100px;
    margin: 80px auto 0px auto;
    width: 1000px;
}

/*■■■装飾ライン■■■
---------------------------------------------------------------*/
hr{
    border: 1px #d3d3d3 solid;
}
.dotted{
    background-image: linear-gradient(to right,#9ed6d8 2px, transparent 3px);
    background-size: 10px 3px;
    background-repeat: repeat-x;
    background-position: bottom right;
}
.dotted2{
    border-bottom: dotted 1px #00a3af;
    color: #9ed6d8;
}


/*■■■ヘッダー■■■
---------------------------------------------------------------*/
.page-header{
    max-width: auto;
    margin: auto;
    padding: 0 4%;
}
.hamburger-menu{
    display: none;
}
header{
    position: fixed;
    height: 60px;
    top: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    border-bottom: 1px dotted #4d4d4d;
    z-index: 1000;
}

header h1{
    margin-top: 16px;
}
.main-nav{
    display: flex;
    font-size: 14px;
    list-style: none;
    text-transform: none;
    margin-top: 21px;
}
.main-nav li{
    margin-left: 20px;
}

header a{
    border-bottom: 1px #fff solid;
}
header a:hover{
    border-bottom: 1px #00a3af dotted;
    transition: ease-in-out .6s;
}

.page-header{
    display: flex;
    justify-content: space-between;
}


/*■■■HOME■■■
---------------------------------------------------------------*/
#home{
    background-image: url(../img/main_illust.jpg);
    background-attachment: fixed;
    background-position: center top;
    background-repeat: no-repeat;
    background-color: rgba(255,255,255,0.25);
    background-blend-mode: lighten;
    min-height: 700px;
    width: auto;
    margin: 0;
    padding: 0;
}

.main-illust{
    background-size: cover;
}

#home .contents{
    padding-top: 320px;
    margin-top: 0;
}
#home .page-title{
    font-family: "Cormorant Garamond";
    font-size: 62px;
    color: #4d4d4d;
    text-align: center;
}

.contents p{
    font-size: 14px;
}


/*■■■ABOUT■■■
---------------------------------------------------------------*/
#about .sub-menutitle{
    color: #9ed6d8;
}
.about{
    background-color: #f9f9f9;
    min-height: 450px;
}
.about .text2{
    display: none;
}
.about .flex{
    width: 800px;
    margin: 30px auto;
}
.flex-left{
    width: 450px;
    margin-top: 40px;
}
.about .more{
    text-align: center;
    margin-top: 30px;
}
.circle-img1{
    display: none;
    background-color: #fff;
    background-size: 100%;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    border: solid 1px #f3f3f3;
    background-image: url("../img/icon_profile.png");
}
.circle-img2{
    background-color: #fff;
    background-size: 100%;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    border: solid 1px #f3f3f3;
    background-image: url("../img/icon_profile.png");
}
/*□□□ABOUT-PAGE□□□
---------------------------------------------------------------*/
.profile{
    min-height: 600px;
}
.profile h2,.profile .sub-menutitle{
    text-align: left;
}
.profile h2{
    font-size: 28px;
    padding-top: 0px;
    letter-spacing: 0.5em;
}
.profile img{
    margin: 5px;
}
.profile .text{
    margin: 100px auto;
    text-align: center;
    color: #686868;
    font-size: 12px;
    line-height: 30px;
    letter-spacing: 0.2em;
}
.profile .text2{
    display: none;
}
.profile .sub-menutitle{
    letter-spacing: 1em;
    color: #9ed6d8;
}
.profile .flex{
    margin: 6% auto;
    width: 900px;
}
.profile .flex-left{
    width: 400px;
    margin: 0;
}
.profile .text-title{
    margin-top: 20px;
    font-weight: 500;
}
.profile .text-title2{
    display: none;
}
.profile .circle-img{
    background-color: #f3f3f3;
    background-size: 100%;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background-image: url("../img/icon_profile.png");
}
.profile .circle-img2{
    display: none;
    background-color: #f3f3f3;
    background-size: 100%;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background-image: url("../img/icon_profile.png");
}
/*------------------------------------*/
.profile2{
    background-color: #f9f9f9;
    height: 550px;
}
.profile2 div{
    width: 800px;
    margin: 0 auto;
}
.profile-contents{
    width: 700px;
    height: 150px;padding-top: 40px;
}
.profile-contents div{
    width: 350px;
    margin: auto;
}
.profile-contents .flex{
    height: 100px;
    margin: 0 auto;
}
.likes{
    margin: auto 0;
}
.likes .text{
    padding-bottom: 10px;
}
.profile-contents .text-title{
    margin: 0;
}
.profile-contents .text{
    font-size: 13px;
}

.profile2 h2{
    text-align: left;
    font-size: 26px;
    font-weight: 600;
    letter-spacing: 0.2em;
}
.history{
    width: 800px;
    margin: 20px 0;
}
.history .text{
    margin: 30px 0;
}
.profile2 img{
    width: 100px;
    height: 100px;
}
/*------------------------------------*/
.skill{
    background-color: #fff;
    min-height: 850px;
    padding: 0 4%;
}

.skill hr{
    margin: 0 auto;
    width: 800px;
}
.skill-title{
    position: relative;
    border: #9ed6d8 1px solid;
    height: 55px;
    width: 230px;
}
.skill .text-title{
    color: #686868;
    font-weight: 500;
    height: 55px;
    max-width: 300px;
    margin: 0;
    text-align: center;
    line-height: 55px;
}
.skill .text{
    font-size: 13px;
    width: 300px;
}
.skill-webdesign,.skill-illust{
    width: 650px;
    margin: 6% auto;
}
.skill .flex{
    justify-content: space-between;
}
.skill .more{
    width: 100px;
    padding-left: 85%;
    padding-top: 3%;
}
.skill .more a{
    text-align: left;
    padding-left: 15px;
}
/*------------------------------------*/
.skill-tool{
    width: 600px;
    margin: 6% auto;
}
.tool1,.tool2{
    height: 80px;
    justify-content: space-between;
}
.skill-tool .text-title{
    font-weight: 600;
    justify-content: center;
    align-items: center;
    width: 300px;
    height: 50px;
}
.skill-tool .text{
    margin: 15px;
    height: 50px;
}
.border .text-title{
    display: flex;
    align-items: center;
}
.border .text-title::after{
    height: 1px;
    flex-grow: 1;
    width: 50px;
    background-color: #686868;
    content: "";
    margin: 15px;
}




/*■■■WORKS■■■
---------------------------------------------------------------*/
#works .sub-menutitle{
    color: #9ed6d8;
}
.works{
    background-color: #fff;
    min-height: 1500px;
}
.works-contents{
    width: 800px;
    margin: 10px auto;
}
.works h3{
    text-align: left;
    color: #4d4d4d;
    font-size: 23px;
    font-weight: 600;
    align-items: center;
    margin-top: 60px;
    margin-bottom: 30px;
}
.works .text-title{
    margin-bottom: -20px;
    position: relative;
    z-index: 2;
}

.works-website,.works-Illust,.works-design{
    margin: 3% auto;
}

.works-text{
    font-size: 13px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}
.works-text2{
    display: none;
    justify-content: space-between;
    margin-top: 15px;
}
.works figure{
    list-style: none;
    display: inline-block;
    width: 260px;
    height: 240px;
}
.works-sample img{
    object-fit: cover;
    position: absolute;
    z-index: 1;
    width: 250px;
    height: 230px;
    padding: 10px;
    border-radius: 30px 5px 30px 5px;
}

.works-text .more{
    position: absolute;
    left: 80%;
}

.works-text a{
    text-align: left;
    padding-left: 15px;
}

/*□□□WORKS□□□
---------------------------------------------------------------*/
.works-contents2{
    height: auto;
    width: 1100px;
}
.works-contents2 h2{
    text-align: left;
    font-size: 23px;
    font-weight: 600;
    padding: 0px 0 10px 0;
}
.works-contents2 .flex{
    width: 980px;
    margin: 0 auto;
    padding: 0;
}

.popup-image{
    margin: 20px auto;
    text-align: center;
    height: 520px;
    overflow-y: auto;
}
.popup-imageroll{
    margin: 20px auto;
    text-align: center;
    height: 520px;
    overflow-y: auto;
}
.popup-image img{
    width: 750px;
    height: auto;
    object-fit: cover;
    border: solid 1px #686868;
}
.popup-imageroll img{
    width: 750px;
    height: auto;
    object-fit: cover;
    border: solid 1px #686868;
}
.popup-texts{
    width: 750px;
    height: 100px;
    margin: auto;
}
.popup-title{
    font-weight: 600;
    font-size: 18px;
    padding: 0px 10px;
    text-align: left;
}
.popup-text{
    font-size: 13px;
    text-align: left;
    margin: 10px;
}

.thumbnail{
    cursor: pointer;
}
.thumbnail img{
    border: 1px solid #f8f8f8;
    border-radius: 30px 5px 30px 5px;
    object-fit: cover;
    width: 300px;
    margin: 0 10px;
}
  @media screen and (max-width: 700px){
    #pop-up:checked + .overlay {
      visibility: hidden;
      opacity: 0;
    }
  }

.md-overlay{
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .7;
    z-index: 9999;
  }
   
  .md-contents{
    display: none;
    position: fixed;
    top: 8%;
    left: 50%;
    width: 85%;
    height: auto;
    overflow: hidden;
    transform: translateX(-50%);
    z-index: 10000;
  }
  .popup-image img{
    pointer-events: none;
  }
  .md-inner{
    border-radius: 5px;
    padding: 24px 60px;
    background: #fff;
    height: auto;
  }
  .md-xmark{
    position: absolute;
    top: 34px;
    right: 30px;
    width: 30px;
    height: 22px;
    z-index: 9999;
    cursor: pointer;
  }
  .md-xmark span {
    height: auto;
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #333;
    border-radius: 4px;
    z-index: 15000;
  }
  .md-xmark:hover > span {
    background-color: #00a3af;
    background-blend-mode: normal ;
    transition: ease-in-out .6s;
  }
  .md-xmark span:nth-of-type(1) {
    top: 0;
    transform: translateY(20px) rotate(-45deg);
  }
  .md-xmark span:nth-of-type(2) {
    bottom: 0;
    transform: translateY(0px) rotate(45deg);
  }
  .spimg{
    display: none;
}





/*■■■order■■■
---------------------------------------------------------------*/
.order{
    background-color: #f9f9f9;
    min-height: 500px;
}
.order .flex{
    padding-left: 80px;
}

.order .more{
    text-align: center;
    margin-top: 2%;
}
.order img{
    width: auto;
    height: 230px;
}
.order .text{
    padding: 70px 0 0 60px;
    width: 430px;
    height: 220px;
}
.order hr{
    border: solid #4d4d4d 1px;
}

/*□□□order□□□
---------------------------------------------------------------*/
#order .sub-menutitle{
    color: #9ed6d8;
}
.orderline{
    height: 600px;
}
.orderline h2{
    width: 250px;
    text-align: center;
    font-weight: 600;
    font-size: 25px;
    border-bottom: dotted #00a3af 2px;
    margin: 0 auto;
}
.orderline .text-title2{
    font-weight: bold;
    padding-top: 8px;
}
.orderline .flex{
    margin: 50px auto 0 auto;
}
.orderline-menu .text-title{
    text-align: center;
    margin-top: 10px;
    font-size: 28px;
    font-weight: 500;
}
.orderline-menu .text-title2{
    border-top: #9ed6d8 solid 1px;
    text-align: center;
    font-size: 15px;
    padding: 15px auto;
}
.orderline-menu div{
    width: 250px;
    text-align: center;
}
.orderline-menu p{
    width: 180px;
    margin: auto;
}
.orderline .text{
    font-size: 13px;
    margin: 5px auto;
}
.orderline01{
    width: 250px;
    height: 350px;
    border-left: 2px solid #d3d3d3;
    border-right: 2px solid #d3d3d3;
}
.orderline02,.orderline03,.orderline04{
    width: 250px;
    height: 350px;
    border-right: 2px solid #d3d3d3;
}


.hearing{
    height: 500px;
    overflow: hidden;
}
.hearing-content h2{
    padding: 0;
    text-align: center;
    margin: 30px auto;
    width: 280px;
    font-weight: 600;
    font-size: 25px;
    border-bottom: dotted #00a3af 2px;
}
.hearing-content{
    height: 350px;
    width: 700px;
    border: #d3d3d3 solid 2px;
    border-radius: 15px;
    margin: auto;
}
.hearing-content ul{
    margin-top: 45px;
}
.hearing-content li{
    color: #4d4d4d;
    font-size: 16px;
    font-weight: 550;
    margin-top: 10px;
}
.hearing-content div{
    width: 400px;
    height: 350px;
    margin: auto;
}


.template{
    height: auto;
    max-height: 1500px;
    width: 900px;
    padding: 0;
}
.template h2{
    text-align: left;
    font-size: 23px;
    font-weight: 600;
    margin-top: 120px;
}
.template .text{
    margin-top: 15px;
}
.template li{
    margin-top: 10px;
}
.accordion-area section{
    background-color: #f9f9f9;
    border: #00a3af 1px solid;
}
.accordion-area > li{
    list-style: none;
    margin: 5px;
}
.template .template-title {
    text-align: left;
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 25px;
    transition: all .5s ease;
}

/*+-*/
.template-title::before,
.template-title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #00a3af; 
}
.template-title::before{
    top:50%;
    right: 4%;
    transform: rotate(0deg);
}
.template-title::after{    
    top:50%;
    right: 4%;
    transform: rotate(90deg);
}

/*　closeというクラスがついたら形状変化　*/
.template-title.close::before{
    transform: rotate(45deg);
  }
.template-title.close::after{
    transform: rotate(-45deg);
  }

/*アコーディオンで現れるエリア*/
.template-box {
    display: none;
    background: #f9f9f9;
    margin:0 3% 3% 3%;
    padding: 3% 3% 3% 8%;
}
.template-box li{
    font-size: 16px;
    font-weight: 600;
}



.charge{
    height: 450px;
    width: 900px;
    padding: 0;
}
.charge h2{
    text-align: left;
    font-size: 23px;
    font-weight: 600;
    margin-top: 120px;
}
.charge .text{
    margin-top: 15px;
}

table .th-none{
    background-color: #fff;
    width: 200px;
}
table th .th-menu{
    width: 150px;
}
table .th-menu2,.th-menu3{
    background-color: #fff;
    border: solid 1px #9ed6d8;
    width: 250px;
}
table{
    width: 900px;
    margin: 15px auto;
}
table th,table td{
    border: none;
}
table th{
    height: 50px;
    text-align: center;
    font-weight: normal;
    font-size: 0.8rem;
    color: #4d4d4d;
    background-color: #9ed6d8;
    padding: 10px 15px;
}
table td{
    font-size: 0.8rem;
    background-color: #f3f3f3;
    padding: 15px 15px;
}


.comission{
    height: 500px;
    width: 900px;
    padding: 0;
}
.comission h2{
    text-align: left;
    font-size: 23px;
    font-weight: 600;
    margin-top: 120px;
}
.comission .text{
    margin-top: 15px;
}

.comission .flex{
    margin-top: 30px;
}

.comission-menu{
    width: 200px;
    height: 200px;
    margin: 15px 35px;
    text-align: center;
    overflow: hidden;
}
.comission-menu img{
    width: 75%;
    height: 75%;
}
.comission-menu:hover img{
    transition: ease-in-out .4s;
    transform: scale(1.04);
}




/*■■■QA■■■
---------------------------------------------------------------*/
#faq .sub-menutitle{
    color: #9ed6d8;
}
.QA{
    width: auto;
    background-color: #fff;
}

.QA h3{
    font-size: 25px;
    font-weight: 600;
    margin-top: 80px;
    margin-left: auto;
    margin-right: auto;
}
.QA .dotted{
    width: 250px;
}

.QA .text-title{
    font-size: 17px;
}
.QAtext{
    width: 720px;
    height: 300px;
    margin: 10px auto;
}
.QA .text-title{
    line-height: 0.8;
    margin-top: 45px;
}


/*■■■CONTACT■■■
---------------------------------------------------------------*/
#contact .sub-menutitle{
    color: #9ed6d8;
}
.contact{
    background-color: #f9f9f9;
    min-height: 400px;
}

.contact .flex{
    margin-top: 45px;
}
.contact-menu{
    width: 180px;
    height: 180px;
    margin: 0 25px;
    text-align: center;
    overflow: hidden;
}
.contact-menu img{
    width: 65%;
    height: 65%;
}
.contact-menu:hover img{
    transition: ease-in-out .4s;
    transform: scale(1.04);
}
/*□□□CONTACT□□□
---------------------------------------------------------------*/
.contact-page{
    width: 800px;
    text-align: left;
    margin: 90px auto;
    padding: 0;
}

.contactform{
    width: 800px;
    padding: 0;
    margin: 0 auto;
}
.contactform div{
    width: 800px;
    margin: 0 auto;
}
.contactform .flex{
    justify-content: left;
    margin-top: 0;
}


.contact-page2 div{
    background: #fff;
    border: #9ed6d8 1px solid;
    min-height: 300px;
    width: 800px;
    margin: 0 auto;
}
.contact-page2 .menutitle{
    width: 400px;
    font-size: 21px;
    margin: 40px auto 25px auto;
    padding: 10px 0;
    border-bottom: #00a3af 2px dotted;
}
.contact-page2 ul {
    font-size: 15px;
    width: 600px;
    margin: 0 auto;
    padding-left: 50px;
}
.contact-page2 li{
    margin-top: 5px;
}




/*■■■FOOTER■■■
---------------------------------------------------------------*/
footer{
    background-color: #fff;
    min-height: 170px;
    left: 0;
    right: 0;
    border-top:1px #4d4d4d dotted;
}

footer .wrapper{
    display: flex;
    justify-content: space-between;
    padding: 0 5%;
    margin-top: 20px;
}
footer hr{
    color: #4d4d4d;
    width: 1100px;
    margin: 0 auto;
}
footer h1{
    margin-top: 15px;
}
footer p{
    text-align: center;
    margin: 100px 0 30px 0;
}

footer a{
    border-bottom: 1px #fff solid;
}
footer a:hover{
    border-bottom: 1px #00a3af dotted;
    transition: ease-in-out .6s;
}


/*■■■PRIVACY POLICY■■■
---------------------------------------------------------------*/
.privacypolicy div{
    margin: 30px auto;
    width: 700px;
}
.privacypolicy .text-title{
    font-size: 18px;
    color: #9ed6d8;
}






/*タブレットサイズ*/
@media (max-width: 960px) {

/*■■■共通：基本■■■
---------------------------------------------------------------*/
body{
    font-size: 16px;
    line-height: 1.6;
    letter-spacing: 0.08em;
}
.wrapper{
    max-width: 960px;
    height: auto;
    padding: 2% 5%;
    margin: 0 auto;
}
.more{
    font-size: 16px;
}

/*スクロール前*/
.js-fadeup{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 1.5s,visibility 1.5s, transform 1.5s;
}
/*スクロール後*/
.js-scroll{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.text{
    font-size: 16px;
}


/*■■■見出し■■■
---------------------------------------------------------------*/
.menutitle{
    font-size: 32px;
}


/*■■■HOME■■■
---------------------------------------------------------------*/
#home{
    min-height: 500px;
}

#home .contents{
    padding-top: 220px;
}


/*■■■ABOUT■■■
---------------------------------------------------------------*/
.circle-img2{
    width: 190px;
    height: 190px;
}
.about .flex{
    width: auto;
    margin: 30px auto;
}

.flex-left{
    max-width: 450px;
    margin-top: 40px;
}
/*------------------------------*/
.profile{
    height: 650px;
}
.profile .text p {
    font-size: 13px;
}
.profile .flex{
    width: auto;
}
.profile .flex-left{
    width: 350px;
    margin-top: 10px;
}
.profile .circle-img{
    width: 190px;
    height: 190px;
}
/*------------------------------*/
.profile2{
    height: 500px;
}
.profile2 div{
    width: auto;
    margin: 0 auto;
}
.profile-contents{
    height: 120px;
    padding-top: 20px;
}
.profile-contents div{
    width: 300px;
    margin: auto;
}
.profile2 img{
    width: 80px;
    height: 80px;
}
/*------------------------------*/
.skill{
    height: 1000px;
}
.skill-webdesign,.skill-illust{
    width: 550px;
}
.skill-title{
    height: 55px;
    width: 210px;
}
.skill .text-title{
    font-size: 15px;
    height: 50px;
    max-width: 280px;
    margin: 0;
    line-height: 55px;
}
.skill .text{
    width: 280px;
}


/*■■■WORKS■■■
---------------------------------------------------------------*/
.works{
    min-height: 1500px;
}
.works h3{
    font-size: 21px;
}
.works-contents{
    width: auto;
    margin: 10px auto;
}
.works figure{
    list-style: none;
    display: inline-block;
    width: 210px;
    height: 210px;
    text-align: center;
}
.works-sample img{
    width: 200px;
    height: 200px;
    padding: 0;
}
.works-text .more{
    position: absolute;
    left: 80%;
}
/*------------------------------*/
.works-contents2{
    height: auto;
    width: auto;
}
.works-contents2 .flex{
    width: 720px;
}
.thumbnail img{
    width: 230px;
}
/*------------------------------*/
.popup-image{
    margin: 30px auto;
    height: 500px;
}
.popup-image img {
    width: 650px;
}
.popup-texts{
    width: 650px;
}


/*■■■order■■■
---------------------------------------------------------------*/
.order{
    min-height: 450px;
}
.order .flex{
    margin-top: 0;
}
.order .text{
    padding: 5%;
    width: auto;
    height: 230px;
}
/*------------------------------*/
.orderline h2{
    font-size: 23px;
}
.orderline-menu div{
    width: 210px;
}
.orderline-menu img{
    width: 90px;
}
.orderline-menu .text-title{
    margin-top: 10px;
    font-size: 23px;
}
.orderline-menu .text-title2{
    font-size: 14px;
}
.orderline .text{
    width: 180px;
    margin: 5px auto;
}
.orderline01{
    width: 250px;
    height: 300px;
}
.orderline02,.orderline03,.orderline04{
    width: 250px;
    height: 300px;
}

.hearing{
    height: 400px;
    padding: 5% 5% 0 5%;
}
.hearing-content{
    height: 320px;
    width: 600px;
}
.hearing-content div{
    height: 250px;
}
.hearing-content h2{
    font-size: 23px;
}
.hearing-content li{
    font-size: 15px;
}

.template{
    height: auto;
    width: auto;
    padding: 0 5%;
}
.template h2{
    font-size: 23px;
    margin-top: 90px;
}
.template-content{
    padding: 0 1.5em 0 3.5em;
}
.template-content ul{
    margin: 3% auto;
}
.templatebox:checked + .template-label + .template-content{
    padding: 0 1.5em 0 3.5em;
}

.charge{
    width: 960px;
}
.charge h2{
    margin-top: 90px;
}
table{
    width: 700px;
    margin: 15px auto;
}
table .th-none{
    width: 110px;
}
table th .th-menu{
    width: 110px;
}
table .th-menu2{
    width: 230px;
}
table .th-menu3{
    width: 160px;
}

.comission{
    height: 500px;
    width: 960px;
}
.comission h2{
    font-size: 23px;
    margin-top: 90px;
}
.comission-menu{
    margin: 0;
    text-align: center;
    overflow: hidden;
}
.comission-menu img{
    width: 75%;
    height: 75%;
}


/*■■■QA■■■
---------------------------------------------------------------*/
.QA{
    min-height: 600px;
}
.QA .text-title{
    font-size: 18px;
}
.QAtext{
    max-width: 700px;
    margin: 0 auto;
}


/*■■■CONTACT■■■
---------------------------------------------------------------*/
.contact{
    min-height: 350px;
}
.contact-menu{
    width: 150px;
    height: 150px;
    margin: 0 15px;
}

/*------------------------------*/
.contact-page{
    width: 800px;
}
.contactform div{
    width: 800px;
}
.contact-page2{
    width: 800px;
    margin: 30px auto 100px auto;
}


}
/*タブレットサイズ*/



/*スマホサイズ*/
@media screen and (max-width:390px) {
/*■■■共通■■■
---------------------------------------------------------------*/
.flex{
    display: block;
    justify-content: center;
}
.anchor{
    margin-top: -90px;
}
.wrapper{
    max-width: 95%;
    padding: 15% 5%;
}

.more a{
    border: 1px #9ed6d8 solid;
    color: #FFF;
    border-radius: 50px;
    width: 120px;
    height: 45px;
    line-height: 40px;
    background-color: #9ed6d8;
}
.more a:hover{
    border: 1px #999 solid;
    border-radius: 50px;
    width: 120px;
    height: 45px;
    line-height: 40px;
    background-color: #00a3af;
}
.more a:checked{
    border: 1px #999 solid;
    border-radius: 50px;
    width: 120px;
    height: 45px;
    line-height: 40px;
    background-color: #00a3af;
}



/*■■■見出し■■■
---------------------------------------------------------------*/

.menutitle-box {
    max-width: 350px;
    padding: 0 5%;
    height: 60px;
}
.menutitle-box h1{ 
    width: auto;   
    height: 60px;
    line-height: 60px;
    font-size: 24px;
}
.menutitle{
    font-size: 24px;
}
.sub-menutitle{
    font-size: 12px;
    text-align: center;
}
.text-title{
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.04em;
    margin-bottom: 10px;
}


/*■■■ヘッダー■■■
---------------------------------------------------------------*/

.page-header{
    display: block;
    justify-content: space-between;
}

header h1{
    margin-top: 16px;
}
.page-header nav{
    display: none;
}
.hamburger-menu{
    display: block;
}

/*　ハンバーガーメニューボタン　*/
.hamburger {
    display : block;
    position: fixed;
    z-index: calc(infinity);
    right : 20px;
    top   : 10px;
    width : 42px;
    height: 42px;
    cursor: pointer;
    text-align: center;
  }
  .hamburger span {
    display : block;
    position: absolute;
    width   : 30px;
    height  : 2px ;
    left    : 6px;
    background : #BBBBBB;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition   : 0.3s ease-in-out;
    transition        : 0.3s ease-in-out;
  }
  .hamburger span:nth-child(1) {
    top: 10px;
  }
  .hamburger span:nth-child(2) {
    top: 20px;
  }
  .hamburger span:nth-child(3) {
    top: 30px;
  }
  
  /* スマホメニューを開いてる時のボタン */
  .hamburger.active span:nth-child(1) {
    top : 16px;
    left: 6px;
    background :#fff;
    -webkit-transform: rotate(-45deg);
    -moz-transform   : rotate(-45deg);
    transform        : rotate(-45deg);
  }
  
  .hamburger.active span:nth-child(2),
  .hamburger.active span:nth-child(3) {
    top: 16px;
    background :#fff;
    -webkit-transform: rotate(45deg);
    -moz-transform   : rotate(45deg);
    transform        : rotate(45deg);
  }
  
  /* メニュー背景　*/
  nav.globalMenuSp {
    position: fixed;
    z-index : 1500;
    top  : 0;
    left : 0;
    color: #fff;
    background: rgba( 71,70,73,0.6 );
    text-align: center;
    width: 100%;
    transform: translateY(-100%);
    transition: all 0.6s;
  }
  
  nav.globalMenuSp ul {
    margin: 0 auto;
    padding: 0;
    width: 100%;
  }
  
  nav.globalMenuSp ul li {
    list-style-type: none;
    padding: 0;
    width: 100%;
    transition: .4s all;
  }
  nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
  }
  nav.globalMenuSp ul li:hover{
    background :#ddd;
  }
  
  nav.globalMenuSp ul li a {
    display: block;
    color: #fff;
    padding: 1em 0;
    text-decoration :none;
  }
  
  /* クリックでjQueryで追加・削除 */
  nav.globalMenuSp.active {
    opacity: 100;
    display: block;
    transform: translateY(0%);
  }


/*■■■HOME■■■
---------------------------------------------------------------*/
#home{
    min-height: 300px;
    background-position: top 30px right -60px;
}
#home .page-title{
    font-size: 35px;
}
#home .contents{
    padding-top: 150px;
}
.main-illust{
    background-size: 500px;
}
.about .text{
    display: none;
}
.about .text2{
    text-align: center;
    display: block;
    margin: 40px auto;
    width: auto;
}


/*■■■ABOUT■■■
---------------------------------------------------------------*/
.circle-img1{
    display: block;
    width: 170px;
    height: 170px;
    margin: 0 auto;
}
.circle-img2{
    display: none;
}
.about .flex{
    max-width: 350px;
    margin: 10px auto;
    text-align: center;
}

.flex-left{
    max-width: 350px;
    margin-top: 10px;
    padding: 0 5%;
}
/*------------------------------*/
.profile .flex{
    margin: 40px auto;
    width: 280px;
}
.profile h2{
    display: none;
}
.profile .sub-menutitle{
    text-align: center;
}
.profile .flex-left{
    width: 280px;
    margin-top: 10px;
    text-align: center;
}
.profile .circle-img{
    display: none;
}
.profile .circle-img2{
    display: block;
    width: 190px;
    height: 190px;
    margin: 20px auto;
}
.profile .text-title{
    display: none;
}
.profile .text{
    display: none;
}
.profile .text2{
    text-align: center;
    display: block;
    margin: 50px auto;
    width: auto;
}
.profile .text2 p{
    color: #686868;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 0.08em;
}
.profile .text-title2{
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.04em;
    margin-bottom: 10px;
    display: block;
}
/*------------------------------*/
.profile2{
    min-height: 750px;
}
.profile2 div{
    width: 280px;
    margin: 0 auto;
}
.profile2 .text{
    margin: 20px 0;
}
.profile-contents{
    height: 120px;
    padding-top: 0;
}
.mb-flex{
    height: 90px;
    display: flex;
}
.mb-flex .text{
    font-size: 14px;
    margin: 0;
}
.profile-contents div{
    width: 280px;
    margin: auto;
}
.profile2 img{
    width: 80px;
    height: 80px;
}
/*------------------------------*/
.skill{
    min-height: 1200px;
    margin-top: 0;
}
.skill hr{
    margin: 0 auto;
    width: 100%;
}
.skill-webdesign,.skill-illust{
    width: 280px;
    margin: 10% auto;
}
.skill-title{
    height: 55px;
    width: 200px;
    margin: 0 auto;
}
.skill .text-title{
    font-size: 15px;
    height: 50px;
    width: 210px;
    margin: 0;
    line-height: 55px;
}
.skill .text{
    width: 230px;
    margin: 10% auto;
    font-size: 14px;
}
.skill .more{
    width: 100px;
    padding: 0;
    margin: 5% auto;
}
.skill .more a{
    text-align: center;
    padding: 0;
}
.border{
    padding: 0;
}
.border .text-title::after{
    display: none;
}
.skill-tool{
    margin: 20px auto;
    width: 280px;
}
.skill-tool .text-title{
    font-weight: 600;
    width: 280px;
    height: 40px;
}
.skill-tool .text{
    width: 280px;
    text-align: center;
    margin: 0 auto;
}
.tool1 ,.tool2 {
    height: 100px;
    margin: 8% auto;
}


/*■■■WORKS■■■
---------------------------------------------------------------*/
.works{
    min-height: 2300px;
}
.works h3{
    font-size: 18px;
    margin-top: 75px;
    margin-bottom: 0;
    text-align: center;
}
.works .text-title{
    text-align: center;
    margin-bottom: 10px;
    position: relative;
    z-index: 2;
}
.works-website{
    margin-top: 25px;
}
.works-contents{
    width: 280px;
    margin: 10px auto;
}
.works-text2 .text{
    margin: 15px 0;
    font-size: 14px;
}
.figre{
    width: 100%;
    padding: 30px;
}
.works figure{
    width: 100%;
    height: 210px;
    display: block;
    text-align: center;
}
.works-sample img{
    border: 1px solid #f8f8f8;
    position: static;
    width: 280px;
    height: 200px;
    padding: 0;
}
.works-text{
    display: block;
    position: static;
    margin-top: 0;
}
.works-text p {
    margin-top: 30px;
}
.works-text .more{
    position: static;
    left: 0;
    margin-top: 30px;
}
.works-text a{
    text-align: center;
    padding: 0;
}

/*------------------------------*/
.works-contents2{
    height: auto;
    margin: 0 auto;
}
.works-contents2 .flex{
    width: 280px;
}
.thumbnail img{
    width: 280px;
}
.c{
    width: 100%;
    text-align: center;
    padding: 0 auto;
}
.works-contents2 h2{
    font-size: 21px;
    margin-top: 25px;
    margin-bottom: 0;
    text-align: center;
}
/*------------------------------*/
.spimg{
    display: block;
}
.pcimg{
    display: none;
}
.thumbnail img{
    margin: 0 auto;
}
.popup-image{
    width: auto;
    height: 350px;
    margin: auto;
}
.popup-imageroll{
    width: auto;
    height: 320px;
    margin: auto auto 20px auto;
}
.popup-image img{
    width: 300px;
    height: 330px;
    object-fit: cover;
    border: solid 1px #686868;
}
.popup-imageroll img{
    width: 300px;
    height: auto;
    object-fit: cover;
    border: solid 1px #686868;
}
.popup-texts{
    width: 320px;
    height: auto;
}
.popup-title{
    font-size: 18px;
    padding: 0px 10px;
    text-align: left;
}
.popup-texts .sub-menutitle {
    font-size: 13px;
    text-align: left;
}
.md-contents{
    top: 5%;
    width: 90%;
  }
.md-inner{
    padding: 50px 0px;
    margin: 0px;
  }
.md-xmark {
    top: 5px;
    right: 20px;
}


/*■■■order■■■
---------------------------------------------------------------*/
.order{
    min-height: 600px;
}
.order .flex{
    width: 280px;
    margin: 0 auto;
    padding: 0;
}
.order .text{
    padding: 0;
    width: 280px;
    height: auto;
}
.order img{
    width: auto;
    height: 190px;
}
.order-img{
    width: 280px;
    text-align: center;
}
.order .more {
    text-align: center;
    margin-top: 30px;
}

/*------------------------------*/
.orderline{
    height: auto;
}
.orderline h2{
    font-size: 23px;
    padding: 0;
}
.orderline .flex{
    width: 250px;
    margin: 0 auto;
}
.orderline-menu{
    margin: 15px 0;
}
.orderline-menu div{
    width: 250px;
}
.orderline-menu img{
    width: 120px;
}
.orderline-menu .text-title{
    margin-top: 30px;
    font-size: 23px;
}
.orderline-menu .text-title2{
    font-size: 14px;
}
.orderline .text{
    font-size: 16px;
    width: 230px;
    margin: 5px auto;
}
.orderline01{
    width: 250px;
    height: auto;
    border-left: 0px solid #d3d3d3;
    border-right: 0px solid #d3d3d3;
}
.orderline02,.orderline03,.orderline04{
    width: 250px;
    height: auto;
    border-right: 0px solid #d3d3d3;
}

.hearing{
    height: 400px;
}
.hearing-content{
    height: 300px;
    width: auto;
}
.hearing-content div{
    height: 250px;
    width: 250px;
}
.hearing-content h2{
    width: 200px;
    margin-top: 30px;
    font-size: 18px;
}
.hearing-content ul {
    margin-top: 20px;
    padding-left: 1.2em;
}
.hearing-content li{
    font-size: 15px;
}

.template{
    height: auto;
    width: 375px;
    margin: auto;
}
.template h2{
    font-size: 21px;
    margin-top: 0;
}
.template-content{
    padding: 0 1.5em 0 3.5em;
}
.template-content ul{
    margin: 8% auto;
}
.templatebox:checked + .template-label + .template-content{
    padding: 0 1.5em 0 3.5em;
}

.table-scroll {
    overflow-x: scroll;
  }
.charge{
    width: 700px;
}
.charge h2{
    font-size: 21px;
    margin-top: 0;
}
table{
    width: 700px;
    margin: 15px auto;
}
table .th-none{
    width: 110px;
}
table th .th-menu{
    width: 110px;
}
table .th-menu2{
    width: 230px;
}
table .th-menu3{
    width: 160px;
}

.comission{
    height: 450px;
    width: 375px;
    margin: 0 auto;
}
.comission h2{
    font-size: 21px;
    margin-top: 0;
}
.comission .flex{
    display: flex;
    height: 150px;
    margin-top: 20px;
    width: 300;
}
.comission-menu{
    width: 120px;
    height: 120px;
    margin: 0;
    overflow: hidden;
}
.comission-menu p{
    font-size: 13px;
}
.comission-menu img{
    width: 80%;
    height: 80%;
}




/*■■■QA■■■
---------------------------------------------------------------*/
.QA{
    min-height: 800px;
}
.QA .text-title{
    font-size: 16px;
}
.QAtext{
    width: 300px;
    margin: 0 auto;
}


/*■■■CONTACT■■■
---------------------------------------------------------------*/
.contact{
    min-height: 250px;
}
.contact .flex{
    display: flex;
}
.contact .menutitle{
    margin-top: 0;
}
.contact-menu{
    width: 120px;
    height: 120px;
    margin: 0;
}
.contact-menu p{
    font-size: 13px;
}
/*------------------------------*/
.contact-page{
    width: 350px;
}
.contactform div{
    width: auto;
}
.contact-page2{
    min-height: 400px;
    margin: 0;
}
.contact-page2 div{
    width: 350px;
    height: 380px;
    margin: 0 auto;
}
.contact-page2 .menutitle {
    width: 300px;
    font-size: 18px;
    margin: 30px auto 25px auto;
    padding: 10px 0;
    border-bottom: #00a3af 2px dotted;
}
.contact-page2 ul {
    font-size: 15px;
    width: 260px;
    margin: 0 auto;
    padding-left: 15px;
}
.contact-page2 li{
    margin-top: 15px;
}


/*■■■FOOTER■■■
---------------------------------------------------------------*/
footer .footer-page{
    display: none;
}
footer{
    min-height: 70px;
}
footer .wrapper{
    max-width: 390px;
}
footer p{
    margin: 20px 0;
}
footer hr{
    max-width: 350px;
}


/*■■■PRIVACY POLICY■■■
---------------------------------------------------------------*/
.privacypolicy div{
    margin: 0px auto 45px auto;
    max-width: 350px;
}
.privacypolicy .text-title{
    font-size: 18px;
}
.privacypolicy .text{
    max-width: 300px;
    margin: 0 auto;
}
.privacy p{
    max-width: 300px;
    margin: 0 auto;
}


}
/*スマホサイズ*/




