@charset "utf-8";

/* ===============================================
 * 基本設定・グローバルスタイル
 * =============================================== */
body {
    min-width: inherit;
    font-family: "Noto Sans JP", sans-serif, "Lato";
    color: #36250D;
}

*,
*:before,
*:after {
    box-sizing: border-box;
}

/* --- ヘッダー関連 --- */
.s5-pageHeader__inner {
    max-width: 1260px !important;
}

.s5-pageHeader,
.s5-frontLogin,
.s5-allProducts,
.s5-pageFooter {
    min-width: inherit;
}

.s5-pageFooter .s5-pageFooter__inner {
    width: auto !important;
}

div#global #header {
    min-width: inherit;
}

div#global #header .header-wrap {
    min-width: inherit;
}

div#global #header .header-wrap .header_logo {
    margin-right: -143px;
}

div#global #header .header-wrap .header_logo .header_logo_inr {
    margin-right: 143px;
}

div#global #header .header-wrap #header-menu {
    min-width: 143px;
}

/* --- ページトップへ戻るボタン --- */
#pageTop.static {
    margin-top: -40px;
    position: relative;
}

#page_top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 10;
    display: none;
}

#page_top>a {
    display: inline-block;
    padding: 25px;
    background: rgba(0, 0, 0, 0.3) url(/assets/images/common/icon_arrow-t-w.png) 49.5% 50% no-repeat;
    transition: all 0.3s;
}

/* ===============================================
 * ユーティリティクラス（汎用クラス）
 * =============================================== */
.img-responsive {
    display: grid;
    max-width: 100%;
    height: auto;
}

.img-responsive-kv {
    display: grid;
    width: 100%;
    max-width: 900px;
    height: auto;
    margin: 0 auto !important;
    position: relative;
}

.text-center {
    text-align: center !important;
}

.text-bold {
    font-weight: 800;
}

.align-center {
    margin-left: auto;
    margin-right: auto;
}

.sp-show {
    display: block;
}

.pc-show {
    display: none;
}

.bg-color {
    background-color: #f6f4f3;
}


/* ===============================================
 * コンポーネント（ボタン、見出しなど）
 * =============================================== */

/* --- 見出し --- */
.h2-headline,
.h3-headline {
    font-weight: 300 !important;
    line-height: 1.2;
    margin: 0 !important;
}

.h2-headline:after,
.h3-headline:after {
    content: attr(data-headline);
    display: block;
    font-weight: bold;
    color: #e66c00;
}

.h2-headline {
    font-size: 40px;
    padding-top: 25px;
}

.h2-headline:after {
    font-size: 15px;
}

.h3-headline {
    font-size: 30px;
    padding-bottom: 25px !important;
}

.h3-headline:after {
    font-size: 15px;
}

.h4-headline {
    font-weight: 600;
    color: #e66c00;
    margin: 0;
}

.h5-headline {
    font-size: 22px;
    font-weight: bold;
    margin: 0;
    padding: 0 0 8px;
    text-align: center;
}

/* --- テキストスタイル --- */
.description {
    font-size: 18px;
    font-weight: 500;
    max-width: 1200px;
    margin: 0 auto;
    line-height: 1.8;
}

.notice {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
    margin: 0;
}

.notice-bold {
    font-size: 22px;
    font-weight: 600;
    text-align: center;
    line-height: 1.6;
    padding-bottom: 1em;
    margin: 0;
}

/* --- ボタン・リンク --- */
#new_member a:hover {
    opacity: 0.5;
}

.btn-apply {
    display: block;
    margin-inline: auto;
    margin-bottom: 1rem;
    padding: 15px;
    max-width: 500px;
    background-color: #e66c00 !important;
    font-size: 18px;
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 500;
}

.btn-apply:hover {
    opacity: 0.5;
}

.txt-link {
    color: #e66c00 !important;
    text-decoration: underline !important;
}

.txt-link:hover {
    text-decoration: none !important;
}

/* --- 下矢印 --- */
.dli-chevron-down {
    display: inline-block;
    vertical-align: middle;
    color: #fff;
    line-height: 1;
    width: .7em;
    height: .7em;
    border: 0.12em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    transform: translateY(-25%) rotate(135deg);
    padding-left: 12px;
    margin-left: 16px;
    margin-bottom: 6px;
}

/* ===============================================
 * レイアウト・セクション
 * =============================================== */

/* --- メインビジュアル --- */
#mainVisual-wrapper {
    background: #f6f4f3;
    width: 100%;
}

