@charset "utf-8";

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

    body {
        height: auto;
        padding-bottom: 4em;
    }

    #pagetop {
        width: 3em;
        bottom: 4.5em;
        right: 0.5em;
    }
    
    .custom .header_menu {
        display: none;
    }
    .custom header .util {
        display: none;
    }
    .custom header.flex {
        align-items: center;
        justify-content: center;
        padding: 0.5em;
        height: 50px;
        min-height: auto;
        box-sizing: border-box;
        position: fixed;
        width: 100%;
        top: 0;
        left: 0;
        z-index: 100000000;
        background: #fff;
        box-sizing: border-box;
    }

    #panel-btn {
        display: inline-block;
        position: absolute;
        width: 40px;
        height: 40px;
        margin: 0;
        border-radius: 50%;
        background: none;
        margin-left: 0;
        top: 0.3em;
        right: 0.5em;
    }
    #panel-btn:hover { background: none; }
    #panel-btn-icon {
        display: block;
        position: absolute;
        top: 50%;
        left: 50%;
        width: 30px;
        height: 2px;
        margin: -1px auto 0 -15px;
        background: #81ab53;
        transition: .2s;
        z-index: 10000000000;
    }
    #panel-btn-icon:before, #panel-btn-icon:after {
        display: block;
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        width: 30px;
        height: 2px;
        margin-left: -15px;
        background: #81ab53;
        transition: .3s;
    }
    #panel-btn-icon:before { margin-top: -8px; }
    #panel-btn-icon:after { margin-top: 6px; }
    
    #panel-btn .close { background: transparent; }
    #panel-btn .close:before, #panel-btn .close:after { margin-top: 0; }
    #panel-btn .close:before { transform: rotate(-45deg); -webkit-transform: rotate(-45deg); }
    #panel-btn .close:after { transform: rotate(-135deg); -webkit-transform: rotate(-135deg); }
    
    .sp_menu_bloc {
        position: absolute;
        background: #fff;
        width: 100%;
        height: calc(100vh - 50px);
        margin: 0;
        padding: 1em;
        box-sizing: border-box;
        z-index: 10000000;
        top: 50px;
        left: 0;
        border-top: solid 1px #81ab53;
        border-bottom: solid 1px #81ab53;
        text-align: left;
        overflow-y: scroll;
    }
    .sp_menu_bloc .sp_menu {

    }
    .sp_menu_link_cell {
    
    }
    .sp_menu_link_cell + .sp_menu_link_cell {
        border-top: solid 1px #81ab53;
        margin-top: 0.5em;
        padding-top: 0.5em;
    }
    
    .sp_menu_link_cell ul {
    
    }
    .sp_menu_link_cell ul li {
    
    }
    .sp_menu_link_cell ul li.lv1 {
        font-size: 4vw;
    }
    .sp_menu_link_cell ul li.lv2 {
        font-size: 4vw;
        margin-left: 1em;
    }
    
    .sp_menu_link_cell ul li a {
        display: block;
        text-decoration: none;
        padding: 0.25em;
    }
    
    main {
        padding-top: 50px;
    }
    
    .custom footer {
        margin-top: 2em;
    }
    .footer_catch {
        margin-bottom: 0;
    }
    .footer_catch p {
        font-size: 5vw;
    }
    .footer_menu {
        display: none;
    }
    .copyright {
        padding: 1em;
    }
    .copyright small {
        display: block;
        font-size: 10px;
        line-height: 1em;
    }
    
    
    
    
    
    .mvs > p {
        width: 100%;
        margin: 0;
        box-sizing: border-box;
        padding: 0.5em;
        font-size: 5vw;
    }
    
    .mvs_content {
        /*height: calc(100vh - 50px);*/
        /*height: 50vh;*/
        height: 133vw;
    }
    .mvs_content > div:first-child {
        background-size:cover!important;
    }
    .mvs_content_back .inner p {
        font-size: 10vw;
        top: 0;
        right: 0;
    }
    
    .mvs_bottom {
        padding: 1em 0.5em
    }
    .mvs_bottom_bloc h2 {
        font-size: 4vw;
    }
    .mvs_bottom_bloc p {
        font-size: 3vw;
    }
    
    .mvs_bottom:after {
        background-position: center bottom;
        height: 68%;
        bottom: auto;
        top: -3em;
        right: 0;
    }
    .points {
        padding: 2em 0;
    }
    .points_title {
        margin-bottom: 1em;
    }
    .points_title h2 span {
        font-size: 20vw;
        line-height: 1em;
    }
    .points_title h2 em {
        font-size: 8vw;
        line-height: 1em;
        margin-bottom: 0.1em;
    }
    .points_title p {
        font-size: 3vw;
        top: 2em;
        left: 3.5em;
    }
    .points_bloc {
        gap: 1em;
    }
    .points_item {
        max-width: none;
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        gap: 1em;
    }
    .points_item figure {
        width: 20%;
        margin: 0;
    }
    .points_item .box {
        flex: 1 0 0%;
    }
    .points_item .box .num {
        font-size: 10vw;
        line-height: 1em;
    }
    .points_item .box p {
        font-size: 3vw;
    }
    
    .facilitys {
        padding: 2em 0;
    }
    
    .facilitys_shibuya:after {
        display:none;
    }
    .facilitys_shoinji:after {
        display:none;
    }
    .facilitys_gakugei:after {
        display:none;
    }
    
    .facilitys_item + .facilitys_item {
        margin-top: 2em;
    }
    .facilitys_item {
        height: auto;
    }
    .facilitys_item figure {
        margin-bottom: 1em;
    }
    .facilitys_bloc .catch p {
        font-size: 4.2vw;
        text-align: center;
    }
    .facilitys_bloc .meta {
        align-items: center;
        justify-content: center;
    }
    .facilitys_bloc .meta h4 {
        font-size: 5vw;
    }
    .facilitys_bloc .meta p {
        font-size: 4vw;
    }
    .facilitys_bloc .cell p {
        font-size: 3vw;
    }
    
    .facilitys_bloc .picto ul li i {
        width: 40%;
        margin: 0 auto 0.2em;
    }
    .facilitys_bloc .picto ul li span {
        font-size: 3vw;
    }
    
    .more {
        font-size: 4vw;
        padding: 1em
    }
    
    .custom .information {
        padding: 2em 0;
    }
    
    .information_list article dl {
        font-size: 3.5vw;
        gap: 0;
    }
    .information_list article dl dt {
        width: 100%;
        font-size: 3vw;
        text-align: left;
    }
    
    .custom .insta_sec {
        padding: 2em 0;
    }
    
    .custom .recruit_list ul li {
        width: 100%;
    }
    .custom .recruit_list ul li a figure {
        width: 25%;
    }
    .custom .recruit_list ul li a .box h4 {
        font-size: 4vw;
        margin-bottom: 0;
    }
    .custom .recruit_list ul li a .box p {
        font-size: 4vw;
    }
    
    
    
    
    
    
    .pages_upper {
        padding: 1em 0;
    }
    .pages_upper_bloc h2 {
        font-size: 4vw;
    }
    .pages_upper_bloc p {
        font-size: 3vw;
    }
    
    .under_mv {
        padding: 1em 0;
    }
    .under_mv_catch {
        margin-top: 1em;
    }
    .under_mv_catch h3 {
        font-size: 4vw;
    }
    .under_mv_catch p {
        font-size: 3vw;
    }
    
    
    .slick-next {
        width: 20px;
        height: 20px;
        right: -7px;
        z-index: 10;
    }
    .slick-prev {
        width: 20px;
        height: 20px;
        left: -7px;
        z-index: 10;
    }
    
    
    
    .shop_service {
        padding: 2em 0;
    }
    .shop_service_list {
        gap: 2em;
        margin-bottom: 2em;
    }
    .shop_service_item {
        max-width: none;
    }
    .shop_service_item figure {
        width: 80%;
        margin: 0 auto 1em;
    }
    .shop_service_item .meta h4 em {
        font-size: 5vw;
    }
    .shop_service_item .meta h4 span {
        font-size: 3vw;
    }
    .shop_service_item .box h5 {
        font-size: 5vw;
    }
    .shop_service_item .box p {
        font-size: 3.5vw;
    }
    
    .rsv_btn_bloc ul {
        gap: 1em;
    }
    
    .shop_facility {
        padding: 2em 0;
    }
    
    .shop_facility_data dl {
        overflow: hidden;
        gap: 0;
        padding: 0.5em;
    }
    .shop_facility_data dl dt {
        width: 100%;
        font-size: 3.5vw;
    }
    .shop_facility_data dl dd {
        flex: none;
        width: 100%;
        font-size: 3.5vw;
    }
    
    .shop_facility_data dl dd ul li {
        width: calc(100% / 2 - 1em);
    }
    
    .shop_hours {
        padding: 2em 0;
    }
    .shop_hours_data {
        overflow-x: auto;
    }
    .times_table {
        white-space: nowrap;
        font-size: 3vw;
    }
    .times_table tbody td.w span {
        font-size: 3vw;
    }
    .times_table tbody td.w i {
        width: 1em;
        height: 1em;
        background-size: contain;
    }
    .times_table tbody th .cell img {
        display: none;
    }
    
    .times_desc ul li {
        font-size: 3vw;
    }
    
    .shop_cal .calendar-box {
		width:100%;
		margin: 0 auto;
		flex-direction: column; /*たて1列に*/
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
	}
	.shop_cal .calendar-box-in {
		width: 90%;
        border: 1px solid #81AB52;
		margin: 0 auto 20px;
		padding: 5% 4% 3%;
        box-sizing: border-box;
        position: static;
	}
    
    .shop_cal .calendar-box-in p {
    font-size: 1.2em;
    margin: 0 0 .5em;
    padding: .2em 0;
}
    .shop_cal h4 {
    font-size: 1.1em;
    line-height: 1em;
    margin-bottom: 15px;
}
.shop_cal p {
    font-size: 1.2em;
    line-height: 1.1em;
    margin-bottom: 40px;
}
    .tbl-calendar {
	width:100%;
	text-align:center;
	margin: 0 auto 10px;
}
    .tbl-calendar th,
