/*

Theme Name:   UNDOWコアホームページ Theme
Description:  This is my custom theme.
Version:      1.0
Author:       Dugong
Author URI:   N/A
License:      N/A
License URI:  N/A
Text Domain:  my-theme

*/


/*********************************
　　　可変値設定
**********************************/
html {
    /* 色 */
    --mainColor: #F69220;
    --accentColor: #005353;
    --subColor: #EA2227;
    --mojiColor: #333333;

    /* サイズ */
    /* 文字 */
    --main-chara-size: 1.24rem;
    --big-chara-size: 2.4rem;
    --small-chara-size: 0.8rem;
}

/* 可変値設定 タブレット */
@media (max-width: 1200px) {
    html {
        /* サイズ */
        /* 文字 */
        --main-chara-size: 1.12rem;
        --big-chara-size: 1.8rem;
        --small-chara-size: 0.6rem;
    }
}

/* 可変値設定 スマホ */
@media (max-width: 768px) {
    html {
        /* サイズ */
        /* 文字 */
        --main-chara-size: 1.08rem;
        --big-chara-size: 1.8rem;
        --small-chara-size: 0.6rem;
    }
}



/*********************************
　　　基本設定
**********************************/
body {
    font-family: 'Nunito Sans', sans-serif;
    color: #333333;
    line-height: 1.5;
    width: 100%;
    overflow-x: hidden;
    font-size: var(--main-chara-size);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

main {
    margin-top: 72px;
}

a,
address {
    text-decoration: none;
    font-style: normal;
    cursor: pointer;
}

.section {
    padding: 48px 32px;
}

/* 基本設定 スマホ */
@media (max-width: 768px) {
    .section {
        padding: 32px 16px 32px;
    }
}

/* スマホ表示時の各ページ上部 余白調整 */
@media (max-width: 768px) {
    .aboutUsMain,
    .lessonMain,
    .privacyPolicyMain,
    .termsMain {
        margin-top: 140px;
    }
}

/*********************************
　　　hタグ
**********************************/
h2 {
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 32px;
    color: #333333;
    text-align: center;
    font-size: 42px;
}

/* h2 タブレット */
@media (max-width: 1200px) {
    h2 {
        font-size: 32px;
    }

}

/* h2 スマホ */
@media (max-width: 768px) {
    h2 {
        font-size: 24px;
    }
}


/*********************************
　　　グリッド
**********************************/
.grid_wrapper {
    width: 100%;
    display: flex;
    margin: 0 auto;
    padding: 8px;
}

.grid_col2 {
    width: 50%;
}

.grid_col3 {
    width: 33.3%;
}

.grid_col4 {
    width: 25%;
}

/* グリッド スマホ */
@media (max-width: 768px) {
    .grid_wrapper {
        display: block;
    }

    .grid_col2 {
        width: 100%;
    }

    .grid_col3 {
        width: 100%;
    }

    .grid_col4 {
        width: 100%;
    }
}



/*********************************
　　　コンテナ
**********************************/
.container {
    margin: 0 auto;
}


/*********************************
　　　セクション
**********************************/
.sectionTitle {
    text-align: center;
}

.sectionTitle_heading {
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -1%;
    margin-bottom: 24px;
}

.sectionTitle_text {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
}


/*********************************
　　　ボタン
**********************************/
/* 基本設定 */
.button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 10px 24px;
    border-radius: 100px;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.5;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    margin: 0 auto;
}

.button--primary {
    background-color: #F69220;
    color: #FFFFFF;
    border: 4px solid #CC8400;
}

.button--primary:hover {
    background-color: #CC8400;
}


/* ボタン オレンジ */
.buttonOrange {
    background-color: #F69220;
    color: #ffffff;
    border: 4px solid transparent
}

.buttonOrange:hover {
    background-color: #ffffff;
    color: #F69220;
    border: 4px solid #F69220;
}


/* ボタン オレンジ サブ */
.buttonOrange_sub {
    background: none;
    border: 4px solid #F69220;
    color: #F69220;
    background-color: #ffffff;
}

.buttonOrange_sub:hover {
    background-color: #f692209a;
    color: #ffffff;
    border: 4px solid transparent;
}


/* ボタン　青緑 */
.buttonNavy {
    background-color: #005353;
    color: #ffffff;
    border: 4px solid #005353
}

.buttonNavy:hover {
    background-color: #ffffff;
    color: #005353;
    border: 4px solid #005353;
}


/* ボタン 青緑 サブ */
.buttonNavy_sub {
    background: none;
    border: 4px solid #005353;
    color: #005353;
}

.buttonNavy_sub:hover {
    background-color: #005353;
    color: #ffffff;
    border: 4px solid transparent;
}


/* ボタン ホワイト */
.button--white {
    background-color: #ffffff;
    color: #CC8400;
    border: 4px solid #CC8400
}

.button--white:hover {
    background-color: #CC8400;
    color: #ffffff;
    border: 4px solid #ffffff;
}

/* ボタン ブラウン */
.buttonBrown {
    background-color: #CC8400;
    color: #ffffff;
    border: 4px solid #ffffff;
}

.buttonBrown:hover {
    background-color: #ffffff;
    color: #CC8400;
    border: 4px solid #CC8400;
    /* opacity: 70%; */
}



/*********************************
　　　オープニングアニメーション
**********************************/

/* ページ本体（メインコンテンツ）のスタイル */
#mainContent {
    /* 初期は完全に透明 */
    opacity: 0;
    /* フェードイン/アウト用 */
    transition: opacity 1s ease-in-out;
    min-height: 100vh;
    /* トップページの背景色 */
    background-color: #ffffff;
    text-align: center;
}

/* 画面全体を覆うオーバーレイのスタイル */
#loadingOverlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    /* 背景色 オレンジ */
    background-color: #F69220;
    display: flex;
    justify-content: center;
    align-items: center;
    /* 他の要素より手前に表示 */
    z-index: 1000;
    /* 初期は不透明 */
    opacity: 1;
    /* フェードアウト用 */
    transition: opacity 1s ease-in-out;
}

