.elementor-14215 .elementor-element.elementor-element-388df61{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-14215 .elementor-element.elementor-element-388df61:not(.elementor-motion-effects-element-type-background), .elementor-14215 .elementor-element.elementor-element-388df61 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-4c95a11 );}.elementor-14215 .elementor-element.elementor-element-5d49819{--display:flex;}.elementor-14215 .elementor-element.elementor-element-190c6e6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:1px 1px;--row-gap:1px;--column-gap:1px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-14215 .elementor-element.elementor-element-190c6e6.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-14215 .elementor-element.elementor-element-66af229{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-8ce73ed{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-538d67d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-994e5b7{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-994e5b7.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-14215 .elementor-element.elementor-element-30abada{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-85c4932{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-2d1a386{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-14215 .elementor-element.elementor-element-8f27cfb{--spacer-size:50px;}.elementor-14215 .elementor-element.elementor-element-f385ff1 > .elementor-container > .elementor-column > .elementor-widget-wrap{align-content:center;align-items:center;}.elementor-14215 .elementor-element.elementor-element-f385ff1:not(.elementor-motion-effects-element-type-background), .elementor-14215 .elementor-element.elementor-element-f385ff1 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0B0080;}.elementor-14215 .elementor-element.elementor-element-f385ff1{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;margin-top:0px;margin-bottom:0px;padding:10px 10px 10px 10px;}.elementor-14215 .elementor-element.elementor-element-f385ff1 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-14215 .elementor-element.elementor-element-b745787 > .elementor-element-populated{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-14215 .elementor-element.elementor-element-b745787 > .elementor-element-populated > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-widget-nav-menu .elementor-nav-menu--main .elementor-item{color:var( --e-global-color-text );fill:var( --e-global-color-text );}.elementor-widget-nav-menu .elementor-nav-menu--main .elementor-item:hover,
					.elementor-widget-nav-menu .elementor-nav-menu--main .elementor-item.elementor-item-active,
					.elementor-widget-nav-menu .elementor-nav-menu--main .elementor-item.highlighted,
					.elementor-widget-nav-menu .elementor-nav-menu--main .elementor-item:focus{color:var( --e-global-color-accent );fill:var( --e-global-color-accent );}.elementor-widget-nav-menu .elementor-nav-menu--main:not(.e--pointer-framed) .elementor-item:before,
					.elementor-widget-nav-menu .elementor-nav-menu--main:not(.e--pointer-framed) .elementor-item:after{background-color:var( --e-global-color-accent );}.elementor-widget-nav-menu .e--pointer-framed .elementor-item:before,
					.elementor-widget-nav-menu .e--pointer-framed .elementor-item:after{border-color:var( --e-global-color-accent );}.elementor-widget-nav-menu{--e-nav-menu-divider-color:var( --e-global-color-text );}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item{color:var( --e-global-color-4c95a11 );fill:var( --e-global-color-4c95a11 );}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item:hover,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item.elementor-item-active,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item.highlighted,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item:focus{color:var( --e-global-color-4c95a11 );fill:var( --e-global-color-4c95a11 );}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--main .elementor-item.elementor-item-active{color:var( --e-global-color-4c95a11 );}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a, .elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-menu-toggle{color:var( --e-global-color-4c95a11 );fill:var( --e-global-color-4c95a11 );}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown{background-color:#0B0080;}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a:hover,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a:focus,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a.elementor-item-active,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a.highlighted,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-menu-toggle:hover,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-menu-toggle:focus{color:#0B0080;}.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a:hover,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a:focus,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a.elementor-item-active,
					.elementor-14215 .elementor-element.elementor-element-2c8a12d .elementor-nav-menu--dropdown a.highlighted{background-color:var( --e-global-color-4c95a11 );}.elementor-bc-flex-widget .elementor-14215 .elementor-element.elementor-element-25ca157.elementor-column .elementor-widget-wrap{align-items:center;}.elementor-14215 .elementor-element.elementor-element-25ca157.elementor-column.elementor-element[data-element_type="column"] > .elementor-widget-wrap.elementor-element-populated{align-content:center;align-items:center;}.elementor-widget-text-editor{color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-14215 .elementor-element.elementor-element-878d051{color:var( --e-global-color-4c95a11 );}@media(max-width:767px){.elementor-14215 .elementor-element.elementor-element-f385ff1{margin-top:0px;margin-bottom:0px;padding:10px 10px 010px 10px;}.elementor-14215 .elementor-element.elementor-element-b745787{width:100%;}.elementor-14215 .elementor-element.elementor-element-878d051{text-align:center;font-size:10px;}}@media(min-width:768px){.elementor-14215 .elementor-element.elementor-element-388df61{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-5d49819{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-190c6e6{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-66af229{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-8ce73ed{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-538d67d{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-994e5b7{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-30abada{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-85c4932{--content-width:800px;}.elementor-14215 .elementor-element.elementor-element-2d1a386{--content-width:800px;}}/* Start custom CSS for html, class: .elementor-element-de72058 *//* ヘッダー全体 */
.spring-header-wrapper {
    font-family: "Noto Sans JP", sans-serif;
    width: 100%;
    background-color: white;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    position: relative; 
    border-radius: 12px;
    overflow: hidden;
}

.spring-header-inner {
    display: flex;
    height: 70px; /* PCでの高さ */
    align-items: stretch;
    justify-content: space-between;
}

/* 1. ロゴエリア（左） */
.header-logo-area {
    background-color: white;
    flex: 0 0 auto;
    padding: 0 25px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.header-logo-text {
    display: flex;
    align-items: center; /* 垂直方向の中央揃え */
    height: 100%;        /* 親要素（ヘッダー）の高さに合わせる */
}

.header-logo-text img {
    max-height: 60%;    /* 親の高さ以上に大きくならないように制限 */
    width: auto;         /* 横幅はアスペクト比を維持して自動調整 */
    display: block;      /* 下の隙間（descender）を消す */
}
.header-logo-icon {
    color: #ec4899; /* pink-500 */
    margin-right: 8px;
    font-size: 0.9em;
}

/* 2. ナビゲーションエリア（中央） */
.header-nav-area {
    flex: 1 1 auto;
    background-color: #ff85a2; 
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-nav-list {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    height: 100%;
    align-items: center;
}

.header-nav-item {
    display: flex;
    align-items: center;
    height: 100%;
    position: relative;
}

/* 区切り線（PCのみ） */
.header-nav-item:not(:last-child)::after {
    content: '';
    display: block;
    width: 1px;
    height: 20px;
    background-color: rgba(255,255,255,0.5);
    margin: 0 30px;
}

.header-nav-link {
    color: white;
    text-decoration: none;
    font-weight: 700;
    font-size: 15px;
    transition: opacity 0.3s;
    letter-spacing: 0.05em;
    display: block;
    white-space: nowrap;
}
.header-nav-link:hover {
    opacity: 0.9;
}

/* 3. CTAエリア（右） */
.header-cta-area {
    flex: 0 0 auto;
    background: linear-gradient(to bottom, #d9f99d 0%, #bef264 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 30px;
    text-decoration: none;
    transition: all 0.3s;
}
.header-cta-area:hover {
    filter: brightness(1.05);
}

.header-cta-text {
    color: #3f6212; /* 濃い緑の文字 */
    font-weight: 900;
    font-size: 16px;
    display: flex;
    align-items: center;
    white-space: nowrap;
}
.header-cta-text i {
    margin-left: 8px;
    font-size: 0.9em;
}

/* --- スマホ対応（メディアクエリ） --- */
@media (max-width: 768px) {
    .spring-header-inner {
        height: 60px; /* 高さを少し確保 */
        padding: 0 5px; /* 全体の余白を詰める */
        gap: 4px; /* 要素間の隙間 */
        align-items: center; /* 垂直中央揃え */
    }

    /* スマホ：ロゴエリア */
    .header-logo-area {
        padding: 0 5px;
        min-width: auto;
        flex: 0 1 auto;
        height: 100%; /* 高さ100%にしてクリック領域確保 */
    }
    .header-logo-text {
        font-size: 16px; /* ロゴ文字サイズ */
    }
    .header-logo-icon {
        margin-right: 4px;
        font-size: 0.8em;
    }

    /* スマホ：ナビゲーション */
    .header-nav-area {
        background-color: transparent; /* 背景色は個別に設定するため透明に */
        flex: 1 1 auto;
        justify-content: flex-end; /* 右寄せ気味 */
        padding: 0;
        height: auto; /* 高さ自動 */
    }
    
    .header-nav-list {
        gap: 4px; /* リンク間の間隔 */
        width: auto;
        justify-content: flex-end;
        height: auto;
    }
    
    .header-nav-item {
        height: auto;
    }
    
    .header-nav-item:not(:last-child)::after {
        display: none;
    }

    .header-nav-link {
        color: white; /* 白文字 */
        font-size: 11px; /* 文字サイズ */
        padding: 8px 10px; /* パディング */
        background-color: #ff85a2; /* ピンク背景 */
        border-radius: 4px; /* 角丸 */
        line-height: 1.2;
        font-weight: 700;
        text-align: center;
        min-width: 60px; /* 最小幅確保 */
    }

    /* スマホ：CTAエリア */
    .header-cta-area {
        padding: 8px 10px;
        background: #bef264;
        min-width: auto;
        border-radius: 4px;
        margin: 0;
        height: auto;
        align-self: center;
        min-width: 70px; /* 最小幅確保 */
        justify-content: center;
    }
    
    .header-cta-text {
        font-size: 11px; /* 文字サイズ調整 */
        justify-content: center;
    }
    .header-cta-text i {
        display: none;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-22e0b2d *//* 春のバナー専用スタイル */
.spring-banner-container {
    position: relative;
    width: 100%;
    /* 背景：空と桜のグラデーション */
    background: linear-gradient(120deg, #e0f2fe 0%, #fff 40%, #ffe4e6 100%);
    border-radius: 12px;
    overflow: hidden;
    padding: 40px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    font-family: "Noto Sans JP", sans-serif;
}

/* 桜の花びらアニメーション装飾 */
.sakura-petal {
    position: absolute;
    background-color: #ffc0cb;
    border-radius: 150% 0 150% 0;
    animation: fall linear infinite;
    z-index: 0;
    opacity: 0.6;
}
@keyframes fall {
    0% { transform: translate(0, -10%) rotate(0deg); opacity: 0; }
    10% { opacity: 0.8; }
    100% { transform: translate(100px, 400px) rotate(360deg); opacity: 0; }
}

/* 左側のイラストエリア（フリー素材の女性などを想定） */
.spring-banner-image {
    width: 40%;
    text-align: center;
    z-index: 1;
}
.spring-banner-image img {
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 10px 10px rgba(0,0,0,0.1));
}

/* 右側のテキストエリア */
.spring-banner-text {
    width: 55%;
    text-align: left;
    z-index: 1;
    color: #1e293b; /* 濃いネイビー */
}

/* キャッチコピー */
.spring-copy-main {
    font-size: clamp(24px, 5vw, 42px); /* レスポンシブフォントサイズ */
    font-weight: 900;
    line-height: 1.4;
    margin-bottom: 20px;
    font-feature-settings: "palt";
}
.spring-copy-main .highlight {
    color: #be185d; /* 濃いピンク */
    position: relative;
    display: inline-block;
}
.spring-copy-main .highlight::after {
    content: '';
    position: absolute;
    bottom: 5px;
    left: 0;
    width: 100%;
    height: 12px;
    background-color: rgba(255, 192, 203, 0.6);
    z-index: -1;
    transform: skewX(-15deg);
}

/* サブコピー */
.spring-copy-sub {
    font-size: clamp(14px, 3vw, 18px);
    font-weight: bold;
    color: #475569;
    margin-bottom: 0;
    background: rgba(255,255,255,0.7);
    display: inline-block;
    padding: 5px 10px;
    border-radius: 4px;
}

/* スマホ対応 */
@media (max-width: 768px) {
    .spring-banner-container {
        flex-direction: column-reverse;
        padding: 30px 15px;
    }
    .spring-banner-image {
        width: 80%;
        margin-top: 20px;
    }
    .spring-banner-text {
        width: 100%;
        text-align: center;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-8d38c9d *//* 春のコンセプトエリア用スタイル */
.spring-concept-section {
    font-family: "Noto Sans JP", sans-serif;
    text-align: center;
    width: 100%;
    margin-bottom: 40px;
}

/* 上部のメッセージエリア（桜色グラデーション） */
.spring-message-box {
    /* 春らしい明るいピンク〜コーラルへのグラデーション */
    background: linear-gradient(135deg, #ff9a9e 0%, #ff6f91 100%);
    color: white;
    padding: 50px 20px 70px; /* 下に三角形がつくので下余白を多めに */
    position: relative;
}

.spring-message-text {
    font-size: clamp(18px, 4.5vw, 26px); /* レスポンシブな文字サイズ */
    font-weight: 700;
    line-height: 1.8;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.15);
    letter-spacing: 0.05em;
}

/* 強調部分の背景 */
.spring-message-highlight {
    background-color: rgba(255,255,255,0.25);
    padding: 4px 10px;
    border-radius: 6px;
    display: inline-block;
    margin: 5px 0;
    border: 1px solid rgba(255,255,255,0.4);
}

/* 下向きの三角形（吹き出しのしっぽ） */
.spring-message-box::after {
    content: '';
    position: absolute;
    bottom: -24px; /* 三角形の高さ分ずらす */
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 25px 25px 0 25px; /* 三角形のサイズ */
    border-color: #ff6f91 transparent transparent transparent; /* 背景色の終端色に合わせる */
    filter: drop-shadow(0 4px 2px rgba(0,0,0,0.05)); /* うっすら影 */
}

/* 下部のCTAエリア */
.spring-cta-area {
    padding: 40px 20px;
    background-color: transparent;
}

/* 注意書きテキスト */
.spring-note-text {
    color: #dc2626; /* 赤字 */
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 24px;
    display: block;
    line-height: 1.5;
}

/* リッチなCTAボタン（春バージョン：オレンジ） */
.spring-cta-button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 640px; /* PCでの最大幅 */
    
    /* 凛学館カラーに近い、元気なオレンジグラデーション */
    background: linear-gradient(to bottom, #f97316 0%, #ea580c 100%);
    
    color: white;
    font-size: clamp(22px, 6vw, 36px);
    font-weight: 900;
    text-decoration: none;
    padding: 24px 20px;
    border-radius: 16px;
    
    /* 立体的な影と境界線 */
    border-top: 1px solid rgba(255,255,255,0.4);
    box-shadow: 0 6px 0 #9a3412, 0 15px 20px rgba(0,0,0,0.2); 
    
    transition: all 0.1s ease;
    position: relative;
    overflow: hidden;
    line-height: 1.2;
    letter-spacing: 0.05em;
    font-feature-settings: "palt";
}

/* ボタンのキラキラエフェクト（光が走るアニメーション） */
.spring-cta-button::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent);
    transform: skewX(-20deg);
    animation: shine 4s infinite;
}

@keyframes shine {
    0% { left: -100%; opacity: 0; }
    20% { left: 200%; opacity: 1; } /* 素早く通り過ぎる */
    100% { left: 200%; opacity: 0; }
}

/* クリック時の挙動（沈み込む） */
.spring-cta-button:active {
    transform: translateY(4px);
    box-shadow: 0 2px 0 #9a3412, 0 5px 10px rgba(0,0,0,0.2);
}

.spring-cta-button i {
    margin-left: 15px;
    font-size: 0.8em;
    color: #ffedd5;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-e8e1bca *//* --- パターンA：共感・課題解決型（春のそよ風Ver） --- */
.spring-ab-section-a {
    font-family: "Noto Sans JP", sans-serif;
    text-align: center;
    width: 100%;
    margin-bottom: 60px;
    color: #334155; /* slate-700 */
    position: relative;
}

/* 上部の帯エリア（春の風アーチ） */
.spring-problem-box-a {
    /* 背景：爽やかな春の空色グラデーション */
    background: linear-gradient(180deg, #e0f2fe 0%, #bae6fd 100%);
    padding: 70px 20px 100px; /* 下部余白を多めに */
    position: relative;
    /* 冬の三角形(▼)ではなく、春らしい「緩やかな曲線」で差別化 */
    border-radius: 0 0 50% 50% / 0 0 40px 40px;
    margin-bottom: -60px; /* 画像を重ねるためのネガティブマージン */
    z-index: 1;
}

/* 悩みアイコンの装飾 */
.spring-problem-icon-a {
    font-size: 40px;
    display: inline-block;
    margin-bottom: 10px;
    animation: float 3s ease-in-out infinite;
}
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

.spring-problem-head-a {
    font-size: clamp(20px, 5vw, 32px);
    font-weight: 900;
    line-height: 1.5;
    margin-bottom: 20px;
    color: #0c4a6e; /* sky-900 濃い青で引き締め */
}

/* 強調マーカー（白） */
.spring-problem-highlight-a {
    background: linear-gradient(transparent 60%, rgba(255,255,255,0.8) 60%);
    padding: 0 5px;
}

.spring-problem-text-a {
    font-size: clamp(14px, 3.5vw, 16px);
    line-height: 1.8;
    color: #334155; /* slate-700 */
    font-weight: 500;
}

/* 画像エリア（角丸・白枠で写真を際立たせる） */
.spring-image-wrapper-a {
    width: 90%;
    max-width: 600px;
    margin: 0 auto 50px;
    position: relative;
    z-index: 2;
    /* 写真風の白い枠をつける */
    background-color: white;
    padding: 12px;
    border-radius: 20px;
    box-shadow: 0 20px 40px -10px rgba(14, 165, 233, 0.2); /* 青みがかった影 */
    transform: rotate(-1deg); /* ほんの少し傾けて遊び心を出す */
    transition: transform 0.3s ease;
}

.spring-image-wrapper-a:hover {
    transform: rotate(0deg) scale(1.02);
}

.spring-image-wrapper-a img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    display: block;
}

/* 解決策エリア */
.spring-solution-area-a {
    padding: 0 20px 40px;
}

.spring-solution-text-a {
    font-size: clamp(15px, 4vw, 18px);
    font-weight: 700;
    line-height: 1.8;
    margin-bottom: 30px;
    color: #334155;
}

.spring-solution-highlight-a {
    color: #0284c7; /* sky-600 */
    font-size: 1.1em;
    border-bottom: 2px dashed #0284c7; /* 点線の下線 */
}

/* --- ベネフィット（結論）：暖色系・希望Ver --- */
.spring-benefit-box-a {
    display: inline-block;
    /* 暖かな日差しをイメージした薄いクリームイエローの背景 */
    background: linear-gradient(135deg, #fffcf0 0%, #fff7ed 100%);
    /* オレンジ系の境界線で温かみを出す */
    border: 3px solid #ffedd5; 
    border-radius: 20px;
    padding: 30px 40px;
    position: relative;
    /* 柔らかい太陽光のような影 */
    box-shadow: 0 15px 30px -5px rgba(251, 146, 60, 0.15);
    margin-top: 20px;
}

/* 「凛学館なら」バッジ：エネルギッシュなサンセットオレンジ */
.spring-benefit-badge-a {
    position: absolute;
    top: -15px;
    left: 50%;
    transform: translateX(-50%);
    /* 活力と希望を感じるグラデーション */
    background: linear-gradient(90deg, #f97316 0%, #fb923c 100%);
    color: white;
    font-size: 14px;
    font-weight: bold;
    padding: 6px 20px;
    border-radius: 50px;
    white-space: nowrap;
    box-shadow: 0 4px 10px rgba(249, 115, 22, 0.3);
}

.spring-benefit-head-a {
    /* 文字色は視認性の高い濃いオレンジ〜茶色系で信頼感を */
    color: #9a3412; 
    font-size: clamp(22px, 5.5vw, 34px);
    font-weight: 900;
    line-height: 1.5;
    margin: 0;
}

/* 「最高のスタートダッシュ」をさらに強調 */
.text-nowrap {
    display: inline-block;
    /* 下線に明るいイエローを引いて「光」を表現 */
    background: linear-gradient(transparent 70%, #fde047 70%);
}

/* 解決策エリアのテキストも少し暖色に寄せると統一感が出ます */
.spring-solution-highlight-a {
    color: #ea580c; /* 鮮やかなオレンジ */
    border-bottom: 2px dashed #fb923c;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-de45d9a *//* --- パターンB：未来・期待型（桜咲くスタートダッシュVer） --- */
.spring-ab-section-b {
    font-family: "Noto Sans JP", sans-serif;
    text-align: center;
    width: 100%;
    margin-bottom: 60px;
    color: #334155;
    /* 背景：春らしい薄いドット柄で軽やかさを演出 */
    background-image: radial-gradient(#fff1f2 2px, transparent 2px);
    background-size: 24px 24px;
    background-color: #fff;
    padding-top: 20px;
}

/* 上部エリア（吹き出し型） */
.spring-future-box-b {
    background-color: white;
    padding: 50px 30px 40px;
    position: relative;
    border: 3px solid #f9a8d4; /* ピンクの枠線 */
    border-radius: 30px;
    margin: 20px auto 40px;
    max-width: 800px;
    /* ポップな立体的な影（ずらし影） */
    box-shadow: 8px 8px 0 #fbcfe8; 
    width: 90%;
    z-index: 2;
}

/* 吹き出しのしっぽ（下向き） */
.spring-future-box-b::after {
    content: '';
    position: absolute;
    bottom: -24px;
    left: 50%;
    transform: translateX(-50%);
    border-width: 24px 24px 0;
    border-style: solid;
    border-color: #f9a8d4 transparent transparent transparent; /* 枠線と同じ色 */
}
/* 吹き出しの中抜き用（枠線だけに見せるため） */
.spring-future-box-b::before {
    content: '';
    position: absolute;
    bottom: -19px; /* 位置微調整 */
    left: 50%;
    transform: translateX(-50%);
    border-width: 20px 20px 0;
    border-style: solid;
    border-color: white transparent transparent transparent;
    z-index: 1;
}

.spring-future-head-b {
    font-size: clamp(20px, 5vw, 30px);
    font-weight: 900;
    line-height: 1.6;
    color: #be185d; /* pink-700 */
    margin-bottom: 20px;
}

/* マーカー風装飾 */
.spring-future-highlight-b {
    background: linear-gradient(transparent 65%, #fde047 65%); /* 黄色のマーカー */
    display: inline;
}

.spring-future-text-b {
    font-size: clamp(14px, 3.5vw, 16px);
    line-height: 1.8;
    color: #475569;
    font-weight: 500;
}

/* 画像エリア（円形・集中線） */
.spring-image-wrapper-b {
    width: 280px;
    height: 280px;
    margin: 0 auto 30px;
    position: relative;
    z-index: 1;
}

/* 画像の周りの装飾リング */
.spring-image-border-b {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    border: 8px solid white;
    /* ふんわりしたピンクの光彩 */
    box-shadow: 0 0 30px rgba(244, 63, 94, 0.2); 
    position: relative;
    background-color: #fff1f2;
}

.spring-image-border-b img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.spring-image-wrapper-b:hover img {
    transform: scale(1.1);
}

/* 装飾：キラキラアイコン */
.spring-sparkle-b {
    position: absolute;
    font-size: 32px;
    color: #fbbf24; /* yellow-400 */
    animation: sparkle 2s infinite ease-in-out;
    z-index: 3;
}
.spring-sparkle-b.top-right { top: -10px; right: 10px; animation-delay: 0.5s; transform: rotate(15deg); }
.spring-sparkle-b.bottom-left { bottom: 10px; left: -10px; animation-delay: 1s; transform: rotate(-15deg); }

@keyframes sparkle {
    0%, 100% { transform: scale(1) rotate(0deg); opacity: 1; }
    50% { transform: scale(1.2) rotate(10deg); opacity: 0.8; }
}

/* 宣言エリア */
.spring-promise-area-b {
    padding: 0 20px 40px;
}

.spring-promise-badge-b {
    display: inline-block;
    background-color: #fb7185; /* rose-400 */
    color: white;
    font-size: 14px;
    font-weight: bold;
    padding: 6px 16px;
    border-radius: 20px;
    margin-bottom: 15px;
    box-shadow: 0 4px 6px rgba(251, 113, 133, 0.3);
}

.spring-promise-desc-b {
    font-size: 16px;
    color: #334155;
    margin-bottom: 24px;
    font-weight: 700;
    line-height: 1.8;
}

.spring-action-text-b {
    font-size: clamp(24px, 6.5vw, 34px); /* 少しサイズアップ */
    font-weight: 900;
    color: #be185d; /* 濃いピンクで視認性を確保 */
    line-height: 1.4;
    /* 白い縁取りを太く全方向につけ、さらに外側にピンクの影を落として浮かせる */
    text-shadow: 
        2px 2px 0 #fff, -2px -2px 0 #fff, 
        -2px 2px 0 #fff, 2px -2px 0 #fff,
        2px 0 0 #fff, -2px 0 0 #fff, 
        0 2px 0 #fff, 0 -2px 0 #fff,
        4px 4px 0 rgba(249, 168, 212, 0.8); /* 影 */
    margin-top: 10px;
    letter-spacing: 0.05em;
    position: relative;
    z-index: 1;
}


/* スマホ調整 */
@media (max-width: 768px) {
    .spring-future-box-b {
        width: 95%;
        padding: 40px 20px;
    }
    .spring-image-wrapper-b {
        width: 220px;
        height: 220px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-bcd1ed5 *//* --- 春の「選ばれる理由」セクションスタイル（モバイルファースト最適化版） --- */
.spring-reason-section {
    font-family: "Noto Sans JP", sans-serif;
    color: #334155; /* slate-700 */
    max-width: 1000px;
    margin: 0 auto 60px;
    padding: 0 15px; /* スマホ用に左右余白を少し狭める */
}

/* セクションタイトル */
.spring-reason-title-box {
    text-align: center;
    margin-bottom: 40px;
}

.spring-reason-main-title {
    font-size: clamp(24px, 6vw, 36px);
    font-weight: 900;
    color: #1e293b;
    margin-bottom: 15px;
    position: relative;
    display: inline-block;
    line-height: 1.4;
}
.spring-reason-main-title::before,
.spring-reason-main-title::after {
    content: '🌸';
    font-size: 0.6em;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.spring-reason-main-title::before { left: -1em; }
.spring-reason-main-title::after { right: -1em; }

.spring-reason-intro {
    font-size: 15px;
    line-height: 1.8;
    display: block; /* スマホではブロック表示で幅を確保 */
    text-align: left; /* スマホでは左揃えの方が読みやすい場合も多いが、短いのでセンター維持か左か。ここではセンター維持 */
    text-align: center;
    margin-top: 10px;
}

/* ---------------------------------------------------
   【総論】リードカード（アウトプット型授業）
--------------------------------------------------- */
.spring-reason-lead-card {
    background-color: #fff0f5; /* 薄い桜色背景 */
    border-radius: 20px;
    box-shadow: 0 8px 25px rgba(255, 182, 193, 0.25);
    margin-bottom: 50px;
    overflow: hidden;
    border: 3px solid #fecdd3; /* ピンクの枠線 */
    position: relative;
}

/* 「CORE METHOD」ラベル */
.spring-lead-badge {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #ec4899; /* pink-500 */
    color: white;
    font-size: 11px;
    font-weight: 900;
    padding: 6px 15px 6px 12px;
    border-radius: 0 0 15px 0;
    letter-spacing: 0.05em;
    z-index: 2;
    box-shadow: 2px 2px 5px rgba(0,0,0,0.1);
}

.spring-lead-head {
    padding: 35px 20px 15px;
    text-align: center;
}

.spring-lead-title {
    font-size: 22px; /* スマホ基準サイズ */
    font-weight: 900;
    color: #be185d; /* pink-700 */
    line-height: 1.4;
    display: flex;
    flex-direction: column; /* スマホではアイコンを上に */
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.spring-lead-title i {
    font-size: 1.5em;
    color: #db2777;
    margin-bottom: 5px;
}

.spring-lead-body {
    padding: 0 20px 30px;
    display: flex;
    flex-direction: column-reverse; /* スマホ: 画像(下にある要素)を上に表示 */
    gap: 20px;
    align-items: center;
}

/* ---------------------------------------------------
   【各論】通常カード（科目別）
--------------------------------------------------- */
.spring-reason-card {
    background-color: white;
    border-radius: 16px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    margin-bottom: 30px;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    position: relative;
}

/* 科目ラベル */
.spring-card-label {
    position: absolute;
    top: 15px;
    left: 15px;
    font-size: 13px;
    font-weight: 900;
    padding: 4px 10px;
    border-radius: 6px;
    z-index: 2;
}
.label-blue { background-color: #e0f2fe; color: #0284c7; }
.label-red  { background-color: #ffe4e6; color: #e11d48; }
.label-green{ background-color: #dcfce7; color: #16a34a; }

/* 見出しエリア（カード内） */
.spring-reason-head-inner {
    padding: 50px 20px 15px; /* 上余白はラベル分確保 */
    font-weight: 700;
    font-size: 20px; /* スマホ基準 */
    color: #1e293b;
    border-bottom: 1px dashed #e2e8f0;
    margin-bottom: 20px;
    line-height: 1.5;
}
.spring-reason-head-inner span {
    background: linear-gradient(transparent 70%, #fef08a 70%); /* 黄色マーカー */
}

/* カード内コンテンツエリア */
.spring-card-content {
    padding: 0 20px 30px;
    display: flex;
    flex-direction: column-reverse; /* スマホ: 画像を上に */
    gap: 20px;
}

/* 共通カラム設定 */
.spring-reason-text-col {
    width: 100%;
}
.spring-reason-img-col {
    width: 100%;
}

.spring-reason-desc {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 15px;
    text-align: left;
}

.spring-reason-img-wrapper {
    background-color: white;
    padding: 6px;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}
.spring-reason-img-wrapper img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    display: block;
}

/* ---------------------------------------------------
   PC・タブレット向けスタイル（768px以上で適用）
   ここで横並びレイアウトに切り替える
--------------------------------------------------- */
@media (min-width: 768px) {
    .spring-reason-section {
        padding: 0 20px;
    }
    
    .spring-reason-main-title {
        font-size: 36px;
    }
    .spring-reason-intro {
        font-size: 16px;
    }

    /* リードカード PCレイアウト */
    .spring-lead-title {
        flex-direction: row;
        font-size: 28px;
    }
    .spring-lead-title i {
        margin-bottom: 0;
        margin-right: 10px;
    }
    .spring-lead-body {
        flex-direction: row; /* 横並びに戻す */
        padding: 0 30px 40px;
        gap: 40px;
    }
    .spring-lead-head {
        padding: 40px 30px 20px;
    }

    /* 通常カード PCレイアウト */
    .spring-reason-head-inner {
        font-size: 24px;
        padding: 60px 30px 10px;
    }
    .spring-card-content {
        flex-direction: row; /* 横並びに戻す */
        padding: 0 30px 30px;
        gap: 30px;
    }
    
    /* カラム幅設定 */
    .spring-reason-text-col, 
    .spring-reason-img-col {
        flex: 1;
        width: auto; /* width:100%を解除 */
    }
    
    .spring-reason-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 10px 25px rgba(0,0,0,0.08);
        transition: transform 0.3s;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ecb5504 *//* --- 基本設定 --- */
.spring-junior-section {
    font-family: "Noto Sans JP", sans-serif;
    color: #334155;
    background-color: #f0fdf4;
    padding: 60px 20px;
    text-align: center;
}

/* タイトルエリア（元のゆったりした設定に復元） */
.spring-junior-title-box { margin-bottom: 30px; }
.spring-junior-badge {
    background-color: #22c55e;
    color: white;
    font-weight: bold;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 14px;
    display: inline-block;
    margin-bottom: 15px; 
}
.spring-junior-title {
    font-size: clamp(24px, 6vw, 36px);
    font-weight: 900;
    color: #14532d;
    margin-bottom: 20px;
    line-height: 1.4;
}
.spring-junior-title i { color: #4ade80; margin-right: 10px; }

.spring-junior-desc {
    font-size: 16px;
    line-height: 1.8;
    max-width: 800px;
    margin: 0 auto;
}

/* --- アコーディオンボタン --- */
.spring-accordion-trigger {
    background: linear-gradient(to bottom, #ffffff 0%, #f0fdf4 100%);
    border: 3px solid #4ade80;
    border-radius: 16px;
    padding: 20px;
    width: 100%;
    max-width: 700px;
    margin: 30px auto 0;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 0 #22c55e;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    outline: none;
}
.spring-accordion-trigger:hover { transform: translateY(-2px); box-shadow: 0 6px 0 #22c55e; }
.spring-accordion-trigger.is-open {
    border-radius: 16px 16px 0 0;
    box-shadow: none;
    background: #4ade80;
    color: white;
}
.spring-accordion-trigger.is-open .spring-trigger-text,
.spring-accordion-trigger.is-open .spring-trigger-icon { color: white; }
.spring-accordion-trigger.is-open .spring-trigger-icon { transform: rotate(180deg); }

.spring-trigger-text { font-size: 18px; font-weight: 700; color: #166534; }
.spring-trigger-icon { font-size: 20px; color: #22c55e; transition: transform 0.3s ease; }

/* --- コンテンツエリア --- */
.spring-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease-out;
    background-color: white;
    max-width: 900px; /* 2カラムに合わせて最大幅を調整 */
    margin: 0 auto;
    border-radius: 0 0 16px 16px;
}
.spring-accordion-content.is-open {
    max-height: 3000px;
    padding: 40px 20px;
    border: 3px solid #4ade80;
    border-top: none;
}

/* --- グリッドレイアウト（PC 2カラム固定 / SP 1カラム） --- */
.spring-card-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* PC: 2カラム固定 */
    gap: 20px;
    text-align: left;
    align-items: stretch;
}

.spring-mini-card {
    background-color: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.spring-card-img-wrapper {
    width: 100%;
    height: 240px; /* 2カラム用に高さをさらに調整 */
    overflow: hidden;
    background-color: #eee;
}

.spring-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.spring-card-body {
    padding: 15px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* タイトルと本文の隙間を解消 */
.spring-card-title {
    font-size: 18px; /* 2カラムなので少し大きく */
    font-weight: 700;
    margin-bottom: 2px;
    color: #1e293b;
    min-height: 2.8em; /* 2カラムだと1〜2行で収まるため調整 */
    display: flex;
    align-items: flex-start;
    line-height: 1.4;
}
.spring-card-title i { margin-right: 6px; margin-top: 3px; color: #22c55e; }

.spring-card-text {
    font-size: 14px; /* 2カラムなので読みやすさを考慮して少し大きく */
    line-height: 1.6;
    color: #475569;
    margin: 0;
}

/* スマホ用の調整 */
@media (max-width: 640px) {
    .spring-card-grid {
        grid-template-columns: 1fr; /* SP: 1カラム */
    }
    .spring-accordion-trigger { flex-direction: column; gap: 5px; }
    .spring-card-img-wrapper { height: 260px; }
    .spring-card-title { min-height: auto; margin-bottom: 4px; }
    .spring-card-text { font-size: 14px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-784a0ad *//* セクション全体 */
    .spring-search-section {
        font-family: "Noto Sans JP", sans-serif;
        color: #334155;
        padding: 40px 10px;
        background-color: transparent;
        max-width: 900px;
        margin: 0 auto;
    }

    .spring-search-title {
        text-align: center;
        font-size: clamp(20px, 5vw, 26px);
        font-weight: 900;
        color: #1e293b;
        margin-bottom: 25px;
    }
    .spring-search-title span { position: relative; z-index: 1; }
    .spring-search-title span::after {
        content: '';
        position: absolute;
        bottom: 4px; left: 0;
        width: 100%; height: 8px;
        background-color: #fecdd3;
        z-index: -1;
        opacity: 0.6;
    }

    /* 検索ボックス */
    .spring-search-box {
        background-color: #fff;
        border: 1px solid #e2e8f0;
        border-radius: 16px;
        padding: 24px;
        margin-bottom: 35px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.03);
    }
    .spring-search-label {
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 700;
        margin-bottom: 15px;
        color: #475569;
    }
    .spring-search-label i { color: #ec4899; margin-right: 8px; }

    .spring-form-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
    .spring-form-group label {
        display: block;
        font-size: 11px;
        font-weight: 700;
        color: #94a3b8;
        margin-bottom: 4px;
        padding-left: 4px;
    }
    .spring-select {
        width: 100%;
        padding: 10px;
        border: 1px solid #cbd5e1;
        border-radius: 8px;
        font-size: 15px;
        appearance: none;
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
        background-position: right 0.5rem center;
        background-repeat: no-repeat;
        background-size: 1.5em 1.5em;
        background-color: #fff;
    }
    .spring-select:disabled { background-color: #f8fafc; color: #cbd5e1; cursor: not-allowed; }

    /* 結果カード */
    .spring-course-card {
        background: white;
        border-radius: 16px;
        overflow: hidden;
        box-shadow: 0 10px 25px -10px rgba(0,0,0,0.1);
        border: 1px solid #e2e8f0;
        margin-bottom: 30px;
    }
    .card-header {
        background: linear-gradient(135deg, #3b82f6, #1d4ed8);
        color: white;
        padding: 14px 20px;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .card-header-title { font-weight: 900; font-size: 17px; }
    .card-badge { background: #f472b6; font-size: 11px; font-weight: 700; padding: 2px 10px; border-radius: 20px; }

    .card-body { padding: 20px; }

    .card-price-box {
        background-color: #fff9db;
        border: 1px solid #ffec99;
        padding: 10px 14px;
        border-radius: 8px;
        margin-bottom: 18px;
        text-align: right;
    }
    .price-label { font-size: 11px; color: #868e96; }
    .price-value { font-size: 20px; font-weight: 900; color: #212529; }

    /* YouTubeアスペクト比固定 (16:9) */
    .card-media { margin-bottom: 18px; border-radius: 10px; overflow: hidden; }
    .video-teaser { 
        position: relative; 
        width: 100%; 
        aspect-ratio: 16 / 9;
        padding-top: 56.25%; /* fallback */
        background: #000; 
        cursor: pointer; 
    }
    .video-teaser > * {
        position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none;
    }
    .video-teaser img { object-fit: cover; opacity: 0.8; }
    .video-teaser .play { display: flex; align-items: center; justify-content: center; pointer-events: none; }

    /* 切り替えタブ（表のすぐ上） */
    .variation-tabs { display: flex; gap: 4px; margin-bottom: 0; flex-wrap: wrap; }
    .tab-btn {
        padding: 6px 14px;
        border: 1px solid #e2e8f0;
        background: #f1f5f9;
        border-radius: 8px 8px 0 0;
        cursor: pointer;
        font-size: 12px;
        font-weight: 700;
        color: #64748b;
        transition: all 0.2s;
        border-bottom: none;
    }
    .tab-btn.active { background: #ec4899; color: white; border-color: #ec4899; }

    .card-table-wrap { 
        background-color: #f8fafc; 
        border-radius: 0 10px 10px 10px; 
        padding: 10px; 
        margin-bottom: 18px; 
        overflow-x: auto;
        border: 1px solid #e2e8f0;
    }
    .schedule-table { width: 100%; border-collapse: separate; border-spacing: 0; min-width: 310px; background: #fff; border-radius: 6px; overflow: hidden; }
    .schedule-table th { background: #f1f5f9; text-align: left; font-size: 11px; color: #475569; padding: 8px 10px; border-bottom: 1px solid #e2e8f0; }
    .schedule-table td { padding: 8px 10px; font-size: 13px; border-bottom: 1px solid #f1f5f9; border-right: 1px solid #f1f5f9; color: #334155; vertical-align: middle; }
    .schedule-table td:last-child { border-right: none; }
    .schedule-table tr:last-child td { border-bottom: none; }

    .card-curriculum { background-color: #fff; border: 1px solid #e2e8f0; border-radius: 8px; padding: 14px; }
    .curriculum-title { font-weight: 700; color: #3b82f6; font-size: 14px; margin-bottom: 8px; display: flex; align-items: center; }
    .curriculum-item { margin-bottom: 8px; font-size: 13px; line-height: 1.5; border-left: 2px solid #e2e8f0; padding-left: 10px; }
    .curriculum-label { font-weight: 900; color: #1e293b; display: block; margin-bottom: 2px; }

    .spring-hint-text { text-align: center; color: #94a3b8; padding: 40px 0; font-size: 14px; }

    @media (max-width: 600px) {
        .spring-form-grid { grid-template-columns: 1fr; }
    }
    /* 追加した注釈エリアのスタイル調整 */
    .variation-note {
        line-height: 1.6;
        margin-top: -1px; /* タブとの隙間を埋める */
    }
    .variation-note p {
        margin: 0 !important;
    }
    .variation-note i {
        color: #3b82f6; /* アイコンの色を青系に */
    }
    
    /* タブが複数行になった時の調整 */
    @media (max-width: 600px) {
        .tab-btn {
            flex: 1 1 calc(50% - 4px); /* スマホでタブを横並び2つにする */
            border-radius: 8px;
            margin-bottom: 4px;
            border-bottom: 1px solid #e2e8f0;
        }
    }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a402809 *//* セクション全体 */
.spring-flow-section {
    font-family: "Noto Sans JP", sans-serif;
    color: #334155;
    background-color: #fffaf0; /* ごく薄いオレンジがかった白（温かみ） */
    padding: 60px 20px;
    text-align: center;
}

/* タイトル */
.spring-flow-title {
    font-size: clamp(24px, 5vw, 32px);
    font-weight: 900;
    color: #1e293b;
    margin-bottom: 10px;
    display: inline-block;
    position: relative;
}
.spring-flow-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background-color: #f97316; /* オレンジ */
    margin: 10px auto 0;
    border-radius: 2px;
}

.spring-flow-note {
    font-size: 13px;
    color: #64748b;
    margin-bottom: 50px;
}

/* ステップ共通スタイル */
.spring-step-box {
    background-color: white;
    max-width: 800px;
    margin: 0 auto;
    border-radius: 20px;
    padding: 40px 30px;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.05);
    border: 3px solid transparent; /* ボーダーのベース */
    position: relative;
    transition: transform 0.3s;
}
.spring-step-box:hover {
    transform: translateY(-3px);
}

/* ステップ番号バッジ */
.spring-step-badge {
    display: inline-block;
    padding: 5px 15px;
    border-radius: 20px;
    color: white;
    font-weight: 900;
    font-size: 14px;
    margin-bottom: 20px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

/* アイコン */
.spring-step-icon {
    font-size: 48px;
    margin: 0 auto 20px; /* 左右autoで中央揃え */
    display: block;
    width: fit-content; /* 幅をコンテンツに合わせる */
}

/* 見出し */
.spring-step-head {
    font-size: 22px;
    font-weight: 900;
    margin-bottom: 20px;
    color: #1e293b;
}

/* 本文 */
.spring-step-desc {
    font-size: 15px;
    line-height: 1.8;
    margin-bottom: 20px;
    text-align: left;
}

/* 矢印（逆三角形） */
.spring-flow-arrow {
    font-size: 30px;
    margin: 20px 0;
    animation: bounceArrow 2s infinite;
}
@keyframes bounceArrow {
    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
    40% {transform: translateY(-10px);}
    60% {transform: translateY(-5px);}
}

/* --- STEP 1: 説明会（桜色） --- */
.step-1 { border-color: #fbcfe8; } /* ピンク枠 */
.step-1 .spring-step-badge { background-color: #ec4899; }
.step-1 .spring-step-icon { color: #ec4899; }
.step-1-arrow { color: #f472b6; }

/* 日程リスト */
.spring-schedule-list {
    background-color: #fff1f2;
    border-radius: 12px;
    padding: 20px;
    text-align: left;
    font-size: 14px;
    margin-top: 20px;
}
.schedule-group-title {
    font-weight: 900;
    color: #be185d;
    margin-bottom: 8px;
    display: block;
}
.schedule-items {
    list-style: none;
    padding: 0;
    margin: 0 0 15px;
    color: #475569;
}
.schedule-items li { margin-bottom: 4px; padding-left: 1em; text-indent: -1em; }
.schedule-items li::before { content: "● "; color: #ec4899; font-size: 0.8em; }

/* --- STEP 2: テスト（若草色・青空色） --- */
.step-2 { border-color: #bae6fd; } /* 水色枠 */
.step-2 .spring-step-badge { background-color: #0ea5e9; }
.step-2 .spring-step-icon { color: #0ea5e9; }
.step-2-arrow { color: #38bdf8; }

/* 予約ボタン */
.spring-test-btn {
    display: inline-block;
    background-color: #0f172a; /* 凛学館ネイビー */
    color: white;
    font-weight: 700;
    padding: 15px 40px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s;
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.3);
    margin-top: 15px;
    width: 100%;
    max-width: 350px;
}
.spring-test-btn:hover {
    background-color: #334155;
    transform: scale(1.05);
}

/* --- STEP 3: スタート（オレンジ・太陽） --- */
.step-3 { border-color: #fdba74; background-color: #fff7ed; } /* オレンジ枠 */
.step-3 .spring-step-badge { background-color: #f97316; }
.step-3 .spring-step-icon { color: #f97316; }

/* 最後のCTAエリア */
.spring-flow-cta-wrap {
    margin-top: 60px;
}
.spring-micro-copy {
    font-size: 14px;
    font-weight: 700;
    color: #475569;
    margin-bottom: 15px;
    display: block;
}

/* リッチなCTAボタン（グリーン） */
.spring-main-cta-btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 600px;
    /* 若草色〜濃い緑のグラデーション */
    background: linear-gradient(to bottom, #84cc16 0%, #65a30d 100%);
    color: white;
    font-size: clamp(24px, 5vw, 32px);
    font-weight: 900;
    text-decoration: none;
    padding: 20px;
    border-radius: 12px;
    border: 1px solid #a3e635;
    border-bottom: 6px solid #3f6212; /* 立体的な影 */
    box-shadow: 0 10px 20px rgba(101, 163, 13, 0.3);
    transition: all 0.1s;
    position: relative;
    overflow: hidden;
    line-height: 1.2;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}
.spring-main-cta-btn:active {
    transform: translateY(4px);
    border-bottom-width: 2px;
    box-shadow: none;
}
.spring-main-cta-btn::after {
    content: '▶';
    margin-left: 15px;
    font-size: 0.8em;
    color: #ecfccb;
}
/* 光るエフェクト */
.spring-main-cta-btn::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 50%; height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,0.4), transparent);
    transform: skewX(-20deg);
    animation: flowShine 3s infinite;
}
@keyframes flowShine {
    0% { left: -100%; }
    20% { left: 200%; }
    100% { left: 200%; }
}

/* スマホ調整 */
@media (max-width: 768px) {
    .spring-step-box { padding: 30px 20px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-de9422e */<!-- 必要なライブラリの読み込み -->
<script src="https://cdn.tailwindcss.com"></script>
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&display=swap" rel="stylesheet">
<script src="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/js/all.min.js"></script>

<style>
/* 共通スタイル */
.spring-final-section {
    font-family: "Noto Sans JP", sans-serif;
    color: #334155;
    background-color: white;
    padding-bottom: 60px;
}

/* --- 特典オファーエリア --- */
.spring-offer-area {
    text-align: center;
    padding: 60px 20px;
    background-color: #fffaf0; /* 薄いオレンジ背景 */
}

.spring-offer-lead {
    font-size: clamp(18px, 5vw, 24px);
    font-weight: 700;
    color: #1e293b;
    margin-bottom: 20px;
    line-height: 1.6;
}

.spring-offer-icon-wrapper {
    width: 80px;
    height: 80px;
    background-color: white;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    margin-bottom: 20px;
    border: 3px solid #3b82f6; /* 青枠 */
}
.spring-offer-icon {
    font-size: 40px;
    color: #3b82f6;
}

.spring-offer-price {
    font-size: clamp(24px, 6vw, 36px);
    font-weight: 900;
    color: #e11d48; /* rose-600 */
    background: white;
    display: inline-block;
    padding: 10px 30px;
    border-radius: 50px;
    box-shadow: 0 4px 15px rgba(225, 29, 72, 0.15);
    border: 2px solid #ffe4e6;
}
.spring-offer-price span {
    font-size: 1.2em;
    color: #e11d48;
}

/* --- FAQエリア --- */
.spring-faq-area {
    max-width: 800px;
    margin: 60px auto;
    padding: 0 20px;
}

.spring-section-title {
    text-align: center;
    font-size: clamp(22px, 5vw, 28px);
    font-weight: 900;
    color: #1e293b;
    margin-bottom: 30px;
    position: relative;
    display: inline-block;
    width: 100%;
}

.spring-faq-item {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    margin-bottom: 15px;
    background-color: white;
    overflow: hidden;
    transition: all 0.3s;
}
.spring-faq-item:hover {
    border-color: #cbd5e1;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.spring-faq-question {
    padding: 18px 20px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: #f8fafc;
    color: #334155;
}
.spring-faq-q-mark {
    color: #3b82f6;
    font-weight: 900;
    margin-right: 10px;
}
.spring-faq-icon {
    transition: transform 0.3s;
    color: #94a3b8;
}

/* 開いている状態 */
.spring-faq-item.is-open .spring-faq-question {
    background-color: #eff6ff; /* 薄い青 */
    color: #1e293b;
}
.spring-faq-item.is-open .spring-faq-icon {
    transform: rotate(180deg);
    color: #3b82f6;
}

.spring-faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    padding: 0 20px;
    font-size: 15px;
    line-height: 1.8;
    color: #475569;
    border-top: 1px solid transparent;
}
.spring-faq-item.is-open .spring-faq-answer {
    border-top-color: #e2e8f0;
    padding: 20px;
    max-height: 500px; /* 十分な高さ */
}

/* --- ラストCTAエリア --- */
.spring-last-cta {
    text-align: center;
    padding: 60px 20px;
    /* 背景：春らしいドット柄 */
    background-image: radial-gradient(#d1fae5 2px, transparent 2px);
    background-size: 30px 30px;
    background-color: #fff;
    position: relative;
}

.spring-cta-head {
    font-size: clamp(24px, 6vw, 36px);
    font-weight: 900;
    color: #1e293b;
    margin-bottom: 20px;
}

.spring-cta-desc {
    font-size: 15px;
    color: #475569;
    margin-bottom: 40px;
    font-weight: 500;
}

.spring-cta-image-wrapper {
    width: 280px;
    height: 280px;
    margin: 0 auto 30px;
    border-radius: 50%;
    overflow: hidden;
    border: 8px solid white;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    position: relative;
}
.spring-cta-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.spring-cta-microcopy {
    font-size: 14px;
    font-weight: 700;
    color: #15803d; /* green-700 */
    margin-bottom: 15px;
    display: block;
}

/* 緑色のビッグボタン */
.spring-green-btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 600px;
    /* 明るいグリーン〜濃いグリーンのグラデーション */
    background: linear-gradient(to bottom, #4ade80 0%, #22c55e 100%);
    color: white;
    font-size: clamp(24px, 5vw, 36px);
    font-weight: 900;
    text-decoration: none;
    padding: 24px 20px;
    border-radius: 16px;
    border-top: 1px solid rgba(255,255,255,0.4);
    border-bottom: 6px solid #15803d; /* 立体的な影 */
    box-shadow: 0 10px 25px rgba(34, 197, 94, 0.4);
    transition: all 0.1s;
    position: relative;
    overflow: hidden;
    line-height: 1.2;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}
.spring-green-btn:active {
    transform: translateY(4px);
    border-bottom-width: 2px;
    box-shadow: none;
}
.spring-green-btn::after {
    content: '▶';
    margin-left: 15px;
    font-size: 0.8em;
    color: #dcfce7;
}
/* 光るエフェクト */
.spring-green-btn::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 50%; height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent);
    transform: skewX(-20deg);
    animation: shineGreen 3s infinite;
}
@keyframes shineGreen {
    0% { left: -100%; }
    20% { left: 200%; }
    100% { left: 200%; }
}

/* スマホ調整 */
@media (max-width: 768px) {
    .spring-cta-image-wrapper {
        width: 220px;
        height: 220px;
    }
}/* End custom CSS */