.tbl-calendar td {
	padding: 10px 5px;
	font-size: 1em;
	border:2px solid #fff;
}
    
	.calendar-description {
		width:100%;
        position: static;
	}
    .calendar-description li {
    font-size: 1em;
}
.calendar-description li span.cl-tt-off {
    font-size: 1.6em;
}
    
    .shop_info {
        padding: 2em 0;
    }
    
    .shop_list {
        padding: 2em 0;
    }
    .shop_list_bloc ul {
        gap: 1em;
    }
    .shop_list_bloc ul li .box .cell i {
        margin-bottom: 0.5em;
    }
    .shop_list_bloc ul li .box .cell span {
        font-size: 4vw;
    }
    
    .service_item {
        gap: 1em;
        margin-bottom: 2em;
    }
    .service_content {
        flex: none;
        width: 100%;
        padding: 0;
    }
    .service_item figure {
        width: 80%;
        margin: 0 auto;
    }
    .service_content .applicable ul {
        gap: 0.5em;
    }
    .service_content .applicable ul li {
        font-size: 4vw;
        line-height: 1em;
        padding: 0.7em 1em 0.5em;
    }
    .service_content .meta {
        gap: 0.5em;
    }
    .service_content .meta h4 em {
        font-size: 5vw;
    }
    .service_content .meta h4 span {
        font-size: 3vw;
    }
    .service_content .box h5 {
        font-size: 5vw;
    }
    .service_content .box p {
        font-size: 3.5vw;
    }
    .service_content .meta i {
    
    }
    .service_content .meta i img {
        width: 2em;
        display: inline-block;
    }
    
    .service_matter {
        padding: 2em 0;
    }
    .medical_subject_list {
        gap: 2em;
    }
    .medical_subject_item .meta h4 em {
        font-size: 5vw;
    }
    .medical_subject_item .meta h4 span {
        font-size: 3vw;
    }
    .medical_subject_item .meta i {
        font-size: 10vw;
    }
    .medical_subject_item .box p {
        font-size: 3.5vw;
    }
    
    .medical_subject_item .box ul {
        gap: 0.5em;
        margin-top: 1em;
    }
    .medical_subject_item .box ul li a {
        font-size: 3vw;
    }
    .medical_subject_item .box ul li {
        min-width: calc(100% / 2 - 0.25em);
        text-align: center;
    }
    
    .ddc_flow {
    padding: 0;
}