/* メッセージのスタイル */
#welcomeMessage {
    color: white;
    font-size: 24px;
    text-align: center;
    /* テキストの改行を有効にする */
    white-space: pre-wrap;
}

/* JavaScriptで文字を1文字ずつ表示するために使用するクラス */
.char-fade-in {
    opacity: 0;
    /* 1文字ごとのフェードイン速度 */
    transition: opacity 0.3s ease-in;
    /* span要素を横並びにする */
    display: inline-block;
}

/* メッセージのフェードアウト用クラス */
.message-fade-out {
    opacity: 0;
    transition: opacity 0.8s ease-out;
}



/*********************************
　　　ヘッダー
**********************************/
header {
    width: 100vw;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    border-bottom: 2px solid #cc7a1d;
}

.headerWrapper {
    position: relative;
}

.header {
    background-color: #F69220;
    height: 72px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    z-index: 10;
    border-bottom: 2px solid #cc7a1d;
}



/*********************************
　　　ナビ
**********************************/
.nav {
    background-color: #F69220;
    padding: 0 64px;
    height: 70px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1;
}

.nav .container {
    max-width: 1440px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.nav_logo {
    position: absolute;
    top: 50%;
    left: 16px;
    transition: background-color 0.3s ease;
}

.nav_logImage {
    height: 60px;
    width: auto;
    background-color: #ffffff;
    border-radius: 8px;
    position: absolute;
    top: 50%;
    left: 16px;
    transform: translateY(-50%);
}

.nav_logImage:hover {
    cursor: pointer;
    opacity: 60%;
}

.nav_links {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.nav_link {
    color: #FFFFFF;
    font-size: 20px;
    font-weight: 500;
    text-decoration: none;
    display: flex;
    align-items: center;
    padding: 16px 32px;
    transition: background-color 0.3s ease;
    position: relative;
}

.nav_link:hover {
    background-color: #fdbc72;
}

/* ナビ ドロップダウンメニュー */
.nav_dropDown::after {
    content: '▼';
    font-size: 10px;
    padding-left: 8px;
}

.dropDown_wrapper {
    position: absolute;
    bottom: 0;
    display: none;
    box-shadow: 0px 3px 8px -2px #777;
    transform: translate(0, 100%);
    color: #FFFFFF;
    line-height: 2.0;
    width: -webkit-fill-available;
    left: 0;
}

.nav_dropDown:hover>.dropDown_wrapper,
.nav_dropDown:focus-within>.dropDown_wrapper {
    display: block;
}

.nav_droDdown {
    position: relative;
    text-align: center;
}

.dropDown_lists {
    background-color: var(--mainColor);
    text-align: center;
}

.dropDown_list {
    transition: all 0.3s;
    padding: 4px 8px 0px;
    width: 100%;
    padding-bottom: 4px;
}

.dropDown_list:hover,
.dropDown_list:hover {
    transition: all 0.3s;
    background-color: #CC8400;
}

.nav_dropDown:hover .nav_dropDown-menu {
    display: flex;
}

.nav_dropDown-item {
    color: #FFFFFF;
    font-size: 24px;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
}


/* ナビ タブレット */
@media (max-width: 1200px) {
    .nav_link {
        font-size: 16px;
        padding: 16px 24px;
    }
}


/* ナビ スマホ */
@media (max-width: 768px) {
    .nav_link {
        font-size: 12px;
        padding: 16px 16px;
    }
}


/* ヘッダー・nav レスポンシブ */
@media (max-width: 768px) {
    .header {
        height: 140px;
        display: block;
    }

    .nav {
        display: block;
        padding: 0;
    }

    .nav_container {
        display: block;
        text-align: center;
    }

    .nav_logo {
        position: inherit;
        display: inline-block;
    }

    .nav_logImage {
        position: inherit;
        transform: translateY(0%);
        display: block;
        margin-top: 16px;
    }

    .nav_links {
        align-items: center;
        justify-content: center;
    }

    /* navの高さに合わせてhero画像の上部位置調整 */
    .hero {
        margin: 140px auto 0;
    }
}



/*********************************
　　　フッター
**********************************/
.footer {
    background-color: var(--mainColor);
    height: 565px;
    position: relative;
    overflow: hidden;
    padding: 0 64px;
}

.footer_inner {
    width: 100%;
    height: 100%;
}

.footer_inner::before {
    content: '';
    position: absolute;
    top: 58.87px;
    left: -0.48px;
    width: 94%;
    height: 304px;
    background-color: #FFFFFF;
    border-radius: 0 72px 72px 0;
    z-index: 1;
}

.footer_top {
    position: absolute;
    top: 82px;
    left: 32.5px;
    display: flex;
    gap: 80px;
    z-index: 2;
}

.footer_logo {
    width: 257px;
    height: 272px;
    object-fit: contain;
}

.footer_linksWrapper {
    display: flex;
    gap: 40px;
}

.footer_links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
}

.footer_link::before {
    content: '';
    display: inline-block;
    height: 18px;
    width: 8px;
    background-color: transparent;
    margin-right: 16px;
    vertical-align: middle;
    transition: background-color 0.3s ease;
}

.footer_link:hover::before {
    width: 8px;
    background-color: #664200;
}

.footer_link {
    color: #664200;
    font-weight: 600;
    text-decoration: none;
    padding: 8px 0;
    font-size: 1.24rem
}

.footer_bottom {
    position: absolute;
    bottom: 24px;
    left: 0px;
    justify-content: space-between;
    align-items: center;
    z-index: 2;
}

.footer_socialLinks {
    display: flex;
    gap: 12px;
    transition: all 0.4s;
}

.footer_social-icon {
    width: 20px;
    height: 20px;
}

.footer_social-icon:hover,
.footer_social-icon:focus {
    opacity: 40%;
    transition: all 0.4s;
    background-color: #fdbc72;
}

.footer_credits,
.footer_creditLinks {
    display: flex;
    align-items: center;
    gap: 24px;
    padding-left: 16px;
    padding-bottom: 16px;
}

hr {
    color: #FFFFFF;
}

.footer_creditText {
    color: #FFFFFF;
    font-weight: 400;
    line-height: 1.5;
    padding: 8px;
}

.footer_creditLink {
    color: #FFFFFF;
    font-weight: 400;
    line-height: 1.5;
    text-decoration: none;
    transition: all 0.4s;
    border-bottom: 2px solid transparent;
}

.footer_creditLink:hover {
    transition: all 0.4s;
    border-bottom: 2px solid #FFFFFF;
}

.footer_creditText_wrapper {
    width: 100vw;
    text-align: center;
}


/* フッター　レスポンシブ */
/* 768pxでは合わないので、個別設定 */
@media (max-width: 900px) {
    .footer_top {
        gap: 0;
    }
    
    .footer_logo {
        width: 200px;
        height: 200px;
        object-fit: contain;
    }
}

/* フッター　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    footer {
        padding: 32px 16px;
        height: 732px;
        overflow: visible;
    }

    .footer {
        height: auto;
        overflow: visible;
        height: 800px;
    }

    .footer_inner {
        height: auto;
    }

    .footer_inner::before {
        width: 80%;
        height: 532px;
    }

    .footer_logo {
        width: 160px;
        height: 160px;
    }

    .footer_top {
        display: block;
    }

    .footer_link {
        font-size: 1.08rem;
    }

    .footer_bottom {
        display: block;
        left: 0;
    }

    .footer_creditLinks {
        display: block;
        padding: 16px;
        line-height: 2rem;
    }
}

@media (max-width: 580px) {
    .footer_linksWrapper {
        display: block;
    }
}



/* ================================== トップページ  ================================== */

/*********************************
　　　ヒーロー
**********************************/
.hero {
    background-color: #FFFFFF;
    padding: 0;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 100vw;
}

.hero_container {
    width: 100%;
    justify-content: flex-start;
}

.hero_contentOverlay {
    display: flex;
    align-items: flex-start;
    gap: 32px;
    z-index: 1;
    justify-content: center;
}

.hero__logo {
    width: 257px;
    height: 272px;
    border-radius: 48px;
    background-color: rgba(255, 255, 255, 0.71);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    z-index: 1;
}

.hero__logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.hero__message-content {
    z-index: 1;
    margin: auto 40px;
}

.hero__message-base {
    display: none;
}

.hero__message {
    position: static;
    width: auto;
    height: auto;
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 400;
    /* font-size: 2.4rem; */
    font-size: 1.4rem;
    line-height: 1.3;
    letter-spacing: -1%;
    color: #333333;
    text-align: left;
    display: block;
}

.hero_topImage {
    width: 96%;
    height: auto;
    overflow: hidden;
    border-radius: 8px;
    margin: 16px auto;
}

.hero__contenText {
    justify-content: center;
    display: flex;
    align-items: center;
    text-align: left;
    color: var(--mainColor);
    font-size: 1.6rem;
}

.hero_TreResult_container {
    background-color: var(--mainColor);
}

.hero_TreResult_title {
    background-color: #FFFFFF;
    color: var(--mainColor);
    font-size: var(--big-chara-size);
    text-align: center;
    border-radius: 16px;
    display: inline-block;
    padding: 0 16px;
    margin: 16px auto;
}

.hero_TreResult_items {
    margin-right: 8px;
    display: flex;
}

.hero_TreResult_items:last-child {
    margin-right: 0;
}

.hero_TreResult_item {
    background-color: #FFFFFF;
    border-radius: 16px;
}

.treImage {
    background-image: url(../images/30minTreResulut_haikei.jpg);
    margin: auto;
    width: -webkit-fill-available;
    border-radius: 16px;
    margin: 8px;
}

.treDescription::before {
    content: '';
    width: 96%;
    background-color: var(--mainColor);
    display: inline-block;
    height: 2px;
    text-align: center;
}

.treDescription {
    font-size: 16px;
    text-align: left;
    padding: 8px;
}


/* ヒーローエリア
   30分トレーニング結果のレスポンシブ */
@media (max-width: 768px) {
    .hero_TreResult_title {
        margin-left: 16px;
        margin-right: 16px;
    }
    .hero_TreResult_items {
        margin: 16px auto;
        display: block;
    }

    .treImage {
        padding: 16px;
    }

    .treDescription {
        font-size: var(--main-chara-size);
        padding: 16px;
    }
}



/* 健康のために */
.toHealth {
    background-color: #FDE4C8;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}


.toHealth_container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    width: 100%;
}

.toHealth_components {
    display: flex;
    flex-direction: column;
    gap: 32px;
    width: 100%;
}

.toHealth_cardRow {
    display: flex;
    gap: 32px;
    width: 100%;
}

.toHealth_card {
    display: flex;
    flex-direction: column;
    flex: 1;
    background-color: #FFFFFF;
    border-radius: 16px;
    overflow: hidden;
    width: 864px;
}

.toHealth_cardImage {
    width: 100%;
    height: 486px;
    object-fit: cover;
}

.toHealth_cardContent {
    padding: 48px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    background-color: #FFFFFF;
}

.toHealth_cardHeading {
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -1%;
    color: #333333;
    margin-bottom: 8px;
    font-size: var(--big-chara-size);
}

.toHealth_cardText {
    font-weight: 400;
    line-height: 1.5;
    color: #05050A;
}

.toHealth_cardActions {
    display: flex;
    align-items: center;
    gap: 24px;
    margin: 0 auto;
}

.toHealth_cardRow_small {
    display: flex;
    justify-content: space-between;
    gap: 32px;
    width: 100%;
}

.toHealth_card_small {
    display: flex;
    flex: 1;
    background-color: #FFFFFF;
    border-radius: 16px;
    overflow: hidden;
}

.toHealth_cardContent_small {
    padding: 32px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 24px;
    width: 100%;
    height: 100%;
}

.toHealth_card-icon {
    width: 56px;
    height: 48px;
    margin-bottom: 8px;
}

.toHealth_cardHeading_small {
    font-weight: 400;
    font-size: 32px;
    line-height: 1.3;
    letter-spacing: -1%;
    color: #333333;
    margin-bottom: 8px;
}

.toHealth_cardText_small {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    margin-bottom: 32px;
}

/* 健康のために レスポンシブ */
/* タブレット */
@media (max-width: 1200px) {
    .toHealth {
        display: block;
    }

    .toHealth_cardActions {
        display: block;
    }

}

/* スマホ */
@media (max-width: 768px) {
    .toHealth {
        display: block;
    }

    .toHealth_cardActions {
        display: block;
    }

    .buttonOrange_sub {
        margin-top: 24px;
    }

    .toHealth_cardRow_small {
        display: block;
    }

    .toHealth_card_small {
        margin-bottom: 32px;
    }
}



/*********************************
　　　トピック
**********************************/
.topic_container {
    margin: 0 auto;
    width: 96%;
}

.topicItems_wrapper {
    border: 4px solid var(--mainColor);
    padding: 32px 16px;
    border-radius: 16px;
}

.topicItem {
    display: flex;
    border-bottom: 2px dotted #333333;
    justify-content: space-between;
    padding-bottom: 8px;
    align-items: center;
}

.buttonTopic {
    background-color: var(--mainColor);
    padding: 8px 16px;
    color: #FFFFFF;
    font-size: var(--main-chara-size);
    transition: all 0.3s;
}

.buttonTopic:hover,
.buttonTopic:focus {
    opacity: 70%;
    transition: all 0.3s;
}

/* 健康のために スマホ */
@media (max-width: 768px) {
    .topicItem {
        display: block;
    }

    .buttonTopic {
        display: block;
        margin: 0 0 0 auto;
    }

    .topicTitle {
        margin-bottom: 8px;
    }
}



/*********************************
　　　トレーニングメニュー
**********************************/
.trainingMenu {
    background-color: #F69220;
    display: flex;
    flex-direction: column;
    align-items: center;
    scroll-margin-top: 72px;
}

.trainingMenu .sectionTitle_heading {
    color: #FFFFFF;
}

.trainingMenu .sectionTitle_text {
    color: #FFFFFF;
}

.trainingMenu_container {
    width: 100%;
    padding: 80px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}

.trainingMenu_componentWrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 80px;
    width: 100%;
}

