/* .title_flex_txt {
    color: #006654;
} */

header .btn a {
    border-color: #006654;
    color: #006654;
}

header .btn a:hover {
    background-color: #006654;
}

p a {
    color: #006654;
}

.media_list_tag {
    color: #006654;
    border-color: #006654;
}

a:hover {
    color: #006654;
}

.bl-hover a:hover {
    color: #006654;
}

header .btn a .arrow::after {
    border-color: #006654;
}

.color_key {
    color: #006654;
}

.title2 {
    font-weight: bold;
    font-size: 26px;
}

.title5 {
    font-size: 14px;
    font-weight: bold;
}

.fo_no {
    font-weight: normal;
}


/* header */

header.temp2021 .navi {
    flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
}

header.temp2021 * {
    font-family: 'Noto Sans JP';
}

header.temp2021 .navi .navCvLang {
    margin: 0;
    width: auto;
}

header.temp2021 .navi ul.sound_icon {
    display: none;
}

header.temp2021 .navi ul li.header_20TOPmail a {
    background-color: #006654;
    border-color: #006654;
}

header.temp2021 .navi ul li.header_20TOPmail a:hover {
    color: #006654;
}

header.temp2021 .navCvLang .on {
    margin-right: 20px;
}

header.temp2021 .navi ul a:hover,
header.temp20201.navi ul li.current a {
    color: #006654;
}

header.temp2021 .navi ul a::after {
    background: #006654;
}

header.temp2021 .navi li:hover .hover_area {
    background-color: #006654;
}

header.temp2020 .navi li.is-active a {
    color: #006654;
}

@media only screen and (max-width: 1095px) {
    header.temp2020 .navi ul li.header_20TOPmail {
        width: 100%;
    }
}


/* locater */

#locator {
    background-color: #F5F5F5;
    margin-top: 90px;
    padding: 10px 0;
}

#locator a {
    font-size: 12px;
}


/* cv */

#contact.new_contact_2021 .col2_m_221 {
    border-color: #006654;
}

#contact.new_contact_2021 .tel .telttl,
#contact.new_contact_2021 .tel p {
    color: #242424;
    text-align: center;
    font-weight: bold;
}

#contact .contact_intxt {
    border-bottom: none;
    text-align: center;
    color: #242424;
    font-weight: bold;
}

#contact .txt_area .tactitle {
    color: #242424;
}

#contact .cvbtn a {
    background-color: #006654;
    color: #fff;
    border-color: #006654;
}

#contact .cvbtn a:hover {
    background-color: #fff;
    color: #006654;
}

#contact .col2_m_221 .col:nth-child(1) {
    border: none;
}

#contact .col2_m_221 {
    position: relative;
}

#contact .col2_m_221:after {
    position: absolute;
    content: '';
    width: 1px;
    height: 100%;
    top: 0;
    left: 50%;
    background-color: #006654;
}

#contact .col2_m_221:before {
    position: absolute;
    content: '';
    width: calc(50% - 80px);
    height: 1px;
    top: 50%;
    right: 40px;
    background-color: #DDDDDD;
}

#contact .txt_area_in+.txt_area_in {
    margin-top: 75px;
}

#contact .txt_area_in {
    flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
}

@media only screen and (max-width: 1010px) {
    #contact .txt_area_in {
        flex-wrap: wrap;
        -ms-flex-wrap: wrap;
    }
    #contact .col2_m_221 {
        padding: 50px 20px;
    }
    #contact .col2_m_221:before {
        width: calc(50% - 20px);
        right: 10px;
    }
}

@media only screen and (max-width: 767px) {
    #contact .col2_m_221:before {
        display: none;
    }
    #contact .col2_m_221:after {
        display: none;
    }
}


/* rss */

.news .rss_date {
    width: 110px;
}

.rss_new {
    width: 120px;
    height: 25px;
    background-color: #006654;
    color: #FFF;
    border-radius: 3px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin-right: 20px;
}


/* footer */

.footer_top {
    background-color: #006654;
}

.footer_address p {
    font-weight: bold;
}

.footer_bottom {
    background-color: #006654;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.footer_bottom li a,
small.copy {
    color: #fff;
    font-weight: bold;
    font-size: 12px;
}

.footer_bottom .navi li+li {
    border-color: #fff;
}

footer a:hover {
    color: #fff;
    opacity: 0.7;
}

.footer_bottom .navListArea {
    display: flex;
    justify-content: space-between;
    width: 130px;
}

.footer_bottom .navListArea .sp_Gnavi img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

@media only screen and (max-width: 1000px) {
    .footer_bottom .navListArea {
        display: none;
    }
}


/* contents */

.content_new_2021 {
    /* margin-top: 120px; */
    margin-bottom: 100px;
}

.lower_head {
    font-size: 26px;
    font-weight: bold;
    color: #242424;
    position: relative;
}

.lower_head .sub {
    font-size: 12px;
    color: #006654;
}

.lower_head:after {
    content: '';
    position: absolute;
    bottom: -30px;
    left: -50vw;
    width: 150vw;
    height: 1px;
    background-color: #ddd;
}

.anchor_btn a {
    border-color: #006654;
    color: #006654;
}

.anchor_btn a:hover {
    background-color: #006654;
}


/* program */

.content_new_2021 #pro_btn {
    border: none;
    padding: 0;
    display: flex;
    align-items: center;
}