.ddc_flow h4 {
    font-family: 'EB Garamond', serif;
    color: #81ab52;
    font-size: 1.1em;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 15px;
    text-align: center;
}
.ddc_flow p {
    font-size: 1.2em;
    line-height: 1.5em;
    font-weight: bold;
    margin-bottom: 40px;
    text-align: center;
}
    
    
.ddc_flow p br {
    display: block;
}
    
    .service_flow h3 {
        display: block;
    font-size: 1.2em;
        line-height: 1em;
    color: #fff;
    text-align: left;
    font-weight: bold;
    background-color: #80AB52;
    padding: 10px 20px;
    margin: 0 0 20px 0;
}
    
    .service_flow h3 span {
    font-family: 'EB Garamond', serif;
    font-weight: normal;
        padding: 0 .5em 0 0;
}
    
.service_ddc_flow {
    margin: 0 auto 20px;
    padding: 20px;
    background-color: #FFFFFF;
    box-sizing: border-box;
}

    .service_flow_item {
        gap: 1em;
    }
    
    #flow .service_flow_item {
        align-items: normal;
        gap: 0;
    }
    
    .service_flow_item .num {
        max-width: 123px;
        width: 60px;
    }
    #flow .service_flow_item .num {
        display: none;
    }
    .service_flow_item .num:after {
        left: 30px;
    }
    
    .flow_box {
        padding-top: 1em;
    }
    
    #flow .flow_box {
        padding-top: 0;
    }

    .flow_box h4 {
        font-size: 3vw;
    }
    .flow_box .box {
        margin: 0;
    }
    #flow .flow_box .box {
        margin: 0 0 20px;
    }
    .flow_box .box.focus {
        padding: 1em;
    }
    
    .flow_box .box.line {
        margin: 20px 0 0
}
    
    .flow_box .box h5 {
        font-size: 3vw;
    }
    .flow_box .box .item h6 {
        font-size: 3vw;
    }

    .flow_box .box ul.list li {
        font-size: 3vw;
    }
    .flow_box .box p.mark {
        font-size: 3vw;
    }
    .flow_box .box dl {
        font-size: 3vw;
    }
    
    .flow_box p {
        font-size: 3vw;
    }
    
    .ddc_flow_item_type {
    width: 100%;
    text-align: center;
}

.ddc_flow_item_type a figure img {
    width: 100%;
    transition: .2s;
}
.ddc_flow_item_type a:hover figure img {
    opacity:0.8;
}

.ddc_flow_item_type p {
    font-size: .9em;
    margin: 20px 0 30px 0;
}

.ddc_flow_item_type .tel {
    font-size: 1.3em;
    margin: 20px 0 0 0;
}

.ddc_flow_item_type .tel:before {
content: "";
width: 30px;
height: 30px;
display: inline-block;
position: relative;
top: -5px;
    left: -10px;
background-image: url(../images/img_training_tel_i.png);
background-size: contain;
background-repeat: no-repeat;
vertical-align: top;
}

.ddc_flow_item_type .tel a {
    text-decoration: none;
}

.ddc_flow_item_type h3 {
    font-size: 1.2em;
    margin: 0;
    font-weight: bold;
}

.ddc_flow_item_type .mail {
    margin: 30px 0 0 0;
}

.ddc_flow_item_type .mail a {
    font-size: 1.4em;
    text-decoration: none;
}

.ddc_flow_item_type .mail a:before {
content: "";
width: 45px;
height: 45px;
display: inline-block;
position: relative;
top: -10px;
    left: -10px;
background-image: url(../images/img_training_mail_i.png);
background-size: contain;
background-repeat: no-repeat;
vertical-align: top;
}

.flow_box h6 {
    font-size: .9em;
    margin: 0 0 20px 0;
}
    
    
    .link {
        min-width: auto;
        font-size: 3vw;
        padding: 1em;
        padding-right: 3.5em;
    }
    .link:after {
        width: 20px;
        height: 20px;
        background-size: contain;
    }
    .link:hover:after {
        width: 20px;
        height: 20px;
        background-size: contain;
    }
    
    .link_training {
        min-width: auto;
        font-size: 3vw;
        padding: 1em;
        padding-right: 3.5em;
    }
    .link_training:after {
        width: 20px;
        height: 20px;
        background-size: contain;
    }
    .link_training:hover:after {
        width: 20px;
        height: 20px;
        background-size: contain;
    }
    
    
    
    .service_fee_bloc dl {
        font-size: 4vw;
    }
    
    .hospital_equipment ul {
        gap: 1em;
    }
    .hospital_equipment ul li {
        width: calc(100% / 2 - 0.5em);
    }
    .hospital_equipment ul li p {
        font-size: 3.5vw;
    }
    
    .foamy_bloc ul {
        gap: 1em;
        margin-bottom: 1em;
    }
    .foamy_bloc ul li {
        width: calc(100% / 2 - 0.5em);
    }
    .foamy_bloc ul li.logo {
        padding: 0;
        width: 100%;
        text-align: center;
    }
    .foamy_bloc ul li.logo img {
        display: block;
        width: 32%;
        margin: 0 auto;
    }
    .foamy_bloc p {
        font-size: 3.5vw;
    }
    
    .ddc_guide {
    padding:3em 0;
}