.trainingMenu_card {
    position: relative;
    width: 480px;
    height: 480px;
    background-color: #FFFFFF;
    border-radius: 50px;
    overflow: hidden;
}

.trainingMenu_cardInner {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: 32px;
}

.trainingMenu_card-top-circle {
    position: absolute;
    top: 105px;
    left: 56px;
    width: 228.6px;
    height: 136.4px;
    border-radius: 100px;
    border: 4px solid #F69220;
    background-color: #FFFFFF;
    display: flex;
    justify-content: center;
    align-items: center;
}

.trainingMenu_card-polygon1 {
    position: absolute;
    top: 120.47px;
    left: 39.43px;
    width: 101.88px;
    height: 42.92px;
    fill: #F69220;
}

.trainingMenu_card-polygon2 {
    position: absolute;
    top: 120.88px;
    left: 44.15px;
    width: 87.73px;
    height: 37.29px;
    fill: #FFFFFF;
}

.trainingMenu_card-effect-text {
    width: 201.07px;
    height: 104.64px;
    font-weight: 400;
    font-size: 32px;
    line-height: 1.16;
    color: #F69220;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.trainingMenu_cardTitle {
    position: absolute;
    top: 16px;
    background-color: #F69220;
    color: #FFFFFF;
    font-size: 24px;
    display: flex;
    padding: 8px 16px;
}

