@charset "utf-8";
/* CSS Document */

/* header, section, nav, div, ul, li {border: solid 1px #000;} */

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

.first_view {
    overflow: hidden;
}


/* ------------------------------------------------------------------------------
|　　　　　　　　　　　　　　　　　　　　共通設定　　　　　　　　　　　　　　　　　　　　|
------------------------------------------------------------------------------ */

/************* 文字設定 *************/
h1, h2, h3, h4, h5, h6, p{
    color: #181d62;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-style: normal;
}

h1{
    font-size: 40px;
}

h2{
    font-size: 32px;
}

h3{
    font-size: 24px;
}

h4{
    font-size: 20px;
}

h5{
    font-size: 16px;
}

/****** h6ちょっと保留で *********/
/* h6{
    font-family: "Bebas Neue", sans-serif;
    font-size: 100px;
} */

p{
    font-size: 16px;
    line-height: 170%;
}

.caption_en{
    font-family: "Outfit", sans-serif;
    font-size: 96px;
}

.caption_en_gnav{
    font-family: "Outfit", sans-serif;
    font-size: 40px;
}

.caption_en_mailto{
    font-family: "Outfit", sans-serif;
    font-size: 20px;
}

.caption_jp{
    font-size: 16px;
    letter-spacing: 0.5em;
}

/* .caption_en_big{
    color: #525252;
    font-family: "Bebas Neue", sans-serif;
    font-size: 200px;
} */

.text_wt{
    color: fff;
}

.fv_title h1{
    font-family: "Outfit", sans-serif;
    font-size: 96px;
    font-weight: 900;
}

.fv_title_ja h2{
    font-size: 16px;
    letter-spacing: 0.5em;
}

.section_title{
    font-family: "Outfit", sans-serif;
    font-size: 72px;
}

.show_website_R h3{
    font-size: 32px;
}

.works_others_caption h3{
    font-size: 24px;
}

.works_others_caption h4{
    font-size: 18px;
}

.text_tag{
    color: #929292;
}

.btn_pur h5{
    color: #fff;
    font-weight: bold;
}

.btn_wt h5{
    font-weight: bold;
}

.ind_profile_disc h3{
    font-size: 40px;
}

.footer_menu h5, header h5{
    font-family: "Outfit", sans-serif;
    font-size: 40px;
}

.btn_contact p{
    font-family: "Outfit", sans-serif;
    font-size: 20px;
    font-weight: bold;
}

.works_disc_text h3{
    font-weight: bold;
}

/* .footer_contact h6{
    color: #fff;
    font-family: "Outfit", sans-serif;
    font-size: 96px;
    font-weight: 900;
    -webkit-text-stroke-width: 1px;
    -webkit-text-stroke-color: #181d62;
    text-shadow: 
        3px 3px 0 #181d62
        -3px 3px 0 #181d62
        -3px -3px 0 #181d62
        3px -3px 0 #181d62;

} */


/************* リンクの色が変わらないようにする設定 ***********/
a{
    text-decoration: none;
    color: inherit; 
}





/* ------------------------------------------------------------------------------
|　　　　　　　　　　　　　　　　PCレイアウト　　　　　　　　　　　　　　　　　　　　　　|
------------------------------------------------------------------------------ */

body{
    background-color: #fff;
}

