@charset "UTF-8";
/*
    Template: swell
    Theme Name: matsuejuku
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

body {
    font-family: "Noto Sans JP", sans-serif;
}

.roboto {
    font-family: "Roboto", sans-serif;
}

.fw100 {
    font-weight: 100important;
}

.fw200 {
    font-weight: 200 !important;
}

.fw300 {
    font-weight: 300 !important;
}

.fw400 {
    font-weight: 400 !important;
}

.fw500 {
    font-weight: 500 !important;
}

.fw600 {
    font-weight: 600 !important;
}

.fw700 {
    font-weight: 700 !important;
}

.fw800 {
    font-weight: 800 !important;
}

.fw900 {
    font-weight: 900 !important;
}

.max-w500 {
    max-width: 500px;
}

.op8 {
    opacity: .8;
}

.c-scrollHint.sp_ {
    display: none;
}

/*header*/
.w-header.pc_ {
    display: flex !important;
}

.header-text span {
    display: block;
    border: 1px solid;
    font-size: 1em;
    letter-spacing: 2px;
    padding: .25em .5em;
    font-weight: 400;
}

.l-header__customBtn.sp_ {
    display: none;
}

.l-fixHeader__inner {
    padding-left: 0;
    padding-right: 0;
}

header:not(.-transparent) .l-header__inner.l-container {
    padding: 0;
}

/*animate*/
.animated-text {
    overflow: hidden;
}

.animated-text {
    opacity: 0;
    transform: translateY(100px);
    transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.animated-text.is-animated {
    opacity: 1;
    transform: translateY(0);
}

/*lead-title*/
.lead-title {
    position: relative;
    margin-bottom: 2em;
}

.lead-title::before {
    content: "爆裂";
    position: absolute;
    font-size: 9em;
    color: #ff141421;
    font-weight: 900;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}

.lead-title h2 {
    font-size: 2em;
    letter-spacing: 2px;
    font-weight: 800;
    line-height: 1.2;
}

/*arrow-link*/
.arrow-link ul {
    padding: 0;
    list-style: none;
}

.arrow-link ul a {
    display: block;
    color: unset;
    border-bottom: 3px solid var(--color_deep01);
    margin-bottom: 1.5em;
    transition-duration: .4s;
}

.arrow-link ul a:hover {
    transform: translateY(-2px);
}

.arrow-link ul a h3 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto .25em;
    font-size: 1.2em;
    font-weight: 800;
}

.arrow-link ul a h3 span {
    display: flex;
    flex-direction: column;
    letter-spacing: 1px;
}

.section-lead ul a h3 span small {
    font-size: .65em;
    opacity: 1;
}

.arrow-link ul a svg {
    color: var(--color_deep01);
    width: 1em;
}

/*section-mv*/
.section-mv {
    position: relative;
    overflow: hidden;
}

.section-mv::before {
    content: "学力向上爆裂";
    position: fixed;
    font-size: 24vw;
    color: rgb(255 255 255 / 5%);
    font-weight: 900;
    width: 100%;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    line-height: 1;
    white-space: break-spaces;
    z-index: 0;
}

.section-mv h2 {
    font-size: 4.2em;
    letter-spacing: 2px;
}

.section-mv img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.section-mv ul {
    display: flex;
    justify-content: space-between;
    gap: 5em;
}

.section-mv ul li {
    width: 50%;
}

.section-mv ul li a {
    color: #fff;
}

/*section-loop*/
.text-loop {
    display: flex;
    overflow: hidden;
    color: #fff;
    font-weight: 300;
    font-size: 1.3em;
}

.text-loop__item {
    display: inline-block;
    transform: translateX(0);
    animation-name: textloop;
    animation-duration: 70s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    white-space: nowrap;
    will-change: transform;
}

.section-loop.section-loop-img {
    margin-bottom: 1em;
}

.section-loop-img .text-loop__item {
    animation-duration: 20s;
    display: flex;
}

.section-loop-img .text-loop__item span {
    width: 300px;
}

.section-loop-img .text-loop__item span img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

@keyframes textloop {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-100%);
    }
}

/*section-copy*/
.section-copy p {
    font-size: 5em;
    font-weight: 800;
    letter-spacing: 2px;
}

/*section-point*/
.section-point .point-number {
    color: var(--color_deep01);
    font-weight: 700;
    font-size: 1.2em;
}

.section-point .point-number .roboto {
    font-size: 2em;
    margin-left: 3px;
}

.section-point h2 {
    margin: -.5em auto 1em;
    font-size: 2em;
    letter-spacing: 1px;
    font-weight: 700;
}

/*section-footer*/
.section-footer .swell-block-linkList__link {
    color: var(--color_main);
}

/*fix-btn*/
.fix-btn-wrap {
    position: fixed;
    right: 0;
    top: 17vh;
    z-index: 99;
    box-shadow: var(--swl-box_shadow);
}

.fix-btn-wrap ul {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.fix-btn-wrap a {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
    background: #032C6E;
    color: #fff;
    padding: 1.5em 1em;
    display: block;
    letter-spacing: 1px;
}

.fix-btn-wrap li:first-child a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25em;
}

.fix-btn-wrap li:nth-child(2) a {
    background: #FF1414;
}

.fix-btn-wrap li:last-child a {
    background: #02C22F;
}

.fix-btn-wrap a svg {
    width: .85em;
}

/*footer*/
.l-footer {
    z-index: 1;
}

