@charset "utf-8";
/* Copyright 2023 FSFIELD All Rights Reserved. */
/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

PC、タブレット、スマートフォン共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/
/* ------------------------------------------------------------

イベント・見学会情報

------------------------------------------------------------ */
/* 一覧
---------------------------------------------- */
.event_list {
    max-width: 1200px;
    margin: 0 auto;
}
.event_items {
    display: flex;
    flex-wrap: wrap;
    max-width: 1200px;
    margin-bottom: -60px;
}
.event_items .item {
    width: calc((100% - 60px)/3);
    margin: 0 30px 60px 0;
}
.event_items .item:nth-of-type(3n) {
    margin-right: 0;
}
.event_items .item a {
    display: block;
}
.event_items .item a .image {
    position: relative;
    padding-top: 66.625%;
    overflow: hidden;
}
.event_items .item a .image img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    transition: transform .3s;
}
.event_items .item a:hover .image img {
    transform: scale(1.05);
}
.event_items .item a .image .noimage {
    background: #EDEFED;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 15px;
}
.event_items .item a .image .noimage img {
    max-width: 211px;
    height: auto;
    position: unset;
}
.event_items .item a .inner {
    padding: 27px 30px;
    border: 1px solid #CDD3CD;
    border-top: none;
}
.event_items .item a .inner .cat {
    color: #AC8071;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin-bottom: 10px;
}
.event_items .item a .inner .ttl {
    color: #333;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.event_items .item a .inner .info {
    color: #757975;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
}
.event_items .item a .inner .info p:not(:last-of-type) {
    margin-bottom: 6px;
}
.event_items .item a .inner .info p span {
    display: inline-block;
}
.event_items .item a .inner .info p .eventdate {
    color: #333;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    font-size: 15px;
}
/*--終了しました--*/
.event_items .item.end a .image::before {
    content: "";
    background: rgba(0, 0, 0, .7);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
.event_items .item.end a .image::after {
    content: "";
    background: url("../img/txt_eventend01.png") no-repeat 0 0;
    background-size: cover;
    width: 154px;
    height: 54px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate3d(-50%, -50%, 0);
    z-index: 1;
}
/* 詳細
---------------------------------------------- */
.event_single {
    max-width: 1100px;
    margin: 0 auto;
}
.main_image {
    text-align: center;
}
.main_image img {
    max-width: 100%;
    height: auto;
}
.article_single .wp_contents {
    margin: 60px 0;
}
.article_single + .btn_back {
    padding-top: 60px;
    border-top: 1px solid #CDD3CD;
}
.event_detail .image {
    margin-bottom: 40px;
}
.event_detail .image img {
    max-width: 100%;
    height: auto;
}
.event_detail .inner {
    padding: 0;
}
.event_detail p {
    font-size: 18px;
    font-weight: 100;
    line-height: 2;
    text-align: left;
    margin-bottom: 60px;
}
.event_detail p.sml-txt {
    font-size: 13px;
    font-weight: 100;
    margin-top: 1em;
}
.event_detail .inner p {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.2;
    text-align: left;
    margin-bottom: 0.8em;
    display: flex;
    position: relative;
}
.event_detail .inner p:before {
    content: "";
    width: 7px;
    height: 17px;
    display: inline-block;
    position: relative;
    margin: 5px 12px 0 0;
    vertical-align: middle;
    background: #1c3661;
}
.event_detail .inner p:last-of-type {
    margin-bottom: 0;
}
.event_detail .inner p span:nth-of-type(1) {
    flex: none;
    width: 120px;
    padding-right: 20px;
}
@media only screen and (max-width:767px) {
    .article_single .wp_contents {
        margin: 30px 0;
    }
    .event_detail .image {
        margin-bottom: 30px;
    }
    .event_detail p {
        font-size: 15px;
        margin-bottom: 30px;
    }
    .event_detail .inner p {
        font-size: 16px;
    }
    .event_detail .inner p:before {
        width: 5px;
        height: 14px;
        margin: 3px 10px 0 0;
    }
}
/*--参加申し込みフォーム--*/
.sec_entry {
    margin-top: 80px;
}
.sec_entry h2 {
    width: 100%;
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    margin-bottom: 0.8em;
    display: block;
    position: relative;
    overflow: hidden;
}
.sec_entry h2:before {
    content: "";
    width: 50%;
    height: 1px;
    display: block;
    position: absolute;
    top: 0.5em;
    left: 0;
    margin-left: -6em;
    background: #1c3661;
}
.sec_entry h2:after {
    content: "";
    width: 50%;
    height: 1px;
    display: block;
    position: absolute;
    top: 0.5em;
    right: 0;
    margin-right: -6em;
    background: #1c3661;
}
.nav_entry {
    border-bottom: 2px solid #122645;
    margin-bottom: 20px;
}
.nav_entry ul {
    display: flex;
}
.nav_entry ul li {
    width: calc((100% - 36px)/7);
    margin-right: 6px;
}
.nav_entry ul li:last-of-type {
    margin-right: 0;
}
.nav_entry ul li button {
    background: #CDD3CD;
    color: #878787;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 1.2;
    border-radius: 4px 4px 0 0;
    width: 100%;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}
.nav_entry ul li button.active {
    background: #193560;
    color: #FFF;
}
.entry_inner {
    display: none;
    border: 1px solid #CDD3CD;
    padding: 0 30px;
}
.entry_inner.active {
    display: block;
}
.entry_inner iframe {
    height: 1300px;
}
@media only screen and (max-width:1024px) { /* 表示領域が1024px以下の場合に適用するスタイル */
    /*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/
    /* ------------------------------------------------------------

	イベント・見学会情報

	------------------------------------------------------------ */
    /* 一覧
	---------------------------------------------- */
    .event_items {
        justify-content: space-between;
        margin-bottom: -30px;
    }
    .event_items .item {
        width: calc(50% - 15px);
        margin: 0 0 30px 0;
    }
    .event_items .item a .inner {
        padding: 13px;
    }
    /* 詳細
	---------------------------------------------- */
} /*--@media--*/
@media only screen and (max-width:767px) { /* 表示領域が767px以下の場合に適用するスタイル */
    /*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/
    /* ------------------------------------------------------------

	イベント・見学会情報

	------------------------------------------------------------ */
    /* 一覧
	---------------------------------------------- */
    .event_items {
        display: block;
        margin: 0;
    }
    .event_items .item {
        width: 100%;
        margin: 0;
        border-bottom: 1px solid #CDD3CD;
    }
    .event_items .item:first-of-type {
        border-top: 1px solid #CDD3CD;
    }
    .event_items .item a {
        padding: 25px 0;
        display: flex;
        align-items: flex-start;
    }
    .event_items .item a .image {
        width: 115px;
        padding-top: 76px;
        flex: none;
    }
    .event_items .item a .image .noimage {
        padding: 5px;
    }
    .event_items .item a .inner {
        padding: 0 0 0 15px;
        width: calc(100% - 115px);
        flex: none;
        border: none;
    }
    .event_items .item a .inner .cat {
        font-size: 1.2rem;
        margin-bottom: 4px;
    }
    .event_items .item a .inner .ttl {
        font-size: 1.2rem;
        letter-spacing: 0.1em;
    }
    .event_items .item a .inner .info p .eventdate {
        font-size: 1.2rem;
    }
    .event_items .item a .inner .info {
        font-size: 1.1rem;
        letter-spacing: 0.1em;
    }
    .event_items .item a .inner .info p:not(:last-of-type) {
        margin-bottom: 3px;
    }
    /*--終了しました--*/
    .event_items .item.end a .image::after {
        background: url("../img/txt_eventend01_sp.png") no-repeat 0 0;
        background-size: cover;
        width: 77px;
        height: 33px;
    }
    /* 詳細
	---------------------------------------------- */
    .article_single + .btn_back {
        padding-top: 30px;
    }
} /*--@media--*/
* オリジナル */ .event_items .item {
    margin: 30px 20px 30px 0 !important;
}
@media only screen and (max-width:767px) {
    .event_items .item {
        margin: 0px 20px 0px 0 !important;
    }
}
/* 追加20250201
---------------------------------------------- */
#event-contents .wp_contents p:last-child {
    margin-bottom: auto;
}
#event-contents {
    text-align: center;
    color: #333;
    letter-spacing: normal;
}
#event-contents img {
    width: 100%;
    height: auto;
}
#event-contents .pconly {
    display: block;
}
#event-contents .sponly {
    display: none;
}
@media only screen and (max-width:767px) {
    #event-contents .pconly {
        display: none;
    }
    #event-contents .sponly {
        display: block;
    }
}
#event-contents aside {
    margin: 0 auto 60px;
    position: relative;
}
@media only screen and (max-width:1180px) {
    #event-contents aside, #entryform aside {
        width: 90.6667%;
    }
}
#entryform aside {
    margin-right: auto;
    margin-left: auto;
}
@media only screen and (max-width:767px) {
    #event-contents article {
        margin-bottom: 60px;
    }
}
#event-contents aside.narrow-contents {
    max-width: 800px;
}
#event-contents aside.wide-contents, #entryform aside.wide-contents {
    max-width: 1100px;
}
@media only screen and (max-width:767px) {
    #event-contents aside.narrow-contents, #event-contents aside.wide-contents, #entryform aside.wide-contents {
        max-width: none;
        width: 90.6667%;
    }
}
#event-contents aside.article_top {
    margin-bottom: 30px;
}
#event-contents aside.main_image {
    margin-bottom: 0;
}
#event-contents aside.event_detail {
    text-align: left;
}
#event-contents .col_flex {
    display: flex;
    flex-wrap: nowrap;
}
#event-contents #schedule h3 {
    color: #1c3661;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin: 0 0 20px;
}
#event-contents .event-schedule {
    display: block;
    padding: 0 78px;
    letter-spacing: -0.4em;
}
#event-contents .event-schedule ul {
    margin: 0;
    padding: 0 10px;
    list-style: none;
    letter-spacing: normal;
}
#event-contents .event-schedule ul li {
    color: #fff;
    font-size: 16px;
    font-weight: 100;
    text-align: left;
    line-height: 1;
    margin: 0 0 10px;
    padding: 5px;
    background-color: #1c3661;
}
#event-contents .event-schedule ul li.off {
    color: #bbb;
    background-color: #e8e8e8;
}
#event-contents .event-schedule ul li.date {
    color: #1c3661;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
    line-height: 1.4;
    margin: 0 0 15px;
    padding: 0;
    background: none;
}
@media only screen and (max-width:767px) {
    #event-contents aside#schedule.narrow-contents {
        width: 100%;
    }
    #event-contents .event-schedule {
        width: 100%;
        padding: 0;
    }
    #event-contents .event-schedule ul {
        padding: 0 15px;
    }
}
#event-contents #present {
    padding: 44px 24px 24px;
    margin-bottom: 20px;
    box-sizing: border-box;
    border: solid 5px #1c3661;
    overflow: visible;
}
#event-contents #present .col_flex {
    justify-content: space-between;
}
#event-contents #present h3 {
    width: 188px;
    height: 63px;
    display: block;
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -94px;
}
#event-contents #present h4 {
    color: #1c3661;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin-bottom: 24px;
}
#event-contents #present h5 {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    text-align: left;
    margin-bottom: 0.8em;
}
#event-contents #present ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
#event-contents #present ul li {
    font-size: 13px;
    font-weight: 100;
    line-height: 1.2;
    text-align: left;
    margin-bottom: 0.8em;
    margin-left: 1em;
    text-indent: -1em;
}
#event-contents #present figure {
    width: 309px;
    height: auto;
}
@media only screen and (max-width:767px) {
    #event-contents #present {
        padding: 44px 15px 30px;
        margin-bottom: 20px;
    }
    #event-contents #present .col_flex {
        flex-direction: column;
    }
    #event-contents #present h4 {
        font-size: 20px;
    }
    #event-contents #present figure {
        width: 44vw;
        margin: 20px auto 0;
    }
}
#event-contents .btn-entry {
    width: 100%;
    text-align: center;
    margin: 80px auto 20px;
    padding-bottom: 20px;
    line-height: 2;
}
#event-contents .btn-entry a {
    width: 100%;
    display: inline-block;
    color: #333;
    font-size: 24px;
    font-weight: 100;
    line-height: 1;
    padding: 30px 0;
    border-radius: 42px;
    background: #EBDE67;
    transition: background .3s;
    text-decoration: none;
}
#event-contents .btn-entry a:hover {
    background: #88CEC9;
}
@media only screen and (max-width:767px) {
    #event-contents .btn-entry {
        margin: 40px auto 0;
    }
    #event-contents .btn-entry a {
        font-size: 20px;
        padding: 24px 0;
        border-radius: 34px;
    }
}
#event-contents #point h3 {
    width: 306px;
    height: auto;
    display: block;
    margin: 0 auto 60px;
}
#event-contents #point .col_flex {
    text-align: left;
    margin-bottom: 60px;
}
#event-contents #point .col_flex.flex_reverse {
    flex-direction: row-reverse;
}
#event-contents #point figure {
    width: 500px;
    height: auto;
    margin: 0 60px 0 0;
    box-shadow: -20px 20px #1c3661;
    box-sizing: border-box;
}
#event-contents #point .flex_reverse figure {
    margin: 0 0 0 60px;
}
#event-contents #point .point-icon {
    width: 90px;
    height: auto;
}
#event-contents #point h4 {
    color: #1c3661;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.8;
    text-align: left;
    margin: 20px 0;
}
#event-contents #point p {
    font-size: 16px;
    font-weight: 100;
    line-height: 2;
    text-align: left;
    margin-bottom: 2em;
}
#event-contents #point p.sml-txt {
    font-size: 13px;
    font-weight: 100;
    margin-top: 1em;
}
@media only screen and (max-width:980px) {
    #event-contents #point h3 {
        width: 240px;
        margin-bottom: 30px;
    }
    #event-contents #point .col_flex, #event-contents #point .col_flex.flex_reverse {
        flex-direction: column-reverse;
        margin-bottom: 30px;
    }
    #event-contents #point figure, #event-contents #point .flex_reverse figure {
        width: 94%;
        height: auto;
        margin: 0 auto 30px 4%;
        box-shadow: -10px 10px #1c3661;
    }
    #event-contents #point .point-icon {
        width: 60px;
        margin: 0 auto;
    }
    #event-contents #point h4 {
        font-size: 18px;
        margin: 20px 0;
    }
    #event-contents #point p {
        font-size: 15px;
    }
}
#event-contents #osusume {
    padding: 60px 60px 46px 0;
    margin-bottom: 20px;
    box-sizing: border-box;
    overflow: visible;
    background: #efefef;
}
#event-contents #osusume .col_item.osusume-ttl {
    width: 360px;
    padding-bottom: 14px;
    align-content: center;
}
#event-contents #osusume h3 {
    color: #1c3661;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin: 20px 0;
}
#event-contents #osusume ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
#event-contents #osusume ul li {
    font-size: 18px;
    font-weight: 100;
    line-height: 1.2;
    text-align: left;
    margin-bottom: 0.8em;
    position: relative;
    padding-left: 80px;
    text-indent: -80px;
}
#event-contents #osusume ul li:before {
    content: "";
    width: 33px;
    height: 29px;
    display: inline-block;
    position: relative;
    margin: 0 23px;
    vertical-align: middle;
    background: url("../img/event/event__icon_check.png") 50% 50% no-repeat;
    background-size: contain;
}
@media only screen and (max-width:767px) {
    #event-contents #osusume {
        padding: 20px 20px 20px 0;
        margin-bottom: 20px;
        box-sizing: border-box;
        overflow: visible;
        background: #efefef;
    }
    #event-contents #osusume .col_flex {
        flex-direction: column;
    }
    #event-contents #osusume .col_item.osusume-ttl {
        width: auto;
        padding-left: 20px;
    }
    #event-contents #osusume ul li {
        font-size: 16px;
    }
}
#event-contents #about {
    padding: 0;
    margin: 160px auto 20px;
    box-sizing: border-box;
    position: relative;
    overflow: visible;
    background: #efefef;
}
#event-contents #about:before {
    content: "";
    width: 703px;
    height: 105px;
    display: block;
    position: absolute;
    top: -100px;
    left: 50%;
    margin-left: -350px;
    background: url("../img/event/event__col03-ill_01.png") 50% 50% no-repeat;
    background-size: contain;
}
#event-contents #about .col_blue {
    width: 100%;
    padding: 80px 150px 60px;
    margin: 0;
    box-sizing: border-box;
    background: #1c3661;
}
#event-contents #about .col_gray {
    width: 100%;
    padding: 90px 60px 72px;
    margin: 0;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}