/* @media only screen and (max-width: 1920px) { */

    /* ------------------------------------------------------------------------------
    |　　　　　　　　　　　　　　　　　　PC インデックス　　　　　　　　　　　　　　　　　　|
    ------------------------------------------------------------------------------ */



    /************* PC インデックス：ファーストビュー ***********/

    .first_view{
        width: auto;
        height: 100vh;
        background-color: #FCE5E4;
        background-image: url(../img/01-001.png);
        background-size: cover;
        background-position: center bottom;
        padding-left: 3%;
        padding-right: 3%;
    }

    /* .fv_title, .fv_title_ja, .fv_chara{
        width: 100%;
        margin: 0 auto;
    } */

    .fv_title{
        width: 100%;
        height: 50%;
        display: flex;
        justify-content: center;
        align-items: flex-end;
    }

    .fv_title_ja{
        width: 100%;
        height: 6%;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .fv_chara{
        width: 100%;
        height: 44%;
        display: flex;
        justify-content: center;
        align-items:flex-start;
        padding-top: 2%;
    }

    @media only screen and (max-width: 1000px) {
        .fv_title_ja{
            height: 10%;
        }
    
        .fv_chara{
            height: 40%;
            padding-top: 10%;
        }

        .fv_chara img{
            max-width: 110px;
            height: auto;
        }
    }

    /************* PC インデックス：ラッパー ***********/
    .ind_wrapper{
        max-width: 1280px;
        background-color: #fff;
        margin: 0 auto;
        padding: 200px 30px;
    }

    
    /************* PC インデックス：Works ***********/
    .ind_works, .ind_profile{
        width: 100%;
        margin: 0 auto;
        margin-bottom: 200px;
    }
    .ind_works_title, .profile_title{
        width: 100%;
        margin: 0 auto;
        display: flex;
        justify-content: center;
        margin-bottom: 100px;
    }

    .ind_works_show_website{
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 100px;
    }

    .show_website_L{
        width: 50%;
        margin-right: 5%;
    }

    .show_website_R{
        width: 45%;
        padding: 30px;
    }

    .caption_wrap, .others_caption_wrap{
        margin-bottom: 25px;
    }

    .caption_margin{
        margin-bottom: 10px;
    }

    .show_website_L img{
        /* width: auto; */
        min-width: 0;
        box-shadow: 10px 10px 700px 16px rgba(17,17,26,0.08);
        position: relative;
    }

    .caption_wrap span, .others_caption_wrap span{
        font-weight: bold;
    }

    .btn_pur{
        width: 320px;
        height: 56px;
        background-color: #181d62;
        border: solid 2px #181d62;
        border-radius: 25px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .btn_pur h5, .btn_wt h5{
        margin-right: 2.5em;
    }

    .btn_wt{
        width: 320px;
        height: 56px;
        background-color: #fff;
        border: solid 2px #181d62;
        border-radius: 25px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .show_website_R .btn_pur{
        margin-bottom: 15px;
    }

    .works_show_others{
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

    .works_others_img{
        margin-bottom: 25px;
    }

    .show_others_row{
        width: 30.5%;
    }

    .works_others_caption{
        width: 100%;
    }

    .works_others_caption .btn_wt{
        width: 100%;
    }


    /************* PC インデックス：Profile ***********/
    .ind_profile{
        margin-bottom: 0;
    }

    .ind_aboutme{
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

    .ind_profile_img{
        width: 28.7%;
    }

    .ind_profile_disc{
        width: 64%;
    }

    .ind_profile_text h3{
        margin-bottom: 30px;
    }

    .ind_profile_text p{
        margin-bottom: 100px;
    }

    .linkto_profile{
        width: 100%;
        display: flex;
        justify-content: flex-end;
    }


    /************* PC インデックス：フッター ***********/
    .footer_menu{
        width: auto;
        height: 100px;
        display: flex;
        justify-content: center;
        align-items: center;
        border-top: solid 1px #929292;
        border-bottom: solid 1px #929292;
    }

    .footer_contact{
        width: auto;
        background-color: #FCE5E4;
        padding-top: 15px;
        padding-bottom: 15px;
    }

    .footer_contact div{
        max-width: 1220px;
        margin: 0 auto;
        display: flex;
        justify-content: center;
        align-items: center;
        padding-top: 15px;
        padding-bottom: 15px;
        margin-bottom: 15px;
    }
    
    .footer_contact img{
        max-width: 472px;
    }

    .btn_contact{
        width: 320px;
        height: 56px;
        background-color: #fff;
        border: solid 2px #181d62;
        border-radius: 25px;
        margin-bottom: 15px;
    }


    /* ------------------------------------------------------------------------------
    |　　　　　　　　　　　　　  　   　　　Works  　　　　 　　　　　　　  　　　　　　　|
    ------------------------------------------------------------------------------ */
    header{
        width: auto;
        height: 80px;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        padding-left: 3%;
        padding-right: 3%;
    }

    .website{
        width: auto;
        display: flex;
        justify-content: center;
        margin-bottom: 100px;
    }

    /* .website img{
        width: auto;
    } */

    .works_text{
        max-width: 1280px;
        margin: 0 auto;
    }

    .works_intro{
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        padding: 0 30px 50px 30px;
        border-bottom: solid 1px #929292;
    }

    .works_disc{
        width: 100%;
        display: flex;
        justify-content: space-between;
        padding: 0 30px 200px 30px;
    }

    .works_disc_L{
        width: 58.5%;
    }

    .works_disc_info{
        padding-top: 30px;
        padding-bottom: 30px;
    }

    .works_disc_text h3{
        margin-bottom: 15px;
    }

    .works_disc_text p{
        margin-bottom: 30px;
    }

    .works_disc_target{
        padding-bottom: 30px;
    }

    .works_disc_R, .works_disc_R_one{
        padding-left: 30px;
        padding-top: 75px;
        width: 38%;
        display: flex;
        align-items: flex-start;
    }

    .works_disc_R div{
        width: 50%;
        display: flex;
        justify-content: center;
    }

    .works_disc_R_one div{
        width: 100%;
        display: flex;
        justify-content: center;
    }

    .otherworks{
        max-width: 1280px;
        padding-left: 30px;
        padding-right: 30px;
        margin: 0 auto 100px auto;
    }

    .otherworks_title{
        width: 100%;
        display: flex;
        justify-content: center;
        margin-bottom: 50px;
    }



    /* ------------------------------------------------------------------------------
    |　　　　　　　　　　　　　     　　　Profile  　　　　 　　　　　　　  　　　　　　　|
    ------------------------------------------------------------------------------ */
    .prof_wrapper{
        max-width: 1280px;
        background-color: #fff;
        margin: 0 auto;
        padding-left: 30px;
        padding-right: 30px;
    }

    /* 中央揃え */
    .profpage_title, .profpage_aboutme, .profpage_aboutme_tex, .prof_design_title, .prof_design_odd_img, .prof_design_even_img, .prof_skill_title, .prof_skill_list_img, .prof_skill_list_p, .prof_others_title, .prof_otherworks_tex{
        display: flex;
        justify-content: center;
    }

     /* 下マージン */
     .profpage_title, .prof_design_title, .prof_design_odd, .prof_design_even, .prof_skill_title{
        margin-bottom: 50px;
     }

     .profpage_aboutme, .prof_design_tex h2, .prof_design_even h2, .prof_skill_list_img{
        margin-bottom: 30px;
     }

     .profpage_aboutme_tex, .prof_design_last {
        margin-bottom: 100px;
     }

    .profpage_aboutme_tex p, .prof_otherworks_tex p{
        text-align: center;
    }

    .prof_design_odd, .prof_design_even{
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .prof_design_odd div, .prof_design_even div{
        width: 48%;
    }

    .prof_skill{
        width: 1280px;
        margin: 0 auto;
        border-top: solid 1px #929292;
        border-bottom: solid 1px #929292;
        padding: 50px 30px 50px 30px;
    }

    .prof_skill_lists{
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

    .prof_skill_list{
        width: 31%;
        align-items: center;
    }

    .prof_skill_list img, .prof_skill_list p{
        margin: 0 auto;
    }

    .prof_skill_app{
        max-width: 1000px;
        margin: 0 auto;
        display: flex;
        justify-content: center;
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .prof_skill_app_tex span{
        font-weight: bold;
    }

    .prof_others_title{
        padding-top: 100px;
    }

    .prof_othersworks{
        width: 100%;
        display: flex;
        justify-content: space-around;
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .prof_otherwork{
        width: 31%;
    }

    .prof_otherwork aside{
        display: flex;
        justify-content: center;
    }

    .prof_otherworks_tex{
        max-width: 1000px;
        margin: 0 auto;
        padding-bottom: 200px;
    }
    








/* ------------------------------------------------------------------------------
|　　　　　　　　　　　　　　　　　モバイルレイアウト　　　　　　　　　　　　　　　　　　|
------------------------------------------------------------------------------ */

@media only screen and (max-width: 768px) {
    .fv_title h1{
        font-size: 64px;
    }

    .fv_chara img{
        max-width: 90px;
        height: auto;
    }
}



    