@charset "UTF-8";
/* 学習塾RainBow */
/* 共通スタイル */
body {
    color: #3f3f3f;
    font-family: 'Zen Maru Gothic', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif !important;
    font-weight: 500;
    font-style: normal;
    counter-reset: number 0;
    font-size: 18px;
    letter-spacing: 0.04rem;
    overflow: hidden;
    background: #ffffff url(img/body-bg.png);
    line-height: 2.2;
}
a {
    color: #DA9C50;
    font-weight: 700;
}
address {
    font-style: normal;
}
img {
    max-width: 100%;
}
#site-loader-overlay {
    background: #e0ffff;
}
#site-loader-spinner {
    border-color: #ffffff #ffffff #a4c5c5 #ffffff !important;
}
.header-bar-fixed {
    background: transparent !important;
}
.header-bar.header-bar-fixed.scrolled{
    background: rgba(255,255,255,0.9) !important;
}
.logo-image {
    top: 25px;
    width: 200px;
    height: auto;
    left: 35px;
}
.logo-image a {
    line-height: 1;
    display: block;
}
.logo-image a img {
    width: 100%;
    display: block;
}
.global-nav > ul > li > a {
    padding: 0 0 0 40px;
    color: #3f3f3f;
    position: relative;
    font-weight: 700;
    text-align: right;
}
.global-nav .current-menu-item > a {
    color: #3f3f3f;
}
.global-nav > ul > li > a:hover {
    color: #DA9C50;
}
.global-nav .sub-menu a {
    background: #ffffff;
    color: #3f3f3f;
    letter-spacing: 1px;
    font-weight: 700;
}
.global-nav .sub-menu .current-menu-item > a {
    color: #3f3f3f;
}
.global-nav .sub-menu a:hover {
    background: #DA9C50;
    color: #ffffff;
}
.global-nav > ul > li > a::after {
    width: 8px;
    height: 8px;
    position: absolute;
    content: '';
    background: #81bc5a;
    border-radius: 50%;
    left: 20px;
    top: 50%;
    margin-top: -8px;
}
.global-nav > ul > li > a:hover::after {
    background: #DA9C50;
}
.pagetop a {
    background: #DA9C50;
}
.footer-bar01 {
    margin-top: 40px;
    background: #3f3f3f;
}
.pagetop a:hover {
    background: #DA9C50;
}
.pagetop a:hover:before {
    color: #ffffff;
}
p.copyright {
    line-height: 1;
    height: auto;
    width: 86%;
    max-width: 1150px;
    margin: 0 auto;
    background: no-repeat;
    text-align: left;
    font-size: 0.8em;
    position: relative;
    z-index: 3;
    text-shadow: 0px 0px 2px #fff, 0px 0px 2px #fff, 0px 0px 2px #fff, 0px 0px 2px #fff;
}
@media only screen and (max-width: 1200px) {
    body {
        font-size: 16px;
    }
    .logo-image {
        margin: 0;
        top: 8px;
        left: 20px;
        width: 150px;
    }
    .header-bar {
        border: none;
        box-shadow: none !important;
    }
    .global-nav a, .global-nav a:hover {
        background: #e0ffff;
        color: #3f3f3f !important;
        letter-spacing: 2px;
    }
    .global-nav .sub-menu a {
        color: #3f3f3f !important;
        background: #e0ffff;
    }
}
@media only screen and (min-width: 768px) {
    a[href^='tel:'], .post-content a[href^='tel:'] {
        pointer-events: none;
        color: #3f3f3f;
        font-weight: 500;
    }
}
@media only screen and (max-width: 767px) {
    body {
        font-size: 14px;
        line-height: 2;
    }
    .pagetop a:before {
        line-height: 40px;
    }
}
/* END 共通スタイル */
/* フロント */
.top-slider-content {
    width: auto !important;
    height: 100% !important;
    background: none;
    padding: 0 !important;
    margin-left: auto;
    margin-right: auto;
    border-radius: 0;
    z-index: 10;
}
#top-slider-content {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.mb_YTPBar .buttonBar {
    display: none;
}
.mb_YTPBar {
    display: none !important;
}
.top-slider-content-inner {
    background: none;
    box-sizing: border-box;
    border-radius: 0;
    text-align: left;
    margin: 0 auto;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
    height: 100% !important;
    width: 100% !important;
}
img.top-slider-logo {
    width: 86% !important;
    height: auto !important;
    min-width: 300px;
    max-width: 700px;
    display: block;
    margin: 0 5% 0 auto;
}
.top-slider-content-inner:after {
    display: none;
}
.top-slider-content-inner:hover:after {
    color: #ffffff;
    bottom: 30px;
}
.top-slider-text {
    font-weight: 500;
    color: #ffffff !important;
    margin-bottom: 0px;
    font-size: 22px !important;
    font-family: 'Zen Maru Gothic', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    text-align: left;
    letter-spacing: 0.3rem;
    line-height: 2;
    display: none;
}
.top-slider-content-inner:hover {
    background: none;
}
.content02-inner {
    width: 86%;
    padding-top: 0;
    padding-bottom: 0;
    position: relative;
    z-index: 2;
    font-size: 0.9em;
}
.article02-title {
    font-size: 16px;
    font-weight: 700;
    font-family: 'Zen Maru Gothic', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.content02-item {
    display: flex;
    flex-direction: column;
    margin-left: 3%;
    width: 31.3333333%;
}
.content02-text {
    margin-bottom: auto;
}
.content02-button {
    font-family: 'Zen Maru Gothic', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    line-height: 50px;
    background: none;
    letter-spacing: 0px;
    display: block;
    font-size: 1.1em;
    text-align: center;
    width: 100%;
    font-weight: 700;
    position: relative;
    margin: 2em auto 0 0;
    color: #81bc5a;
    padding: 0 20px;
    border: 3px dashed #81bc5a;
    box-sizing: border-box;
    border-radius: 30px;
    overflow: hidden;
}
.content02-item:nth-child(2) .content02-button {
    border-color: #e5983e;
    color: #e5983e;
}
.content02-button:hover {
    color: #ffffff;
    background: none;
}
.content02-button::before {
    width: 3px;
    height: 100%;
    position: absolute;
    content: '';
    background: #81bc5a;
    left: -5px;
    top: 0;
    z-index: -1;
    transition: 0.4s;
}
.content02-item:nth-child(2) .content02-button:before {
    background: #e5983e;
}
.content02-item:nth-child(2) .content02-button:hover {
    color: #fff;
}
.content02-button:hover::before {
    width: calc(100% + 5px);
}
.content02-inner-img {
    margin: 0 auto 20px;
    display: block;
    width: 100%;
}
.content02-title {
    color: #81bc5a;
    margin: 0 auto 15px;
    padding: 0;
    font-size: 1.2em;
    text-align: left;
    font-weight: 700;
    line-height: 1.6;
}
.content02-item:nth-child(2) .content02-title {
    color: #e5983e;
}
p.article02-text {
    font-size: 12px;
    color: #3f3f3f;
}
.article03-content {
    background: #f3f3f3;
    padding: 15px 20px;
}
.button {
    margin-bottom: 0;
}
.button a {
    color: #3f3f3f;
    font-size: 15px;
    border: 1px solid;
    background: #ffffff;
    box-sizing: border-box;
    font-weight: 700;
    transition: 0.4s;
}
.button a:hover {
    color: #ffffff;
    background: #3f3f3f;
    border-color: #3f3f3f;
}
.headline-primary {
    text-align: center;
    font-size: 1.4em;
    line-height: 1;
    margin-bottom: 2em;
}
.headline-primary::before {
    content: "TOPICS";
    display: block;
    font-size: 2em;
    line-height: 1;
    margin-bottom: 30px;
    color: #3f3f3f;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.1em;
}
.article02-date {
    color: #676767;
    font-weight: 500;
}
@media only screen and (max-width: 1200px) {
    .global-nav-button {
        border-left: none;
    }
    .global-nav-button:before {
        color: #3f3f3f;
    }
    .global-nav > ul > li > a {
        color: #3f3f3f !important;
        background: #ffffff;
        line-height: 50px;
        height: 50px;
        text-align: left;
        padding: 0 0 0 20px;
    }
    .global-nav .menu_social.menu-item-has-children > a span::before {
        color: #023742;
    }
    .global-nav .menu-item-has-children > a span::before {
        color: #70a3a3;
        background: #e0ffff;
    }
}
@media only screen and (max-width: 1024px) {
    .content02-inner {
        padding: 0;
    }
}
@media only screen and (max-width: 991px) {
    .top-slider-text {
        font-size: 28px !important;
    }
    .content02-item {
        width: 100%;
        margin: 0 auto 4em;
    }
    .content02-inner {
        display: -webkit-box;
        display: block;
        font-size: 1em;
    }
    .column-layout03-item:first-child {
        margin-right: 0;
    }
    .content01-title {
        font-size: 24px !important;
        margin-bottom: 20px;
    }
    .column-layout03 {
        padding: 0;
    }
}
/* END フロント */
/* 固定ページ共通 */
.main {
    padding-bottom: 0;
    position: relative;
    overflow: hidden;
    background: none;
}
.signage-title.headline-font-type {
    font-size: 1.5em;
    line-height: 1;
}
.signage-title-sub {
    line-height: 1;
    text-align: center;
    width: 86%;
    max-width: 1150px;
    margin: 1em auto 0;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #DA9C50;
    text-shadow: 0px 0px 2px #ffffff, 0px 0px 2px #ffffff, 0px 0px 2px #ffffff;
}
.breadcrumb-wrapper {
    background: none;
    z-index: 3;
}
.primary-full {
    position: relative;
}
.signage {
    height: 300px;
}
.page .post-header {
    display: none;
}
.signage-title.headline-font-type {
    text-align: center;
    width: 86%;
    max-width: 1150px;
    margin: 0 auto;
    font-weight: 700;
    font-size: 2em;
    text-shadow: 0px 0px 2px #ffffff, 0px 0px 2px #ffffff, 0px 0px 2px #ffffff;
}
.post-title {
    color: #3f3f3f;
    font-weight: 700;
    font-size: 1.5em !important;
}
.post-content h2 {
    padding: 0;
    margin: 0;
    font-size: 1.5em;
    line-height: 1.6;
    position: relative;
    box-sizing: border-box;
}
.post-content h2:after {
    content: '';
    display: block;
    width: 50px;
    height: 3px;
    margin: 0.75em auto 0.75em 0;
    background: #bad662;
}
.post-content h3 {
    margin: 0 auto 15px;
    font-size: 1.2em;
    line-height: 1.6;
    padding: 15px 20px;
    position: relative;
    text-align: left;
    background: #e0ffff;
    border-radius: 6px;
}
.post-content h4 {
    padding: 0;
    margin: 0 auto 0.5em;
    font-size: 1.1em;
}
.post-content p {
    letter-spacing: 1px;
    margin-bottom: 0;
    position: relative;
    line-height: 28px;
    font-size: 16px;

}
.post-content a {
    color: #DA9C50;
    font-weight: 700;
}
.post-content a:hover {
    color: #37abab;
}
.post-content td, .post-content th {
    background: none;
    border-left: none;
    border-right: none;
    vertical-align: middle;
    padding: 1em 0;
    line-height: 1.6;
    font-weight: 500;
    box-sizing: border-box;
    font-size: 20px;
    font-weight: 700;
}
.post-content th {
    width: 30%;
    padding-right: 1em;
    background: none;
    text-align: left;
    box-sizing: border-box;
    border-bottom: 1px solid #a4dbdb;
    color: #629d9d;
    font-size: 20px;
    font-weight: 700;
}
.post-content ul {
    list-style: none;
    margin-left: 0;
}
.post-content li, .post-content dt, .post-content dd {
    position: relative;
    margin-bottom: 5px;
    line-height: 1.8;
}
.post-content li:last-child, .post-content dt:last-child, .post-content dd:last-child {
    margin-bottom: 0px;
}
.icon-file-text:before {
    content: "\e909";
}
@media only screen and (max-width: 1150px) {
    .main > .inner {
        width: 86%;
        padding: 0;
    }
}
@media only screen and (max-width: 485px) {
    .post-content td, .post-content th {
        width: 100%;
        display: block;
    }
    .post-content th {
        padding-bottom: 0;
        padding-right: 0;
        font-weight: 700;
        border-bottom: none;
    }
    .post-content td {
        padding-top: 0.25em;
    }
}
/* END 固定ページ共通 */
/* アーカイブ */
.blog .main, .single .main, .archive .main {
    padding: 5em 0;
}
h2.archive-title {
    text-align: center;
    margin-bottom: 1.5em;
    font-size: 1.5em;
}
@media only screen and (max-width: 485px) {
    .blog .main, .single .main, .archive .main {
        padding: 4em 0;
    }
}
/* アーカイブ END */
/* ブログページ詳細 */
.single h2, .single h3 {
    margin-top: 50px;
}
.single h2:first-child, .single h3:first-child {
    margin-top: 0;
}
.sns_default_top {
    text-align: left;
    margin-top: 0px;
}
.single .post-content {
    padding-top: 0;
}
.styled-post-list1-meta {
    margin-bottom: 20px;
    border-bottom: 1px solid #d3d3d3;
    padding-bottom: 20px;
}
a.styled-post-list1-title.headline-font-type {
    line-height: 1.6;
    color: #ffa6a6;
}
.single-post .post-header {
    display: block;
}
.headline-bar {
    font-weight: 700;
    margin-bottom: 1em;
    border-bottom: 1px solid;
}
.nav-links01 {
    border-top: 1px solid #3f3f3f;
    border-bottom: 1px solid #3f3f3f;
}
.nav-links01-previous a:hover, .nav-links01-next a:hover {
    color: #737373;
}
.nav-links01-previous + .nav-links01-next {
    border-left: 1px solid #3f3f3f;
}
.side_widget:first-child a {
    font-weight: normal;
    font-size: 0.8em;
}
.side_widget:first-child a:hover {
    color: #333;
}
.sns {
    text-align: left;
}
@media only screen and (max-width: 485px) {
    h1.post-title {
        font-size: 18px !important;
    }
}
/* END ブログページ詳細 */
/* コンタクトフォーム */
.wpcf7 {
    border: none;
    background: none;
    margin: 0 auto !important;
}
.wpcf7 form {
    margin: 0;
}
table.contact_form th, table.contact_form td {
    font-size: 16px;
    padding: 30px 0;
}
table.contact_form th {
    padding-right: 15px;
    font-weight: 500;
}
.wpcf7 input, .wpcf7 textarea {
    border-radius: 3px;
    padding: 20px;
    border: 1px solid #9d9d9d;
    background: #efefef;
    color: #3f3f3f;
}
.wpcf7 .wpcf7-not-valid {
    background: #ffffff;
    border-color: #ff5150;
}
span.any {
    background: #e8e8e8;
    font-size: 0.7em;
    padding: 2px 5px;
    margin-left: 10px;
}
span.required {
    background: #e63e3e;
    color: #ffffff;
    font-size: 0.7em;
    padding: 2px 5px;
    margin-left: 10px;
}
.wpcf7 select, .wpcf7 .wpcf7-list-item-label {
    font-size: 14px;
}
span.wpcf7-list-item {
    display: block;
    margin: 0;
    font-weight: 500;
}
.wpcf7 input.wpcf7-submit {
    width: 100%;
    max-width: 400px;
    line-height: 1em;
    height: 70px;
    font-weight: 700;
    font-size: 1.2em;
    background: #DA9C50;
    border-radius: 0;
    padding: 0;
}
.wpcf7 input.wpcf7-submit:hover {
    background: #DA9C50;
}
@media only screen and (max-width: 991px) {
    table.contact_form th {
        width: 30%;
    }
}
@media only screen and (max-width: 767px) {
    .wpcf7 input.wpcf7-submit {
        width: 86%;
    }
}
@media only screen and (max-width: 485px) {
    table.contact_form th, table.contact_form td {
        display: block;
    }
    .wpcf7 input.wpcf7-submit {
        width: 100%;
    }
    .wpcf7 select, .wpcf7 .wpcf7-list-item-label {
        font-size: 12px;
    }
}
/* END コンタクトフォーム */
/* ========================================
お知らせ基本スタイル
==========================================*/
.post-type-archive-news .main, .category-blog .main {
    background: #1c1c1c;
}
.post-header {
    text-align: left;
    margin-bottom: 2em;
}
#single_share_bottom {
    text-align: left;
    margin-top: 50px;
}
.article04-content h4.headline-font-type {
    font-size: 20px;
    color: #ffffff;
    font-weight: 700;
    font-style: normal;
}
.article04 {
    background: #2e2e2e;
}
.article04-text {
    line-height: 2;
    color: #737373;
}
.article04-date {
    color: #ffffff;
    font-weight: 700;
    font-style: normal;
}
.article04 a:hover .article04-title {
    color: #737373;
    font-weight: 700;
}
.article07-content {
    padding: 0 10px;
}
.article07-meta {
    margin-bottom: 0;
    font-weight: 700;
}
.article07-title {
    color: #ffffff;
}
@media only screen and (max-width: 485px) {
    h4.article04-title.headline-font-type {
        font-size: 15px;
    }
}
/* 共通オリジナル */
.header-bar-inner {
    width: 100%;
}
.footer_about_inner {
    width: 65%;
    box-sizing: border-box;
    padding-right: 3em;
}
address.footer_tel span {
    font-size: 0.7em;
    margin-right: 0.5em;
}
.footer_about_sec {
    color: #fff;
    width: 86%;
    max-width: 1150px;
    margin: 0 auto 3em;
    position: relative;
    z-index: 3;
}
.flex-inner {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
}
p.footer-info span {
    margin-right: 0.5em;
}
a.footer_but {
    display: block;
    line-height: 50px;
    color: #DA9C50;
    max-width: 300px;
    box-sizing: border-box;
    position: relative;
    text-align: left;
    font-weight: 700;
    transition: 0.4s;
    padding: 0 20px;
    margin: 20px auto 0 0;
    background: #ffffff;
    border-radius: 10px;
}
a.footer_but::after {
    position: absolute;
    font-family: "Font Awesome 5 Free";
    content: "\f0e0";
    font-weight: 700;
    font-size: 1.5em;
    right: 20px;
    transition: 0.4s;
}
a:hover.footer_but {
    background: #DA9C50;
    color: #ffffff;
    text-shadow: none;
}
a:hover.footer_but::after {
    color: #ffffff;
}
a.footer-but {
    display: block;
    float: left;
    margin-right: 10px;
    width: 40px;
    height: 40px;
    position: relative;
    color: #3f3f3f;
    background: #fff;
    border-radius: 50%;
}
a.footer-but span {
    display: none;
}
a.footer-but.instagram::after {
    content: "\ea92";
    display: block;
    font-family: "design_plus";
    font-size: 18px;
    position: absolute;
    line-height: 40px;
    text-align: center;
    width: 100%;
}
a.footer-but.twitter::after {
    content: "\e904";
    display: block;
    font-family: "design_plus";
    font-size: 18px;
    position: absolute;
    line-height: 40px;
    text-align: center;
    width: 100%;
}
a:hover.footer-but.instagram {
    background: #8d00a4;
}
a:hover.footer-but.twitter {
    background: #0094e0;
}
a:hover.footer-but::after {
    color: #ffffff;
}
ul.footer-list li a {
    color: #fff;
}
ul.footer-list li::before {
    font-family: "Font Awesome 5 Free";
    content: "\f061";
    font-weight: 700;
    position: absolute;
    left: 0;
    transition: 0.3s;
}
ul.footer-list li:hover::before {
    left: 3px;
}
footer {
    background: url(img/footer-bg.png) top center;
    box-sizing: border-box;
    font-size: 0.8em;
    padding: 6em 0;
    background-size: cover;
    position: relative;
}
footer a {
    color: #fff;
    font-weight: 500;
}
.footer-line-box {
    width: 40%;
    background: #6e6e6e;
    box-sizing: border-box;
    padding: 2em;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.footer-menu {
    width: 35%;
    box-sizing: border-box;
    padding-left: 3em;
    font-size: 1em;
}
.footer_about_inner h2 {
    font-weight: 500;
    font-size: 1.2em;
    line-height: 1;
    margin-bottom: 10px;
}
p.footer-address {
    padding-left: 1.25em;
    position: relative;
    line-height: 1.6;
}
p.footer-address::before {
    font-family: "Font Awesome 5 Free";
    content: "\f3c5";
    position: absolute;
    top: 0;
    font-weight: 700;
    left: 0;
    color: #8fc7c7;
}
address.footer_tel {
    line-height: 1;
    margin-top: 10px;
}
address.footer_tel a {
    color: #fff !important;
}
p.footer_tel-caution {
    line-height: 1.6;
    margin: 10px auto 0 0;
    font-size: 0.8em;
    color: #fb4242;
}
p.footer-info {
    line-height: 1.6;
    margin: 10px auto 0;
}
.footer-line-box h3 {
    width: 100%;
    font-size: 1.2em;
    text-align: center;
}
.footer-line-box p {
    width: 100%;
}
a.footer-line {
    background: #fff;
    width: 100%;
    max-width: 380px;
    color: #3f3f3f;
    line-height: 50px;
    margin: 20px auto 0;
    box-sizing: border-box;
    padding: 0 0 0 20px;
    position: relative;
    border: 1px solid #ffffff;
}
a.footer-line::after {
    font-family: 'design_plus';
    content: '\e909';
    position: absolute;
    right: 25px;
    font-size: 1.6em;
    color: #02a400;
}
a:hover.footer-line {
    border: 1px solid #ffffff;
    background: #6e6e6e;
    color: #ffffff;
}
a:hover.footer-line::after {
    color: #ffffff;
}
ul.footer-menu-list {
    width: 46%;
    margin-right: 8%;
}
ul.footer-menu-list:nth-of-type(2n) {
    margin-right: 0;
}
ul.footer-menu-list li {
    margin-bottom: 0.5em;
}
ul.footer-menu-list li:last-of-type {
    margin-bottom: 0;
}
ul.footer-menu-list li a {
    display: block;
    position: relative;
    transition: 0.4s;
    text-align: left;
}
ul.footer-menu-list li a.footer-link-but::before {
    font-family: "Font Awesome 5 Free";
    content: "\f2d2";
    margin-right: 10px;
}
ul.footer-menu-list li a::after {
    width: 0%;
    height: 1px;
    content: '';
    position: absolute;
    background: #DA9C50;
    transition: 0.4s;
    left: 0;
    bottom: 0;
}
ul.footer-menu-list li a:hover::after {
    width: 100%;
}
a.yoyakuru {
    display: block;
    width: 100%;
    max-width: 300px;
    margin: 1em auto 0 0;
}
a.yoyakuru img {
    display: block;
    width: 100%;
    transition: 0.5s;
    opacity: 1;
}
a:hover.yoyakuru img {
    opacity: 0.6;
}
ul.footer-sns {
    width: 90px;
    display: block;
    margin: 2em auto 0 0;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
}
ul.footer-sns li {
    width: 40px;
    height: 40px;
    margin-right: 10px;
}
ul.footer-sns li:last-of-type {
    margin-right: 0;
}
ul.footer-sns li a {
    display: block;
    background: #ffffff;
    line-height: 40px;
    border-radius: 50%;
    position: relative;
    width: 40px;
    height: 40px;
}
ul.footer-sns li a span {
    display: none;
}
ul.footer-sns li a::after {
    font-family: 'design_plus';
    content: '\e902';
    position: absolute;
    top: 0;
    left: 0;
    color: #333;
    width: 100%;
    text-align: center;
}
ul.footer-sns li a.sns-but.facebook::after {
    content: '\e902';
}
ul.footer-sns li a.sns-but.instagram::after {
    content: '\ea92';
}
@media only screen and (min-width: 1201px) {
    .global-nav > ul > li.global-menu-home > a {
        display: none;
    }
}
@media only screen and (max-width: 1200px) {
    .global-nav > ul > li > a::after {
        position: relative;
        width: auto;
        text-align: left;
        bottom: 0;
        display: inline;
        margin-left: 10px;
        color: #3f3f3f;
        font-weight: 700;
    }
}
@media only screen and (max-width: 970px) {
    .footer_about_inner {
        width: 50%;
    }
    .footer-line-box {
        width: 50%;
    }
    .footer-line-box h3 {
        font-size: 1.1em;
        line-height: 1.6;
        margin-bottom: 0.5em;
    }
    .footer-menu {
        width: 50%;
    }
}
@media only screen and (max-width: 767px) {
    footer {
        padding-bottom: calc(6em + 50px);
        font-size: 1em;
    }
}
@media only screen and (max-width: 485px) {
    .footer_about_inner {
        width: 100%;
        padding: 0;
        text-align: center;
    }
    .footer-line-box {
        width: 100%;
        padding: 2em 0 3em;
        background: no-repeat;
        margin: 2em 0 0;
        border-top: 1px solid #5d5d5d;
        border-bottom: 1px solid #5d5d5d;
    }
    a.footer_but {
        margin-left: auto;
        margin-right: auto;
    }
    a.yoyakuru {
        margin-left: auto;
    }
    footer {
        padding: 4em 0 calc(3em + 50px);
    }
    ul.footer-sns {
        margin-left: auto;
    }
    p.footer-address {
        padding: 0;
    }
    p.footer-address::before {
        position: relative;
        margin-right: 10px;
    }
    .footer-menu {
        width: 100%;
        padding: 0;
        margin-top: 40px;
        max-width: 250px;
        margin-left: auto;
        margin-right: auto;
    }
    p.copyright {
        text-align: center;
    }
}
/* 共通オリジナル END */
/* ========================================
ここから固定ページオリジナル
==========================================*/
/* 固定共通オリジナル */
.content_full {
    position: relative;
}
.content_inner {
    width: 86%;
    max-width: 1150px;
    margin: 0 auto;
    position: relative;
    padding: 5em 0;
    box-sizing: border-box;
}
@media only screen and (max-width: 485px) {
    .content_inner {
        padding: 4em 0;
    }
}
/* 固定共通オリジナル END */
/* ========================================
お問い合わせ基本スタイル
==========================================*/
/* privacy */
.privacy_box {
    margin-bottom: 70px;
}
p.text_left {
    text-align: right;
}
/* privacy END */
address.contact-tel {
    font-size: 2em;
    font-weight: 700;
    line-height: 1;
}
address.contact-tel span {
    font-size: 0.8em;
    margin-right: 0.6em;
    color: #bc5b28;
}
address.contact-mobile {
    line-height: 1;
    margin-top: 1em;
    font-weight: 700;
}
address.contact-mobile span {
    color: #bc5b28;
}
p.contact-caution {
    font-size: 0.8em;
    margin-top: 1em;
}
.mail-box {
    margin: 4em auto 0;
    max-width: 800px;
}
.mail-caution-box {
    background: #fff;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 1.5em 2em;
    font-size: 0.9em;
    line-height: 1.8em;
    margin: 0.5em auto 2em;
}
.mail-caution-box h3 {
    background: none;
    border-radius: 0;
    padding: 0;
    margin-bottom: 0.5em;
}
.wpcf7 form p {
    margin-bottom: 1em;
    font-weight: 700;
}
.wpcf7 form p:last-of-type {
    margin-bottom: 0;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output {
    border: none;
    border-radius: 0;
    margin: 0 auto;
    background: #d82f2f;
    color: #ffffff;
    box-sizing: border-box;
    padding: 1em 1.5em;
}
@media only screen and (max-width: 485px) {
    .tel_sec .content_inner {
        padding: 70px 0;
    }
    address.contact_tel {
        font-size: 24px;
    }
    .mail_caution h3 {
        font-size: 15px;
    }
    .mail_caution {
        padding: 15px 20px;
    }
    .wpcf7 form p:last-child {
        margin: 0;
    }
}
/* ========================================
お問い合わせ基本スタイル END
==========================================*/
/* フロントオリジナル */
.main-front-container {
    width: 100%;
    position: relative;
    height: 100%;
}
.main-front-copy-box {
    position: absolute;
}
.main-front-copy-box img {
    display: block;
    width: 100%;
}
.main-front-copy-box.top-left {
    top: 0;
    right: 30px;
    width: 50%;
    max-width: 228px;
}
.main-front-copy-box.bottom-right {
    bottom: 30px;
    right: 30px;
    width: 30%;
    max-width: 200px;
}
.content02-button:hover::after {
    color: #ffffff;
}
.front_second_inner {
    width: 86%;
    margin: 0 auto;
    max-width: 1150px;
    z-index: 2;
    position: absolute;
    left: 0;
    right: 0;
    top: -30px;
    text-align: center;
    color: #fff;
}
.front_second_inner img {
    max-width: 80%;
}
.front_second {
    position: relative;
    margin: 0% auto 6em;
}
.front_second_inner-text {
    position: relative;
}
.third-box {
    width: 86%;
    margin: 0 auto 4em;
}
.front-third-inner {
    position: relative;
}
.third-box:last-of-type {
    margin-bottom: 0;
}
.third-box:nth-of-type(even) .front-third-inner {
    flex-direction: row-reverse;
}
.front-third-text {
    box-sizing: border-box;
    width: 40%;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.front-third-text img {
    width: 250px;
}
.front-third-img {
    width: 60%;
    box-sizing: border-box;
}
.front-third-img img {
    display: block;
    width: 100%;
}
.third-box:nth-of-type(odd) .front-third-text {
    padding-right: 4em;
}
.third-box:nth-of-type(even) .front-third-text {
    padding-left: 4em;
}
.front_intro-outer {
    position: relative;
}
.front_intro_inner {
    position: relative;
    padding-left: calc(50% + 50px);
}
.front_intro-outer .inner {
    position: relative;
    z-index: 2;
}
#content01 {
    padding: 6em 0;
}
.front_second_inner-text h3 {
    font-size: 1.4em;
    line-height: 1.5;
    margin-bottom: 20px;
    color: #DA9C50;
}
.front-third-text h3 {
    font-size: 1.2em;
    margin-top: 20px;
    margin-bottom: 20px;
    color: #81bc5a;
    width: 100%;
    line-height: 1.6;
}
.front-third-text h3 span {
    color: #e5983e;
}
.front-third-text p {
    width: 100%;
}
.front_topics {
    margin: 6em auto calc(4em - 10px);
}
.front_intro-inner {
    width: 86%;
    max-width: 1150px;
    margin: 0 auto;
}
.front_inner-text {
    width: 50%;
    box-sizing: border-box;
    position: relative;
    z-index: 2;
    padding-top: 2em;
    padding-right: 2em;
}
.front_inner-img {
    width: 50%;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}
.front_inner-img img {
    display: block;
    width: 100%;
}
.content02 {
    padding: 4em 0 6em;
}
#content01::after {
    width: 100%;
    height: 2em;
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    background: url(/wp-content/themes/story_tcd041/img/content01.png);
    background-size: auto 2em;
    z-index: 2;
}
#content01::before {
    width: 3px;
    height: 20px;
    background: #c6ebeb;
    position: absolute;
    top: 0;
    content: '';
    left: calc(50% - 1px);
    z-index: 10;
    border-radius: 2px 2px 0 0;
}
.front_inner-text h2 {
    color: #81bc5a;
    line-height: 1.6;
    font-size: 1.6em;
    margin: 0 auto 20px 0;
}
.front_inner-text h2 span {
    color: #e5983e;
}
.third-box:nth-of-type(1) .front-third-text::before {
    color: #DA9C50;
}
.third-box:nth-of-type(2) .front-third-text::before {
    color: #bad662;
}
.third-box:nth-of-type(3) .front-third-text::before {
    color: #DA9C50;
}
.article03 > a:hover .article03-title {
    color: #DA9C50;
}
@media only screen and (max-width: 970px) {
    .front_intro_inner {
        padding: 0px 7%;
    }
    .front_intro-outer .inner {
        width: 100%;
    }
    .content02-item:last-of-type {
        margin-bottom: 0;
    }
    .content02::before {
        height: 100%;
    }
    .third-box {
        margin-bottom: 5em;
        width: 100%;
    }
    .front-third-text {
        width: 100%;
        padding: 0 7% !important;
        margin: 0 0 2em !important;
    }
    .front-third-img {
        width: 93%;
    }
    .third-box:nth-of-type(even) .front-third-img {
        margin-left: 7%;
    }
    .main-front-copy-box.bottom-right {
        bottom: unset;
        top: 30px;
    }
    .front_inner-text {
        width: 100%;
        padding: 0;
    }
    .front_inner-img {
        width: 100%;
        margin: 30px auto 0;
    }
    .content02-title {
        text-align: center;
    }
    .content02-button {
        margin-left: auto;
    }
    .front_second_inner-text {
        padding-left: 30%;
    }
}
@media only screen and (max-width: 767px) {
    .front_topics {
        margin: 6em auto calc(6em - 15px);
    }
    .article03-title {
        font-size: 1em;
    }
    .main-front-copy-box.bottom-right {
        top: 20px;
        right: 20px;
        width: 20%;
    }
	.main-front-copy-box img {
		height: 270px;
		width: auto;
	}
}
@media only screen and (max-width: 485px) {
    .front_intro_inner h2 {
        font-size: 1.2em;
    }
    .front-third-text {
        padding: 0 7% 1em;
    }
    .article03 {
        margin: 0 auto 1em !important;
        width: 100%;
    }
    .article03:last-of-type {
        margin-bottom: 0 !important;
    }
    .front_topics {
        margin-bottom: 4em;
    }
    .header-youtube, .header-video {
        height: 290px;
    }
    #content01 {
        padding: 4em 0;
    }
    .content02-title {
        font-size: 1.2em;
    }
    .content02 {
        padding: 4em 0;
    }
    .front_second {
        padding: 0 0 4em;
        background: url(/wp-content/themes/story_tcd041/img/front_second-sp.jpg) center;
        margin-bottom: 4em;
    }
    .front_second_inner-text {
        padding: 0;
    }
}
/* ENDフロントオリジナル */
/* contact */
.tel-box {
    text-align: center;
}
.tel-box h2::after {
    margin-left: auto;
}
address.tel-address {
    line-height: 1.5;
    font-size: 2em;
}
address.tel-address span.tel-contact {
    font-size: 0.8em;
    margin-right: 10px;
    font-weight: 700;
    color: #DA9C50;
}
p.tel-info {
    margin-top: 10px;
}
p.tel-caution {
    color: #eb3e3e;
}
.line-box {
    margin: 4em auto 0;
}
.line-box h2 {
    text-align: center;
}
.line-box h2::after {
    margin-left: auto;
}
a.line-but {
    display: block;
    line-height: 60px;
    box-sizing: border-box;
    border: 3px solid #02a400;
    max-width: 400px;
    margin: 0 auto;
    padding: 0 25px;
    position: relative;
    border-radius: 10px;
    color: #02a400;
}
a.line-but::after {
    font-family: 'design_plus';
    content: '\e909';
    color: #02a400;
    position: absolute;
    right: 20px;
    font-weight: 500;
    font-size: 30px;
}
a:hover.line-but {
    background: #02a400;
    color: #ffffff;
}
a:hover.line-but::after {
    color: #ffffff;
}
.line-box p {
    text-align: center;
    margin-top: 20px;
}
.mail-box h2 {
    text-align: center;
}
.mail-box h2::after {
    margin-left: auto;
}
.mail-caution p {
    margin: 0 auto 20px;
    text-align: center;
}
@media only screen and (max-width: 485px) {
    .main-front-copy-box.top-left {
        top: auto;
        bottom: 10px;
        max-width: none;
		width: auto;
    }
    p.tel-info {
        text-align: left;
    }
    p.tel-caution {
        text-align: left;
    }
    .line-box p {
        text-align: left;
    }
    .mail-caution p {
        text-align: left;
    }
}
/* contact END */
/* message */
.greeting-img {
    width: 40%;
}
.greeting-container {
    align-items: center;
    margin: 0 auto 3em;
}
.greeting-img img {
    display: block;
    width: 100%;
}
.greeting-profile {
    width: calc(60% - 40px);
    margin-right: 40px;
}


