@charset 'utf-8';
body{
	background-color: #f5f5f5;
	font-family: 'メイリオ', Meiryo,'ヒラギノ角ゴシック','Hiragino Sans','Meiryo UI','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','ヒラギノ角ゴ StdN','Hiragino Kaku Gothic StdN','ＭＳ ゴシック',sans-serif;
}

header { background: #6fe3be;}
.navigation-wrap {background-color: #6fe3be;}
footer { background-color: rgba(71,71,71,1.0);}

.postList-item {
    background: #fff;
    border: 1px solid #ddd;
}.post-header {
    border-bottom: 1px solid #999;
}
.title {
    color: #333;
}
.info-text {
    color: #555;
}
.image-wrap {
    border: 2px solid #333;
}
.course_name._free,
.coupon._free {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: #ffffff;
    background-image: linear-gradient(80deg, #d3bb74 20%, #ffffff 50%, #d3bb74 80%);
}
.course_name._half,
.coupon._half {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: #ffffff;
    background-image: linear-gradient(190deg, #c6c6c6 20%, #ffffff 50%, #868686 80%);
}
.attention {
    color: #555;
}
/* 無料券バナー関係 */
.bottom_img {
    text-align: center;
    margin: 0 auto;
    padding: 0 16px;
    background: #000;
}
.bottom_img>a {
    display: block;
    max-width: 1200px;
    margin: 0 auto;
}
.bottom_img>a>img {
    max-width: 100%;
    display: block;
}
.logojack_button {
    z-index: 1;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    height: 0;
    left: 0;
    text-align: left;
    max-width: 1300px;
    margin: 0 auto;
    width: 100%;
}
.logojack_button>a {
    /* display: block;
    position: absolute;
    top: calc(100vh - 365px );
    left: -166px;
    transform: scale(0.8);
    transition: all ease-out .2s; */
    
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    transform: scale(0.8);
    transition: all ease-out .2s;
}
.logojack_button>a:hover {
    transform: scale(1.1);
}
.logojack_button>a>img {
    display: block;
}

@media(max-width:768px){
    .image-wrap {
        border: 1px solid #333;
    }
    .postList-item {
        background: #fff;
        border: 1px solid #ddd;    }
    .bottom_img {display: none;}
    .logojack_button {
        display: block;
        position: fixed;
        top: auto;
        bottom: 10px;
        left: 10px;
        width: 80px;
        height: 154px;
    }
    .logojack_button>a {
        display: inline;
        position: relative;
        top: auto;
        left: 0;
        bottom: 0;
        transform: scale(0.8);
        transition: all ease-out .2s;
        width: 100px;
    }
    .logojack_button>a>img {
        display: block;
        width: 100%;
    }
}


/*--------------------------*/
article.postList-item {
    padding: 0;
}

.post-header {
    margin: 0;
    padding: 10px;
    border-bottom: none;
    display: block;
}

.post-body {
    flex-direction: column;
    align-items: center;
}

.image-wrap {
    border: none;
    margin: 0;
    width: 100%;
    height: auto;
    position: relative;
}

.detail-wrap {
    width: calc(100% - 30px);
    background: #dddddd;
    margin: 15px 15px 0;
}

.attention {
    padding: 15px;
    color: #FFF;
    margin: 0;
}

.buttonbox {
    padding: 15px;
    margin: 0;
}

.l-container,.postList-body {
    background: #fafafa;
}

h1.title {
    font-size: 18px;
    padding: 0;
}

.shop-en {
    padding: 0.25em 0;
    font-size: 14px;
    color: #333;
}

.detail-button {
    width: 100%;
}
.detail-button .button {
    background: linear-gradient(135deg, #0d35ac, #0f6dbd);
    color: #fff;
    margin: 0;
    width: 100%;
}
.sortButton-wrap._active {
    margin-right: 0;
    padding: 8px 8px 2px;
    max-height: 240px;
    overflow: hidden;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    pointer-events: all;
}
.sort-wrap {
    background: #bee7da;
}
.sortButton {
    height: 100%;
}
article.postList-item {
    border-radius: 5px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgb(0 0 0 / 50%);
    border: none;
}
.attention-head {
    font-size: 20px;
    text-align: center;
    margin-bottom: 15px;
    color: #0d35ac;
    font-weight: bold;
    border-bottom: 3px solid #0d35ac;
    border-top: 3px solid;
    padding: 4px 0;
}
.attention {
    padding: 15px;
    color: #111;
    margin: 0;
    line-height: 1.5em;
}
.header .lang-select {
    display: flex;
    padding-right: 30px;
    align-items: center;
    height: 100%;
    position: relative;
}

.header .lang-select-img {
    padding: 9px;
    box-sizing: border-box;
}

.header .lang-select-text {
    width: 100%;
    text-align: center;
    font-size: 14px;
    text-wrap: nowrap;
}

.header .lang-select:after {
    display: block;
    content: "";
    position: absolute;
    top: 11px;
    right: 11px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    width: 6px;
    height: 6px;
    transform: rotate(135deg);
}

.header .lang-select-drawer {
    width: 100%;
    position: absolute;
    display: none;
    top: 50px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.header #open-drawer:checked ~ .lang-select-drawer {
    display: block;
}

.header .lang-select-drawer-list {
    background-color: #fff;
    border: 1px solid #DDD;
    padding: 5px;
}

.header .lang-select-drawer-list ul {
    max-width: 980px;
    margin: 0 auto;
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.header .lang-select-drawer-list li {
    position: relative;
}

.header .lang-select-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
    color: #333;
}

.header .lang-select-check-text {
    font-size: 16px;
}

.header .lang-select-check-img {
    padding: 10px 10px 10px 0;
    max-width: 20px;
    opacity: 0;
}

.header .lang-select-check-close {
    display: block;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

.header .lang-select-wrapper {
    margin: 7px;
    border: 1px solid #ccc;
    border-radius: 5px;
    position: relative;
    width: 130px;
}

.header #open-drawer {
    display: none;
}

.header .lang-select-wrapper > label {
    cursor: pointer;
}


.l-header-assets {
    max-width: 98%;
    width: 1280px;
    margin: 0 auto;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

header.l-header.header {
    background: #FFF;
}

img.l-header-pic {
    width: 200px;
}




.header .lang-select-wrapper {
    margin: 7px;
    border: 1px solid #ccc;
    border-radius: 5px;
    position: relative;
    width: 130px;
}

.header #open-drawer {
    display: none;
}

.header .lang-select-wrapper > label {
    cursor: pointer;
}

.header .lang-select {
    display: flex;
    padding-right: 30px;
    align-items: center;
    height: 100%;
    position: relative;
}

.header .lang-select-img {
    padding: 9px;
    box-sizing: border-box;
}

.header .lang-select-text {
    width: 100%;
    text-align: center;
    font-size: 14px;
    text-wrap: nowrap;
}

.header .lang-select:after {
    display: block;
    content: "";
    position: absolute;
    top: 11px;
    right: 11px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    width: 6px;
    height: 6px;
    transform: rotate(135deg);
}

.header .lang-select-drawer {
    width: 100%;
    position: absolute;
    display: none;
    top: 50px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.header #open-drawer:checked ~ .lang-select-drawer {
    display: block;
}

.header .lang-select-drawer-list {
    background-color: #fff;
    padding: 10px;
    border: 1px solid #DDD;
}

.header .lang-select-drawer-list ul {
    max-width: 980px;
    margin: 0 auto;
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.header .lang-select-drawer-list li {
    position: relative;
}

.header .lang-select-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
    color: #333;
}

.header .lang-select-check-text {
    margin: 0;
    font-size: 14px;
}

.header .lang-select-check-img {
    padding: 10px 10px 10px 0;
    max-width: 20px;
    opacity: 0;
}

.header .lang-select-check-close {
    display: block;
    width: 100%;
    height: 100%;
}

.l-header-assets {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 98%;
    width: 1280px;
    margin: 0 auto;
    box-sizing: border-box;
}


.attention {
    display: block;
    font-size: 15px;
    box-shadow: 0 2px 4px rgb(0 0 0 /25%);
}
.l-mainimg>picture {
    height: 100%;
    text-align: center;
    display: block;
}
.l-mainimg>picture>img {
    display: block;
}
.navigation-parent {
    font-weight: bold;
}

.navigation-wrap:before {
    content: "";
    display: none;
}
span.navigation-spText {
    display: none;
}
@media(max-width:768px){
    span.navigation-spText {
        font-size: 18px;
        color: #fff;
        padding: 12px 8px;
        display: inline-block;
    }
}
.catchcopy-inner {
    max-width: 98%;
    width: 1280px;
    margin: 0 auto;
    box-sizing: border-box;
    color: #FFF;
    font-size: 16px;
    line-height: 1.25em;
}

.l-catchcopy {
    background: #5e9382;
    padding: 16px 0;
    text-align: center;
}
@media (max-width: 768px) {
    nav.l-navigation.navigation-body._active {
        max-height:100%;
        overflow: scroll;
        box-sizing: border-box;
    }
}


.select-terms {
    width: calc(50% - 32px);
    padding: 1em 0;
    position: relative;
}
.select-terms-list {
    display: none;
}

.select-terms-active {
    display: flex;
    gap: 4px;
    word-break: keep-all;
    align-items: center;
    font-weight: bold;
}

nav.l-navigation.navigation-body {
    gap: 32px;
}

.select-terms-active>span {
    width: 100%;
    background: #ffffff55;
    padding: 1em;
    border-radius: 5px;
    cursor: pointer;
}
nav.l-navigation.sort-body {
    display: block;
}

nav.l-navigation.sort-body {
    display: block;
}

.select-terms-list.is-active {
    display: block;
    position: absolute;
    top: calc(100% - 8px);
    background: #FFFFFFDD;
    left: 0;
    width: 100%;
    border: 1px solid #DDD;
    box-shadow: 0 2px 8px rgb(0 0 0 / 25%);
    max-height: 30vh;
    overflow-y: scroll;
    z-index: 1;
}
a.navigation-parent {
    color: #333;
}


@media (max-width: 768px) {
    nav.l-navigation.navigation-body {
        display: flex;
        position: relative;
        background: none;
        gap: 8px;
    }
    nav.l-navigation.navigation-body._active {
        padding: 0;
    }
    .navigation-wrap {
        width: 100%;
        border: none;
        padding: 16px 2%;
    }
    .select-terms {
        width: 100%;
        padding: 0;
    }
    .sortButton-wrap {
        margin-right: 0;
        padding: 0;
        max-height: none;
        overflow: hidden;
        border-bottom: none;
        pointer-events: all;
    }
}
a.navigation-parent.js-locationChange {
    margin-right: 0;
    width: 100%;
    padding: 16px 8px;
    cursor: pointer;
    pointer-events: all;
}

a.navigation-parent.js-locationChange.active {
    background: #ddf7ef;
    border-radius: 5px;
}

button.sortButton.js-locationChange.is-active {
    background: #6fe3be;
    color: #FFF;
}