.mainVisual-bg {
    background: #ffd54f;
}

.mainVisual-kv {
    display: grid;
    place-content: center;
    margin-inline: auto;
}

.mainVisual-kv .sp-show {
    margin-bottom: 15px;
}

/* --- コンテンツラッパー --- */
.new_member-wrapper {
    background-color: #f6f4f3;
    padding: 40px 0 0;
}

.new_member-container {
    background-color: #fff;
    margin: 30px auto;
    padding: 50px 4% 37px;
    width: 96%;
}

.new_member-contents {
    margin-bottom: 30px;
}

.new_member-contents h4 {
    font-size: 23px;
    padding: 10px 0 !important;
}

.new_member-contents .image1 {
    width: 100%;
    margin: 0 auto;
    padding: 20px 0;
}

.new_member-contents .image2 {
    padding: 10px 0;
}

.description-inner {
    padding: 2em 4% 0;
}

/* --- プレゼント内容 --- */
.present-image-wrap {
    margin: 5em auto 3em;
    display: flex;
    justify-content: center;
}

.present-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 4em;
}

.present-item {
    position: relative;
    width: min(100%, 360px);
    border: 2px solid #372410;
    border-radius: 16px;
}

.present-image {
    width: 100%;
    height: auto;
    padding: 2.5em;
    border-radius: 16px 16px 0 0;
    background: #FFFDEE;
    display: block;
}

.present-icon {
    position: absolute;
    top: -3em;
    left: calc((100% - 70px) / 2);
    width: 70px;
    height: 70px;
    z-index: 2;
}

#about-present .present-item .description {
    padding: 1em .5em 1em;
}

/* --- αアカデミーについて --- */

#about-aAcademy h2 {
    line-height: 1;
    margin-bottom: 20px !important;
}

#about-aAcademy h2 img {
    vertical-align: bottom;
    width: 300px;
    padding-bottom: 10px;
}

.about-aAcademy-contents {
    padding: 2em 4% 2.5em;
    background-color: #F5F4F2;
}

.aAcademy-logo-link img {
    margin-inline: auto;
    padding-top: 28px;
    display: block;
}

.aAcademy-logo-link:hover {
    opacity: 0.5;
}

.aAcademy-course-wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2.5em;
    margin-inline: auto;
    padding: 0;
    list-style: none;
}

.aAcademy-course-box {
    width: min(100%, 360px);
    background: #FFFDEE;
    border: 2px solid #372410;
    border-radius: 16px;
    padding: 1.4em;
    position: relative;
    display: flex;
    flex-direction: column;
}

.aAcademy-course-box .icon-video-course {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 3;
    width: 60px;
    height: 60px;
}

.aAcademy-course-box .icon-blank {
    position: absolute;
    bottom: 16px;
    right: 16px;
    z-index: 2;
    width: 20px;
    height: 20px;
}

.aAcademy-course-link {
    color: #36250D;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.aAcademy-course-image {
    width: 100%;
    height: auto;
    margin-bottom: 1em;
}

.aAcademy-course-text {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}


.aAcademy-course-box .notice {
    margin-top: 0;
}

/* --- αcafeとは --- */
#about-acafe h2 {
    line-height: 1;
    margin-bottom: 20px !important;
}

#about-acafe h2 img {
    vertical-align: bottom;
    width: 140px;
    padding-bottom: 10px;
}

.acafe-logo {
    display: flex;
    justify-content: center;
}

.about-box-wrap {
    margin: 0 auto;
    padding: 0;
}

.about-box {
    margin: 0 auto 2em;
    padding: 1.4em;
    width: min(100%, 360px);
    background: #FFFDEE;
    border: 2px solid #372410;
    border-radius: 16px;
    list-style: none;
    position: relative;
}

.about-box img {
    display: flex;
    margin: 0 auto;
    width: 60%;
    height: auto;
}

.step-icon {
    position: absolute;
    top: -3em;
    left: calc((100% - 70px) / 2);
    width: 70px;
    height: 70px;
    z-index: 4;
}

/* --- 応募ボタンエリア --- */
.apply-for-campaign {
    padding: 50px 4%;
}

/* --- パララックス（背景固定） --- */
.parallax {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.parallax-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    z-index: -1;
}

.parallax-inner {
    position: relative;
    z-index: 1;
    padding: 40px;
    background: rgba(0, 0, 0, 0.2);
}

.parallax-text {
    margin: 20px auto 0;
    font-size: 16px;
    line-height: 1.6;
    font-weight: bold;
    color: #FFF;
}