.pro_btn_contents {
    display: block;
}

#pro_btn p {
    width: 200px;
}

#pro_btn ul {
    border: none;
    padding-top: 0;
}

#pro_btn li a {
    color: #009EA8;
    border-color: #009EA8;
}

#pro_btn li a:hover {
    background-color: #006654;
    border-color: #006654;
}

#pro_box_in .pro_cat {
    color: #009EA8;
    border: 1px solid #009EA8;
}

.content_new_2021 #pro_box_in .item {
    border: 1px solid #CECECE;
    background-color: transparent;
    padding: 0;
    min-height: 545px;
}

#pro_box_in .item_wrap {
    padding: 0 15px;
}

.media_card_txt2:first-of-type {
    padding-top: 10px;
    border-top: 1px solid #DDDDDD;
}

.media_card_txt2 {
    display: flex;
    flex-wrap: wrap;
}

.media_card_txt2 dt {
    font-weight: bold;
    width: 45px;
}

.media_card_txt2 dd {
    width: calc(100% - 45px);
}

#pro_btn li a.current {
    border-color: #009EA8;
    background-color: #009EA8;
}

#pro_box_in .pro_title {
    min-height: auto;
}

.media_card_txt,
.media_card_txt2,
.media_card_txt2 dt,
.media_card_txt2 dd {
    font-size: 14px;
}

.program_area .pro_cat {
    border-color: #009EA8;
    color: #009EA8;
}

.program_area .item {
    border: 1px solid #CECECE;
    background-color: transparent;
    padding: 0;
}

.program_area .item .item_wrap {
    padding: 0 15px;
}

.media_card_txt2:last-of-type {
    margin-bottom: 30px;
}

.movie_link .title {
    font-size: 18px;
    font-weight: bold;
    margin-top: 20px;
}

.movie_link .program_area .item .item_wrap {
    padding: 0;
    display: flex;
    justify-content: center;
}

.movie_link .media_card_txt2:first-of-type {
    border-top: none;
}

.movie_link .media_card_txt2 dt,
.movie_link .media_card_txt2 dd {
    width: auto;
}


/* プログラム詳細 */

.title1 {
    font-size: 26px;
    font-weight: bold;
}

.protag .one {
    max-width: 320px;
    height: 50px;
    border: 1px solid #006654;
    color: #006654;
    border-radius: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    font-weight: bold;
}

.anchor_btn.square a {
    border-radius: 0;
    position: relative;
}

.anchor_btn.square a::after {
    position: absolute;
    content: '';
    border-right: 1px solid #006654;
    border-bottom: 1px solid #006654;
    width: 9px;
    height: 9px;
    transform: rotate(45deg);
    left: 30px;
    top: 26px;
}

.anchor_btn.square a:hover::after {
    border-color: #FFF;
}

header .btn a .arrow::after {
    top: 21px;
}

.flex .w80 {
    width: 70%;
}

.flex header .btn a .arrow::before {
    position: absolute;
    content: '';
    width: 10px;
    height: 1px;
    background-color: #006654;
    top: 24px;
    right: 15px;
    transition: all .3s ease 0s;
}

.flex header .btn a:hover .arrow::before {
    right: 10px;
    background-color: #fff;
}

@media only screen and (min-width: 980px) {
    .flex header .btn a .arrow::after {
        top: 19px;
    }
    .flex header .btn a .arrow::before {
        right: 30px;
        top: 23.5px;
    }
    .flex header .btn a:hover .arrow::before {
        right: 20px;
    }
}

.top_btn_right {
    margin-left: auto;
}

.protable {
    border-top: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
    border-collapse: collapse;
    width: 100%;
}

.protable tr {
    padding: 15px;
    border-bottom: 1px solid #dddddd;
}

.protable th {
    background-color: #F5F5F5;
    color: #006654;
    font-size: 16px;
    font-weight: bold;
    padding: 15px 30px;
    vertical-align: middle;
}

.protable td {
    font-size: 14px;
    color: #242424;
    vertical-align: middle;
    padding: 15px;
}

.layout_01 .name1 {
    font-size: 24px;
    font-weight: bold;
    color: #006654;
}

.layout_01 .name1 .sub {
    font-size: 15px;
}

.layout_01 .view_more {
    font-size: 16px;
    font-weight: bold;
    color: #006654;
    text-align: right;
    display: block;
}

.img_box03 .photo_note {
    text-align: right;
}

.layout_01 dl.m80 {
    margin-bottom: 80px;
}

.pro_detail_txt {
    border-top: 1px solid #ddd;
    padding-top: 10px;
    padding-bottom: 20px;
}