.greeting-text{
    width: calc(60% - 40px);
    margin-left: 40px;
}
.flex-reverse-inner{
    flex-direction: row-reverse;
}
.flex-reverse-inner .greeting-text{
    margin-right: 40px;
    margin-left: 0;
}
h2.greeting-title {
    font-size: 1.3em;
    margin: 0 auto 30px;
}
h2.greeting-title::after {
    display: none;
}
h2.greeting-title span.name-title {
    display: block;
    font-size: 0.8em;
    font-weight: 500;
    color: #DA9C50;
}
.greeting-profile h3 {
    padding: 0;
    background: no-repeat;
    font-size: 1.1em;
    color: #628f8f;
    margin-bottom: 10px;
}
ul.greeting-list li {
    padding-left: 1.25em;
}
ul.greeting-list li::before {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    font-weight: 700;
    position: absolute;
    left: 0;
    top: 0;
    color: #649090;
}
@media only screen and (max-width: 485px) {
    .greeting-img {
        width: 100%;
        margin: 0 auto 20px;
    }
    .greeting-text,
    .flex-reverse-inner .greeting-text{
        width: 100%;
        margin-inline: 0;
    }
    .greeting-profile {
        width: 100%;
        margin: 0;
    }
    h2.greeting-title {
        text-align: center;
    }
}
/* message END */
/* price */
p.tax-price {
    text-align: center;
}
.price-container {
    margin: 3em auto 0;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
}
.price-container h2 {
    width: 100%;
    text-align: center;
}
.price-container h2::after {
    margin-left: auto;
}
.price-box {
    width: calc(50% - 10px);
    margin-right: 20px;
    box-sizing: border-box;
    border: 1px solid #c3c3c3;
    border-radius: 10px;
    padding: 25px calc(25px + 0.5em);
}
.price-box:nth-of-type(even) {
    margin-right: 0;
}
.price-box h3 {
    background: none;
    /*padding: 0 0 0 1.25em;*/
}
.price-box h3 span{
    color: #8EBB66;
}
/*.price-box h3::before {
  font-family: "Font Awesome 5 Free";
  content: "\f303";
  position: absolute;
  top: 0;
  left: 0;
  color: #DA9C50;
}*/
.post-content td {
    border-bottom: 1px solid #c8ffff;
}
.price-caution {
    margin: 2em auto 0;
    background: #f7b8b8;
    box-sizing: border-box;
    padding: 20px calc(20px + 0.5em);
    border-radius: 10px;
}
.price-caution p {
    padding-left: 1.25em;
}
.price-caution p::before {
    content: '※';
    position: absolute;
    top: 0;
    left: 0;
    color: #ffffff;
}
img.price-icon {
    display: block;
    margin: 0 auto 10px;
    width: 100%;
    max-width: 80px;
}
@media only screen and (max-width: 485px) {
    .price-box {
        width: 100%;
        margin: 0 auto 20px;
    }
    .price-box:last-of-type {
        margin-bottom: 0;
    }
}
/* price END */
/* timetable */
.schedule-container {
    max-width: 800px;
    margin: 0 auto;
}
/* timetable END */
/* trial */
.trial-intro {
    width: 100%;
    margin: 0 auto 2em;
}
.trial-text {
    width: 60%;
    box-sizing: border-box;
}
.trial-img {
    width: calc(40% - 30px);
    margin-left: 30px;
}
.trial-img img {
    display: block;
    width: 100%;
    border-radius: 10px;
}
.trial-contact {
    margin: 3em auto 0;
    background: #DA9C50;
    box-sizing: border-box;
    padding: 30px calc(30px + 0.5em);
    border-radius: 20px;

}
.trial-contact h3 {
    background: none;
    padding: 0;
    color: #ffffff;
    margin-bottom: 10px;
}
a.trial-but {
    padding-left: 1.25em;
    display: block;
    margin: 20px auto 0;
    position: relative;
    color: #ffffff;
}
a.trial-but::before {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    position: absolute;
    left: 0;
    top: 0;
    color: #fff;
}
a:hover.trial-but {
    color: #ffffff;
}
a:hover.trial-but::before {
    color: #DA9C50;
}
@media only screen and (max-width: 485px) {
    .trial-text {
        width: 100%;
        margin: 0 auto 20px;
    }
    .trial-img {
        width: 100%;
        margin: 0;
    }
}
/* trial END */
/* faq */
.faq-sec h2, .faq-sec p {
    padding-left: 45px;
}

