@charset 'UTF-8'; /* PC */
/**
 * ViewportScale v0.2.1
 * Copyright (c) 2018 Kite
 * MIT License
 */
/*==========================================================================
# reset - ブラウザの差異や不要なスタイルを無くすためのスタイル
========================================================================== */
* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p, div, span, img, a, table, tr, th, td, small, button, time, figure {
    border: 0;
    font: inherit;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
}

html {
    line-height: 1;
}

ol, ul {
    list-style: none;
}

li, dd {
    list-style-type: none;
}

header, footer, nav, section, article, aside, figure, figcaption {
    display: block;
}

img {
    border: none;
    vertical-align: bottom;
}

a {
    cursor: pointer;
    text-decoration: none;
}

html {
    font-size: 62.5%;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    position: relative;
    color: #000;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.6;
    background: #FFF;
}

p {
    word-wrap: normal;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.8;
    color: #000;
}

a, a:hover {
    text-decoration: none;
    color: #000000;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

a:hover {
    opacity: 0.6;
}

a.ud {
    text-decoration: underline;
    color: #7f7f7f;
}

a.ud:hover {
    text-decoration: none;
}

.left, .fl {
    float: left;
}

.right, .fr {
    float: right;
}

.clearfix:before, .clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.hv:hover {
    opacity: 0.6;
}

.font-min {
    /*     font-family: ten-mincho, serif; */
    font-family: arno-pro-display,serif;
    font-weight: 400;
    font-style: normal;
}

.font-ryumin {
    font-family: a-otf-ryumin-pr6n, serif !important;
    font-weight: 300;
    font-style: normal;
}

.sp {
    display: none;
}

.pc {
    display: block;
}

.flex {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-around;
    justify-content: space-between;
}

.align-center {
    align-items: center;
}

.container {
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

/*スクロールバー表示させる*/
.scroll::-webkit-scrollbar {
    width: 8px;
}

.scroll::-webkit-scrollbar-thumb {
    background: #f8c384;
    border-radius: 10px;
}

.scroll::-webkit-scrollbar-track-piece:start {
    background: #ffead2;
}

.scroll::-webkit-scrollbar-track-piece:end {
    background: #fff;
}

.none-display {
    display: none;
}

/*============================
COMMON
============================*/
img {
    max-width: 100%;
    height: auto;
}

.hide {
    display: none;
}

.flex {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-around;
    justify-content: space-between;
}

.sp_btn {
    position: fixed;
    top: 24px;
    left: 3%;
    width: 60px;
    height: 36px;
    z-index: 11;
    padding: 0;
    background: transparent;
    cursor: pointer;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    display: block;
}

.sp_btn:hover {
    opacity: 0.6;
}

.sp_btn span {
    width: 46px;
    height: 2px;
    background: #231815;
    border: 1px solid #656565;
    display: block;
    position: absolute;
    left: 7px;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.sp_btn span:nth-child(1) {
    top: 10px;
}

.sp_btn span:nth-child(2) {
    top: 18px;
}

.sp_btn span:nth-child(3) {
    top: 26px;
}

.sp_btn.active span:nth-child(1) {
    transform: rotate(-45deg);
    top: 19px;
    background: #FFF;
    border: none;
    height: 3px;
}

.sp_btn.active span:nth-child(2) {
    display: none;
}

.sp_btn.active span:nth-child(3) {
    transform: rotate(45deg);
    top: 19px;
    background: #FFF;
    border: none;
    height: 3px;
}

@media screen and (max-width:768px) {
    .sp_btn span {
        width: 32px;
        height: 2px;
    }
}

.sp_menu {
    background: rgba(0,0,0,0.68);
    position: fixed;
    width: 100%;
    height: 100vh;
    left: 0;
    top: 0;
    z-index: 10;
}

.header_navi {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.header_navi ul {
    margin: 0 2%;
}

.header_navi ul ul {
    margin: 10px 0 0 20px;
}

.header_navi li {
    margin: 0 0 10px;
    text-align: left;
}

.header_navi a {
    color: #FFF;
    font-size: 20px;
}

.side-btn {
    position: fixed;
    bottom: 90px;
    right: 3%;
    width: 80px;
    z-index: 10;
}

.side-btn__icon {
    background: #686255;
    border-radius: 50%;
    padding: 0;
    margin: 0 0 20px;
}

.side-btn__icon:nth-child(2n) {
    background: #b8b0a3;
}

.side-btn__icon a {
    display: block;
    text-align: center;
    height: 80px;
    width: 80px;
    padding: 12px 0 0;
}

.side-btn__icon img {
    margin: auto;
    width: 30px;
    display: block;
    height: 36px;
}

.side-btn__icon p {
    font-size: 12px;
    color: #FFF;
}

.slidebtn__scroll {
    border: 2px solid #686254;
    border-radius: 50%;
    background: #FFF;
}

.slidebtn__scroll a {
    display: block;
    text-align: center;
    height: 80px;
    width: 80px;
    padding: 17px 2px 0 0px;
}

.slidebtn__scroll img {
    margin: auto;
    width: 35px;
    display: block;
    height: 27px;
}

.slidebtn__scroll p {
    font-size: 12px;
    color: #686254;
    font-weight: bold;
}

.main {
    padding: 0 0 80px;
}

.contents {
}

.more {
    font-family: arno-pro-display,serif;
    font-weight: 400;
    font-style: normal;
    position: relative;
    display: block;
    font-size: 20px;
    line-height: 1;
}

.more::after {
    content: " ";
    display: block;
    width: 82px;
    height: 9px;
    background: url(../img/common/v_01.svg) no-repeat top left;
    background-size: contain;
    position: relative;
    top : 0;
    margin: 0;
}

.btn {
    border: 2px solid #000;
    padding: 15px 0;
    max-width: 300px;
    width: 100%;
    display: block;
    text-align: center;
    font-size: 18px;
    margin: 30px auto;
}

.top-mv {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/top/mv.jpg) no-repeat center center;
    background: #FFF;
    background-size: cover;
}

.top-mv__logo {
    box-shadow: 0 0 10px #fff;
    background: #ffffffa1;
    padding: 20px;
}

.top-mv__logo img {
}

section {
    padding: 100px 0%;
}

section h2 {
    font-size: 54px;
    font-family: arno-pro-display,serif;
    font-weight: 400;
    color: rgb(0, 0, 0);
    line-height: 0.48;
    text-align: center;
    margin: 0 0 40px;
    margin: 0 0 60px;
}

.page-link {
    display: block;
    margin: 0 auto 30px;
    font-size: 16px;
    max-width: 300px;
    background: #FFF;
    font-weight: bold;
    text-align: center;
    padding: 5px 0;
    border: 2px solid #000;
    position: relative;
}

section h2 span {
    display: block;
    font-size: 18px;
    color: rgb(0, 0, 0);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    margin: 26px 0 0;
    font-family: 'source-han-sans-japanese';
}

section p {
    margin: 0 0 30px;
}

.top-news {
    padding: 100px 3%;
}

.top-news .container {
}

.top-news h2 {
}

.top-news h2 span {
}

.top-news ul {
}

.top-news ul::after {
    content: "";
    display: block;
    width: 30.6%;
}

.top-news li {
    width: 30.6%;
}

.top-news li a {
    display: block;
}

.top-news li a .img {
    margin: 0 0 5px;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 108%;
    padding-top: 100%;
}

.top-news li a span {
    font-size: 16px;
}

.top-news h3 {
    /*font-size: 20px;*/
    font-weight: 500;
    font-size: 16px;
}

.top-course {
}

.entry-contents .top-course {
    /* max-width: 600px; */
    margin: 0 auto 0;
}

.entry-contents .oshare-box:nth-child(2n+1) {
    background-position: right center;
    background-size: 90%;
}

.entry-contents .oshare-box:nth-child(2n+1) .top-course__box {
    padding: 30px 0px 30px;
    margin: 0;
    /* width: 60%; */
}

.entry-contents .top-course__box h3 {
    margin: 0 0 20px;
    font-size: 28px;
    font-family: arno-pro-display,serif;
    font-weight: 400;
}

.entry-contents .top-course__box h4 {
    font-size: 16px;
    margin: 0 0 40px;
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 700;
}

.entry-contents .top-course > p {
    text-align: center;
}

.top-course h2 {
}

.top-course h2 span {
}

.oshare-box {
    background-position: right center;
    background-repeat: no-repeat;
    padding: 70px 0;
    background-size: 1000px;
    margin: 0 0 60px;
}

.oshare-box:nth-child(2n+1) {
    background-position: left center;
}

.oshare-box .container {
}

.top-course__box {
    width: 40%;
    background: #FFF;
    /* background: #ffffffad; */
    padding: 30px 0px 30px;
}

.oshare-box:nth-child(2n+1) .top-course__box {
    margin: 0 0 0 auto;
    padding: 30px 0 30px 30px;
}

.top-course__box h3 {
    font-size: 32px;
    line-height: 1.2;
    margin: 0 0 14px;
}

.top-course__box h4 {
    font-size: 16px;
    font-weight: 500;
    margin: 0 0 20px;
}

.top-course__box .more {
}

.top-course__box p {
    font-size: 14px;
}

.three-post__block {
    margin: 100px 3% 0;
}

.three-post__block ul {
}

.three-post__block li {
    width: 30.5%;
}

.three-post__block li .img {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 106%;
    margin: 0 0 10px;
}

.three-post__block li h3 {
    font-size: 32px;
    margin: 0 0 6px;
}

.three-post__block li p {
    font-size: 16px;
}

.three-post__block li .more {
}

.two-post__block {
    margin: 100px 3% 0;
    margin: 0 3%;
}

.two-post__block ul {
}

.two-post__block li {
    width: 47.5%;
}

.two-post__block li .img {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 106%;
    margin: 0 0 10px;
    padding-top: 100%;
    margin: 0;
}

.two-post__block li h3 {
    font-size: 32px;
    margin: 0 0 6px;
}

.two-post__block li p {
    font-size: 16px;
}

.two-post__block li .more {
}

.top-interview {
    background: #f8f8f8;
    padding: 100px 100px;
}

.top-interview .container {
}

.top-interview h2 {
}

.top-interview h2 span {
}

.slick-post {
    margin: 0 0 40px;
}

.slick-post ul {
}

.slick-post li {
    width: 32%;
    position: relative;
    margin: 0 10px;
}

.slick-post a {
}

.slick-post .img {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 72%;
}

.slick-post .txt {
    background: #FFF;
    padding: 40px 30px;
}

.slick-post .txt a {
}

.slick-post .txt p {
    margin: 0 0 16px;
}

.slick-post .txt h3 {
    font-weight: 500;
    margin: 0 0 15px;
    font-size: 14px;
}

.slick-post .txt .more {
    margin: 30px 0 0;
}

.top-etc {
}

.top-etc .oshare-box {
}

.top-etc .oshare-box .container {
}

.top-etc .oshare-box .top-course__box {
}

.top-etc .oshare-box .top-course__box h3 {
}

.top-etc .oshare-box .top-course__box h4 {
}

.top-etc .oshare-box .top-course__box p {
}

.top-etc .oshare-box .top-course__box .more {
}

.top-gallery {
    padding: 0px 3% 100px;
}

.top-gallery .container {
    max-width: 800px;
}

.top-gallery .img {
    width: 49%;
}

.top-gallery .txt {
    width: 49%;
    background: #2c211d;
    padding: 50px 30px;
}

.top-gallery h2 {
    color: #FFF;
    text-align: left;
}

.top-gallery h2 span {
    color: #FFF;
    font-size: 18px;
    text-align: left;
}

.top-gallery p {
    color: #FFF;
}

.top-gallery .more {
    color: #FFF;
}

.top-gallery .more::after {
    background-image: url(../img/common/v_04.svg);
}

.top-blog {
    background: #faf5ef;
    padding: 100px 100px;
}

.top-blog .container {
}

.top-blog h2 {
}

.top-blog h2 span {
}

.top-blog .slick-post {
}

.top-blog .slick-post ul {
}

.top-blog .slick-post li {
}

.top-blog .slick-post li a {
}

.slick-post .category-name {
    display: block;
    background: #000;
    color: #FFF;
    position: absolute;
    left: 0;
    top: 0;
    padding: 5px 20px;
    font-size: 16px;
    font-weight: 700;
}

.top-blog .slick-post .img {
}

.top-blog .slick-post .txt {
}

.top-blog .slick-post .txt a {
}

.top-blog .slick-post .txt p {
}

.top-blog .slick-post .txt h3 {
}

.top-blog .slick-post .txt .more {
}

.top-blog .btn {
}

.top-links {
}

.top-links .container {
    max-width: 800px;
}

.top-links .box {
    width: 49%;
    width: 47.5%;
}

.top-links .box a {
    display: block;
    background-repeat: no-repeat;
    background-position: center center;
    padding: 100px 0 50px;
    text-align: center;
    padding: 100% 0 0 0;
    position: relative;
}

.top-links .txt {
    position: absolute;
    margin: auto;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 50px;
}

.top-links .txt a {
}

.top-links .txt h2 {
    color: #FFF;
    margin: 0;
}

.top-links .txt span {
    color: #FFF;
}

.top-links .txt .more {
    margin: 0 auto 0;
    width: 170px;
    color: #FFF;
    text-align: left;
}

.top-links .txt .more::after {
    background-image: url(../img/common/v_04.svg);
}

.site-footer {
    padding: 0 0 40px;
}

.site-footer .container {
}

.site-footer__sitemap {
    margin: 0 0 30px;
}

.site-footer__sitemap > div {
    /* width: 25%; */
    text-align: center;
    display: flex;
    justify-content: center;
    /* align-items: center; */
    /* border-right: 1px solid #5f5f5f; */
}

.site-footer__sitemap > div.site-footer__logo {
    /*     align-items: center; */
}

.site-footer__logo a {
    display: block;
}

.site-footer__logo a img {
}

.site-footer__navi {
    padding: 0px 2%;
}

.site-footer__navi ul {
}

.site-footer__navi li {
    text-align: left;
    margin: 0 0 10px;
}

.site-footer__navi a {
}

.site-footer__sns {
    margin: 30px auto 0;
}

.site-footer__sns ul {
}

.site-footer__sns li {
    margin: 0 3px;
}

.site-footer__sns a {
}

.site-footer__sns img {
}

.site-footer .copyright {
    text-align: right;
}

/* lower_mv */
.confirm_complete .lower-mv {
    display: none;
}

.lower-mv .lower-mv__img-box,
.lower-mv .lower-course-mv__img-box {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.lower-mv__img-box {
    width: 50%;
    height: 758px;
}

.lower-course-mv__img-box {
    width: 100%;
    height: 540px;
    position: relative;
}

.lower-course-mv__img-box::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(104, 98, 85, 0.2);
}

.lower-mv .lower-mv__ttl-box {
}

.lower-mv__ttl-box {
    width: 50%;
    background: #fdf6f0;
    align-items: center;
    justify-content: center;
}

.lower-course-mv__ttl-box {
    position: absolute;
    padding-right: 9vw;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
}

.lower-mv__ttl-box .lower-mv--lower-ttl {
}

.lower-mv--lower-ttl {
    font-size: 50px;
    font-family: arno-pro-display,serif;
    font-weight: 400;
    color: rgb(0, 0, 0);
    line-height: 1.48;
    text-align: center;
    margin: 0 0 40px;
}

.lower-course-mv--lower-ttl {
    font-size: 7.4rem;
    font-family: arno-pro-display,serif;
    font-weight: 200;
    font-style: normal;
    color: #fff;
    line-height: 1.1;
    letter-spacing: 0.03em;
    text-align: left;
    text-shadow: 0 0 12px rgba(104, 98, 85, 0.9);
}

.lower-mv__ttl-box flex{
    display: block;
    font-size: 18px;
    color: rgb(0, 0, 0);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    margin: 26px 0 0;
    font-family: a-otf-ryumin-pr6n, serif;
}

.remake{
    padding-top: 270px;
}

.lower-mv__ttl-box h1.page-ttl{
    display: block;
    font-size: 18px;
    color: rgb(0, 0, 0);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    margin: 26px 0 0;
    font-family: a-otf-ryumin-pr6n, serif;
}

.lower-course-mv__ttl-box h1.course-page-ttl {
    display: block;
    font-size: 2.0rem;
    letter-spacing: 0.2rem;
    color: #fff;
    font-weight: 700;
    line-height: 1.6;
    margin: 16px 0 0;
    font-family: a-otf-ryumin-pr6n, serif;
    text-shadow: 0 0 12px rgba(104, 98, 85, 0.9);
}

@media (min-width: 768px) and (max-width: 1080px) {
    .lower-course-mv__img-box {
        position: relative;
    }

    .lower-course-mv__ttl-box {
        padding-right: 0;
        width: 50%;
        padding-right: 2vw;
    }

    .lower-course-mv__img-box {
        height: 450px;
    }

    .lower-course-mv--lower-ttl {
        font-size: 4.4rem;
    }

    .lower-course-mv__ttl-box h1.course-page-ttl {
        font-size: 1.6rem;
    }
}

@media screen and (max-width: 766px) {
    .lower-course-mv__ttl-box {
        width: 100%;
        padding-right: 0;
    }

    .lower-course-mv--lower-ttl {
        font-size: 4.0rem;
        text-align: center;
        text-shadow: 0 0 12px rgba(104, 98, 85, 0.9);
    }

    .lower-course-mv__ttl-box h1.course-page-ttl {
        font-size: 1.4rem;
        text-align: center;
        margin: 4px 0 0;
        text-shadow: 0 0 8px rgba(104, 98, 85, 0.9);
    }
}

.lower-mv__ttl-box span{
    display: block;
    font-size: 18px;
    color: rgb(0, 0, 0);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    margin: 26px 0 0;
    font-family: a-otf-ryumin-pr6n, serif;
}

.section__ttl {
    font-size: 32px;
    line-height: 1.2;
    margin: 0 0 14px;
    text-align: center;
}

.section__sub-ttl {
    font-size: 16px;
    font-weight: 500;
    margin: 0 0 20px;
    text-align: center;
    line-height: 2;
}

.section__name-ttl {
    font-size: 24px;
}

.section__name-ttl span {
    display: block;
    font-size: 18px;
    margin: 4px 0 0;
}

/* about us */
.about__sec01 {
    padding: 100px 3%;
}

.about__sec01 .container {
}

.about__sec01 .section__ttl {
}

.about__sec01 .section__sub-ttl {
}

.about__sec01 .about__item {
}

.about__item {
    padding: 57px 0 0;
}

.about__item .text-box {
    width: 50%;
}

.about__item .nunber__ttl {
    margin: 20px 0 0;
    font-size: 32px;
}

.about__item .nunber__ttl span {
    display: block;
    color: #686255;
    font-size: 28px;
}

.about__item .t1 {
    margin: 30px 0 0px;
}

.about__item .img-box {
    width: 50%;
}

.about__item .img-box img {
}

.about__sec02 {
    padding: 100px 3%;
}

.about__sec02 .container {
    /* border-top: 1px solid; */
    /* border-bottom: 1px solid; */
}

.about__sec02 .section__ttl {
    /* padding: 65px 0 0; */
}

.about__sec02 .section__sub-ttl {
}

.about__sec02 .about__item {
    padding: 57px 0 113px;
}

.about__sec02 .about__item .text-box {
}

.about__sec02 .about__item .section__name-ttl {
}

.about__sec02 .about__item .section__name-ttl span {
}

.about__sec02 .about__item .t1 {
    margin: 56px 0 0px;
}

.about__sec02 .about__item .t2 {
    margin: 18px 0 0px;
}

.about__sec02 .about__item .t2 span {
    font-weight: bold;
}

.about__sec02 .about__item .img-box {
}

.about__sec02 .about__item .img-box img {
}

/* contact */
.contact__sec {
    padding: 100px 3%;
}

.contact__sec .container {
}

.contact__sec .t1 {
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    margin: 0 0 75px;
}

.contact__sec .t1.contact-msg ,.confirm_complete .contact__sec .t1.confirm-msg {
    display: block;
}

.contact__sec .t1.confirm-msg ,.confirm_complete .contact__sec .t1.contact-msg {
    display: none;
}

.contact__sec .contact__form {
}

.contact__form {
}

.contact__form .contact__form--item {
}

.form__date {
    margin: 0 0 10px;
    font-size: 14px;
    padding: 8px 8px 7px;
}

.form__select {
    margin: 0 0 10px;
    font-size: 14px;
    padding: 10px;
}

.contact__form--item {
    justify-content: flex-start;
    align-items: center;
    margin: 0 0 46px;
}

.contact__form--item.radio__item {
    margin: 0 0 64px;
}

.contact__form--item.textarea__item {
    align-items: flex-start;
    margin: 0 0 66px;
}

.contact__form--item dt {
    width: 242px;
    font-size: 14px;
}

.contact__form--item dd {
    width: calc(100% - 242px);
}

.contact__form--item dd p {
    margin: 0 0 10px;
    line-height: 1.4;
}

.contact__form--item .radio__wap {
    padding: 0px 0 0px;
}

.radio__wap {
}

#mailformpro .radio__wap ul {
}

#mailformpro .radio__wap ul li {
    margin: 0 0 18px;
    border-bottom: 1px solid #ddd;
    padding: 0 0 10px;
}

#mailformpro .radio__wap ul h4 {
    margin: 0 0 8px;
    font-size: 16px;
}

