@charset "UTF-8";

/* Repeatable Patterns
----------------------------------------------------*/

html {
    font-size: 62.5%;
}

html.is-scroll-prevent {
    height: 100%;
    overflow: hidden;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    position: relative;
    z-index: 0;
    color: #383838;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* print setting */
@media print {
    html {
        font-size: 38%;
    }

    body {
        -webkit-print-color-adjust: exact;
    }
}


a {
    color: inherit;
    transition: 0.3s ease-out;
    text-decoration: none;
}

a:hover {
    filter: brightness(120%);
}

a img,
a svg {
    transition: 0.3s ease-out;
}

::-moz-selection {
    background: #05ABC9;
    color: #fff;
    text-shadow: none;
}

::selection {
    background: #05ABC9;
    color: #fff;
    text-shadow: none;
}

img {
    width: 100%;
    height: auto;
    max-width: none !important;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
    img {
        image-rendering: -webkit-optimize-contrast;
    }
}

svg {
    fill: currentcolor;
    overflow: visible;
}

ul {
    list-style-type: none;
    padding: 0;
}

input,
textarea,
select,
button {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0;
    border: none;
    transition: 0.3s ease-out;
    cursor: pointer;
    color: #383838;
    border: none;
}


.wrapper {
    width: calc(1166 / 1366 * 100%);
    margin-left: auto;
    margin-right: auto;
    max-width: 1166px;
}

.sub_wrapper-1 {
    width: calc(1026 / 1206 * 100%);
    margin-left: auto;
    margin-right: auto;
}

.sub_wrapper-2 {
    width: calc(676 / 1206 * 100%);
    margin-left: auto;
    margin-right: auto;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.en {
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 700;
}

/*テキスト*/

.heading {
    color: #fff;
    font-size: 11rem;
    letter-spacing: -.05rem;
    font-style: italic;
    text-shadow:
        1px 1px 0px #05ABC9, -1px -1px 0px #05ABC9,
        -1px 1px 0px #05ABC9, 1px -1px 0px #05ABC9,
        1px 0px 0px #05ABC9, -1px 0px 0px #05ABC9,
        0px 1px 0px #05ABC9, 0px -1px 0px #05ABC9;
    margin: 0;
}

.sub_heading-1 {
    font-size: 6rem;
    font-style: italic;
    line-height: 1;
    color: #f8821d;
    margin: 0;
    padding-bottom: 1.2rem;
}

.sub_heading-2 {
    font-size: 2.8rem;
    letter-spacing: .2rem;
    line-height: 1.5;
    margin: 0;
}

.sub_heading-3 {
    font-size: 3.2rem;
    line-height: 1.5;
    margin: 0;
}

.text_01 {
    font-size: 2rem;
    line-height: 1.75;
    text-align: justify;
    margin: 0;
}

.text_02 {
    font-size: 1.6rem;
    line-height: 1.75;
    text-align: justify;
    margin: 0;
}

.link_box {
    background: #05ABC9;
    color: #fff;
    border-radius: 5rem;
    width: 34rem;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    font-size: 4rem;
    font-style: italic;
    display: block;
    margin: auto;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.link_box img {
    width: 4rem;
    margin-right: 1.6rem;
}

/* ヘッダー
----------------------------------------------------*/

.header_inner{
    padding-top: 2.8rem;
    padding-bottom: 3.2rem;
    position: relative;
    justify-content: space-between;
    align-items: center;
}

.header_logo_container{
    width: 32%;
}

.header_logo {
    margin: 0;
}

.header_logo span {
    display: block;
}

.header_logo_name {
    width: 30rem;
    padding-bottom: .6rem;
}

.header_logo_jp {
    font-size: 1.5rem;
    color: #05ABC9;
    padding-bottom: .8rem;
}

.header_logo_en {
    font-size: 1.8rem;
    color: #05ABC9;
    font-weight: 600;
    font-style: italic;
}

.header_nav {
    width: 68%;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-top: 1.8rem;
}

.header_nav_list {
    margin: 0;
}

.header_nav_item {
    font-size: 1.9rem;
    font-weight: 600;
}

.header_nav_item + .header_nav_item{
    padding-left: 3rem;
}

.header_nav_item.current span{
    padding-bottom: .5rem;
    border-bottom: 3px solid #05ABC9;
}

.header_nav_item a:hover{
    color: #05ABC9;
}

.header_sub{
    position: absolute;
    top: 0;
    right: 0;
    align-items: center;
    justify-content: flex-end;
}

.sns_list{
    margin: .4rem 1.6rem 0 0;
    align-items: center;
}

.sns_item{
    margin-right: 2.2rem;
}

.sns_item-li {
    margin-right: 2rem;
}

.sns_link img{
    width: auto;
    height: 2.3rem;
}

.sns_item-x img{
    height: 2rem;
}

.header_contact_link {
    padding: 1.4rem 2.8rem;
    background: #F8821D;
    color: #fff;
    font-size: 2rem;
    font-style: italic;
}

/* メインコンテンツ　トップページ
----------------------------------------------------*/

.main_container {
    overflow: hidden;
}

.top_slider_container {
    position: relative;
}

.top_main_slider {
    z-index: 0;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
}

.top_slider_text {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 1;
    color: #fff;
    text-align: right;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.top_slider_jp {
    margin: 0;
    line-height: 4rem;
    padding-bottom: 1.6rem;
}

.top_slider_jp span {
    display: block;
}

.top_slider_jp-1 {
    font-size: 2.4rem;
}

.top_slider_jp-2 {
    font-size: 3rem;
}

.top_slider_en {
    font-style: italic;
    font-size: 11rem;
    line-height: 9.6rem;
    margin: 0;
}

/*トップ共通*/

.top_section {
    padding-top: 10rem;
    padding-bottom: 14rem;
    z-index: 0;
    position: relative;
}

.top_header {
    padding-bottom: 12rem;
}

.top_header_text {
    color: #05ABC9;
    padding-top: 2rem;
}

/*プロフィール*/

.top_profile_intro {
    padding-bottom: 13.2rem;
}

.top_profile_intro_heading {
    width: 50%;
    line-height: 2;
}

.top_profile_intro_heading span {
    border-bottom: 3px solid #F8821D;
    display: inline-block;
}

.top_profile_intro_text {
    width: 50%;
}

.top_profile_main_img {
    width: 42%;
    padding-right: 10%;
}

.top_profile_main_body {
    width: 58%;
}

.top_profile_main_heading {
    padding-bottom: 4.8rem;
}

.profile_main {
    padding-bottom: 5.2rem;
}

.profile_name_container {
    padding-bottom: 2.8rem;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.profile_position {
    font-size: 1.8rem;
    margin: 0;
    padding-left: 2.4rem;
}

.profile_client_heading_container {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-bottom: 1.2rem;
}

.profile_client_heading_sub {
    font-size: 1.6rem;
    padding-left: 2rem;
}

.client_list {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.client_item {
    width: calc(100% / 3);
    padding: 0 5% 6%;
}

.top_profile_link {
    margin-top: 6rem;
}

/*SERVICES*/

.top_services_container {
    background: #FCFBF4;
}

.top_services_header {
    text-align: right;
}

.top_services_header .top_header_text {
    text-align: right;
}

.services_list {
    margin: 0 -3%;
    justify-content: center;
}

.services_item {
    width: 40%;
    padding: 0 3% 6%;;
}

.line_bg_container {
    background: #fff;
    border-radius: 3.5rem;
    border: 2px solid #05ABC9;
    position: relative;
}

.line_bg {
    position: absolute;
    top: 1.4rem;
    left: 1.4rem;
    width: 100%;
    height: 100%;
    border-radius: 3.5rem;
    background: repeating-linear-gradient(135deg, #05ABC9, #05ABC9 2px, #fff 2px, #fff 6px);
    z-index: -1;
}

.services_link {
    display: block;
    padding: 5rem 4.8rem 5.4rem;
    text-align: center;
}

.services_img {
    padding-bottom: 2rem;
}

.services_item:nth-child(1) .services_img {
    width: 13rem;
}

.services_item:nth-child(2) .services_img {
    width: 13rem;
}

.services_item:nth-child(3) .services_img {
    width: 15.8rem;
}

.services_item:nth-child(4) .services_img {
    width: 10.6rem;
}

.services_heading_en {
    color: #f8821d;
    font-size: 4rem;
    font-style: italic;
    padding-bottom: .8rem;
}

.services_heading_jp {
    font-size: 1.7rem;
    color: #05abc9;
    margin: 0;
    padding-bottom: 2.4rem;
}

.top_services_link {
    margin-top: 4rem;
}


/*WORKS*/
.works_slider {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
}

.works_slider img {
    margin: 0 1rem;
    width: auto;
    height: 40rem;
}

.works_slider p {
    margin: 1rem 1rem 0;
    color: #aaa;
}

.top_works_link {
    margin-top: 8rem;
}

/*RECOMMENDATION*/
.top_recommendation_container {
    background: rgba(248, 130, 29, 0.65);
}

.top_recommendation_header {
    text-align: right;
}

.top_recommendation_header .top_header_text {
    text-align: right;
}

.recommendation_item {
    padding-bottom: 4.8rem;
}

.recommendation_item_inner {
    padding: 5.2rem 7.2rem;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.recommendation_img {
    width: 20%;
}

.recommendation_body {
    width: 72%;
}

.recommendation_name {
    color: #05abc9;
    font-size: 1.8rem;
    line-height: 1.3;
    margin: 0;
    padding-bottom: 1.2rem;
}

/*CONTACT*/
.contact_container {
    background: #05abc9;
    padding-top: 14rem;
    color: #fff;
}

.contact_header {
    text-align: center;
    padding-bottom: 12rem;
}

.contact_heading {
    color: #60C7D9;
    padding-bottom: 4rem;
    text-shadow: 1px 1px 0px #fff, -1px -1px 0px #fff, -1px 1px 0px #fff, 1px -1px 0px #fff, 1px 0px 0px #fff, -1px 0px 0px #fff, 0px 1px 0px #fff, 0px -1px 0px #fff;
}

.contact_text {
    text-align: center;
}

.contact_form_title {
    padding-bottom: 1.2rem;
}

.icon_mandatory {
    color: #F8821D;
}

.contact_form_box {
    margin: 0 0 4rem;
}

.contact_form_box input,
.contact_form_box select,
.contact_form_box textarea {
    width: 100%;
    padding: 1.6rem 2.4rem;
    font-size: 1.6rem;
    line-height: 1.75;
}

.submit_box {
    background: #f8821d;
    color: #fff;
    border-radius: 10rem;
    width: 34rem;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    font-size: 4.6rem;
    font-style: italic;
    display: block;
    margin: 8rem auto 0;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.form_mailer_credit {
    text-align: center;
    font-size: 1.4rem;
    margin: 4rem 0 .5rem;
    display: block;
}


/* フッター
----------------------------------------------------*/

.main_footer {
    background: #05abc9;
    color: #fff;
    padding-top: 14rem;
    padding-bottom: 5rem;
    position: relative;
    margin-top: -.5rem;
}

.footer_copyright {
    font-size: 2rem;
    font-style: italic;
    font-weight: 600;
}

/*トップへ戻る*/
.page_top {
    position: absolute;
    right: 6rem;
    bottom: 3rem;
    text-align: center;
    cursor: pointer;
}

.page_top img{
    transform: rotate(-90deg);
    width: 5.6rem;
}

.page_top span{
    font-size: 3.2rem;
    font-style: italic;
    color: #fff;
    display: block;
    padding-top: 1rem;
}


/* 下層　PROFILE&VISION
----------------------------------------------------*/

.page_header{
    position: relative;
    padding-left: 8rem;
    margin-top: 6rem;
}

.page_header::before{
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    display: block;
    width: 4rem;
    height: 100%;
    background: repeating-linear-gradient(135deg, #05ABC9, #05ABC9 2px, #fff 2px, #fff 6px);
}

.page_section{
    padding-top: 12rem;
    padding-bottom: 14rem;
    z-index: 0;
    position: relative;
}

.profile_section_heading {
    text-align: center;
    padding-bottom: 10rem;
}

.profile_section_heading *{
    display: inline-block;
    border-bottom: 5px solid #F8821D;
}

.page_profile_main{
    margin-bottom: 8rem;
}

.page_profile_main_img {
    width: 32%;
    padding-right: 8%;
}

.page_profile_main_body {
    width: 68%;
}

.profile_works_heading_container {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-bottom: 1.2rem;
}

.profile_works_heading_sub{
    font-size: 1.6rem;
    padding-left: 2rem;
}

.profile_works_list{
    list-style: disc;
}

.profile_works_item{
    margin-left: 2.2rem;
}

.page_profile_link{
    background: #F4F4F4;
    display: block;
    position: relative;
}

.page_profile_link:hover{
    filter: brightness(100%);
}

.page_profile_link_inner{
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.page_profile_link_img{
    width: 32%;
}

.page_profile_link_body{
    width: 68%;
    padding-left: 5%;
}

.page_profile_link_logo{
    width: 15.8rem;
    padding-bottom: 1.6rem;
}

.page_profile_link_text{
    color: #05abc9;
    font-size: 2.2rem;
    line-height: 1.5;
    font-weight: 700;
    margin: 0;
}

.page_profile_link_click{
    position: absolute;
    right: 0;
    top: 0;
    border-style: solid;
    border-width: 0 11rem 11rem 0;
    border-color: transparent #F8821D transparent transparent;
    transition: 0.3s ease-out;
}

.page_profile_link_click span{
    position: absolute;
    left: 1.5rem;
    top: 2.8rem;
    color: #fff;
    font-size: 2.6rem;
    font-style: italic;
    transform: rotate(45deg);
    width: 11rem;
    text-align: center;
}

.page_profile_link:hover .page_profile_link_click{
    filter: brightness(120%);
}

/*VISION*/

.page_vision_container{
    background: #FCFBF4;
}

.page_vision_intro_heading{
    color: #05abc9;
    text-align: center;
}

.page_vision_intro_img{
    margin-bottom: 4rem;
}

.page_vision_img{
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.page_vision_sub_heading{
    color: #05abc9;
    text-align: center;
    font-size: 2.4rem;
    line-height: 1.5;
    padding-top: 6rem;
    padding-bottom: 3.2rem;
    margin: 0;
}

.page_vision_img_list{
    padding-top: 5rem;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.page_vision_img_list img{
    margin-top: 2%;
}

.page_vision_img_list img:nth-child(1){
    width: 30%;
}

.page_vision_img_list img:nth-child(2){
    width: 68%;
}

.page_vision_img_list img:nth-child(3){
    width: 60%;
}

.page_vision_img_list img:nth-child(4){
    width: 38%;
}


/* 下層　SERVICES
----------------------------------------------------*/

.services_intro{
    margin-bottom: 8rem;
}

.services_intro_header{
    width: 42%;
}

.page_visdev_container .sub_heading-1{
    font-size: 5.2rem;
}

.services_intro_sub_heading{
    font-size: 2.2rem;
    line-height: 1.2;
    color: #F8821D;
    margin: 0;
}

.services_intro_text{
    width: 58%;
}

.services_contents{
    padding-top: 4rem;
    padding-bottom: 4rem;
    border-top: 2px solid #E9883B;
    border-bottom: 2px solid #E9883B;
}

.services_contents_header{
    width: 42%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
}

.services_contents_heading{
    font-size: 3.4rem;
    padding-bottom: 1rem;
}

.services_contents_sub_heading{
    font-size: 1.5rem;
    margin: 0;
}

.services_contents_body{
    width: 58%;
}

.services_contents_list{
    list-style-type: disc;
}

.services_contents_item{
    margin-left: 2.2rem;
    line-height: 1.5;
}

.services_contents_item + .services_contents_item{
    padding-top: .6rem;
}

.consulting_img{
    display: block;
    margin-top: 8rem;
    margin-bottom: 8rem;
}

.services_achievement{
    background: rgba(248, 130, 29, 0.2);
    padding: 4.8rem 8rem 5.2rem;
    margin-top: 8rem
}

.services_heading-2{
    padding-bottom: 5.2rem;
    text-align: center;
}

.services_achievement .services_heading-2{
    padding-bottom: 3.2rem;
}

.services_achievement_list{
    list-style-type: disc;
    margin: 0;
}

.services_achievement_item{
    margin-left: 2.2rem;
}

.services_achievement_item + .services_achievement_item{
    padding-top: 0.8rem;
}

.services_achievement_item h4{
    line-height: 1.5;
}

.services_achievement_item p{
    padding-top: .4rem;
}

/*WORKSHOP*/

.page_workshop_container{
/*    background: #FCFBF4;*/
}

.workshop_slider_container{
    padding-top: 8rem;
    padding-bottom: 10rem;
}

.workshop_slider {
    z-index: 0;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
}

.workshop_slide img{
    margin: 0 1rem;
    width: auto;
    height: 58rem;
}

.workshop_menu_container{
    padding-bottom: 10rem;
}

.workshop_menu_list{
    margin: 0 -3%;
}

.workshop_menu_item{
    width: 50%;
    padding: 0 3% 6rem;
}

.workshop_menu_inner{
    padding: 4rem 4rem;
}

.workshop_menu_sub_heading{
    font-size: 1.6rem;
    line-height: 1.3;
    font-weight: 700;
    padding-bottom: .8rem;
    color: #05abc9;
}

.workshop_menu_heading{
    font-size: 2rem;
    line-height: 1.3;
    color: #05abc9;
    margin: 0;
    padding-bottom: 2rem;
}

.workshop_menu_link{
    color: #05abc9;
    display: block;
    font-size: 1.6rem;
    padding-top: 1rem;
    text-align: right;
    text-decoration: underline;
}

.workshop_program_container{
    padding-bottom: 4rem;
}

.workshop_program_inner{
    padding: 6rem 6rem;
}

.workshop_program_heading{
    font-size: 2.2rem;
    color: #05abc9;
    text-align: center;
    margin: 0;
    padding-bottom: 4.8rem;
}

.workshop_program_list{
    margin: 0;
    padding-bottom: 2.4rem;
    border-top: 1px dashed #05abc9;
}

.workshop_program_item{
    padding-top: 2.8rem;
    padding-bottom: 2.8rem;
    border-bottom: 1px dashed #05abc9;
}

.workshop_program_header{
    margin-bottom: 1.6rem;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.workshop_program_number{
    width: 8%;
    font-size: 4.6rem;
    color: #fff;
    font-style: italic;
    text-shadow: 1px 1px 0px #F8821D, -1px -1px 0px #F8821D, -1px 1px 0px #F8821D, 1px -1px 0px #F8821D, 1px 0px 0px #F8821D, -1px 0px 0px #F8821D, 0px 1px 0px #F8821D, 0px -1px 0px #F8821D;
}

.workshop_program_title{
    width: 92%;
    color: #F8821D;
    line-height: 1.3;
}

.workshop_voice_container{
    padding-top: 10rem;
}

.voice_list{
    margin: 0 -2.5%;
}

.voice_item{
    width: calc(100% / 3);
    padding: 0 2.5% 6rem;
}

.voice_inner{
    background: #fff;
    border-radius: 3.5rem;
    padding: 4rem 4rem 4rem;
    border: 2px solid #F8821D;
    position: relative;
}

.voice_inner::before{
    position: absolute;
    content: "";
    bottom: -3.3rem;
    right: 3rem;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 3.3rem 3.3rem 0;
    border-color: transparent #F8821D transparent transparent;
    display: block;
}

.voice_inner::after{
    position: absolute;
    content: "";
    bottom: -3rem;
    right: 3rem;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 3rem 3rem 0;
    border-color: transparent #fff transparent transparent;
    display: block;
}

.voice_name{
    font-size: 1.4rem;
    line-height: 1.5;
    margin: 0;
    padding-top: 1.2rem;
}

/*SEMINAR*/

.seminar_img{
    padding-top: 8rem;
    padding-bottom: 8rem;
}

.seminar_theme_container{
    padding-bottom: 8rem;
}

.seminar_theme_list{
    margin: 0 -3%;
}

.seminar_theme_item{
    width: 50%;
    padding: 0 3% 6rem;
}

.seminar_theme_inner{
    padding: 4rem 4rem;
}

.seminar_theme_heading {
    font-size: 2rem;
    line-height: 1.3;
    color: #05abc9;
    margin: 0;
    padding-bottom: 2rem;
}

.seminar_voice_sub_heading{
    font-size: 1.6rem;
    line-height: 1.3;
    display: block;
    padding-top: 1rem;
}


/* 下層　COMPANY
----------------------------------------------------*/

.company_section_heading{
    width: 80%;
    margin: 0 auto 8rem;
}

.page_company_main{
    margin: 0;
}

.page_company_main dt{
    width: 20%;
    padding-bottom: 1.6rem;
}

.page_company_main dd{
    width: 80%;
    margin: 0;
    padding-bottom: 1.6rem;
}

.page_company_main ul{
    margin-left: 2rem;
}

.page_company_main li{
    list-style: disc;
}

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

PCのみ

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

@media screen and (min-width: 768px) {
    .display_sp {
        display: none !important;
    }
}


@media screen and (max-width: 1249px) and (min-width: 1000px) {
    html {
        font-size: 55%;
    }
    
    .wrapper {
        width: 90%;
    }
}

@media screen and (max-width: 999px) and (min-width: 768px) {
    html {
        font-size: 52%;
    }

    .wrapper {
        width: 95%;
    }
    
    .sub_wrapper-1,
    .sub_wrapper-2 {
        width: 95%;
    }
    
    .heading {
        font-size: 10rem;
    }
    
    .sub_heading-1 {
        font-size: 5.2rem;
    }
    
    .top_profile_intro_heading {
        width: 100%;
        padding-bottom: 4rem;
    }
    
    .top_profile_intro_text {
        width: 100%;
    }
}


@media screen and (max-width: 899px) and (min-width: 768px) {
    .header_nav_item {
        font-size: 1.7rem;
    }

    .header_nav_item + .header_nav_item {
        padding-left: 2rem;
    }
}

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

スマートフォンのみ

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


@media screen and (max-width: 767px) {

    .wrapper {
        width: 100%;
        padding-left: 2.4rem;
        padding-right: 2.4rem;
    }
    

    .sub_wrapper-1,
    .sub_wrapper-2 {
        width: 100%
    }

    .display_pc {
        display: none !important;
    }
    

    /*テキスト*/

    .heading {
        font-size: 6.4rem;
        letter-spacing: 0rem;
    }

    .sub_heading-1 {
        font-size: 4rem;
    }

    .sub_heading-2 {
        font-size: 2rem;
        letter-spacing: .1rem;
    }

    .sub_heading-3 {
        font-size: 2rem;
    }

    .text_01 {
        font-size: 1.6rem;
    }

    .text_02 {
        font-size: 1.4rem;
    }

    .link_box {
        border-radius: 5rem;
        width: 80%;
        padding-top: 2rem;
        padding-bottom: 2rem;
        font-size: 2.6rem;
    }

    .link_box img {
        width: 2.4rem;
        margin-right: 1rem;
    }


    /* ヘッダー
    ----------------------------------------------------*/

    .main_header{
        position: relative;
    }
    
    .header_inner {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
    
    .header_logo_container{
        width: calc(100% - 3.2rem);
        padding-right: 2rem;
    }

    .header_logo {
        padding-top: 0;
    }

    .header_logo_name {
        width: 21.6rem;
        padding-bottom: .2rem;
    }

    .header_logo_jp {
        font-size: 1.1rem;
        padding-bottom: .4rem;
    }

    .header_logo_en {
        font-size: 1.32rem;
    }

    /*ドロワーメニュー*/

    .drawer-hamburger {
        width: 3.2rem;
        height: 4rem;
        padding: 0;
        background: none;
        position: fixed;
        right: 2.4rem;
        top: 1.2rem;
        z-index: 999;
    }

    .drawer-hamburger-icon,
    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        transition: all .3s cubic-bezier(.19, 1, .22, 1);
    }

    .drawer-hamburger-icon {
        position: relative;
        display: block;
        width: 100% !important;
        height: 2px;
        margin-top: 0 !important;
        background-color: #05abc9;
    }

    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        position: absolute;
        content: " ";
        height: 2px;
        width: 100% !important;
        background-color: #05abc9;
        left: 0;
        right: 0;
        margin: auto;
        border-radius: 1px;
    }

    .drawer-hamburger-icon:before {
        top: -.8rem !important;
    }

    .drawer-hamburger-icon:after {
        top: .8rem !important;
    }

    .is-opened .drawer-hamburger-icon:before {
        transform: rotate(30deg);
        top: 0 !important;
        background: #fff;
    }

    .is-opened .drawer-hamburger-icon:after {
        transform: rotate(-30deg);
        top: 0 !important;
        background: #fff;
    }

    .drawer-nav {
        background: #05abc9;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        position: fixed;
        top: -100%;
        bottom: 0;
        left: 0;
        z-index: 99;
        overflow-y: scroll;
        width: 100%;
        height: 100vh; /* カスタムプロパティ未対応ブラウザ用のフォールバック */
        height: calc(var(--vh, 1vh) * 100);
        max-height: 100%;
        transition: top .4s cubic-bezier(.19, 1, .22, 1);
        -webkit-overflow-scrolling: touch;
    }

    .is-opened .drawer-nav {
        top: 0;
        transition: top .4s cubic-bezier(.19, 1, .22, 1);
    }

    .drawer_inner {
        min-height: 100vh;
        min-height: calc(var(--vh, 1vh) * 100);
        padding-top: 7rem;
        padding-bottom: 5rem;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .drawer_nav_container{
        width: 100%;
    }
    
    .drawer_nav_list{
        margin: 0;
    }
    
    .drawer_nav_item{
        font-size: 2.4rem;
        text-align: center;
    }
    
    .drawer_nav_item + .drawer_nav_item{
        padding-top: 2.8rem;
    }
    
    .drawer_nav_item a{
        color: #fff;
        font-style: italic;
    }
    
    .drawer_contact_link{
        margin-top: 4rem;
        background: #f8821d;
    }

    .sns_list{
        margin: 3.2rem 0 0;
        padding: 1.2rem 2rem;
        justify-content: center;
    }

    .sns_item{
        margin-left: 1rem;
        margin-right: 1rem;
    }

    .sns_item-li {
        margin-right: .8rem;
    }

    .sns_link img{
        width: auto;
        height: 2.6rem;
    }

    .sns_item-x img{
        height: 2.4rem;
    }


    /* メインコンテンツ　トップページ
    ----------------------------------------------------*/

    .top_main_slider {
        z-index: 0;
        margin: 0 calc(50% - 50vw);
        width: 126vw;
    }
    
    .top_slider_text{
        right: 2.4rem;
    }

    .top_slider_jp {
        line-height: 1.8rem;
        padding-bottom: .4rem;
    }

    .top_slider_jp-1 {
        font-size: 1.3rem;
    }

    .top_slider_jp-2 {
        font-size: 1.5rem;
    }

    .top_slider_en {
        font-size: 5.6rem;
        line-height: 4.6rem;
    }

    /*トップ共通*/

    .top_section {
        padding-top: 6rem;
        padding-bottom: 8rem;
    }

    .top_header {
        padding-bottom: 4.8rem;
    }

    .top_header_text {
        padding-top: 1.2rem;
    }

    /*プロフィール*/

    .top_profile_intro {
        padding-bottom: 6rem;
    }

    .top_profile_intro_heading {
        width: 100%;
        padding-bottom: 2.4rem;
    }

    .top_profile_intro_text {
        width: 100%;
    }

    .top_profile_main_img {
        width: 64%;
        margin: auto;
        padding-right: 0;
        padding-bottom: 4rem;
    }

    .top_profile_main_body {
        width: 100%;
    }

    .top_profile_main_heading {
        padding-bottom: 3.2rem;
        text-align: center;
    }

    .profile_main {
        padding-bottom: 4rem;
    }

    .profile_name_container {
        padding-bottom: 2rem;
    }
    
    .profile_name{
        padding-right: 1.2rem;
    }

    .profile_position {
        font-size: 1.5rem;
        padding-left: 0;
    }

    .profile_client_heading_sub {
        font-size: 1.4rem;
        padding-left: 1.2rem;
    }

    .client_list {
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .client_item {
        padding: 0 3% 6%;
    }

    .top_profile_link {
        margin-top: 4rem;
    }

    /*SERVICES*/

    .services_list {
        margin: 0;
    }

    .services_item {
        width: 84%;
        margin: auto;
        padding: 0 0 3.2rem;
    }

    .line_bg {
        top: 1rem;
        left: 1rem;
    }

    .services_link {
        padding: 3.2rem 2.8rem 3.6rem;
    }

    .services_img {
        padding-bottom: 1.6rem;
    }

    .services_item:first-child .services_img {
        width: 9.1rem;
    }

    .services_item:nth-child(2) .services_img {
        width: 11rem;
    }

    .services_item:last-child .services_img {
        width: 7.4rem;
    }

    .services_heading_en {
        font-size: 3rem;
        padding-bottom: .6rem;
    }

    .services_heading_jp {
        font-size: 1.4rem;
        padding-bottom: 1.6rem;
    }

    .top_services_link {
        margin-top: 2rem;
    }


    /*WORKS*/

    .works_slider img {
        margin: 0 .3rem;
        height: 18rem;
    }

    .works_slider p {
        margin: .5rem 1rem 0;
        font-size: 1.1rem;
    }

    .top_works_link {
        margin-top: 6rem;
    }

    /*RECOMMENDATION*/
    
    .recommendation_item{
        padding-bottom: 0;
    }
    
    .recommendation_item + .recommendation_item {
        padding-top: 4.8rem;
    }

    .recommendation_item_inner {
        padding: 3.2rem 2.8rem;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .recommendation_img {
        width: 48%;
        padding-bottom: 2.4rem;
    }

    .recommendation_body {
        width: 100%;
    }

    /*CONTACT*/
    .contact_container {
        padding-top: 8rem;
    }

    .contact_header {
        text-align: center;
        padding-bottom: 6.8rem;
    }

    .contact_heading {
        padding-bottom: 3.2rem;
    }

    .contact_form_title {
        padding-bottom: 1rem;
    }

    .contact_form_box {
        margin: 0 0 2.4rem;
    }

    .contact_form_box input,
    .contact_form_box select,
    .contact_form_box textarea {
        padding: 1.2rem 1.6rem;
        font-size: 1.4rem;
    }

    .submit_box {
        width: 80%;
        padding-top: 2rem;
        padding-bottom: 2rem;
        font-size: 2.6rem;
        margin-top: 4.8rem;
    }

    .form_mailer_credit {
        font-size: 1.2rem;
    }


    /* フッター
    ----------------------------------------------------*/

    .main_footer {
        padding-top: 12rem;
        padding-bottom: 4rem;
    }

    .footer_copyright {
        font-size: 1.5rem;
    }

    /*トップへ戻る*/
    .page_top {
        right: 2.4rem;
        bottom: 3rem;
    }

    .page_top img{
        width: 4rem;
    }

    .page_top span{
        font-size: 2.2rem;
        padding-top: .8rem;
    }
    

    /* 下層　PROFILE&VISION
    ----------------------------------------------------*/

    .page_header{
        padding-left: 2.8rem;
        margin-top: 2.8rem;
    }

    .page_header::before{
        width: 1rem;
    }

    .page_section{
        padding-top: 6rem;
        padding-bottom: 8rem;
    }

    .profile_section_heading {
        padding-bottom: 4.8rem;
    }

    .page_profile_main{
        margin-bottom: 6rem;
    }

    .page_profile_main_img {
        width: 60%;
        margin: auto;
        padding-right: 0;
        padding-bottom: 2.8rem;
    }

    .page_profile_main_body {
        width: 100%;
    }
    
    .page_profile_container .profile_name_container{
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        padding-bottom: 2.8rem;
    }
    
    .page_profile_container .profile_position{
        font-size: 1.3rem;
        padding-top: .8rem;
    }

    .profile_works_heading_container {
        padding-bottom: 1.2rem;
    }

    .profile_works_heading_sub{
        font-size: 1.4rem;
        padding-left: 1.2rem;
    }

    .page_profile_link_img{
        width: 100%;
    }

    .page_profile_link_body{
        width: 100%;
        padding-left: 2.8rem;
        padding-right: 2.8rem;
        padding-top: 3.2rem;
        padding-bottom: 3.2rem;
    }

    .page_profile_link_logo{
        width: 10rem;
        padding-bottom: 1.2rem;
    }

    .page_profile_link_text{
        font-size: 1.8rem;
    }

    .page_profile_link_click{
        border-width: 0 9rem 9rem 0;
    }

    .page_profile_link_click span{
        left: 1.6rem;
        top: 2rem;
        font-size: 2.2rem;
        width: 8rem;
    }

    /*VISION*/

    .page_vision_img{
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
    
    .page_visdev_container .sub_heading-1{
        font-size: 4rem;
    }

    .page_vision_sub_heading{
        font-size: 1.8rem;
        padding-bottom: 2.4rem;
    }

    .page_vision_img_list{
        padding-top: 2rem;
    }

    .page_vision_img_list img{
        margin-top: 2rem;
    }

    .page_vision_img_list img:nth-child(1){
        width: 100%;
    }

    .page_vision_img_list img:nth-child(2){
        width: 100%;
    }

    .page_vision_img_list img:nth-child(3){
        width: 100%;
    }

    .page_vision_img_list img:nth-child(4){
        width: 100%;
    }



    /* 下層　SERVICES
    ----------------------------------------------------*/

    .services_intro{
        margin-bottom: 5.2rem;
    }

    .services_intro_header{
        width: 100%;
        padding-bottom: 3.2rem;
    }

    .services_intro_sub_heading{
        font-size: 2rem;
    }

    .services_intro_text{
        width: 100%;
    }

    .services_contents{
        padding-top: 3.2rem;
        padding-bottom: 3.2rem;
    }

    .services_contents_header{
        width: 100%;
        padding-bottom: 2.8rem;
    }

    .services_contents_heading{
        font-size: 2.4rem;
        padding-bottom: 1rem;
    }

    .services_contents_sub_heading{
        font-size: 1.3rem;
    }

    .services_contents_body{
        width: 100%;
    }

    .services_contents_item + .services_contents_item{
        padding-top: .4rem;
    }

    .consulting_img{
        margin-top: 4rem;
        margin-bottom: 4rem;
    }

    .services_achievement{
        padding: 4rem 2.8rem 4rem;
        margin-top: 5rem;
    }

    .services_heading-2{
        padding-bottom: 3.6rem;
    }

    .services_achievement .services_heading-2{
        padding-bottom: 2.4rem;
    }
    
    .services_achievement_item{
        margin-left: 1.8rem;
    }

    /*WORKSHOP*/
    
    .services_contents_text{
        font-size: 1.2rem;
        padding-top: 1rem;
    }

    .workshop_slider_container{
        padding-top: 6rem;
        padding-bottom: 6rem;
    }

    .workshop_slide img{
        margin: 0 .3rem;
        height: 26rem;
    }

    .workshop_menu_container{
        padding-bottom: 8rem;
    }

    .workshop_menu_list{
        margin: 0 ;
    }

    .workshop_menu_item{
        width: 100%;
        padding: 0 0 3.2rem;
    }

    .workshop_menu_inner{
        padding: 3.2rem 2.8rem;
    }

    .workshop_menu_sub_heading{
        font-size: 1.4rem;
        padding-bottom: .6rem;
    }

    .workshop_menu_heading{
        font-size: 1.7rem;
        padding-bottom: 1.4rem;
    }
    
    .workshop_menu_link{
        font-size: 1.4rem;
    }

    .workshop_program_container{
        padding-bottom: 2rem;
    }

    .workshop_program_inner{
        padding: 4rem 2.8rem;
    }

    .workshop_program_heading{
        font-size: 1.8rem;
        line-height: 1.3;
        padding-bottom: 2.4rem;
    }

    .workshop_program_list{
        padding-bottom: 1.6rem;
    }

    .workshop_program_item{
        padding-top: 2rem;
        padding-bottom: 2rem;
    }

    .workshop_program_header{
        margin-bottom: 1rem;
    }

    .workshop_program_number{
        width: 20%;
        font-size: 3.4rem;
    }

    .workshop_program_title{
        width: 80%;
    }
    
    .workshop_program_text{
        font-size: 1.2rem;
    }

    .workshop_voice_container{
        padding-top: 6rem;
    }

    .voice_list{
        margin: 0 0;
    }

    .voice_item{
        width: 100%;
        padding: 0 0 4rem;
    }

    .voice_inner{
        padding: 2.8rem 2.8rem;
    }


    .voice_name{
        font-size: 1.3rem;
        padding-top: .8rem;
    }

    /*SEMINAR*/

    .seminar_img{
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .seminar_theme_container{
        padding-bottom: 6rem;
    }

    .seminar_theme_list{
        margin: 0;
    }

    .seminar_theme_item{
        width: 100%;
        padding: 0 0 3.2rem;
    }

    .seminar_theme_inner{
        padding: 2.8rem 2.8rem;
    }

    .seminar_theme_heading {
        font-size: 1.6rem;
        padding-bottom: 1.2rem;
    }

    .seminar_voice_sub_heading{
        font-size: 1.3rem;
    }

    /* 下層　COMPANY
    ----------------------------------------------------*/

    .company_section_heading{
        width: 86%;
        margin: 0 auto 4rem;
    }

    .page_company_main dt{
        width: 30%;
        padding-bottom: 1.2rem;
    }

    .page_company_main dd{
        width: 70%;
        padding-bottom: 1.2rem;
    }

}

@media print,
screen and (max-width: 320px) {
    html {
        font-size: 56%;
    }
}