.trainingMenu_cardDescription {
    width: 264px;
    font-weight: 400;
    font-size: 24px;
    line-height: 1.16;
    color: #F69220;
    text-align: center;
    margin-top: 8px;
}

.trainingMenu_cardLine {
    width: 80%;
    height: 8px;
    background-color: #F69220;
    margin: 4px auto;
}

.trainingMenu_cardImage {
    width: 64%;
    height: 64%;
}

.trainingMenu_cardInner .marginTop {
    margin-top: 32px;
}


/* トレーニングメニュー　レスポンシブ調整 */
/* タブレット */
@media (max-width: 1200px) {
    .trainingMenu {
        display: block;
        padding: 64px 32px;
        scroll-margin-top: 140px;
    }

    .trainingMenu_container {
        padding: 48px 0;
    }

    .trainingMenu_card {
        width: 420px;
        height: 420px;
    }

    .trainingMenu_cardTitle {
        font-size: 20px;
    }

    .trainingMenu_cardInner {
        margin-top: 32px;
    }

    .trainingMenu_cardDescription {
        font-size: 20px;
    }
}


/* トレーニングメニュー スマホ */
@media (max-width: 768px) {
    .trainingMenu {
        display: block;
    }

    .trainingMenu_card {
        width: 360px;
        height: 376px;
    }

    .trainingMenu_cardTitle {
        font-size: 16px;
    }

    .trainingMenu_cardInner {
        margin-top: 24px;
    }

    .trainingMenu_cardDescription {
        font-size: 16px;
    }
}


/*********************************
　　　お客様の感想
**********************************/
.reviews {
    background-color: #FFFFFF;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

.reviews_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
}

.reviews_content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 19px;
    width: 100%;
}