#mailformpro .radio__wap ul p {
}

.radio__wap ul .contact__form--radio {
    margin: 0 20px 10px 0px;
    font-weight: bold;
    display: inline-block;
}

.radio__wap .contact__form--radio {
    /* width: 250px; */
    margin: 24px 0 0px;
}

.radio__wap .contact__form--radio .radio__input {
    margin: 0px 5px 0px 0px;
    width: 16px;
    height: 16px;
    position: relative;
    top: 2px;
}

.radio__wap .contact__form--radio .radio__part {
}

.contact__form--item .must {
}

.contact__form--item .form__input {
    border-radius: 0;
    border: 1px solid;
    /* height: 71px; */
    line-height: 1.4;
    max-width: 707px;
    width: 100%;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    padding: 20px 20px;
    font-size: 16px;
}

.contact__form--item .form__textarea {
    border-radius: 0;
    border: 1px solid;
    height: 322px !important;
    max-width: 707px !important;
    width: 100% !important;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    padding: 10px 20px;
    font-size: 16px;
}

.contact__form .submit__btn {
    display: block;
    margin: 0 auto;
    width: 86%;
    max-width: 336px;
    border: none;
    background: #696357;
    text-align: center;
    cursor: pointer;
    font-size: 18px;
    color: #FFF;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    padding: 32px 0 36px;
}