#event-contents #about .col_gray:before {
    content: "";
    width: 100%;
    height: 120px;
    display: block;
    position: absolute;
    top: -25px;
    left: -48%;
    background: #1c3661;
    transform: rotate(-10deg);
}
#event-contents #about .col_gray:after {
    content: "";
    width: 100%;
    height: 120px;
    display: block;
    position: absolute;
    top: -25px;
    right: -48%;
    background: #1c3661;
    transform: rotate(10deg);
}
#event-contents #about .col_blue h3 {
    color: #fff;
    font-size: 42px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin: 0 0 40px;
}
#event-contents #about .col_blue p {
    color: #fff;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.8;
    text-align: left;
    margin-bottom: 60px;
}
#event-contents #about .col_gray h4 {
    color: #1c3661;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
    margin: 0 0 60px;
}
#event-contents #about .col_gray p {
    color: #1c3661;
    font-size: 16px;
    font-weight: 100;
    line-height: 1.8;
    text-align: left;
    margin-bottom: 1.8em;
}
#event-contents #about .col_blue .col_flex {
    justify-content: space-between;
}
#event-contents #about .col_blue .col_flex figure {
    width: 370px;
    height: auto;
}
#event-contents #about .col_gray .col_flex figure {
    width: 337px;
    height: auto;
    margin-left: 40px;
}
@media only screen and (max-width:1180px) {
    #event-contents #about .col_blue .col_flex {
    }
    #event-contents #about .col_blue .col_flex .col_item {
        width: 50%;
    }
    #event-contents #about .col_blue .col_flex .col_item figure {
        width: 100%;
    }
}
@media only screen and (max-width:767px) {
    #event-contents #about {
        margin: 24vw auto 20px;
    }
    #event-contents #about:before {
        width: 100%;
        height: 13.6vw;
        top: -13vw;
        left: 0;
        margin: 0;
    }
    #event-contents #about .col_blue {
        padding: 30px 20px 0;
    }
    #event-contents #about .col_gray {
        padding: 90px 20px 40px;
    }
    #event-contents #about .col_gray:before, #event-contents #about .col_gray:after {
        height: 100px;
        top: -25px;
    }
    #event-contents #about .col_blue h3, #event-contents #about .col_gray h4 {
        font-size: 22px;
        margin-bottom: 1em;
    }
    #event-contents #about .col_blue p, #event-contents #about .col_gray p {
        font-size: 16px;
        margin-bottom: 1.8em;
    }
    #event-contents #about .col_gray .col_flex {
        flex-direction: column;
    }
    #event-contents #about .col_blue .col_flex figure {
        width: 100%;
    }
    #event-contents #about .col_gray .col_flex figure {
        width: 196px;
        margin: 0 auto;
    }
}