.reviews_cardRow {
    display: flex;
    gap: 32px;
    width: 100%;
}

.reviews_card {
    flex: 1;
    background-color: #F2F2F2;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 16px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.reviews_cardContent {
    display: flex;
    flex-direction: column;
    gap: 24px;
    text-align: left;
}

.reviews_musicalNotes {
    display: flex;
    gap: 4px;
}

.reviews_musicalNotes img {
    width: 20px;
    height: 28px;
}

.reviews__quote-title {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    font-size: 1.24rem;
    text-align: left;
    border-bottom: 2px solid #333;
    display: inline-block;
    width: fit-content;
}

.reviews_quoteText {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
}

.reviews_avatar {
    display: flex;
    align-items: center;
    gap: 16px;
}

.reviews_avatarImage {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    background-color: #ffffff;
}

.reviews_avatarText {
    font-weight: 600;
    line-height: 1.5;
    color: #333333;
    opacity: 0.33;
}

.reviews_button {
    margin-top: 19px;
}

/* お客様の感想　レスポンシブ */
/* タブレット */
@media (max-width: 1200px) {
    .reviews-row {
        display: block;
    }
}

/* お客様の感想　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .reviews {
        padding: 64px 16px;
    }

    .reviews_cardRow {
        display: block;
    }

    .reviews_card {
        margin-bottom: 24px;
    }
}



/*********************************
　　　営業時間
**********************************/
.businessHours {
    background-color: #E5F2E5;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    scroll-margin-top: 72px;
}

.businessHours_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.businessHours_text {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    text-align: center;
    max-width: 913px;
}

.businessHours_content {
    position: relative;
    width: 681px;
    height: 332px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.businessHours_icon {
    position: absolute;
    width: 184px;
    height: 184px;
    left: 52.01px;
    top: 34.98px;
    object-fit: cover;
}

.businessHours_timeInfo {
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
    display: block;
    margin-left: 104px;
}

.businessHours_timeTitle {
    margin-bottom: 24px;
}

.businessHours_timeTitle-wrapper {
    background-color: #005353;
    padding: 8px 16px;
}

.businessHours_timeTitle_p {
    font-family: 'Aboreto', cursive;
    font-weight: 400;
    font-size: 32px;
    line-height: 1.22;
    color: #FFFFFF;
    text-align: center;
}

.businessHours_hours {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    text-align: left;
}

/* 営業時間　レスポンシブ */
/* タブレット */
@media (max-width: 1200px) {
    .businessHours_text {
        width: auto;
        position: inherit;
    }
}

/* 営業時間　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .businessHours {
        scroll-margin-top: 140px;
    }

    .businessHours_text {
        width: auto;
        position: inherit;
    }

    .businessHours_content {
        position: inherit;
        width: auto;
        display: block;
    }

    .businessHours_icon {
        position: inherit;
        margin-top: 24px;
    }

    .businessHours_timeTitle_p {
        font-size: 24px;
    }

    .businessHours_timeInfo {
        position: inherit;
        transform: translate(0);
        margin-left: 0;
        margin-top: 24px;
    }
}



/*********************************
　　　料金
**********************************/
.price {
    background-color: #FFFFFF;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 56px;
    scroll-margin-top: 72px;
}

.price_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 56px;
}

.price_cards {
    display: flex;
    gap: 32px;
    width: 100%;
}

.price_card {
    flex: 1;
    background-color: #F2F2F2;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 16px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 32px;
}

.price_cardContent {
    display: flex;
    flex-direction: column;
    gap: 32px;
    width: 100%;
}

.price_cardHeader {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    width: 100%;
}

.price_cardTitle {
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: -1%;
    color: #333333;
}

.price_cardIcon {
    width: 72px;
    height: 32px;
}