.ddc_guide h4 {
    font-size: 1.1em;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 15px;
    text-align: center;
}
.ddc_guide p {
    font-size: 1.2em;
    line-height: 1.52em;
    font-weight: bold;
    margin-bottom: 40px;
    text-align: center;
}
    
    .service_guide_bloc {
        border: solid 1px #81ab51;
        padding: 1em;
        margin-bottom: 2em;
    }
    .service_guide_bloc .box h4 {
        font-size: 4vw;
    }
    .service_guide_bloc .box p {
        font-size: .9em;
    }
    
    .service_guide_bloc .box li {
    font-size: 3.5vw;
}
    
    .service_guide_bloc .btn_bloc ul {
        gap: 1em;
    }
    .service_guide_bloc .btn_bloc ul li {
        width: 100%;
    }
    .service_guide_bloc .btn_bloc ul li .link {
        width: 100%;
        box-sizing: border-box;
    }
    
    .service_fee {
    
    }
    .service_fee p {
        font-size: 3.5vw;
    }
    
    .service_fee .btn_bloc ul {
        gap: 1em;
    }
    .service_fee .btn_bloc ul li {
        width: 100%;
    }
    .service_fee .btn_bloc ul li .link {
        width: 100%;
        box-sizing: border-box;
    }
    
    .service_fee .btn_bloc {
        margin-top: 1em;
    }
    
    .ddc_guide .tel_box .tel {
    font-size: 1.5em;
    margin: 10px 0 0 0;
}

.ddc_guide .tel_box .tel:before {
content: "";
width: 30px;
height: 30px;
top: 0px;
    left: -10px;
}

.ddc_guide .tel_box h3 {
    font-size: 1.1em;
    margin: 0;
    font-weight: bold;
    text-align: center;
}

.ddc_guide .tel_box p {
    font-size: .9em;
    margin: 20px 0 0 0;
}
    
    .pethotel_item h4 {
        font-size: 4vw;
    }
    .pethotel_item p {
        font-size: 3.5vw;
    }
    
    
    .pethotel_type {
        gap: 1em;
    }
    .pethotel_type .item {
        max-width: none;
        width: calc(100% / 2 - 0.5em);
    }
    .pethotel_type .item .meta {
        height: 4em;
    }
    .pethotel_type .item .meta h4 {
        font-size: 4vw;
    }
    .pethotel_type .item .meta p {
        font-size: 3vw;
    }
    .pethotel_type .item figure {
        margin-bottom: 0.5em;
    }
    .pethotel_type .item > p {
        font-size: 3vw;
    }
    
    .service_course_bloc + .service_course_bloc {
        margin-top: 1em;
    }
    .service_course_bloc {
        padding: 1em;
    }
    .service_course_bloc h4 {
        font-size: 5vw;
    }
    .service_course_bloc .item .menu dl {
        gap: 0.5em;
    }
    .service_course_bloc .item .menu dl dt {
        font-size: 3vw;
        padding: 0.7em 0.5em 0.5em;
    }
    .service_course_bloc .item .menu dl dd {
        font-size: 3.5vw;
    }
    .service_course_bloc .item .box h5 {
        font-size: 4vw;
    }
    .service_course_bloc .item .box p {
        font-size: 3vw;
    }
    
    .nursingcare_oneday .item:after {
        display:none;
    }
    
    .nursingcare_oneday {
        gap: 1em;
    }
    .nursingcare_oneday .item {
        max-width: none;
    }
    .nursingcare_oneday .item figure {
        width: 80%;
        margin: 0 auto 1em;
    }
    .nursingcare_oneday .item .box h4 {
        font-size: 4vw;
    }
    .nursingcare_oneday .item .box p {
        font-size: 3vw;
        text-align: center;
    }
    
    .service_fitness p {
        font-size: 3vw;
    }
    .service_fitness figure {
        width: 50%;
        margin: 0 auto;
    }
    
    .service_fitness_equipment {
        gap: 1em;
    }
    .fitness_equipment_item {
        max-width: none;
    }
    .fitness_equipment_item figure {
        width: 80%;
        margin: 0 auto 1em;
    }
    .fitness_equipment_item .box h4 {
        font-size: 4vw;
        text-align: center;
    }
    .fitness_equipment_item .box p {
        font-size: 3vw;
    }
    
    .service_fitness_equipment:after {
        display:none;
    }
    
    .service_training_policy p {
        font-size: 4vw;
    }
    
    .service_ddc {
        gap: 1em;
    }
    
    .ddc_type {
    max-width:90%;
    margin:0 auto;
}
    
    .ddc_item .meta i {
        font-size: 10vw;
        line-height: 10vw;
    }
    .ddc_item .meta h4 {
        font-size: 4vw;
        line-height: 1em;
    }
    .ddc_item .box p {
        font-size: 3vw;
    }
    
    .service_training_menu ul {
        gap: 1em;
    }
    .service_training_menu ul li {
        width: calc(100% / 2 - 0.5em);
    }
    .service_training_menu ul li h4 {
        font-size: 3.5vw;
    }
    
    
    .ddc_club {
    max-width: 94%;
    margin: 0 auto;
    padding: 30px 20px 60px;
    background-color: #ECFBDA;
    border-radius: 16px;
        box-sizing: border-box;
}