.parallax-text .link-text[target=_blank]::after {
    content: "";
    display: inline-block;
    width: 15px;
    height: 15px;
    background-image: url(../img/icon_blank_white.svg);
    transform: translateY(2px);
    margin-inline: 2px 4px;
}

.parallax .parallax-bg {
    background-image: url(../img/acafe_parallax.jpg);
    background-size: contain;
    background-repeat: repeat;
    z-index: 0;
}

/* ===============================================
 * レスポンシブ：スマホ（〜640px）
 * =============================================== */
@media screen and (max-width: 640px) {
    .s5-pageHeader__inner {
        padding: 0 !important;
    }

    div#global #user_data {
        display: none;
    }

    div#global #header .header-wrap {
        padding: 0 15px !important;
    }

    div#global #header .header-wrap:before,
    div#global #header .header-wrap:after {
        content: "";
        display: block;
        overflow: hidden;
    }

    div#global #header .header-wrap:after {
        clear: both;
    }

    div#global #header .header-wrap .header_logo {
        margin-right: 0;
        width: auto;
    }

    div#global #header .header-wrap .header_logo .header_logo_inr {
        margin-right: 0;
    }

    div#global #header .header-wrap .header_logo .header_logo_inr .logo-data {
        margin-top: 15px;
    }

    div#global #header .header-wrap .header_logo .header_logo_inr .logo-data>img {
        width: 78px;
    }

    div#global #header .header-wrap .header_logo .header_logo_inr .logo-data>p {
        display: block;
        margin-left: 0;
        margin-top: 7px;
        width: 160px;
    }

    div#global #header .header-wrap .header_logo .header_logo_inr .logo-data>p span {
        margin-left: 0;
    }

    div#global #header .header-wrap #header-menu {
        float: right;
        min-width: 107px;
    }

    div#global #header .header-wrap #header-menu>ul>li {
        height: 74px;
        padding: 0 10% !important;
        width: 50%;
    }

    div#global #header .header-wrap #header-menu>ul>li:first-child {
        width: 50%;
    }

    div#global #header .header-wrap #header-menu>ul>li a i {
        line-height: 74px;
        margin-top: 0 !important;
        vertical-align: middle;
    }

    div#global #header .header-wrap #header-menu>ul>li a i.ico.shosinsya {
        background: url(/assets/images/common/shosinsya.svg) left 50% no-repeat;
        background-size: auto 31px;
        height: 100%;
    }

    div#global #header .header-wrap #header-menu>ul>li a .menu-name {
        display: none;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul {
        padding-top: 0;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div {
        float: none;
        width: 100%;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column2,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column2,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column2,
    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column3,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column3,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column3,
    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column4,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column4,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column4 {
        margin-top: -10px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column2 .menu-category:first-child,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column2 .menu-category:first-child,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column2 .menu-category:first-child,
    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column3 .menu-category:first-child,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column3 .menu-category:first-child,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column3 .menu-category:first-child,
    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div.navi_column4 .menu-category:first-child,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div.navi_column4 .menu-category:first-child,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div.navi_column4 .menu-category:first-child {
        margin-bottom: 0;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category {
        border-bottom: 1px solid #d5d5d5;
        padding: 15px 15px 15px 15px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category+.menu_section,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section {
        margin-bottom: 10px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category+.menu_section+.menu_section,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu_section,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu_section {
        margin-bottom: 10px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category+.menu_section+.menu_section+.menu-category,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu_section+.menu-category,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu_section+.menu-category {
        margin-bottom: 10px;
        margin-top: -10px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category+.menu_section+.menu-category,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu-category,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category+.menu_section+.menu-category {
        margin-bottom: 0;
        margin-top: -10px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div .menu-category_sub,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div .menu-category_sub,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div .menu-category_sub {
        border-bottom: 1px solid #d5d5d5;
        padding: 0 15px 10px 15px;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div ul,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div ul,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div ul {
        padding: 0 0 0 0;
    }

    div#global #header .categoryHeader .nav .nav_c_li>ul>li>.clearfix>div ul>li,
    div#global #header .categoryHeader .nav #alpha_cafe #container #contents section#sec06 .rank-col .nav_c_li>ul>li>.note-right>div ul>li,
    #alpha_cafe #container #contents section#sec06 .rank-col div#global #header .categoryHeader .nav .nav_c_li>ul>li>.note-right>div ul>li {
        border-bottom: 1px solid #d5d5d5;
        margin-left: 0;
        margin-right: 0;
        margin-top: 0;
        padding: 10px 15px 10px 15px;
        text-indent: 0;
    }

    div#global #header .categoryHeader .nav .nav_c_li {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    div#global #header .categoryHeader .nav .nav_close {
        background: #fff;
        margin-top: -10px;
        padding-left: 15px !important;
        padding-right: 15px !important;
        position: relative;
        z-index: 1;
    }

    div#global.fixed #header .header-wrap #header-menu>ul>li {
        height: 50px;
    }

    div#global.fixed #header .header-wrap #header-menu>ul>li a i {
        line-height: 50px;
    }

    div#global.fixed #header .header-wrap #header-menu>ul>li a i.ico.shosinsya {
        height: 100%;
    }

    div#global.fixed #header .header-wrap #header-menu>ul>li a .menu-name {
        display: none;
    }

    #pageTop.static {
        margin-top: 20px;
        position: static;
    }
}

/* ===============================================
 * レスポンシブ：タブレット（640px以上）
 * =============================================== */
@media screen and (min-width: 640px) {
    .sp-show {
        display: none;
    }

    .pc-show {
        display: block;
    }

    .description {
        width: 95%;
    }

    .h2-headline {
        font-size: 60px;
        padding-top: 30px;
    }

    .h2-headline:after {
        font-size: 16px;
    }

    .h3-headline {
        font-size: 40px;
        padding-top: 30px;
    }

    .h3-headline:after {
        font-size: 18px;
    }

    .new_member-contents h4 {
        font-size: 22px;
        padding-bottom: 10px !important;
    }

    .new_member-wrapper {
        padding: 40px 30px 0;
    }

    .new_member-container {
        padding: 40px 30px;
        margin: 30px auto 0;
    }

    .mainVisual-kv {
        max-width: 992px;
    }

    .apply-for-campaign {
        padding: 30px 15px 60px;
    }

    .parallax-text {
        text-align: center;
    }

    .present-item {
        width: calc(50% - 1.75em);
        max-width: 360px;
    }

    .aAcademy-course-box {
        width: calc(50% - 0.75em);
        max-width: 360px;
    }

    .aAcademy-course-wrap {
        gap: 1.5em;
        max-width: calc(360px * 2 + 1.5em);
    }

    .present-container {
        gap: 1.5em;
    }

    .aAcademy-course-box .h5-headline {
        min-height: 3.3em;
    }
}

/* ===============================================
 * レスポンシブ：PC（992px以上）
 * =============================================== */
@media screen and (min-width: 992px) {
    .h2-headline {
        font-size: 70px;
    }

    .h2-headline:after {
        font-size: 18px;
    }

    .h3-headline {
        font-size: 50px;
    }

    .h3-headline:after {
        font-size: 20px;
    }

    .btn-apply {
        font-size: 22px;
        padding: 20px;
    }

    #mainVisual-wrapper {
        background: #fff !important;
    }

    .mainVisual-kv {
        max-width: 1200px;
    }

    .new_member-wrapper {
        padding: 60px 0 0;
    }

    .new_member-container {
        max-width: 992px;
        padding: 40px 30px 80px;
    }

    .new_member-contents h4 {
        font-size: 25px;
        padding-bottom: 15px !important;
    }

    .apply-for-campaign {
        padding: 40px 15px;
    }

    .about-box-wrap {
        display: flex;
        gap: 1.5em;
    }

    .about-box {
        margin-bottom: 0;
        padding: 0.5em 1em 1.5rem;
        flex: 1;
    }

    .about-box img {
        width: 65%;
    }

    .about-acafe-contents-inner {
        max-width: 1140px;
        margin: 0 auto;
    }
}

/* ===============================================
 * レスポンシブ：大型PC（1200px以上）
 * =============================================== */
@media screen and (min-width: 1200px) {
    .description {
        font-size: 18px;
        line-height: 1.7;
    }

    .new_member-container {
        max-width: 1200px;
        padding: 80px 30px;
    }

    .new_member-contents h4 {
        font-size: 28px;
        line-height: 1.5;
        padding-bottom: 16px !important;
    }

    .apply-for-campaign {
        padding: 40px 0 50px;
    }

    .about-acafe-container h2 img {
        padding-bottom: 14px;
        width: 230px;
    }

    .about-box {
        aspect-ratio: 1/1;
        padding: 1em 1.5em 1.5em;
    }

    .parallax-inner {
        padding: 70px 40px;
    }
}