.price_cardDetails {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.price_cardPrice {
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 400;
    font-size: 48px;
    line-height: 1.2;
    letter-spacing: -1%;
    color: #333333;
}

.price_cardDuration {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
}

.price_divider {
    width: 100%;
    height: 1px;
    background-color: #005353;
    height: 2px;
    border-radius: 8px;
}

.price_includes {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 8px 0;
    width: 100%;
}

.price_includesTitle,
.price_excludesTitle {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    margin-bottom: 8px;
}

.price_includesList,
.price_excludesList {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.price_includesList li,
.price_excludesList li {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
}

.price_includesIcon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin: 8px 8px 4px 0;
}

.price_button {
    width: 469px;
    margin-top: 80px;
}

.lesson_buttonWarapper {
    margin-top: -32px;
}


/* 料金　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .price {
        scroll-margin-top: 140px;
    }

    .price_cards {
        display: block;
    }

    .price_card {
        margin-bottom: 32px;
    }

    .price_container {
        gap: 32px;
    }

    .price_button {
        width: auto;
        padding: 8px 32px;
        margin-top: 0px;
        margin-bottom: 16px;
    }

    .lesson_buttonWarapper {
        margin-top: -8px;
    }
}



/*********************************
　　　アクセス
**********************************/
.access {
    background-color: #E5F2E5;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    scroll-margin-top: 72px;
}

.access_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

.access_shopName {
    font-weight: 400;
    font-size: 24px;
    line-height: 1.4;
    letter-spacing: -1%;
    color: #333333;
    text-align: center;
}

.access_content {
    display: flex;
    width: 88%;
    position: relative;
    margin: 0 auto;
}

.access_addressInfo {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 48%;
    margin-right: 24px;
}

.access_addressText {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
}

.access_mapInfo {
    position: relative;
    width: 48%;
    height: 658px;
    border-radius: 50px;
    overflow: hidden;
    border: 4px solid #005353;
}

.access_mapImage {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.access_mapInfo .button {
    position: absolute;
    bottom: 93px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.access_addressInfo .button {
    width: 250px;
}


/* アクセス　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .access {
        scroll-margin-top: 140px;
    }

    .access_content {
        flex-direction: column-reverse;
        width: 100%;
    }

    .access_container {
        gap: 24px
    }

    .access_shopName {
        font-size: 20px;
    }

    .access_mapInfo {
        width: 100%;
    }

    .access_addressInfo {
        width: 100%;
        margin-top: 32px;
    }

    .access_addressText {
        text-align: left;
    }
}



/* ================================== UNDOWコアについて ================================== */

/*********************************
　　　健康への思い
**********************************/

.concept {
    background-color: #FDE4C8;
    flex-direction: column;
    align-items: center;
    gap: 80px;
    margin-top: 72px;
    scroll-margin-top: 72px;
}

.concept .container {
    align-items: center;
    gap: 80px;
    width: 100%;
}

.concept .sectionTitle {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    width: 100%;
}

.concept .component {
    flex-direction: row;
    justify-content: stretch;
    align-items: stretch;
    gap: 32px;
    width: 100%;
}

.concept .card {
    flex-direction: column;
    flex: 1;
    background-color: #FDE4C8;
    border: 1px solid #FDE4C8;
    border-radius: 16px;
    overflow: hidden;
}

.concept .content-top {
    display: flex;
    flex-direction: row;
    gap: 8px;
}

.concept .content-top .content {
    display: flex;
    flex-direction: row;
    justify-content: stretch;
    align-items: stretch;
    gap: 24px;
    width: 60%;
}

.concept .content-top p {
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    text-align: left;
    position: relative;
}

.concept_emphasisText {
    font-size: 1.4rem;
    justify-content: center;
    display: flex;
    font-weight: 500;
    margin: 32px auto;
}

.concept .image-about-us-idea {
    height: 448px;
    border-radius: 140px 140px 0 0;
    object-fit: cover;
    width: 40%;
    margin: auto 16px;
}

.concept .content .actions {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 24px;
    width: 100%;
    padding: 48px;
}

.concept .button.secondary {
    background-color: #F69220;
    color: #FFFFFF;
    border: 4px solid rgba(5, 5, 10, 0.15);
}

.concept .button.secondary:hover {
    background-color: #CC8400;
}

/* コンセプト　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .concept {
        padding: 32px 16px;
        margin-top: 140px;
        scroll-margin-top: 140px;
    }

    .concept .content-top {
        display: block;
    }

    .concept .content-top .content {
        width: 100%;
    }

    .concept .image-about-us-idea {
        width: 100%;
        margin-top: 40px;
    }

    .concept .content .actions {
        display: block;
        width: auto;
    }

    .actions .button {
        width: 100%;
    }
}



/*********************************
　　　トレーニングの流れ
**********************************/
.trainingFlow {
    background-color: #F2F2F2;
    align-items: center;
    gap: 80px;
    justify-content: center;
    scroll-margin-top: 72px;
}

.trainingFlow .container {
    flex-direction: column;
    align-items: center;
    gap: 80px;
    width: 100%;
}

.trainingFlow .frame {
    margin-top: 120px;
}

.trainingFlow .trainingFlow_wrapper {
    width: 80%;
    height: auto;
    background-color: #ffffff;
    padding: 60px 30px 30px;
    margin: 0 auto;
    border-radius: 40px;
    position: relative;
    min-height: 320px;
    margin-top: -40px;
}

.trainingFlow .trainingFlow_wrapper:last-child {
    min-height: 320px;
    border-radius: 0 0 40px 40px;
}

.trainingFlow_wrapper_layer0 img {
    max-width: 320px;
    max-height: 320px;
}

/* トレーニングフロー 図のレイヤー調整 */
.trainingFlow_wrapper_layer0 {
    z-index: 0;
}
.trainingFlow_wrapper_layer1 {
    z-index: 1;
}
.trainingFlow_wrapper_layer2 {
    z-index: 2;
}
.trainingFlow_wrapper_layer3 {
    z-index: 3;
}
.trainingFlow_wrapper_layer4 {
    z-index: 4;
}
.trainingFlow_wrapper_layer5 {
    z-index: 5;
}
.trainingFlow_wrapper_layer6 {
    z-index: 6;
}

.trainingFlow .trainingFlow_wrapper .rectangle-18 {
    width: 100%;
    height: 276px;
    background-color: #EBEAFF;
}

.trainingFlow .trainingFlow_wrapper.arrow-right .rectangle-18 {
    background-color: #FFFFFF;
}

.trainingFlow .trainingFlow_wrapper .trainingFlow_fukidashi_triangle7,
.trainingFlow .trainingFlow_wrapper .trainingFlow_fukidashi_triangle6 {
    z-index: 2;
}

.trainingFlow .trainingFlow_wrapper .trainingFlow_fukidashi_triangle6 {
    width: 48px;
    height: 80px;
    background-color: #FFFFFF;
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
}

.trainingFlow .trainingFlow_wrapper .trainingFlow_fukidashi_triangle7 {
    width: 48px;
    height: 80px;
    background-color: #EBEAFF;
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
}

.rectangle-18 {
    text-align: center;
}

.trainingFlow .trainingFlow_wrapper .completed_text {
    font-weight: 400;
    font-size: 40px;
    line-height: 0.95;
    color: #005353;
    z-index: 3;
    padding-top: 24px;
}

.trainingFlow .trainingFlow_wrapper .completed_title {
    font-weight: 400;
    font-size: 40px;
    line-height: 0.95;
    color: #005353;
    top: 91.09px;
    left: 583px;
    z-index: 3;
    margin-top: 40px;
}

.trainingFlow .trainingFlow_wrapper .icon {
    width: 212px;
    height: 212px;
    object-fit: cover;
    z-index: 2;
    position: absolute;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
}

.trainingFlow .trainingFlow_wrapper .text-description {
    font-weight: 400;
    line-height: 1.5;
    color: #005353;
    text-align: left;
    width: 72%;
    height: auto;
    margin-top: 24px;
    font-size: var(--main-chara-size);
}

.trainingFlow .trainingFlow_wrapper .text-title {
    font-weight: 400;
    font-size: 32px;
    line-height: 1.1875;
    color: #005353;
    text-align: left;
    top: 40px;
    transform: translateY(50%);
    margin-left: 104px;
}

.trainingFlow .trainingFlow_wrapper.arrow-right .text-title {
    position: absolute;
    transform: translateY(50%);
    margin-top: 32px;
}

.trainingFlow .trainingFlow_wrapper .stepNumber {
    width: 80px;
    height: 80px;
    left: 60px;
    top: 23.84px;
    z-index: 4;
}

.trainingFlow .trainingFlow_wrapper.arrow-right .stepNumber {
    left: auto;
}

.trainingFlow .trainingFlow_wrapper .circleOuter {
    width: 80px;
    height: 80px;
    border: 2px solid #005353;
    border-radius: 50%;
    position: relative;
}

.trainingFlow .trainingFlow_wrapper .circleInner {
    width: 64px;
    height: 64px;
    background-color: #005353;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.trainingFlow .trainingFlow_wrapper .number {
    font-weight: 400;
    font-size: 60px;
    color: #FFFFFF;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.trainingFlow .trainingFlow_wrapper:nth-child(2n) {
    background-color: #EBEAFF;
}

.trainingFlow .trainingFlow_wrapper:nth-child(n + 2) {
    border-radius: 0 0 40px 40px;

}


/* トレーニングの流れ　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .trainingFlow {
        padding: 32px 16px;
        scroll-margin-top: 140px;
    }

    .trainingFlow .trainingFlow_wrapper {
        margin-top: -24px;
    }

    .trainingFlow .trainingFlow_wrapper .circleOuter {
        width: 56px;
        height: 56px;
    }

    .trainingFlow .trainingFlow_wrapper .circleInner {
        width: 48px;
        height: 48px;
    }

    .trainingFlow .trainingFlow_wrapper .number {
        font-size: 44px;
    }

    .trainingFlow .trainingFlow_wrapper .text-title {
        top: 20px;
        margin-left: 72px;
    }

    .trainingFlow .trainingFlow_wrapper .text-description {
        width: 100%;
        margin-top: 120px;
    }

    .trainingFlow .trainingFlow_wrapper .icon {
        width: 120px;
        height: 120px;
        object-fit: cover;
        z-index: 2;
        position: absolute;
        left: 50%;
        top: 120px;
        transform: translateX(-50%);
    }

    /*1つ目の要素だけ、上の吹き出しがないので、上部余白を個別指定*/
    .trainingFlow .trainingFlow_wrapper_layer6 {
        padding-top: 24px;
    }

    .trainingFlow_wrapper_layer6 p:first-child {
        margin-top: 8px;
    }

    .trainingFlow_wrapper_layer0 img {
        width: 240px;
        height: 240px;
    }

    .trainingFlow .trainingFlow_wrapper .completed_title,
    .trainingFlow .trainingFlow_wrapper .completed_text {
        font-size: 32px;
    }

    .trainingFlow .trainingFlow_wrapper.arrow-right .text-title_reception {
        margin-top: 0;
    }

    .trainingFlow .trainingFlow_wrapper .icon_reception {
        top: 96px;
    }
}



/*********************************
　　　お客様の声（UNDOWコアについて）
**********************************/
.testimonial {
    background-color: #FFFFFF;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}

.testimonial .container {
    flex-direction: column;
    align-items: center;
    gap: 80px;
    width: 100%;
}

.testimonial .content {
    flex-direction: column;
    gap: 32px;
    width: 100%;
}

.testimonial .row {
    display: flex;
    flex-direction: row;
    justify-content: stretch;
    align-items: stretch;
    gap: 32px;
    width: 100%;
    flex-wrap: wrap;
}

.testimonial .column {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 32px;
    background-color: #F2F2F2;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 16px;
    flex: auto;
    width: 320px;
}

.testimonial .content .musicalNotes {
    display: flex;
    flex-direction: row;
    gap: 4px;
}

.testimonial .content .musicalNotes img {
    width: 20px;
    height: 28px;
    fill: #FFFFFF;
}

.testimonial .content .quote {
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 400;
    line-height: 1.5;
    color: #333333;
    text-align: left;
    margin-top: 16px;
}

.testimonial .avatar {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    width: 100%;
}

.testimonial .avatarImage {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    background-color: #FFFFFF;
}

.testimonial .avatar-content {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.testimonial .avatar-content .name {
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 1.5;
    color: #333333;
}

.testimonial .avatar-content .occupation {
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5;
    color: #333333;
}

.testimonial .actions {
    margin: 48px auto 0;
    justify-content: center;
    display: flex;
}

.testimonial .button.primary {
    background-color: #F69220;
    color: #FFFFFF;
    border: 4px solid #CC8400;
}

.testimonial .button.primary:hover {
    background-color: #CC8400;
}


/*  お客様の声　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .testimonial {
        padding: 32px 16px;
    }
}



/*********************************
　　　スタッフのご紹介
**********************************/
.introduction {
    background-color: #CCE5CC;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}

.introduction .container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 80px;
    width: 100%;
}

.introduction .frame {
    display: flex;
    flex-direction: row;
    padding: 39px 6px;
    width: 100%;
    justify-content: center;
    align-items: center;
}

.introduction .instructorImage {
    width: 318px;
    height: 570px;
    border-radius: 140px 140px 0 0;
    object-fit: cover;
    margin-right: 56px
}

.introduction .fukidashi {
    width: 40px;
    height: 32px;
    rotate: -16deg;
    clip-path: polygon(100% 0, 0 50%, 100% 100%);
    background-color: #ffffff;
    position: absolute;
    left: -32px;
    top: 36px;
}

.introduction .instructor_wrapper {
    position: relative;
}

.introduction .greetingMessage {
    background-color: #FFFFFF;
    border-radius: 50px;
}

.introduction .instructor_contents {
    padding: 24px;
}

.introduction .qualifications {
    font-weight: 400;
    line-height: 1.16;
    color: #005353;
    text-align: left;
}

.introduction .qualification-title {
    font-family: 'Aboreto', cursive;
    font-weight: 400;
    font-size: 24px;
    line-height: 1.16;
    color: #005353;
    text-align: center;
    border: 2px solid #005353;
    margin-top: 24px;
    margin-bottom: 16px;
    display: inline-block;
    padding: 8px 16px;
}

.introduction .experience {
    font-family: 'Aboreto', cursive;
    font-weight: 400;
    line-height: 1.16;
    color: #005353;
    text-align: left;
}

.introduction .greeting {
    font-family: 'Aboreto', cursive;
    font-weight: 400;
    line-height: 1.16;
    color: #005353;
    text-align: left;
}

.introduction .greeting-title {
    font-family: 'Aboreto', cursive;
    font-weight: 400;
    font-size: 24px;
    line-height: 1.16;
    color: #005353;
    text-align: center;
    padding: 8px 16px;
    border: 2px solid #005353;
    display: inline-block;
    margin-bottom: 16px;
}

.introduction .trainingFlow_fukidashi_triangle3 {
    fill: #FFFFFF;
}


/* スタッフの紹介　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .introduction {
        padding: 32px 16px;
    }

    .introduction .container {
        display: block;
    }

    .introduction .frame {
        display: block;
        text-align: center;
        padding-top: 0px;
    }

    .introduction .instructorImage {
        width: 240px;
        height: 240px;
        border-radius: 50%;
        margin-right: 0px;
        object-position: top;
    }

    .introduction .instructor_content {
        text-align: left;
    }

    .introduction .greetingMessage {
        margin-top: 40px;
    }

    .introduction .fukidashi {
        top: -4px;
        left: 44%;
        transform: translateX(-50%);
        rotate: 90deg;
    }
}



/*********************************
　　　数字で見るUNDOWコア
**********************************/
.inNumbers {
    background-color: #FDE4C8;
    flex-direction: column;
    align-items: center;
    gap: 80px;
}

.inNumbers .container {
    flex-direction: column;
    align-items: center;
    gap: 80px;
    width: 100%;
}

.inNumbers_frameWrapper {
    display: flex;
    flex-direction: row;
    padding: 39px 6px;
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
}

.inNumbers_itemWrapper {
    width: 520px;
    position: relative;
    margin: 32px;
    text-align: center;
    padding: 16px;
    display: flex;
    align-items: stretch;
}


.inNumbers .inNumbers_item {
    background-color: #FFFFFF;
    border-radius: 50px;
}
.inNumbers .description {
    font-weight: 400;
    line-height: 1.16;
    color: #F69220;
    text-align: left;
    height: auto;
    padding: 24px;
    font-size: var(--main-chara-size);
}

.inNumbers .line {
    width: 72%;
    height: 8px;
    background-color: #F69220;
    border-radius: 4px;
    display: inline-block;
}

.inNumbers .number {
    font-family: 'ヒラギノ角ゴシック';
    font-size: 296px;
    font-weight: 700;
    color: #F69220;
    text-align: center;
}


/* 数字で見る　レスポンシブ */
/* スマホ */
@media (max-width: 768px) {
    .inNumbers {
        padding: 32px 16px;
    }

    .inNumbers .frame-item {
        margin: 0 auto;
        width: 96%;
        min-width: auto;
    }

    .inNumbers .number {
        font-size: 196px;
    }
}



/* ================================== レッスン ================================== */

/*********************************
　　　レッスン
**********************************/
.lesson_container {
    width: 96%;
    margin: 0 auto;
}

.lesson_description {
    text-align: left;
}

.lessonProgram_imgWrapper {
    width: 96%;
    height: auto;
    overflow-x: scroll;
    display: flex;
    justify-content: center;
    margin: auto;
    margin: 0 auto;
}
/* 1000px以下だとdisplay:flexで画像が縮小されてしまうため調整 */
@media (max-width: 1000px) {
    .lessonProgram_imgWrapper {
        margin: 0 auto;
        display: block;
    }
}

.lesson_container img {
    height: 400px;
}

.lessonMain .price_divider {
    background-color: #CC8400;
}

.Precautions_content .Precautions_lists {
    text-align: left;
    margin-bottom: 32px;
}

.lessonMain .buttonOrange {
    justify-content: center;
    display: flex;
    margin: 48px auto;
}

.lessonMain .access {
    background-color: #ecd3af;
}

.lessonMain .access_mapInfo {
    border: 4px solid #CC8400;
}

.lessonMain .buttonBrown {
    border: 4px solid #CC8400;
}



/* ================================== プライバシーポリシー ================================== */

.privacyPolicy_container {
    margin-top: 72px;
    scroll-margin-top: 72px;
    text-align: left;
}
.privacyPolicy_list {
    list-style: disc;
    margin-left: 2.4rem;
}

.privacyPolicy_link {
    border-bottom: 1px solid #333333;
}

.privacyPolicy_link:hover {
    opacity: 80%;
}

/* 画像素材について */
.imageMaterial_container  {
    text-align: left;
}

/* スマホ */
@media (max-width: 768px) {
    .privacyPolicy_container {
        margin-top: 140px;
        scroll-margin-top: 140px;
    }
}


/* ================================== 利用規約 ================================== */

.terms_container {
    margin-top: 72px;
    scroll-margin-top: 72px;
    text-align: left;
}

.terms_list {
    margin-left: 1rem;
}

/* スマホ */
@media (max-width: 768px) {
    .terms_container {
        margin-top: 140px;
        scroll-margin-top: 140px;
    }
}