.contact__form .submit__btn[type=submit] {
    -webkit-appearance: none;
    border-radius: 0;
}

/* faq */
.faq__sec01 {
}

.faq__sec01 .container {
}

.faq__sec01 .section__ttl.font-min {
    margin: 0px 0 13px;
}

.faq__sec01 .faq__list {
    justify-content: flex-start;
}

.faq__sec01 .faq__list li {
}

.faq__list li {
    width: 300px;
    margin-right: calc((100% - 900px) / 2);
    margin-top: 47px;
}

.faq__list li:nth-child(3n) {
    margin-right: 0;
}

.faq__list li .faq__list--link {
    display: block;
    width: 100%;
    padding: 26px 40px 24px 39px;
    background: #fdf6f0;
    font-size: 16px;
    position: relative;
}

.faq__list li .faq__list--link::after {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background: url("../img/common/v_05.svg") no-repeat top left;
    position: absolute;
    top: 0;
    margin: auto;
    bottom: 0;
    right: 20px;
}

.faq__sec02 {
}

.faq__sec02 .container {
}

.faq__sec02 .section__ttl.font-min {
    margin: 0 0 27px;
}

.faq__sec02 .faq__list {
}

.faq__sec02 .faq__list li {
}

.faq__list li .faq__list--ttl {
    padding: 13px 20px 13px 40px;
    background: #fdf6f0;
    font-size: 16px;
    width: 241px;
    margin: 0 0 24px;
}

.faq__list li .faq__list--question {
    padding: 0px 0px 7px 38px;
    font-size: 16px;
    background: url(../img/faq/q.png) center left no-repeat;
}

.faq-detail__sec {
}

.faq-detail__sec .container {
}

.faq-detail__sec .faq-detail__ttl {
}

.faq-detail__ttl {
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    font-size: 16px;
    display: inline-block;
    padding: 16px 40px 16px 40px;
    background: #fdf6f0;
    line-height: 1.2;
    font-weight: bold;
    /* width: 240px; */
    text-align: left;
    margin: 0 0 35px;
}

.faq-detail__sec .faq-detail__list {
}

.faq-detail__list {
}

.faq-detail__list li {
    margin: 45px 0 0;
    margin: 0 0 45px;
}

#mailformpro .faq-detail__list li {
    margin: 0 0 25px;
}

.faq-detail__list .faq-detail__item {
}

.faq-detail__item {
    background: #fdf6f0;
}