.h135 {
    height: 135px;
}

.mcenter {
    margin: 0 auto;
    text-align: center;
}

.layout_01 .name.right {
    text-align: right;
    font-weight: bold;
}

.w_100 {
    width: 100%;
}

.mw_800 {
    max-width: 800px;
}

.table02 th {
    font-weight: bold;
}

.table02 td {
    margin-bottom: 15px;
}

.table02 .name {
    color: #006654;
}

.table02.name_wauto .name {
    width: auto;
}

.table02.name_wauto th {
    width: 250px;
}

@media only screen and (max-width: 750px) {
    table.circleTable th {
        position: static;
    }
    .table02.name_wauto th,
    table.table02 .th,
    table.table02 td,
    table.table02 .name,
    table.table02 .text {
        display: block;
        width: 100%;
    }
    table.table02 th {
        width: 100%;
        display: block;
    }
    .anchor_btn.square a {
        padding: 20px 25px;
    }
    .anchor_btn.square a::after {
        left: 10px;
        top: 23px;
    }
}

.hr_ddd {
    width: 100%;
    height: 1px;
    background-color: #dddddd;
}

iframe {
    max-width: 100%;
}

@media screen and (max-width: 800px) {
    .flex .w100_tab {
        width: 100%;
    }
    .btn_c_tab {
        margin: 10px auto;
    }
}

.mail_box fieldset {
    border: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.mail_box fieldset>input,
.formbox-editor fieldset>textarea,
.formbox-editable-field {
    /* margin: 10px 0; */
    outline: none;
    border: 1px solid #eee;
}

.mail_box fieldset {
    border: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.mail_box #btnSubmit {
    background-color: #006654 !important;
    color: #ffffff;
    font-family: 'Noto Serif JP', serif !important;
}

.mail_box #btnSubmit:hover {
    opacity: 0.7;
}

.mail_box .formbox-field-email-1403134 {
    /* border: 2px solid #f1f2f2; */
    border-radius: 0;
    box-sizing: border-box;
    color: #000;
    font-family: Helvetica, Arial, sans-serif;
    font-size: 14px;
    width: 100%;
    height: auto;
    margin-bottom: 10px;
}

.mail_box .in_box .flex .right {
    width: 50%;
    margin-left: 20px;
}

@media only screen and (max-width: 767px) {
    .mail_box .in_box .flex .right {
        width: 100%;
        margin-left: 0;
        margin-top: 20px;
    }
}

/* 21/08/30 修正 */
header.temp2020 .navi ul li.header_20TOPmail {
    margin-left: 20px;
}
/* sec_title */
.sec_title {
    background-color: #28C89B;
    display: inline-block;
    padding: 10px 20px;
    border-radius: 50vh;
    font-weight: normal;
    font-size: 24px;
}

.btn_square a {
    border-radius: 0;
}

.common_margin01 {
    margin-bottom: 160px;
}

.common_margin02 {
    margin-bottom: 80px;
}

.common_margin01-40 {
    margin-bottom: 120px;
}



.contact.new19 {
    margin-bottom: 160px;
}

.content_new_2021 {
    margin-bottom: 160px;
}

@media screen and (max-width:1024px) {
    .common_margin01 {
        margin-bottom: 90px;
    }

    .common_margin02 {
        margin-bottom: 50px;
    }

    .common_margin01-40 {
        margin-bottom: 50px;
    }

    .contact.new19 {
        margin-bottom: 90px;
    }

    .content_new_2021 {
        margin-bottom: 90px;
    }
    #mail_news.y21 {
        margin-bottom: 90px;
    }
}

@media screen and (max-width:767px) {
    .common_margin01 {
        margin-bottom: 60px;
    }

    .common_margin02 {
        margin-bottom: 30px;
    }

    .common_margin01-40 {
        margin-bottom: 20px;
    }

    .contact.new19 {
        margin-bottom: 60px;
    }

    .content_new_2021 {
        margin-bottom: 60px;
    }
    #mail_news.y21 {
        margin-bottom: 60px;
    }
}

/* 21/09/03 修正 */
/* ----------------------------- */

.sec_title {
    font-size: 17px;
    margin-left: -3%;
    background-color: #75C79C;
    color: #005941;
}
@media screen and (max-width: 1100px) {
    .sec_title {
        margin-left: 0;
    }
}

.title_bob {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    border-bottom: 1px solid #75C79C;
    padding-bottom: 10px;
}

.title_ltgt {
    display: inline-block;
    height: auto;
    padding: 0 20px;
    position: relative;
    color: #006654;
    font-size: 15px;
    font-weight: bold;
}

.title_ltgt::before {
    content: ">";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: #75C79C;
    font-size: 25px;
}

.title_ltgt::after {
    content: "<";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    color: #75C79C;
    font-size: 25px;
}

.protag .one {
    color: #75C79C;
    border-color: #75C79C;
    display: inline-flex;
    height: auto;
    padding: 10px 30px;
}