.ddc_club_ttl {
    margin-bottom: 30px;
}

.ddc_club_ttl figure {
    margin-bottom: 0.5em;
}
    
.ddc_club_ttl figure img {
    display: block;
    width: 20%;
    margin: 0 auto 0.5em;
}

.ddc_club_ttl h3 {
    font-size: 1.6em;
    line-height: 1.6em;
    font-weight: bold;
    margin-bottom: 0.2em;
}

.ddc_club_ttl p {
    font-size: 1.2em;
    line-height: 1em;
    font-weight: bold;
    margin-bottom: 0.2em;
}

.ddc_club_about {
    width: 100%;
    padding: 20px;
    margin-bottom: 0;
    border-radius: 10px;
    box-sizing: border-box;
}

.ddc_club_about h4 {
    font-size: 1.1em;
    line-height: 1.6em;
    font-weight: bold;
    margin-bottom: 1em;
    text-align: left;
}

.ddc_club_about p {
    font-size: 1em;
    line-height: 2.1em;
    margin-bottom: 40px;
    text-align: left;
}
    
.ddc_club_about p br {
    display: none;
}

.ddc_club_about .list_box {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    border: 2px #95AF27 solid;
    border-radius: 6px;
}

.ddc_club_about .list_box .top_txt {
    font-size: .8em;
    top: 0;
    left: 50%;
    width: 96%;
    padding: 5px 0;
    box-sizing: border-box;
    transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
    background-color: #80AB52;
    border-radius: 30px;
}

.ddc_club_about .list_box ul {
margin: 40px 0 0 0;
padding: 0;
gap: 1.5em;
}

.ddc_club_about .list_box ul li {
    width: 100%;
    list-style-type: none;
    font-size: 1em;
    margin: 0;
    padding: 0 0 0 2.5em;
    text-align: left;
    font-weight: bold;
}

.ddc_club_about .list_box ul li:before {
content: url(../images/img_training_dcc_list_i.png);
width: 33px;
height: 33px;
position:absolute;
top:-5px;
left:0;
}


.ddc_club_program {
    width: 100%;
    text-align: center;
    padding: 50px 0;
    margin-bottom: 10px;
    box-sizing: border-box;
}

.ddc_club_program h4 {
    font-family: 'EB Garamond', serif;
    color: #81ab52;
    font-size: 1.1em;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 15px;
}
.ddc_club_program p {
    font-size: 1.2em;
    line-height: 1.3em;
    font-weight: bold;
    margin-bottom: 80px;
}

.ddc_club_program .list_box {
    width: 100%;
    padding: 0;
    box-sizing: border-box;
}

.ddc_club_program .list_box ul {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin: 20px 0 0 0;
padding: 0;
box-sizing: border-box;
gap: 4em .5em;
}

.ddc_club_program .list_box ul li {
    width: 48%;
    list-style-type: none;
    margin: 0;
    padding: 2.5em 0 20px;
    position: relative;
    text-align: left;
    font-weight: bold;
    position: relative;
    background-color: #80AB52;
    color: #FFFFFF;
    border-radius: 16px;
}

.ddc_club_program .list_box ul li .top_num {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    font-size: 2em;
    color: #FFFFFF;
    text-align: center;
    position: absolute;
    top: 0;
    left: 50%;
    padding: 0;
}

.ddc_club_program .list_box ul li h5 {
    font-size: 1.2em;
    line-height: 1.6em;
    font-weight: bold;
    margin: 0 0 15px 0;
    text-align: center;
}

.ddc_club_program .list_box ul li figure {
    text-align: center;
    margin: 0 0 15px 0;
}
    
.ddc_club_program .list_box ul li figure img {
    width: 60%;
}

.ddc_club_program .list_box ul li p {
    font-size: 1em;
    line-height: 1.5em;
    margin: 0;
    padding: 0 15px;
}

.ddc_club_flow {
    width: 100%;
    text-align: center;
    padding: 0;
    margin-bottom: 30px;
    border-radius: 10px;
    box-sizing: border-box;
}

.ddc_club_flow h4 {
    font-size: 1.2em;
    line-height: 1.6em;
    font-weight: bold;
    margin: 0 0 30px 0;
    padding: 15px 0;
    background-color: #80AB52;
    color: #FFFFFF;
}

.ddc_club_flow dl {
display:flex;
flex-wrap: wrap;
    box-sizing: border-box;
}

.ddc_club_flow dt {
    font-size: 1.1em;
    background-color: #BC9842;
    width: 20%;
    margin: 0 0 20px 0;
    padding: 10px;
    box-sizing: border-box;
    color: #FFFFFF;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ddc_club_flow dd {
    display: block;
    align-items: center;
padding: 10px;
margin: 0 0 20px 0;
width: 80%;
background: #fff;
box-sizing: border-box;
    border: 2px #BC9842 solid;
}
    
.ddc_club_flow dd:nth-of-type(3) {
padding: 60px 10px;
}

.ddc_club_flow dd h5 {
    font-size: 1em;
    text-align: left;
    width: 100%;
    margin: 0 0 5px 0;
    padding: 0;
    box-sizing: border-box;
    color: #BC9842;
    font-weight: bold;
}