.faq-detail__item .question {
    font-size: 16px;
    padding: 29px 80px 25px 95px;
    font-weight: bold;
    position: relative;
    cursor: pointer;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.contact__course .faq-detail__item .question {
    width: 100%;
    padding: 20px 60px 20px 20px;
}

.contact__course .faq-detail__item .question:before {
    display: none;
}

.contact__course .faq-detail__item .question:after {
    top: 22px;
}

.faq-detail__item .question:hover {
    opacity: 0.6;
}

.glossary .faq-detail__item .question {
    padding: 29px 80px 25px 30px;
}

.faq-detail__item .question:before {
    content: '';
    width: 30px;
    height: 28px;
    background: url("../img/common/q.svg") center center no-repeat;
    background-size: contain;
    position: absolute;
    margin: auto;
    top: 8px;
    bottom: 0;
    left: 39px;
}

.glossary .faq-detail__item .question:before {
    display: none;
}

.faq-detail__item .question:after {
    content: " ";
    display: block;
    width: 16px;
    height: 16px;
    background: url("../img/common/plus.svg") no-repeat top left;
    position: absolute;
    top: 32px;
    right: 32px;
    margin: 0 auto;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.faq-detail__item .question.active:after {
    background-image: url("../img/common/minus.svg");
    width: 20px;
    height: 20px;
    top: 38px;
    right: 30px;
}

.faq-detail__item .answer {
    padding: 29px 80px 35px 95px;
    font-weight: bold;
    font-size: 16px;
    color: #686255;
    position: relative;
}

.contact__course .faq-detail__item .answer {
    width: 100%;
    padding: 20px 60px 20px 20px;
}

.contact__course .faq-detail__item .answer:before {
    display: none;
}

.glossary .faq-detail__item .answer {
    padding: 29px 80px 35px 30px;
}

.faq-detail__item .answer:before {
    content: '';
    width: 27px;
    height: 27px;
    background: url(../img/common/a.svg) center center no-repeat;
    background-size: contain;
    position: absolute;
    top: 28px;
    left: 37px;
}

.glossary .faq-detail__item .answer:before {
    display: none;
}

.faq-detail__sec .btn {
    margin: 115px auto 30px;
    max-width: 366px;
    border: none;
    background: #696357;
    color: #FFF;
    padding: 32px 0;
}

/* glossary */
.glossary_sec {
}

.glossary_sec .container {
}

.glossary_sec .glossary__aside {
}

.glossary__aside {
    width: 240px;
    /* padding: 49px 0 0; */
}

.glossary__aside .glossary__aside__list {
}

.glossary__aside__list {
    width: 100%;
}

.glossary__aside__list li {
    margin-bottom: 14px;
    width: 100%;
}

.glossary__aside__list a {
    display: block;
    background: #fdf6f0;
    background: #686255;
    color: #FFF;
    font-weight: bold;
    padding: 24px 39px 22px 39px;
    font-size: 16px;
    position: relative;
}

.glossary__aside__list a:after {
    content: '＞';
    position: absolute;
    right: 13px;
}

.glossary__aside__list .nonactive {
    pointer-events: none;
}

.glossary__aside__list .nonactive:after {
    content: none;
}

.glossary_sec .glossary__article {
}

.glossary__article {
    width: calc(100% - 356px);
}

.glossary__article .glossary__item {
}

.glossary__item {
    padding: 0 0 70px;
}

.glossary__item:last-child {
    padding: 0 0 0px;
}

.glossary__item .section__ttl.font-min {
    text-align: left;
    margin: 0 0 3px;
}

.glossary__item .glossary__list {
}

.glossary__list {
}

.glossary__list li {
    width: 48%;
    margin: 20px 0 0;
}

.glossary__list a {
    display: block;
    background: #fdf6f0;
    font-weight: bold;
    padding: 24px 39px 22px 39px;
    font-size: 16px;
    position: relative;
}

.glossary__list a:after {
    content: '＞';
    position: absolute;
    right: 20px;
}

/* comapny */
.company_sec {
}

.company_sec .container {
}

.company_sec .company_table {
}

.company_table {
    width: 100%;
    max-width: 950px;
    margin: 0 auto;
}

.company_table tbody {
}

.company_table tr {
}

.company_table td {
    border: 1px solid;
    font-size: 14px;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
    padding: 26px 30px 24px;
    width: 30%;
}

.company_table td:last-child {
    width: 70%;
}

/* request */
.request__sec {
}

.request__sec .container {
}

.request__sec .section__ttl {
    margin: 0 0 40px;
}

.btn2 {
    text-decoration: none;
    display: block;
    margin: 30px auto;
    text-align: center;
    width: 100%;
    max-width: 350px;
    background: #686255;
    color: #FFF;
    padding: 24px 0;
    position: relative;
    font-size: 18px;
}

.btn2.black {
    background: #000;
}

.btn2:hover {
    color: #FFF;
}

.btn2::after {
    content: " ";
    display: inline-block;
    width: 33px;
    height: 10px;
    background: url(../img/marriage_ring/v_02.svg) no-repeat top left;
    position: relative;
    top : 0;
    margin: 0 0 0 11px;
}

.entry-contents .btn2 {
    text-decoration: none;
}

.entry-contents .btn {
    text-decoration: none;
}

.entry-contents .more {
    text-decoration: none;
}

.entry-contents {
    padding: 40px 3%;
}

.entry-contents.padding-top {
    padding-top: 80px;
}

.entry-contents h2 {
    font-size: 32px;
    font-family: ten-mincho, serif;
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 400;
    color: rgb(0, 0, 0);
    line-height: 1;
    text-align: center;
    margin: 0 0 40px;
}

.entry-contents h2 span {
    display: block;
    font-size: 18px;
    color: rgb(0, 0, 0);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    margin: 26px 0 0;
    font-family: 'source-han-sans-japanese';
}

.entry-contents h3 {
    font-size: 18px;
    margin: 0 0 30px;
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 700;
}

.entry-contents h4 {
    font-size: 18px;
}

.entry-contents p {
    font-size: 16px;
    margin: 0 0 30px;
}

.entry-contents ul {
    margin: 30px 0 30px;
}

.entry-contents li {
    font-size: 18px;
    margin: 0 0 10px;
}

.entry-contents a {
    text-decoration: underline;
}

.entry-contents .post-detail p > a:not([class*="btn"]),
.entry-contents .post-detail td a {
    color: #199BFF !important;
}

.entry-contents figure {
    margin: 0 0 30px;
}

.entry-contents figcaption {
    font-size: 16px;
    margin: 10px 0 0;
}

.entry-contents table {
    width: 100%;
    margin: 0 0 60px;
}

.entry-contents td {
    padding: 10px 20px;
    border: 1px solid #333;
    vertical-align: middle;
}

.entry-contents th {
    padding: 10px;
    border: 1px solid #333;
    background: #ccc;
    width: 170px;
    vertical-align: middle;
    text-align: center;
}

.marrigae-ring__block {
    margin: 70px 0 50px;
}

.marrigae-ring__block ul {
}

.marrigae-ring__block li {
    margin: 0 0 80px;
}

.marrigae-ring__block .img {
    width: 50%;
}

.marrigae-ring__block .img img {
}

.marrigae-ring__block .txt {
    width: 46%;
}

.marrigae-ring__block li:nth-child(2n+1) .txt {
    order: -1;
}

.marrigae-ring__block h3 {
    margin: 0 0 40px;
    font-size: 18px;
    /* font-family: a-otf-ryumin-pr6n, serif; */
    /* font-weight: 700; */
}

.marrigae-ring__block p {
}

.btn-gray {
}

.marriage-ring__guide {
    max-width: 800px;
    margin: 0 auto 40px;
    width: 100%;
}

.marriage-ring__guide h2 {
}

.marriage-ring__guide ul {
}

.marriage-ring__guide li {
    border: 1px solid #000;
}

.marriage-ring__guide li .img {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    /* padding: 13%; */
    width: 320px;
    background-color: #b8b0a3;
    position: relative;
    min-height: 100px;
}

.marriage-ring__guide li .img div {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
}

.marriage-ring__guide li .img::before {
    content: " ";
    display: block;
    background-repeat: no-repeat;
    background-position: top left;
    background-size: contain;
    position: absolute;
    top : 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}

.marriage-ring__guide li .img::before {
    margin: auto 40px;
}

.marriage-ring__guide li .icon01::before {
    width: 70px;
    height: 60px;
    background-image: url(../img/marriage_ring/icon01.svg);
}

.marriage-ring__guide li .icon02::before {
    width: 70px;
    height: 45px;
    background-image: url(../img/marriage_ring/icon02.svg);
}

.marriage-ring__guide li .icon03::before {
    width: 70px;
    height: 33px;
    background-image: url(../img/marriage_ring/icon03.svg);
}

.marriage-ring__guide li .txt {
    width: calc(100% - 320px);
    display: flex;
    align-items: center;
    padding: 0 40px 0;
}

.marriage-ring__guide li h3 {
    margin: 0 0 0 auto;
    padding: 0 0px 0 30px;
    width: 80%;
    text-align: center;
    font-size: 22px;
    /* font-family: a-otf-ryumin-pr6n, serif; */
    /* font-weight: 700; */
}

.marriage-ring__guide li p {
    margin: 0;
    padding: 20px 0;
}

.marriage-ring__guide > p {
    text-align: right;
}

.marriage-ring__guide .btn2 {
    margin: 60px auto 30px;
}

.marriage-ring__material {
    max-width: 780px;
    margin: 0 auto 40px;
    width: 100%;
}

.marriage-ring__material h2 {
}

.marriage-ring__material p {
    text-align: center;
}

.marriage-ring__material ul {
}

.marriage-ring__material ul.reverse {
}

.marriage-ring__material ul.reverse .txt {
    order: -1;
    width: 50%;
}

.marriage-ring__material ul.reverse .img {
    width: 50%;
    padding-top: 35%;
    background-size: contain;
    background-color: #b5b2a1;
}

.marriage-ring__material ul.row-type {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
}

.marriage-ring__material ul.row-type li {
    width: 46%;
}

.marriage-ring__material ul.row-type .img {
    width: 100%;
    padding-top: 50%;
}

.marriage-ring__material ul.row-type .txt {
    width: 100%;
    padding: 30px;
}

.marriage-ring__material li {
    border: 1px solid #000;
    margin: 0 0 50px;
}

.marriage-ring__material .img {
    width: 40%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    padding-top: 30%;
}

.marriage-ring__material .txt {
    width: 60%;
    padding: 50px 50px;
}

.marriage-ring__material .txt h3 {
}

.marriage-ring__material .txt p {
    text-align: left;
}

.marriage-ring__material .more {
}

.marriage-ring__material .btn2 {
}

.marriage-ring__option {
    max-width: 780px;
    margin: 0 auto 40px;
    width: 100%;
}

.marriage-ring__option h2 {
}

.marriage-ring__option p {
    text-align: center;
}

.marriage-ring__option ul {
}

.marriage-ring__option li {
    margin: 80px 0 80px;
}

.marriage-ring__option li h3 {
    text-align: center;
}

.marriage-ring__option li img {
    display: block;
    margin: 0 auto;
}

.marriage-ring__option li p {
}

.stone-list {
}

.stone-list ul {
}

.stone-list li {
    width: 14.4%;
    text-align: center;
    margin: 0 0 50px;
}

.stone-list.dia-list li {
    width: 20%;
}

.stone-list span {
    display: block;
    margin: 0 0 4px;
    font-weight: 400;
    font-size: 16px;
}

.stone-list img {
}

.stone-list h4 {
    font-weight: 400;
    font-size: 12px;
    margin: 10px 0 0;
}

.marriage-ring__faq {
    max-width: 780px;
    margin: 0 auto 0px;
    width: 100%;
    background: #faf5ef;
    padding: 30px;
    position: relative;
}

.marriage-ring__faq h2 {
    text-align: left;
    margin: 0 0 20px;
}

.marriage-ring__faq p {
}

.marriage-ring__faq .more {
    position: absolute;
    bottom: 40px;
    right: 50px;
}

.marriage-ring__links {
    max-width: 780px;
    margin: -80px auto 0px;
    width: 100%;
}

.marriage-ring__links ul {
    margin: 0;
}

.marriage-ring__links li {
    width: 45%;
    margin: 0;
}

.marriage-ring__links .btn2 {
    margin: 0;
}

/* access */
.bg_gray {
    background: #f8f8f8;
}

.access_sec01 {
}

.access_sec01 .full_container {
}

.access_sec01 .section__ttl {
    width: 100%;
    margin: 0 0 40px;
}

.access_sec01 .access__map {
    width: 50%;
    height: 520px;
}

.access__map {
}

.access__map iframe {
    width: 100%;
    height: 100%;
}

.access_sec01 .access__info {
}

.access__info {
    width: 46%;
}

.access__info .access__info--ttl {
    font-size: 18px;
    margin: 0 0 10px;
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 700;
}

.access__info .t1 {
    margin: 0 0 35px;
}

.access__info .t2 {
    margin: 0 0 60px;
}

.access__info .more {
}

.access__info .more:after {
    width: 155px;
    height: 11px;
    background: url(../img/access/arrow.svg) no-repeat top left;
}

.access_sec02 {
}

.access_sec02 .container {
}

.access_sec02 .section__ttl {
    margin: 0 0 0px;
}

.access_sec02 .access__list {
}

.access__list {
}

.access__list .access__list--item {
}

.access__list--item {
    width: 48%;
    background: #FFF;
    margin: 50px 0 0;
}

.access__list--item img {
    width: 100%;
}

.access__list--item .section__ttl {
    padding: 20px 6%;
    text-align: left;
}

.access__list--item .t1 {
    padding: 0 6% 0;
}

.access_sec03 {
}

.access_sec03 .access__map {
    height: 500px;
}

.access_sec03 .access__map iframe {
}

.pagenation {
    max-width: 1000px;
    margin: 0 auto;
    padding: 40px 0 0;
}

.wp-pagenavi {
    text-align: center;
}

.wp-pagenavi a {
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    font-size: 16px;
    display: inline-block;
    border: 1px solid #000;
    padding: 8px 10px;
    margin: 0 5px;
    text-decoration: none;
}

.wp-pagenavi a:hover {
    color: #000;
    border-color: #000;
}

.wp-pagenavi span {
    border: 1px solid #000;
    padding: 8px 10px;
    margin: 0 5px;
    font-size: 16px;
    display: inline-block;
}

.wp-pagenavi .current {
    border-color: #000;
    background: #000;
    color: #FFF;
}

.archive-list {
    /* margin: 60px 0 0; */
}

.archive-list ul {
}

.archive-list li {
    padding: 0 170px 30px 0;
    margin: 0 0 30px;
    position: relative;
    border-bottom: 1px solid #000;
}

.archive-list .date {
    font-size: 16px;
    display: block;
    margin: 0 0 10px;
}

.archive-list li h3 {
    margin: 0;
}

.archive-list .category {
    background: #686255;
    display: inline-block;
    padding: 5px 20px 8px;
    color: #FFF;
    margin: 0 20px 0 0;
}

.archive-list li .more {
    position: absolute;
    right: 40px;
    bottom: 20px;
}

/* aftercare */
.aftercare__sec {
    padding: 100px 3%;
}

.aftercare__sec .container {
}

.aftercare__sec .container > .t1 {
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}

.aftercare__sec .contact__form {
}

.aftercare__sec .aftercare__form--block {
}

.aftercare__form--block {
}

.aftercare__form--block .aftercare__ttl {
    background: #faf5ef;
    padding: 10px 20px 12px;
    font-size: 16px;
    margin: 60px 0 0px;
    /* font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif; */
    font-family: a-otf-ryumin-pr6n, serif;
    text-align: left;
    font-weight: 700;
    line-height: 1.4;
}

.aftercare__form--block .contact__form--item {
}

.aftercare__form--block .contact__form--item dt {
}

.aftercare__form--block .contact__form--item dd {
    width: 100%;
}

.aftercare__form--block .contact__form--item {
    margin: 0 0 30px;
}

.aftercare__form--block .contact__form--item dt {
    width: 100%;
    font-size: 18px;
    margin: 0 0 14px;
}

.aftercare__form--block .contact__form--item dd {
}

.aftercare__form--block .contact__form--item dd .form__input {
}

.aftercare__form--block .contact__form--item.radio__item {
}

.aftercare__form--block .contact__form--item.radio__item dt {
}

.aftercare__form--block .contact__form--item.radio__item dd.radio__wap {
}

.aftercare__form--block .contact__form--item.radio__item dd.radio__wap .contact__form--radio {
    display: block;
    width: 100%;
    margin: 10px 0 10px;
    font-size: 16px;
}

.aftercare__form--block .contact__form--item.radio__item dd.radio__wap .contact__form--radio .radio__input {
}

.aftercare__form--block .contact__form--item.radio__item dd.radio__wap .contact__form--radio .radio__part {
}

.aftercare__sec .aftercare__textbox {
    border: 1px solid #000;
    padding: 30px 30px;
    margin: 0 0 60px;
}

.aftercare__textbox {
}

.aftercare__textbox .t1 {
    font-size: 14px;
    margin: 0;
}

.aftercare__textbox .t1 span {
    font-size: 16px;
    font-weight: bold;
    margin: 0 0 7px;
    display: block;
}

.aftercare__sec .submit__btn {
}

.interview-mv {
    background-repeat: no-repeat;
    background-size: contain;
    background-position: right center;
    background-color: #f8f8f8;
    padding: 70px 3% 320px;
    margin: 0 0 -120px;
}

.interview-mv .container {
}

.interview-mv .txt {
    width: 50%;
    background: #FFF;
    padding: 30px 30px 50px;
}

.interview-mv h3 {
    font-size: 32px;
    line-height: 1.4;
    margin: 0 0 30px;
}

.interview-mv h4 {
}

.entry-contents figure table {
}

.entry-contents figure table {
    width: 100%;
}

.entry-contents figure table tbody {
}

.entry-contents figure table tr {
}

.entry-contents figure table th ,.entry-contents figure table td {
    font-size: 14px;
    padding: 20px 30px;
    border: 1px solid #000;
    text-align: left;
}

.entry-contents figure table th {
    background: #faf5ef;
}

.entry-contents figure table td {
}

.low-list {
}

.low-list ul {
}

.low-list li {
    margin: 0 0 50px;
}

.low-list li h3 {
    background: #faf5ef;
    padding: 10px 20px 12px;
    margin: 0 0 14px;
}

.low-list li p {
    padding: 0 0 0 20px;
}

.top__bnrsec {
    margin: 100px 0;
    padding: 0;
}

.top__bnrsec.first-child {
    margin: 150px 0;
    padding: 0;
}

.top__bnrsec .container {
}

.top__bnrsec .top__bnr {
}

.top__bnr {
    width: 100%;
    align-items: center;
    height: 350px;
    /* min-height: 350px; */
    background-image: url(../img/top/bnrlink01.jpg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.top__bnr a {
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: flex-end;
    padding: 0 5%;
    text-decoration: none;
}

.top__bnr a.left {
    justify-content: flex-start;
}

.top__bnr a.right {
    justify-content: flex-end;
}

.top__bnr .top__bnr--ttl {
    line-height: 1.2;
    font-weight: 100;
    font-size: 50px;
}

.top__bnr--ttl {
    margin: 0;
    color: #fff;
    font-family: ten-mincho, serif;
}

.top__bnr--ttl span {
    color: #FFF;
    font-weight: 100;
    font-size: 16px;
    margin: 30px 0 0;
    display: block;
    font-family: 'source-han-sans-japanese','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
}

.top__bnr--ttl.textright {
    text-align: right;
}

.top__bnr--ttl.textright span {
    text-align: right;
}

.top__bnr--ttl.textleft {
    text-align: left;
}

.top__bnr--ttl.textleft span {
    text-align: left;
}

.top .container {
    max-width: 1200px;
}

.top__instagram--list {
}

.top__instagram--list .top__instagram--thmb {
}

.top__instagram--thmb {
    width: 31%;
    margin: 0 0 3.3%;
}

.top__instagram--thmb a {
    display: block;
}

.top__instagram--thmb .img {
    padding-top: 100%;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.top-course .two-post__block .container {
    max-width: 1000px;
}

.top-news .container {
    max-width: 1000px;
}

.top-links .container {
    max-width: 1000px;
}

.top-course__link {
    position: relative;
    display: block;
}

.top-course__link .txt {
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    height: 100px;
    width: 100%;
}

.two-post__block ul li:nth-child(2) .top-course__link .txt {
    height: 148px;
}

.top-course__link .txt h3 {
    text-align: center;
    color: #FFF;
    font-size: 50px;
    line-height: 1;
    margin: 0 0 18px;
    font-family: arno-pro-display,serif;
    font-weight: 400;
}

.top-course__link .txt p {
    text-align: center;
    color: #FFF;
}

.must-icon {
    padding: 2px 8px 3px;
    background: #cb1616;
    color: #FFF;
    font-size: 12px;
    margin: 0 8px 0 0;
}

.top-course.nolinks {
    padding: 0 0 100px;
}

.top-course.nolinks .container {
    max-width: 1200px;
}

.top-course.nolinks .two-post__block li .img {
    padding-top: 60%;
}

.request__sec .t1 {
    font-size: 16px;
    text-align: center;
    line-height: 2;
    margin: 0px 0 70px;
}

.request__sec .t2 {
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    margin: 0 0 45px;
}

.breadcrumbs {
    margin: 20px 0 20px;
    padding: 0 3%;
}

.breadcrumbs span {
    font-size: 14px;
    margin: 0 10px 0;
}

.breadcrumbs span:first-child {
    margin: 0 5px 0 0;
}

.top-mv .video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top-mv {
    position: relative;
}

.top-mv__logo {
    position: absolute;
}

.tube {
    width: 100%;
    height: 100%;
}

.tube iframe {
    width: 100%;
    height: 100%;
}

.top-banner__list {
    padding: 50px 0% 0;
}

.top .top-banner__list {
    padding: 100px 0 0;
}
.top-banner__list:nth-child(3){
    padding: 20px 0 0;
}

.top-banner__list .container {
}

.top-banner__list h2 {
    font-size: 54px;
}

.top-banner__list p {
}

.top-banner__block {
    padding: 30px 3%;
}

.top-banner__block .container {
}

.top-banner__block a {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    /* justify-content: center; */
    align-items: center;
    padding: 70px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    min-height: 350px;
    text-decoration: none;
}

.top-banner__block h3 {
    margin: 0;
    color: #fff;
    line-height: 1.2;
    font-weight: 100;
    font-size: 50px;
    width: 100%;
}

.top-banner__block:nth-child(2n+1) h3 {
    text-align: right;
}

.top-banner__block h3 span {
    color: #FFF;
    font-weight: 100;
    font-size: 16px;
    margin: 30px 0 0;
    display: block;
}

.top-banner__block p {
    margin: 20px 0 0;
}

.contact__form {
}

.contact__form .table {
}

.contact__form table {
    width: 100%;
}

.contact__form tbody {
}

.contact__form tr {
}

.contact__form th {
    text-align: left;
    padding: 40px 0px 30px 0;
    position: relative;
    vertical-align: top;
    width: 240px;
}

.contact__form th .must {
    background: #cb1616;
    display: inline-block;
    padding: 5px 10px;
    margin: 0 10px 0 0;
    color: #FFF;
    font-size: 12px;
    border-radius: 5px;
    line-height: 1;
}

.contact__form th .any {
    background: #7f7f7f;
    display: inline-block;
    padding: 5px 10px;
    margin: 0 10px 0 0;
    color: #FFF;
    font-size: 12px;
    border-radius: 5px;
    line-height: 1;
}

.contact__form td {
    text-align: left;
    padding: 30px 0px 30px 0;
}

.contact__form .hasDatepicker {
    padding: 20px 10px;
    font-size: 14px;
    margin: 0 20px;
}

.contact__form .hasDatepicker.mwform_datepic01 {
    margin: 0 0px;
}

.contact__form td .error {
}

.contact__form td .mwform_text_1 {
    font-size: 14px;
    width: 100%;
    padding: 15px 10px;
    color: #000;
}

.contact__form .mwform-radio-field {
}

.contact__form .mwform_radio_wrap {
    margin: 10px 0 0;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-around;
    justify-content: space-between;
}

.mwform_radio_wrap.radiowap2 {
    justify-content: flex-start;
}

.contact__form td .mwform-radio-field label {
}

.contact__form td .mwform_radio_01 {
}

.contact__form td .mwform-radio-field-text {
    font-size: 13px;
}

.contact__form .radiowap2 .mwform-radio-field-text {
    font-size: 14px;
}

.contact__form .mwform_textarea_1 {
    width: 100%;
    height: 300px;
    font-size: 16px;
    line-height: 1.6;
    padding: 10px;
}

.contact__form p {
}

.contact__form .submit-btn {
    text-align: center;
}

.contact__form input[type="submit"] {
    appearance: none;
    -webkit-appearance: none;
}

.contact__form .mwform_submitButton_1 {
    background: rgb(105, 99, 87);
    color: #FFF;
    font-size: 14px;
    text-align: center;
    padding: 20px 100px;
    font-weight: bold;
    border: none;
    cursor: pointer;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.contact__form .mwform_submitButton_1:hover {
    opacity: 0.6;
}

/*============================
#reserve_type_block
============================*/
#reserve_type_block {
    margin: 10px 0 0;
}

#reserve_type_block .mwform-radio-field {
    margin: 0 0 14px;
}

#reserve_type_block .mwform-radio-field label {
}

#reserve_type_block input {
}

#reserve_type_block .mwform-radio-field-text {
    font-size: 16px;
}

#reserve_type_block input {
}