.faq-sec h2 {
    font-size: 1.2em;
    margin-bottom: 0.25em;
}

.faq-sec h2::after {
    display: none;
}

.faq-sec p {
    margin-bottom: 2em;
    padding-bottom: 2em;
    border-bottom: 1px solid #dddddd;
}

.faq-sec p:last-of-type {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.faq-sec h2::before {
    width: 30px;
    height: 30px;
    line-height: 30px;
    background: #c2efef;
    position: absolute;
    left: 0;
    top: 0;
    content: 'Q';
    text-align: center;
    font-size: 16px;
    border-radius: 50%;
}

.faq-sec p::before {
    width: 30px;
    height: 30px;
    line-height: 28px;
    background: #DA9C50;
    position: absolute;
    left: 0;
    top: 0;
    content: 'A';
    text-align: center;
    font-size: 16px;
    color: #fff;
    font-weight: 700;
    border-radius: 50%;
    text-indent: 0.1em;
}
/* faq END */

/* information */
.map-box {
    margin: 3em auto 0;
    height: 400px;
}

table a {
    display: block;
}
/* スマホ動画 */
video {display:block;}

#main-image {
    background-color: rgba(0, 0, 0, 0);
}
video {
    min-height: 20%;
    min-height: 20vh;
    min-width: 20%;
    min-width: 20vw;
    width:100%;
    height:auto;
    background: url('') no-repeat;
    background-attachment: fixed;
    background-position: center center;
}
#bg-video {
    min-height: 464px;
    right:0;
    bottom:0;
    z-index:-1;
}
/* よやくる */
.yoyakuru-box {
    max-width: 300px;
    margin: 3% 0;
}
.yoyakuru-box img {
    width: 100%;
}
@media only screen and (max-width: 485px) {
    .yoyakuru-box {
        margin: 3% auto;
    }
}
/* よやくる END */
.summer-banner {
    display: block;
    margin-bottom: 45px;
    box-shadow: 0 10px 15px 0 rgb(0 0 0 / 15%);
    transition: 0.3s;
}
.summer-banner img {
    width: 100%;
}
.summer-banner:hover {
    opacity: 0.6;
}
/* TOP 夏期講習バナー */
.summer-banner {
    width: 100%;
    max-width: 850px;
    margin: 0 auto 4.4em;
    /* 	display:none; */
}
.front-banner {
    margin: 0 auto 4.4em;
    max-width: 590px;
    /* display: none; */
}
.front-banner img {
    width: 100%;
}
.top-slider-wrapper {
    width: calc(100% - 320px);
    margin-left: 35px;
}
.visible-phone {
    display: none;
}
@media only screen and (max-width: 767px) {
    .top-slider-wrapper {
        width: 100%;
		margin-left: 0;
    }

    .front_second_inner {
        color: inherit;
        margin-top: 20px;
        position: static;
    }

    .visible-phone {
        display: block;
    }

    .hidden-phone {
        display: none;
    }
}
@media only screen and (max-width: 485px) {
    .front-banner {
        margin: 0 auto 2em;
    }
}