.w-beforeFooter {
    margin-top: 0;
}

.l-content {
    margin-bottom: 0;
}

.c-widget+.c-widget {
    margin-top: 0;
}

/*page-result*/
.page-section-pass-list ul {
    padding: 0;
}

.page-section-pass-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 1.3em;
    font-weight: 400;
    border-bottom: 1px solid #ddd;
    padding-bottom: .5em;
    letter-spacing: 3px;
}

/*page-flow*/
.page-section-flow .cap_box_ttl {
    font-size: 1.2em;
    letter-spacing: 5px;
}

/*page-online*/
.page-section-online-feature .swell-block-column {
    background: #fff8f8;
    padding: 1.5em;
}

.page-section-online-feature .feature-label {
    background: var(--color_deep01);
    width: fit-content;
    color: #fff;
    font-size: .9em;
    font-weight: 400;
    padding: .15em .5em;
}

.page-section-online-feature h3 {
    margin-top: 0;
    letter-spacing: 1px;
}

/*page-others*/
.base-feature-columns .swell-block-column {
    background: #fff8f8;
    padding: 1em;
}

@media not all and (min-width: 600px) {

    /*section-mv*/
    .section-mv {
        padding-bottom: 0 !important;
    }

    .section-mv::before {
        font-size: 50vw;
        position: fixed;
    }

    .section-mv h2 {
        font-size: 2.6em;
    }

    .section-mv ul {
        flex-direction: column;
        gap: 0;
        align-items: flex-end;
    }

    .section-mv ul li {
        width: 70%;
    }

    .section-mv figure {
        margin: 0 -1em;
    }

    /*section-copy*/
    .section-copy p {
        font-size: 2.1em;
        padding: 1em 0;
    }

    /*fix-btn*/
    .fix-btn-wrap {
        top: unset;
        bottom: 0;
        width: 100%;
    }

    .fix-btn-wrap ul {
        flex-direction: unset;
        justify-content: space-between;
    }

    .fix-btn-wrap li {
        width: 33.3%;
    }

    .fix-btn-wrap a {
        -ms-writing-mode: unset;
        writing-mode: unset;
        text-orientation: unset;
        padding: 1.5em 1em;
        text-align: center;
    }

    /*footer*/
    .l-footer {
        padding-bottom: 6em;
    }
}

/*page-contact*/
.contact-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 3em;
}

table.contact-table {
    max-width: 800px;
}

.contact-table th {
    font-weight: 400;
    font-size: .9em;
    width: 30%;
}

.contact-table th, .contact-table td {
    border-left: none;
    border-right: none;
    background: unset;
    letter-spacing: 1px;
    padding: 1.5em 1em;
}

.contact-table td input, .contact-table td textarea {
    width: 100%;
    padding: .75em .5em;
    border: none;
    background: #f2f6fa;
    border-radius: 5px;
    font-size: 16px;
}

.contact-table td input[type="checkbox"], .contact-table td input[type="radio"] {
    width: unset;
    position: relative;
    top: 1px;
}

.contact-table th p {
    display: flex;
    flex-direction: column;
}

.contact-table th span {
    display: inline-block;
    background: var(--color_deep01);
    width: fit-content;
    color: #fff;
    font-size: .75em;
    padding: 0 .25em;
    margin-bottom: -.25em;
    border-radius: 2px;
}

.contact-table th span.any {
    background: #cbcbcb;
}

.contact-table td .contact-class-title {
    display: block;
    margin-top: 1.5em;
    font-size: .9em;
    margin-bottom: .5em;
    font-weight: 400;
}

.contact-table td input::placeholder, .contact-table td textarea::placeholder {
    opacity: .6;
}

.contact-table td .wpcf7-checkbox, .contact-table td .wpcf7-radio {
    display: flex;
    flex-wrap: wrap;
    gap: .5em;
}

.contact-table td .wpcf7-list-item {
    margin: 0;
    font-weight: 300;
    padding: .25em .5em;
    display: inline-block;
    border: 1px solid #999;
    border-radius: 5px;
}

.contact-table td .wpcf7-list-item:has(input:checked) {
    background: #d2e7ff;
    font-weight: 500;
}

.contact-table td .td-text {
    font-size: .9em;
    margin-bottom: 1em;
}

.contact-table td .wpcf7-not-valid-tip {
    color: #f77b7b;
    font-size: .9em;
}

.submit-btn {
    border: none;
    padding: .5em 3em;
    font-size: 1.1em;
    letter-spacing: 2px;
    background: var(--color_deep01);
    color: #fff;
}

.submit-btn:disabled {
    background: #ddd;
}

.wpcf7-spinner {
    display: none;
}

.grecaptcha-badge {
    visibility: hidden;
}

.recaptcha-message {
    font-size: .75em;
    margin-top: 2em;
}

@media not all and (min-width: 600px) {
    .contact-table tr {
        display: flex;
        flex-direction: column;
        border-bottom: 1px solid #e9e9e9;
        gap: .5em;
    }

    .contact-table tr:first-child {
        border-top: 1px solid #e9e9e9;
    }

    .contact-table th {
        width: 100%;
        border: none;
        padding-bottom: 0;
    }

    .contact-table th p {
        display: unset;
    }

    .contact-table th span {
        margin-right: .5em;
        position: relative;
        bottom: 1px;
    }

    .contact-table td {
        border: none;
        padding-top: 0;
    }

}