.reserve_time_block {
    display: inline-block;
    margin: 0 0 30px;
}

.reserve_time_select {
    font-size: 14px;
    padding: 20px 10px;
}

.reserve_time_select option {
}

.reserve_time_block input {
}

.single_thumb {
    margin: 0 0 60px;
    /* width: 200px; */
}

.single_thumb img {
    width: 100%;
}

.container.w800 {
    max-width: 800px;
}

.blog .single_thumb .container {
    width: 100%;
}

@media screen and (max-width: 1250px) {
    .site-footer__sitemap {
        margin: 0 120px 30px 0;
    }
}

.mbinputT,
.mbinputM,
.mbinputB,
.mbinput {
	display: none;
}
.mbbanner {
	background: #ccc;
	width: 100%;
	padding: 15px;
	margin-bottom: 50px!important;
	text-align: center;
}				
#header_wrap {
	width: 100%;
	height: 84px;
}	
.columnBox {
	margin-top: -50px;	 
}
.newsHeadline {
	max-width: 800px;
	margin: 0 auto -10px;
}
.newsHeadline p {
	text-align: center;
	padding: 7px 0 12px;
	letter-spacing: 4px;
	background: #fafafa;
	color: #666;
	font-size: 14px;
}			 
#ez-toc-container {
	width: 100%!important;
	padding: 20px!important;
	margin-bottom: 50px!important;
	font-size: 120%!important;
	background: #fafafa!important;
	border: none!important;
	display: table!important;
}
.ez-toc-title-container {
	padding-bottom: 15px!important;
}			
@media screen and (max-width: 768px){
	.newsHeadline {
		margin-bottom:-15px;
	}
	.newsHeadline p {
		letter-spacing: 1px;		
		font-size: 12px;		  
	}
	#header_wrap {
		height: 72px;
	}
	.columnBox {
		margin-top: -10px;	 
	}			  
}

.ts_date {
    overflow: hidden;
}

.ts_date .ts {
	background: #1f1715;
	color: #fff;
	display: block;
	font-size: 12px;
	border-radius: 5px;
	padding: 2px 10px 3px;
	margin-right: 2px;
	float: left;
}

.ts_date .date {
    float: right;
}

.voiceList a {
    text-decoration: none;
}

/*============================
common
============================*/

.nav_sns {
    width: 140px;
    margin: 0 auto 20px;
    clear:both;
}

.nav_btn {
    padding: 0 0 20px;
    width: 100%;
    display: flex;
    margin: 0 auto;
}
.nav_btn li {
    width: calc(25% - 15px);
    margin-right: 20px;
    display: block;
    text-align: center;
}
.nav_access {
    margin-right: 0!important;
}
.nav_btn li a {
    border-radius: 5px;
    text-align: center;
    color: #fff;
    display: block;
}
.nav_btn li.nav_reserve a {
    background: #686255 url(/wp-content/themes/icci/img/common/icon_calendar_wh.svg) left 5px center no-repeat;
    border: 1px solid #686255;
    background-size: auto 20px;
    color: #fff!important;
}

.nav_btn li.nav_tel a {
    background: #877e70 url(/wp-content/themes/icci/img/common/icon_tel_wh.svg) left 5px center no-repeat;
    border: 1px solid #877e70;
    background-size: auto 20px;
    color: #fff!important;
}

.nav_btn li.nav_request a {
    background: #aba293 url(/wp-content/themes/icci/img/common/icon_memo_wh.svg) left 5px center no-repeat;
    border: 1px solid #aba293;
    background-size: auto 20px;
    color: #fff!important;
}

.nav_btn li.nav_access a {
    background: #fff url(/wp-content/themes/icci/img/common/icon_access.svg) left 5px center no-repeat;
    border: 1px solid #686255;
    background-size: auto 20px;
    color: #686255!important;
}
.btn2 {
    background: #686255 !important;
}
.txt-jp {
    color: #fff;
    margin-top: 5px;
}

.t1Insta {
    text-align: center;
    font-weight: bold;
    margin-top: -50px;
    margin-bottom: 20px;
}

.t1Insta img {
    vertical-align: middle;
}


.caution {
    color: #c00;
}

.caution a {
    color: #c00;
    text-decoration: underline;
}

.caution a:hover {
    text-decoration: none;
}

.btn2.black {
    background: #686255!important;
}

.side-btn {
    bottom: 20px;
}

.side-btn__icon:nth-child(2n) {
  background: #877e70
}

.side-btn__icon:nth-child(3n) {
  background: #aba293;
}