.ddc_club_flow dd p {
    font-size: .9em;
    text-align: left;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.ddc_club_btn {
    width: 100%;
    text-align: center;
    padding: 0;
}

.ddc_club_btn p {
    margin: 0 0 20px 0;
    padding: 0;
}

.ddc_club_btn p a img {
    transition: .2s;
}
.ddc_club_btn p a:hover img {
    opacity:0.8;
}

.ddc_personal {
    max-width: 94%;
    margin: 0 auto 40px;
    padding: 50px 20px;
    border-radius: 16px;
    box-sizing: border-box;
}

.ddc_personal_ttl {
    text-align: center;
    margin-bottom: 30px;
}

.ddc_personal_ttl figure {
    margin-bottom: 0.5em;
}
    
.ddc_personal_ttl figure img {
    display: block;
    width: 25%;
    margin: 0 auto 0.5em;
}

.ddc_personal_ttl h3 {
    font-size: 1.2em;
    line-height: 1.6em;
    font-weight: bold;
    margin-bottom: 0.2em;
}

.ddc_personal_ttl p {
    font-size: 1.1em;
    line-height: 1em;
    font-weight: bold;
    margin-bottom: 0.2em;
}

.ddc_personal_about {
    width: 100%;
    background: #fff;
    text-align: center;
    padding: 20px;
    margin-bottom: 0;
    border-radius: 10px;
    box-sizing: border-box;
}

.ddc_personal_about h4 {
    font-size: 1.1em;
    line-height: 1.6em;
    font-weight: bold;
    margin-bottom: 1em;
    text-align: left;
}

.ddc_personal_about p {
    font-size: 1em;
    line-height: 2.1em;
    margin-bottom: 40px;
    text-align: left;
}
    
.ddc_personal_about p br {
    display: none;
}

.ddc_personal_about .list_box {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    border: 2px #446023 solid;
    border-radius: 6px;
}

.ddc_personal_about .list_box .top_txt {
    font-size: .8em;
    top: 0;
    left: 50%;
    width: 96%;
    padding: 5px 0;
    box-sizing: border-box;
    transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
    background-color: #446023;
    border-radius: 30px;
}

.ddc_personal_about .list_box ul {
margin: 40px 0 0 0;
padding: 0;
box-sizing: border-box;
gap: 1.5em;
}

.ddc_personal_about .list_box ul li {
    width: 100%;
    list-style-type: none;
    font-size: 1em;
    margin: 0;
    padding: 0 0 0 2.5em;
    position: relative;
    text-align: left;
    font-weight: bold;
}

.ddc_personal_about .list_box ul li:before {
content: url(../images/img_training_personal_list_i.png);
width: 33px;
height: 33px;
position:absolute;
top:-5px;
left:0;
}

.ddc_personal_onayami {
    width: 100%;
    text-align: center;
    padding: 30px 0 0;
    margin-bottom: 20px;
    box-sizing: border-box;
}

.ddc_personal_onayami h4 {
    font-size: 1.2em;
    line-height: 1.5em;
    font-weight: bold;
    margin-bottom: 40px;
}

.ddc_personal_onayami .list_box {
    width: 100%;
    margin: 0 0 30px 0;
    padding: 0;
    box-sizing: border-box;
}

.ddc_personal_onayami .list_box ul {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin: 20px 0 0 0;
padding: 0;
box-sizing: border-box;
gap: 1em .3em;
}

.ddc_personal_onayami .list_box ul li {
    list-style-type: none;
    width: 47%;
    margin: 0;
    padding: 0;
    text-align: left;
    font-weight: bold;
}

.ddc_personal_onayami p {
    font-size: 1em;
    line-height: 1.5em;
    margin: 0;
    text-align: left;
}

.ddc_personal_btn {
    width: 100%;
    text-align: center;
    padding: 0;
}

.ddc_personal_btn p {
    margin: 0 0 20px 0;
    padding: 0;
}

.ddc_personal_btn p a img {
    transition: .2s;
}
.ddc_personal_btn p a:hover img {
    opacity:0.8;
}

.ddc_event_btn p  {
    width: 80%;
    text-align: center;
    margin: 0 auto;
}

.ddc_event_btn p a img {
    transition: .2s;
}
.ddc_event_btn p a:hover img {
    opacity:0.8;
}

.ddc_price {
    max-width: 100%;
    margin: 0 auto;
    padding: 30px 20px 0;
}

.ddc_price h4 {
    font-family: 'EB Garamond', serif;
    color: #81ab52;
    font-size: 1.1em;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 15px;
    text-align: center;
}
    
.ddc_price_item h6 {
    font-size: 1em;
    padding: 0;
    margin: 20px 0;
}
.ddc_price p {
    font-size: 1.2em;
    line-height: 1em;
    font-weight: bold;
    margin-bottom: 10px;
    text-align: center;
}

.ddc_price_box {
    gap: 0;
}

.ddc_price_item {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.ddc_price_item h5 {
    font-size: 1.2em;
    color: #fff;
    text-align: center;
    font-weight: bold;
    background-color: #80AB52;
    padding: 10px 0;
    margin: 0 0 20px 0;
}

.ddc_price_item table {
	margin: 0 0 30px 0;
    padding: 0;
}

.ddc_price_item table th {
    font-size: .9em;
    padding-top: 12px;
    padding-right: 0;
    padding-left: 0;
    padding-bottom: 12px;
    width: 30%;
    box-sizing: border-box;
}

.ddc_price_item table td {
    font-size: .8em;
    text-align: center;
    border-bottom: 1px solid #94AE27;
    padding: 12px 0;
    border-left: 1px solid #94AE27;
    box-sizing: border-box;
    font-weight: bold;
}

.ddc_price_item table td.price {
    font-size: 1em;
    text-align: right;
    padding: 0 10px 0 0;
}

.ddc_price_item table td.price span {
    font-size: .7em;
}

.ddc_price_item p {
    font-size: .9em;
    line-height: 1.5em;
    text-align: left;
}
    
    
    
    
    
    

    .service_cafe {
        gap: 1em;
    }
    .service_cafe figure {
        width: 80%;
        margin: 0 auto;
    }
    .cafe_bloc .meta h4 {
        font-size: 5vw;
        text-align: center;
    }
    .cafe_bloc .meta p {
        font-size: 3vw;
    }
    .cafe_bloc .box h5 {
        font-size: 4vw;
    }
    .cafe_bloc .box ul {
        font-size: 3vw;
    }
    .cafe_bloc .box p {
        font-size: 3vw;
    }
    
    .cafe_bloc .btn_bloc ul li {
        width: 100%;
    }
    
    .faq_content {
        padding: 2em 0;
    }
    .faq_guide_bloc p {
        font-size: 3.5vw;
        text-align: left;
    }
    .faq_guide_bloc ul {
        gap: 1em;
    }
    .faq_guide_bloc ul li a {
        font-size: 3vw;
    }
    
    .faq_bloc dl dt {
        font-size: 4vw;
    }
    .faq_bloc dl dd {
        font-size: 3vw;
    }
    
    .company_content {
        padding: 2em 0;
    }
    .koyaru_bloc figure {
        width: 80%;
        margin: 0 auto 1em;
    }
    .koyaru_bloc .box {
        flex: none;
        width: 100%;
        margin: 0;
    }

    .koyaru_bloc .box .ttl {

    }
    .koyaru_bloc .box .ttl p {
        font-size: 4vw;
        text-align: center;
    }
    .koyaru_bloc .box .ttl h4 {
        font-size: 5vw;
        text-align: center;
    }
    .koyaru_bloc .box h5 {
        font-size: 5vw;
        text-align: center;
    }




    .koyaru_bloc .box p {
        font-size: 3.5vw;
    }
    
    .advertisement_bloc  figure {
        width: 80%;
        margin: 0 auto 1em;
    }
    .advertisement_bloc  .box {
        flex: none;
        width: 100%;
        margin: 0;
    }
    .advertisement_bloc .box .ttl {

    }
    .advertisement_bloc .box .ttl p {
        font-size: 4vw;
        text-align: center;
    }
    .advertisement_bloc .box .ttl h4 {
        font-size: 5vw;
        text-align: center;
    }
    .advertisement_bloc .box h5 {
        font-size: 5vw;
        text-align: center;
    }
    .advertisement_bloc  .box p {
        font-size: 3.5vw;
    }
    
    .outline_bloc .box {
        flex: none;
        margin-right: 0;
        margin-bottom: 1em;
        width: 100%;
    }
    
    .outline_bloc .box dl {
        padding: 0.5em;
        gap: 0;
    }
    .outline_bloc .box dl dt {
        width: 100%;
        font-size: 3vw;
    }
    .outline_bloc .box dl dd {
        flex: none;
        width: 100%;
        font-size: 3.5vw;
    }
    
    .outline_bloc .map {
        width: 100%;
        aspect-ratio: 4/4;
    }
    .outline_bloc .map iframe {
        width: 100%;
        height: 100%;
    }
    
    .groupinformation_bloc .box dl {
        padding: 0.5em;
        gap: 0;
    }
    .groupinformation_bloc .box dl dt {
        width: 100%;
        font-size: 3vw;
    }
    .groupinformation_bloc .box dl dd {
        flex: none;
        width: 100%;
        font-size: 3.5vw;
    }
    
    .recruit_page_bloc {
    
    }
    .recruit_page_item {
        gap: 1em;
    }
    .recruit_page_item .meta h3 {
        font-size: 5vw;
        margin-bottom: 0.2em;
    }
    .recruit_page_item .meta p {
        font-size: 4vw;
    }
    .recruit_page_item .btn_bloc {
        width: 100%;
    }

    .recruit_page_item .btn_bloc p {
        font-size: 4vw;
    }

    .recruit_page_item .btn_bloc ul {
        gap: 0.5em;
    }
    .recruit_page_item .btn_bloc ul li a:after {
        width: 20px;
        height: 20px;
        background-size: contain!important;
    }
    .recruit_page_item .btn_bloc ul li a:hover:after {
        width: 20px;
        height: 20px;
        background-size: contain!important;
    }
    
    .privacy_page {
        padding: 2em 0;
    }
    .privacy_item + .privacy_item {
        margin-top: 1em;
    }
    .privacy_item > * + * {
        margin-top: 0.2em;
    }
    .privacy_item p {
        font-size: 3.5vw;
    }
    .privacy_item h3 {
        font-size: 4vw;
    }
    .privacy_item h4 {
        font-size: 3.5vw;
    }
    .privacy_item ul {
        font-size: 3.5vw;
    }
    
    .modal_meta h3 {
        font-size: 4vw;
    }
    .modal_meta p {
        font-size: 3vw;
    }
    .modal_data dl dt {
        font-size: 3vw;
        padding: 0.7em 1em 0.5em;
    }
    .modal_data dl dd {
        font-size: 3v;
    }

    .modal_flow ol li {
        font-size: 4vw;
    }
    
    .fix_banner1 {
        display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    background-color: #83B14F;
    z-index: 100000;
    width: 100%;
    }
    
    .fix_banner1 dl {
        width: 60%;
display:flex;
flex-wrap: wrap;
        margin: 0 auto;
}

.fix_banner1 dt {
width: 30%;
padding: 10px;
box-sizing: border-box;
}

.fix_banner1 dd {
    padding: 10px 0;
    margin: 0;
    width: 70%;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    color: #FFFFFF;
    font-weight: bold;
}
    
    .fix_banner1 dd a {
        font-size: 1.1em;
    color: #FFFFFF;
    font-weight: bold;
    text-decoration: none;
}
    

    .fix_banner2 {
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: space-between;
        position: fixed;
        /* top: 50%; */
        /* transform: translateY(-50%); */
        /* -webkit-transform: translateY(-50%); */
        bottom: 0;
        left: 0;
        background: #fff;
        z-index: 100000;
        width: 100%;
    }
    .fix_banner2 a {
        width: 50%;
    }
    
    .fix_banner3 {
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -ms-flex-wrap: nowrap;
        -webkit-flex-wrap: nowrap;
        flex-wrap: nowrap;
        align-items: flex-start;
        justify-content: space-between;
        position: fixed;
        /* top: 50%; */
        /* transform: translateY(-50%); */
        /* -webkit-transform: translateY(-50%); */
        bottom: 0;
        left: 0;
        background: #fff;
        z-index: 100000;
        width: 100%;
    }









    .dr_content {
        gap: 1em;
    }
    .dr_content figure {
        width: 80%;
        margin: 0 auto;
    }
    .dr_box {
        flex: none;
        width: 100%;
    }
    .dr_meta {
        text-align: center;
    }
    .dr_meta .en {
        font-size: 4vw;
    }
    .dr_meta h4 {
        align-items: center;
        justify-content: center;
    }
    .dr_meta h4 .name {
        font-size: 5vw;
    }
    .dr_meta h4 .kana {
        font-size: 4vw;
    }
    .dr_meta .pos {
        font-size: 3.5vw;
    }
    .dr_data .item {
        width: 100%;
    }
    .dr_data .item > dl > dt {
        font-size: 3vw;
    }
    .dr_data .item > dl > dd {
        font-size: 3.5vw;
    }
    
    .dr_data .item > dl > dd > dl > dt {
        font-size: 3vw;
    }
    .dr_data .item > dl > dd > dl > dd {
        flex: none;
        width: 100%;
        font-size: 3.5vw;
    }
    .dr_message {
        padding: 1em;
    }
    .dr_message h5 {
        font-size: 6vw;
        top: -0.6em;
    }
    .dr_message p {
        font-size: 3vw;
    }
    
    
    
    
    
    
    
    .custom .insta_sec h2 {
        font-size: 5vw;
    }
    .custom .insta_sec h3 {
        font-size: 4vw;
        margin-bottom: 1em;
    }
    .facilitys h2 {
        font-size: 5vw;
    }
    .facilitys h3 {
        font-size: 4vw;
        margin-bottom: 1em;
    }
    .information_bloc h2 {
        font-size: 5vw;
    }
    .information_bloc h3 {
        font-size: 4vw;
        margin-bottom: 1em;
    }
    .recruit_bloc h2 {
        font-size: 5vw;
    }
    .recruit_bloc h3 {
        font-size: 4vw;
        margin-bottom: 1em;
    }
    .relation_bloc h2 {
        font-size: 5vw;
    }
    .relation_bloc h3 {
        font-size: 4vw;
        margin-bottom: 1em;
    }
    
    .ttl_bloc p {
        font-size: 4vw;
    }
    .ttl_bloc h3 {
        font-size: 5vw;
    }
    .ttl_bloc h4 {
    font-size: 1.2em;
    line-height: 1.6em;
    font-weight: bold; 
}
    .ttl_bloc h3 span {
        font-size: 3vw;
        vertical-align: top;
    }
    .ttl_bloc {
        margin-bottom: 1em;
    }
    
    .more_links_bloc a {
        max-width: 100%;
        font-size: 4vw;
    }
    
    .side_btn {
    display: none;
}

/* シフト表 */

.area-calendar {
    width: 100%;
    padding: 30px 10px 20px;
    border-radius: 10px;
    margin: 20px auto 50px;
    box-sizing: border-box;
}
.area-calendar h2 {
	color: #fff;
	font-size: 1.4em;
	line-height: 1em;
	margin: 0 0 30px 0;
    text-align: center;
}
    
.area-calendar p {
    margin: 10px 0 0;
    font-size: .8em;
}

.area-calendar p .staff_sekiguchi {
    font-size: 1.1em;
}

/* Fullcarender */
.fc .fc-button{font-size:.8em;}

.fc .fc-toolbar-title {
    font-size: 1.2em;
}

.fc-direction-ltr .fc-daygrid-event .fc-event-time {
    display: none;
}

.fc-daygrid-event-dot {
    display: none;
}

.fc-event-title {
    margin: 0;
    padding: .1em .35em;
    font-size: 1em;
    font-size: var(--fc-small-font-size,1em);
    font-weight: normal;
    color: #FFFFFF;
}

.fc-daygrid-event-harness {
    margin: 0 1px 1px;
   background-color: #81AB52;
    border-radius: 3px;
}

table.fc-col-header  {
	border-collapse:separate;
}
table.fc-col-header th {
    font-size: .8em;
	padding-top: 10px;
	padding-bottom: 10px;
	border-right: none;
	box-sizing: border-box;
}
table.fc-col-header th:nth-child(1) {
	border-left: none;
}
th.fc-col-header-cell {
    border-top: none;
    background-color: #446123;
    color: #FFFFFF;
}

th.fc-col-header-cell a {
    color: #FFFFFF;
}

table.fc-scrollgrid-sync-table td {
	background-color: #fff !important;
    font-size: .75em;
    letter-spacing: -0.05em;
}

table.fc-scrollgrid-sync-table td.fc-day-sun {
	background-color: #f8d6e4 !important;
}

table.fc-scrollgrid-sync-table td.fc-day-sat {
	background-color: #cfe5f3 !important;
}

table.fc-scrollgrid-sync-table td .event_holiday {
	background-color: #F04343 !important;
	border: none !important;
	text-align: center;
}
    
}