@media screen and (min-width: 768px){
    .pcbr { display:block; }
    .spbr { display:none; }
}
@media screen and (max-width: 767px){
    .pcbr { display:none; }
    .spbr { display:block; }
}

/* 01242026 */
.cl-white{
    color: #fff !important;
}
.trail-lesson-price{
    font-size: 26px;
}
@media only screen and (min-width: 768px){

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


/* 開校記念キャンペーンのご案内 */
.campaign-notice {
  margin: 24px 0 32px;
  padding: 18px;
  background: #DA9C50;
  border: 2px solid #bad662;
  border-radius: 16px;
}

.campaign-notice__inner {
  max-width: 980px;
  margin: 0 auto;
}

.campaign-notice__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: #bad662;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0 0 10px;
}

.campaign-notice__title {
  margin: 0 0 10px;
  font-size: clamp(18px, 2.2vw, 24px);
  font-weight: 800;
  line-height: 1.35;
  color: #222;
}

.campaign-notice__body p {
  margin: 0 0 10px;
  color: #333;
  line-height: 1.8;
  font-size: 15px;
}

.campaign-notice__note {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed rgba(0, 0, 0, 0.25);
  font-size: 13px;
  color: #333;
}

/* SP微調整 */
@media (max-width: 768px) {
  .campaign-notice {
    padding: 16px;
    border-radius: 14px;
  }
  .campaign-notice__body p {
    font-size: 14px;
  }
}

span.tax {
	font-size: 75%;
}