@media screen and (max-width: 1380px) {
    .nav_btn {
        flex-wrap: wrap;
    }
    .nav_btn li {
        width: calc(50% - 10px);
        margin-right: 20px;
    }
    /*
    .nav_btn li:nth-child(2n) {
        margin-right: 0;
    }
    */
    .nav_tel {
        margin-right: 0!important;   
    }
    .nav_access {
           margin-right: 0;
    }
    .header_navi a {
        font-size: 14px!important;   
    }
}

@media screen and (min-width: 769px) {
    /*
    body {
        padding-top: 140px;   
    }
    .header-logo {
        right: auto;
        left: calc(100vw - 140px);
    }
    .header_navi a {
        font-size: 18px;   
    }    
    .header_navi ul ul li a {
        font-size: 16px;   
    }    
    .sp_menu .header_navi {
        padding: 80px 20px 20px;
    }    
    */    
    .header_navi {
        position: relative;    
        display: table;
        width: 100%;
        padding: 45px 200px;
    }    
    .header_navi .inner {
        display: table-cell;
        vertical-align: middle;   
    }
    .nav_btn {
        width: 100%;
    }    
    .nav_inner {
       text-align: center;
       margin: 0 auto;  
        width: 100%; 
        display: flex;
    }


    .nav_inner ul.font-ryumin {
        width: 50%;
    }
    
    .nav_btn li a {
        font-size: 18px;
        padding: 10px 5px;
    }    
    .faqbtn .btn2 {
        margin-top: 100px;   
    }
    .faqbtn .btn {
        margin-top: 40px;   
    }
    .topBanner {
        max-width: 800px;   
        margin: 100px auto 50px;        
    }
    .topBanner img {
        width: 100%;
        height: auto;   
    }
    .cglBox {
        display: table;   
        width: 100%;
    }
    .cglInfo {
        display: table-cell;   
        vertical-align: top;
    }
    .cglInfo .inner {
        border: 1px solid #000;
        padding: 40px;
        text-align: center;
    }    
    .cglInfo .inner ul {    
        display: inline-block;
        margin: 0;
    }
    .cglInfo .inner li {
        margin: 0;
        border: none;
        text-align: left;
        list-style: disc;
    }
    .cglInfo .inner h3 {
        margin: 0 0 20px;
        /* font-size:      */
    }    
    .cglImage {
        display: table-cell;   
        width: 250px;
        vertical-align: top;
        padding-left: 30px;
    }
    .cglImage img {
        width: 100%;
        height: auto;   
    }
}

@media screen and (max-width: 768px) {
	body {
		overflow-x: hidden;
	}
	body.fix {
		overflow-y: hidden;
		width: calc(100% - 15px);
	}
	.header_fix {
		width: 100%;
		position: fixed;
		top: 0;
		left: 0;     
		z-index: 2001;   
	}
	.header_fix.fix {
		/*height: 100%;*/
		z-index: 2001;   
		background: #fff;
		overflow-y: scroll;
	}

	.header_fix.fix #header_wrap {
		position: relative;
		width: 100%;
		display: block;
		top: 0;
		left: 0;
		z-index: 2002;
	}
	.header_fix.fix .sp_btn {
		position: absolute;
	}

	.header_fix.fix .header-logo {
		position: absolute;
	}

	.sp_btn.active span:nth-child(1),
	.sp_btn.active span:nth-child(2),
	.sp_btn.active span:nth-child(3) {
		background: #231815;
		border: 1px solid #656565;
	}
	.sp_menu li li:before {
		content: "ー ";
		font-family: arial;
	}
	.header_navi {
		height: auto!important;
		display: block;
		padding: 0 10px 10px;
	}
	.header_navi a {
		color: #333!important;
	}
    body {
        padding-top: 48px;   
    }
    .header-logo {
        right: auto;
        left: calc(100vw - 90px);
    }
    .nav_list {
        padding-bottom: 30px;   
    }
    .header_navi ul {
        margin: 0!important;   
    }
    .header_navi ul ul li a {
        font-size: 12px;   
    }
    .sp_menu {
        background: none;
        position: relative;
           
    }
    .sp_menu .header_navi {
        padding: 0 20px 20px;
    }        
    .nav_btn li a {
        font-size: 14px;
        padding: 7px 5px;
    }   
    .nav_btn {
        padding: 0 0 20px;
        width: 100%;
        display: block;
    }    
    .nav_btn li {
        width: 100%;
        margin: 0 0 7px;
    }
    .faqbtn .btn2 {
        margin-top: 50px;   
    }
    .faqbtn .btn {
        margin-top: 30px;   
    }
    .topBanner {
        max-width:100%;     
        margin: 50px 0 20px;
    }
    .topBanner img {
        width: 100%;
        height: auto;   
    }
    .cglBox { 
        width: 100%;
    }
    .cglInfo {
        width: 100%;
    }
    .cglInfo .inner {
        border: 1px solid #000;
        padding: 25px 15px;
        text-align: center;
        margin-bottom: 30px;
    }    
    .cglInfo .inner ul {    
        display: inline-block;
        margin: 0;
    }
    .cglInfo .inner li {
        margin: 0;
        border: none;
        text-align: left;
        list-style: disc;
        font-size: 13px;
    }
    .cglInfo .inner h3 {
        margin: 0 0 15px;  
        font-size: 16px;
    }    
    .cglImage {
        width: 100%;
    }
    .cglImage img {
        width: 50%;
        height: auto;   
    }    
    .rv__img {
        height: auto!important;   
    }
}



.top__voice--list {
}

.top__voice--thmb {
    width: 31%;
    margin: 0 0 3.3%;
}

.top__voice--thmb a {
    display: block;
}

.top__voice--thmb .img {
    padding-top: 100%;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

/*============================
202212
============================*/

@media screen and (max-width: 768px) {
    .pcimage {
        display: none;   
    }
    .columnList a {
        width: 100%;
        display: table!important;
    }
    .top-news .columnList li {
        margin: 0 0 20px;
        padding-bottom: 20px;
        border-bottom: 1px dotted #ccc;
    }    
    .top-news .columnList li a .img {
        width: 30%;
        height: auto;
        display: table-cell;
        padding: 0!important;
        vertical-align: top;
    }
    .columnList a .info {
        width: 70%;
        display: table-cell;
        padding: 0 0 0 10px;
        box-sizing: border-box;
        vertical-align: top;
    }
    .columnList a .info h3 {
        font-size: 14px !important;
        line-height: 1.4;
    }    
    .page-linkColumn {
        margin-top: 30px!important;   
    }
    .time_cat {
           border-bottom: 1px solid #eee;
           padding-bottom: 10px;
           margin-bottom: 10px;
           overflow: hidden;
    }
    .time_cat .t {
           float: right;
           font-size: 11px!important;
           display: block;
           padding-top: 1px!important;
    }
    .time_cat .c {
           display: inline-block;
          background: #686255;
          color: #fff;
          padding: 0 8px!important;
           font-size: 12px!important;
          float: left;
    }
}
@media screen and (min-width: 769px) {
    .spOnly {
        display: none!important;         
    }
    .spimage {
        display: none;   
    }
     .top-news .columnList li a .img img {
        display: none;    
    }   
    .page-linkColumn {
        margin-top: 50px!important;   
    }
    .time_cat {
           border-bottom: 1px solid #eee;
           padding-bottom: 10px;
           margin-bottom: 10px;
           overflow: hidden;
           padding-top: 5px;
    }
    .time_cat .t {
           float: right;
           font-size: 12px;
           display: block;
           padding-top: 0px!important;
    }
    .time_cat .c {
           display: block;
          background: #686255;
          color: #fff;
          padding: 0 8px!important;
           font-size: 13px;
          float: left;
    }
}
@media screen and (min-width: 1024px) {
    .time_cat .t {
           font-size: 13px;
           display: block;
           padding-top: 0px!important;
    }
    .time_cat .c {
          padding: 0 8px!important;
           font-size: 14px;
    }
}


.topNewsList {
    margin-bottom: 50px;
    border-top: 1px solid #ccc;
}
.topNewsList li {
    border-bottom: 1px solid #ccc;
    width: 100%;
}
.topNewsList li a {
    display: block;
    padding: 25px 0;
}

.topNewsList li .the_time {
    color: #877e70;
}
@media screen and (max-width: 768px) {
    .top-news {
        padding: 0px 3% 15px!important;
    }
     .topNewsList li .the_time {   
        display: block;
     }
    .topNewsList li {
        margin-bottom: 0;
    }
    .topNewsList li a {
        padding: 20px 0;
    }    
    .top-news li a span {        
        font-size: 14px!important;  
    }
}

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

    .nav_btn li.nav_reserve a {
        background: #1f1715 url(/wp-content/themes/icci/img/common/icon_calendar_wh.svg) left 5px center no-repeat;
        border: 1px solid #1f1715;
        background-size: auto 20px;
        color: #fff!important;
    }

    .nav_btn li.nav_tel a {
        background: #686255 url(/wp-content/themes/icci/img/common/icon_tel_wh.svg) left 5px center no-repeat;
        border: 1px solid #686255;
        background-size: auto 20px;
        color: #fff!important;
    }

    .nav_btn li.nav_line a {
        background: #877e70 url(/wp-content/themes/icci/img/common/icon_line.svg) left 5px center no-repeat;
        border: 1px solid #aba293;
        background-size: auto 20px;
        color: #fff!important;
        /*
        background: #26ab39 url(/wp-content/themes/icci/img/common/icon_line.svg) left 5px center no-repeat;
        border: 1px solid #26ab39;       
        background-size: auto 20px;         
        */
    }

    .nav_btn li.nav_request a {
        background: #aba293 url(/wp-content/themes/icci/img/common/icon_memo_wh.svg) left 5px center no-repeat;
        border: 1px solid #aba293;
        background-size: auto 20px;
        color: #fff!important;
    }

    .nav_btn li.nav_access a {
        background: #fff url(/wp-content/themes/icci/img/common/icon_access.svg) left 5px center no-repeat;
        border: 1px solid #686255;
        background-size: auto 20px;
        color: #686255!important;
    }
}

/*============================
202301
============================*/

.gCaution {
    margin: 0 0 10px!important;
    font-size: 11px!important;
}
.galleryBg {
    background:#f6f6f6;
    padding: 0 0 100px;
}
.gallerySide {
    float: left;
    width: calc(30% - 40px);
    background:#fff;
    padding: 20px;
}

.gallerySearch .box {
    margin-bottom: 10px;
}

.gallerySearch  select {
    width: 100%;
    border: 2px solid #ccc;
    padding: 10px 5px;
    padding-right: 30px;
    background: #fff url(/wp-content/themes/icci/img/arrow.png) right 5px center no-repeat;
    background-size: 8px auto;
  -webkit-appearance: none;
  appearance: none; 
}
.gallerySearch  select::-ms-expand {
  display: none; 
}
.gallerySearch select{
    font-size:90%;
}

.galleryMain {
    float: right;
    width: 70%;
}

.op_caution {
    font-size: 80%!important;
    color: #000!important;
    opacity: 1!important;
}
.search_title {
    font-weight: bold;
    margin: 0 0 20px!important;
    padding: 0!important;
}
.search_btn {
    border: none;
    border-radius: 100px;
    display: inline-block;
    padding: 15px 60px;
    background: #686254;
    color: #fff;
    font-size: 15px;
    margin-top: 10px;
}
.center {
    text-align: center;
}
.galleryList {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin: 0!important;
    padding: 0;
}
.galleryList li {
    width: calc(50% - 12px);
    margin-right: 20px;
    margin-bottom: 20px;
    background: #fff;
}
.galleryList li:nth-child(even) {
    margin-right: 0;
}
.galleryList li .img {
    width: 100%;
    background-position: center center;
    background-size: cover;
    position: relative;
}
.galleryList li .img img {
    width: 100%;
    height: auto;
}

.galleryList li a {
    text-decoration: none!important;
}
.g_cat {
      color: #686254;
      background: #fff;
      padding: 3px 10px;
      display: inline-block!important;
      margin: 0!important;
      font-size: 13px!important;
      position: absolute;
      z-index: 2;
      right: 0;
      bottom: 0;
      font-weight: bold;
}
.galleryList li .txt {
    padding: 5px 5px 5px 10px;
}
.g_term {
    display: inline-block;
    margin: 0 5px 5px 0!important;
    background: #f6f6f6;
    font-size: 10px!important;
    padding: 2px 4px;
    color: #454545;
}

.galleryResult {
    padding-bottom: 20px;
}
.entry-contents p.galleryResultCnt {
    font-size: 14px;
    margin-bottom: 10px!important;
}
.entry-contents p.galleryResultCnt span {
    font-size: 24px!important;
}
.galleryResultBlock {
    display: inline-block;
    border: 1px solid #877e70;
    padding: 2px 3px;
    margin-right:4px!important;
    margin-bottom: 4px!important;
    font-size: 10px!important;
}
.g_li_box {
    position: relative!important;
}

.galleryList .slick-arrow {
    position: absolute;
    top: 50%;
    z-index: 3;
    display: block;
    width: 30px;
    height: 30px;
    text-indent: -9999px;
    cursor: pointer;
}
.slick-arrow:hover {
    opacity: 0.7;
}
.galleryList .slick-next {
    right: 0;
    margin: -15px -5px 0 0;
    background: url(/wp-content/themes/icci/img/gallery/s_next.png);
    background-size: 30px 30px;
}
.galleryList .slick-prev {
    left: 0;
    margin: -15px 0 0 -5px;
    background: url(/wp-content/themes/icci/img/gallery/s_prev.png);
    background-size: 30px 30px;
}
@media screen and (min-width:901px) {
    .galleryFooterNav {
        display: none;
    }
}
@media screen and (max-width:900px) {
    .gallery-area {
        padding: 0;   
    }
    .galleryBg {
        padding: 0 0 10px;   
    }
    .gallerySide {
        background: none;   
        float: none;
        width: 100%;
        padding: 15px;
    }
    .galleryMain {
        float: none;
        width: 100%;
    }
    .galleryList .g_li {
        width: 100%;
        margin-right: 0;
        margin-bottom: 0;
        padding: 15px;
    }
    .galleryList li .txt {
        padding: 5px 0 0 0;   
    }
    .gallerySearch {
        border: 1px solid #686255;
        padding: 10px;   
    }
    .search_title {
        margin-bottom: 0!important;   
        text-align: center;
        font-size: 16px!important;
    }
    .accordion_head {
        position: relative;   
        cursor:pointer;
    }
    .accordion_head:hover {
        opacity: 0.7;    
    }    
    .accordion_head:after {
        position: absolute;
        top: 0;
        right: 0;
        content:"＋";   
        font-size: 16px!important;
    }
    .accordion_head.selected:after {
        position: absolute;
        top: 0;
        right: 0;
        content:"ー";   
        font-size: 16px!important;
    }    
    .accordion_body {
        padding-top: 10px;   
    }
    .galleryFooterNav {
        padding: 30px 10px 10px;   
    }
    .galleryResult {
        padding: 0 10px 20px;
    }
    .galleryList .slick-next {
        margin: -15px -10px 0 0;
    }
    .galleryList .slick-prev {
        margin: -15px 0 0 -10px;
    }
}

.messageText{
    font-size: 13px;
}
@media screen and (max-width: 768px){
    .messageText{
        font-size: 11px !important;
		margin:0 20px;
    }
}

.center {
	text-align: center;   
}
.cancel__policy {
	max-width: 780px;
	margin: 0 auto 40px;
	width: 100%;            
}
.cp {
	padding: 0
}
.cancel__policy h3 {
	text-align: center;
	margin-bottom: 0;   
}
.cpTable {
	margin-bottom: 20px!important;    
	font-size: 16px;
}

.cpTable th {
    background: #f6f6f6!important;
}
.cpTable table {
	border: none!important;
	margin: 0;
	width: auto!important;
}    
.cpTable table th {
	border: none!important;
	margin: 0;
	width: auto;
	background: none!important;
	padding: 0 10px 0 0;
	text-align: left;
}   

.cpTable table th:before {
	content:  "・";  
}
.cpTable table td {
	border: none!important;
	margin: 0;
	padding: 0;
}                     
.cpTable th span {
	   font-size: 12px;
}   
.entry-contents p.ct {
	font-size: 12px!important;
	margin: 0;
}

@media screen and (min-width: 769px){
    .cpTable td .sp {
        display: none;
    }    
}

@media screen and (max-width: 768px){
    .cpTable {
	    margin-bottom: 10px!important;    
	    font-size: 12px;
    }
    .cpTable th {
        padding: 5px;   
        width: auto!important;
    }
    .cpTable th span {
	       font-size: 10px!important;
    }   
    .cpTable td {
        padding: 5px 10px;   
    }
}
.cancel_inner {
    padding-top: 0px;
}
.cancel_inner .cp {
    padding-bottom: 50px;
}
.centerTxt {
	text-align: center;
	padding-bottom: 50px;
}
@media screen and (max-width: 768px){
	.cancel_inner .cp {
    	padding-bottom: 20px;
	}
	.centerTxt {
		padding-bottom: 20px;
	}
	.entry-contents.ccl {
		padding-bottom: 0;
	}
}

#site_footer {
    background: rgba(0,0,0,0.68);
    padding: 10px 0;
}
#site_footer .header_navi {
    height: auto;
}

.header_navi li li::before {
  content: "ー ";
  font-family: arial;
  color: #fff;
}

#site_footer .footer-logo {
    text-align: center;
    padding: 50px 0;
}
#site_footer .footer-logo img {
    width: 100px;
    height: auto;
}
#site_footer .footer-copyright {
    text-align: center;
    color: #fff;
    letter-spacing: 1px;
    font-family: a-otf-ryumin-pr6n, serif !important;
}
@media screen and (min-width: 769px){
    .header_navi a {
        font-size: 18px;   
    }
    .nav_inner ul.font-ryumin.ful01 {
      width: 50%;  
    }
    .nav_inner ul.font-ryumin.ful02 {
      width: 25%;  
    }
    .nav_inner ul.font-ryumin.ful03 {
      width: 25%;  
    }
}
@media screen and (max-width: 768px){
    .svMenu{
        margin: 10px 0 0 10px;
    }
    .sp_menu .header_navi{
        background: rgba(0,0,0,0.68);
        padding: 20px;
    }
    .nav_btn a {
        border: none!important;   
    }
    #header_wrap {
        background: #fff;   
    }
    .header_navi a {
        color: #fff!important;   
    }
    #site_footer .header_navi a {
        color: #fff ;
    }
    #site_footer .header_navi .nav_access a {
        color: #686255 !important;
    }
    #site_footer .footer-copyright {
        font-size: 10px !important;
    }
    #site_footer {
        padding: 20px 10px;   
    }
}

@media screen and (min-width: 768px){
	.bottom-btn {
		display: none;	
	}
}
@media screen and (max-width: 767px){
    #site_footer {
        padding-bottom: 120px!important;   
    }
	.side-btn {
		display: none;	
	}
	.bottom-btn {
		padding-top: 2px;	
		background: rgba(35,35,35,0.85);
		/*background: #000;*/
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 200;
		padding: 3px 2px;
	    box-sizing: border-box;
	}
	.bottom-btn ul {
	    display: flex;    
	    width: 100%;
    }
	.bottom-btn ul li {
	    box-sizing: border-box;
	    padding: 2px;
	}
	.bottom-btn a {
	    display: block;
	    margin: 0;
        text-align: center;
        border-radius: 5px;
        line-height: 1;
        padding: 4px 5px;
        color: #fff;
	}    
	.bottom-btn span {
	    display: block;    
	    font-size:11px;
	    margin-bottom: 3px;
	    border-top: 1px dotted #fff;
	    padding-top: 4px;
	}	
	.bottom-btn strong {
	    display: block;    
	    font-size:13px;
	    border-top: 1px dotted #fff;
	    padding: 8px 0 5px;
	}		
	.bottom-btn img {
	    width: 14px;
	    height: 14px;   
	    margin-bottom: 4px;
	 }    
	.sBtnReserve {
        width: 33.3%;   
    }
	.sBtnTel {
        width: 33.4%;   
    }
	.sBtnRequest {
        width: 33.3%;   
    }
	.sBtnReserve a {
        background: #686255;
    }    
	.sBtnTel a {
	    background: #877e70; 
    }
	.sBtnRequest a {
	    background: #aba293;
    }
	.sBtnRequest span {
	    letter-spacing: -1px;    
    }
}
.gcLink {
	    text-align: right;
	    font-size: 10px!important;
	    padding:10px 10px 10px;
	    color: #565656;
	    margin: 0!important;
}
@media screen and (min-width: 768px){
	.gcLink  {
		display: none;	
	}
}

.mediaList {
	width: 100%;
	display: table;
}
.mediaList ul {
	display: table-row;
}
.mediaList ul li {
	width: calc(25% - 15px);
	text-align: center;
	vertical-align: middle;
	display: table-cell;
	padding-right: 20px;
	padding-top: 30px;
	padding-bottom: 60px;
}
.mediaList ul li:nth-child(4n){
	padding-right: 0;
}
.mediaList li img {
	max-width:100%;
	max-height: 35px;
	height: auto;
}
@media screen and (max-width: 768px) {
	.mediaList ul li {
		width: calc(25% - 12px);
		padding-right: 16px;
		padding-top: 15px;
		padding-bottom: 30px;
	}
}

 .fixedBtn {
  background: rgba(35,35,35,0.85);
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 200;
  padding: 7px 4px;
  box-sizing: border-box;
}
.fixedBtn ul {
    display: flex;
}
.fixedBtn li {
    width: 32%;
    margin: 0 1% 0 0;
    line-height: 1;
    display: table;
    
}
.fixedBtn li:first-child {
    margin-left: 1%;
}
.fixedBtn a {
    display: table-cell;
    padding: 15px 5px;
    border-radius: 5px;
    color: #fff;
    line-height: 1;
    font-size: 16px;
    text-align: center;
}
.fixedBtn a span {
    width: 20px;
    white-space: nowrap;
    padding-right: 5px;
}
.fixedBtn a span img {
    width: auto;
    height: 16px;
}
.fixedBtn a strong {
    display: inline-block!important;
    padding-right: 5px;
}
.sBtnTel img {
    margin-bottom: -1px;
}

/*============================
202307
============================*/

.blog__instagram {
    padding-top: 20px;
}
.top__instagram--thmb {
    width: calc(25% - 20px);
    margin: 0 10px 20px;
}
.instagramBtn {
    margin: 70px auto 70px;
    text-align: center;
}
.instagramBtn .inner {
    display: inline-block;
    font-family: arno-pro-display,serif;
    font-size: 24px;
    letter-spacing: 2px;
}
.instagramBtn a:before {
    content:"";
    background: url(../img/common/icon_instagram_blk.png);
    display: inline-block;
    background-size: 30px 30px;
    width: 30px;
    height: 30px;
    margin-bottom: -10px;
    margin-right: 10px;
}
.center {
    text-align: center;
}
.instagramFrwBtn {
    border: 1px solid #ccc;
    padding: 20px 150px;
    font-family: arno-pro-display,serif;
    font-size: 24px;
    letter-spacing: 2px;
    display: inline-block;
    position: relative;
    margin: 0 0 100px;
}
.instagramFrwBtn:after {
    content: ">";
    position: absolute;
    top: 50%;
    right: 10px;
    font-size: 18px;
    line-height: 1;
    margin-top: -9px;
    display: block;
    color: #000;
}
@media screen and (max-width: 768px){
    .top__instagram h2 {
        margin-bottom: 15px;
    }
    .top__instagram--thmb {
        width: calc(33.3% - 5px)!important;
        margin: 0 2.5px 5px!important;
    }
    .top__instagram--thmb:nth-child(3n){
        margin-right: 0;
    }
    .top__instagram--thmb:nth-child(n+10){
        display: none;
    }

    .top__instagram {
        margin-top: 50px;   
    }
    .blog__instagram {
        padding-top: 0;
    }
    .instagramBtn {
        margin: 30px auto 45px;
    }
    .instagramBtn .inner {
        font-size: 18px;
    }
    .instagramBtn a:before {
        background: url(../img/common/icon_instagram_blk.png);
        background-size: 24px 24px;
        width: 24px;
        height: 24px;
        margin-bottom: -8px;
        margin-right: 7px;
    }
    .instagramFrwBtn {
        border: 1px solid #ccc;
        padding: 10px 75px;
        font-size: 16px;
        margin: 0 0 75px;
    }
    .instagramFrwBtn:after {
        font-size: 16px;
        margin-top: -8px;
    }
}

/*============================
20231119
============================*/

.mb60 {
	margin:0 auto 60px;
}
.mt60 {
	margin:60px auto 0;
}
.mb30 {
	margin-bottom: 30px;
}

  .FAQPage {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 8px;
    margin-top: 40px !important;
  }
  .FAQPage li {
    width: calc(100% / 2 - 16px);
    list-style: none;
    font-size: 16px;
    margin-bottom: 24px;
  }
  .FAQPage .Q {
    background-color: #ffffff;
    padding: 24px 16px;
    border-radius: 5px;
    font-weight: normal;
    margin-bottom: 16px;
  }
  .FAQPage .A {
    font-weight: normal;
  }
  @media screen and (max-width: 768px){
    .FAQPage {
      display: block;
      margin-bottom: 40px !important;
    }
    .FAQPage li {
      width: 100%;
      margin-bottom: 24px;
      font-size: 14px;
    }
    .FAQPage .Q {
      padding: 16px;
      margin-bottom: 12px;
    }
  }
  .marriage-ring__faq h2 {
    text-align: center !important;
    margin: 24px auto 48px !important;
  }
.topCtMore {
    text-align: right;
    padding-top: 10px;
    text-decoration: underline;
}

.btn3 {
	text-decoration: none !important;
    display: block;
    margin: 50px auto 10px auto;
    text-align: center;
    width: 100%;
    max-width: 350px;
    background: #686255;
    color: #FFF;
    padding: 24px 0;
    position: relative;
    font-size: 18px;
}
.btn3:before {
  content: "";
  display: inline-block;
  position: absolute;
    left: 50px;
  width: 28px;
  height: 28px;
  margin: 0;
  background: url("https://www.1-daikanyama.jp/wp-content/themes/icci/img/common/icon_calendar_wh.svg") no-repeat;
  background-size: contain;
  vertical-align: middle;
}
@media screen and (max-width: 768px){
	  .btn3 {
		  max-width: 300px;
	  }
	  .btn3:before {
		  left: 40px;
	  }
}

.btn3:hover {
	color: #ffffff !important;
}
.btn3 img {
	width: 28px;
}

.courseIntroduction {
	padding:100px 20px;    
}
.courseIntroduction h2 {
	font-size: 26px;    
}
.courseIntroduction h3 {
	font-size: 20px;
	font-family: arno-pro-display,serif;    
	text-align: center;
	font-weight: bold;
	margin: 0 0 30px;
}
.courseIntroduction .one {
	max-width: 800px;
	margin: 0 auto 50px;
 }
.courseIntroduction .courseIntroductionBox {
	display: table;    
	border: 1px solid #afa799;
	border-radius: 10px;
	width: 100%;
	margin-bottom: 20px;
}
.courseIntroduction .courseIntroductionBox .image {
	display: table-cell;    
	vertical-align: middle;
	width: 350px;
}
.courseIntroduction .courseIntroductionBox .info {
	display: table-cell;    
	vertical-align: middle;
	padding: 30px 0;
	position: relative;
}
.courseIntroductionBox {
	text-align: center;    
}

.courseIntroductionBox .bnr {
	position: absolute;
	 top: -10px;
	 right: -10px;
}
.courseIntroductionBox .bnr img {
	width: 100px;
	height: auto;
	border-radius: 5px;
}

.courseIntroductionBox h4 {
	font-size: 22px;
	font-family: arno-pro-display,serif;    
	text-align: center; 
	margin: 0 0 15px;
}
.courseIntroductionBox .time {
	background: #afa799;
	padding: 10px;     
	text-align: center; 
	margin: 0 0 20px;
	color: #fff;
	font-size: 18px;
}
.courseIntroductionBox .time span {
	font-size: 12px;
}
.courseIntroductionBox table {
	border-top: 1px solid #ccc;    
	width: calc(100% - 60px);
	margin: 0 30px 20px;
}
.courseIntroductionBox table th {
	border-bottom: 1px solid #ccc;    
	padding: 7px 10px 7px 0;
	text-align: left;
	font-weight: bold;
	vertical-align: middle;
}
.courseIntroductionBox table td {
	border-bottom: 1px solid #ccc; 
	padding: 7px 0 7px 0;
	text-align: right;
	vertical-align: middle;
}
.courseIntroductionBox ul {
	margin: 0 40px 20px;    
   }
.courseIntroductionBox ul li {
	list-style: disc!important;
	text-align: left;
}
.courseIntroductionBox .btn2 {
	margin: 0 auto;    
}

.courseIntroductionBox .btn2 {
	padding: 15px;
	font-size: 16px;
	border-radius: 6px;
	width: calc(100% - 60px);
	margin: 0 30px;
	max-width: 100%!important;
}
.courseIntroduction .two {
	display: flex;
	flex-wrap: wrap;
	max-width: 800px;
	margin: 0 auto 30px;
	justify-content: flex-start; 
}
.courseIntroduction .two .courseIntroductionBox {
	width: calc(50% - 10px);
	margin-right: 20px;
	margin-bottom: 20px;
}
.courseIntroduction .two .courseIntroductionBox:nth-child(2n){
	margin-right: 0;    
}
.courseIntroduction .two .courseIntroductionBox .image {
	display: none;
}
.courseIntroduction .courseIntroductionBox .info .thumbnail {
	margin: 0;
	padding: 0;
}
.courseIntroduction .courseIntroductionBox .thumbnail img {
	width: 100%;
	height: auto;    
}
.courseIntroduction .courseIntroductionBox .copy {
	display: inline-block;
	margin: 0 auto 5px;
	border: 1px solid #afa799;  
	padding: 0 15px;

	font-family: arno-pro-display,serif;   
}
.courseIntroduction .option {
	max-width: 800px;
	width: 100%;
	margin: -30px auto 50px;
}
.courseIntroductionBox li span,
.courseIntroduction .option span {
	color: #e85c5d;
}
@media screen and (min-width: 821px) {	    
	.courseIntroduction .one .courseIntroductionBox .thumbnail {
		display: none;
	}
}	    
@media screen and (max-width: 820px) {
	.courseIntroduction {
		padding:75px 20px 0;    
	}
	.courseIntroduction .courseIntroductionBox {
		display: block;  
	}
	.courseIntroduction .courseIntroductionBox .image {
		display: none;
	}
	.courseIntroduction .courseIntroductionBox .info {
		display: block;    
	}
	.courseIntroduction .two {
		display: block;
		margin-bottom: 50px;
	}
	.courseIntroduction .two .courseIntroductionBox {
		width: 100%;
		margin-right: 0;
		margin-bottom: 20px;
	}
	.courseIntroduction .option {
		max-width: 800px;
		width: 100%;
		margin: -30px auto 50px;
	} 
}

/* アコーディオン */
.stone-accordion {
    max-width: 100%;
    border-bottom: 1px solid #000;
}

.stone-accordion summary span {
    font-size: 26px;
    margin: 0 0 12px;
    font-family: a-otf-ryumin-pr6n, serif;
    font-weight: 400;
    color: rgb(0, 0, 0);
    line-height: 1;
    text-align: center;
}

.stone-accordion summary {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 0.5em 2em;
    cursor: pointer;
}

.stone-accordion summary::-webkit-details-marker {
    display: none;
}

.stone-accordion summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 9px;
    height: 9px;
    margin-left: 10px;
    border-bottom: 1px solid #000;
    border-right: 1px solid #000;
    content: '';
    transition: transform .3s;
    position: absolute;
    right: 20px;
}

.stone-accordion[open] {
    border-bottom: none;
}

.stone-accordion[open] summary::after {
    transform: rotate(225deg);
}

.stone-accordion::details-content {
  opacity: 0;
  transition: opacity 600ms;
}

.stone-accordion[open]::details-content {
  opacity: 1;
}

/* ヘッダーやナビメニューなど重要な部分だけに適用 */
.header-logo, .nav_btn, h1, h2, h3 {
    font-family: 'source-han-sans-japanese', sans-serif;
}
  
/* 本文には代替フォントを使用（後から置き換え） */
body {
    font-family: 'Hiragino Sans', 'Hiragino Kaku Gothic Pro', sans-serif;
}
  
/* フォント読み込み完了後に本文のフォントも変更 */
.wf-active body {
    font-family: 'source-han-sans-japanese', 'Hiragino Sans', sans-serif;
}
.poster-image {
    width: 100%;
    height: auto;
}
/* PC用画像（デフォルト） */
.poster-mobile {
    display: none;
}
/* スマホ用画像（768px以下） */
@media screen and (max-width: 768px) {
    .poster-desktop {
        display: none;
    }
    .poster-mobile {
        display: block;
    }
}

.wp-caption{
    width: auto !important;
}
