/* ===== 夢キャリカレッジ セクション ===== */
.l-college {
    background: #d85b2d;
    position: relative;
    padding: 80px 0 100px;
    /* overflow: clip にすることで子孫のparallaxはみ出しは抑えつつ、
       sticky 子孫（アンカーナビ）のスクロール基準を阻害しない */
    overflow: hidden;
    overflow: clip;
}
.l-college .is-chalk { font-family: "Yusei Magic", "Noto Sans JP", cursive; font-weight: normal; }
/* パララックス装飾パターン（JSでスクロール連動） */
.l-college .l-college__bg {
    position: absolute;
    top: -50%;
    left: 0;
    right: 0;
    height: 200%;
    background-image: url('../images/yume-career/schoolicons/bg.png');
    background-repeat: repeat;
    background-position: center top;
    background-size: contain;
    opacity: 0.16;
    filter: brightness(1.6);
    pointer-events: none;
    z-index: 0;
    will-change: transform;
    transform: translate3d(0, 0, 0);
}
.l-college .l-container,
.l-college .c-college__hero-outer { position: relative; z-index: 1; }
@media (max-width: 768px) {
    .l-college .l-college__bg {
        opacity: 0.12;
    }
}

/* ---- 共通パーツ ---- */
.c-college__pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #d85b2d;
    color: #fff;
    padding: 8px 22px;
    border-radius: 100px;
    font-size: 15px;
    font-weight: bold;
    box-shadow: 0 4px 0 rgba(120,35,15,0.25);
    position: relative;
}
.c-college__pill.is-yellow { background: #ffd149; color: #b53c16; }
.c-college__pill.is-white { background: #fff; color: #d85b2d; border: 2px solid #d85b2d; box-shadow: 0 4px 0 rgba(216,91,45,0.25); }

.c-college__squiggle {
    display: block;
    margin: 12px auto 0;
    width: 120px;
    height: 12px;
}
.c-college__squiggle path { stroke: #ffd149; stroke-width: 3; fill: none; stroke-linecap: round; }
.c-college__squiggle.is-red path { stroke: #d85b2d; }
.c-college__squiggle.is-white path { stroke: #fff; }

.c-college__section-title {
    text-align: center;
    margin-bottom: 40px;
}
.c-college__section-title-pill {
    display: inline-block;
    background: #fff;
    color: #d85b2d;
    padding: 8px 28px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 18px;
    position: relative;
    box-shadow: 0 4px 0 rgba(120,35,15,0.2);
    letter-spacing: 0.06em;
}
.c-college__section-title-pill::after {
    content: "";
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
    border: 8px solid transparent;
    border-top-color: #fff;
    border-bottom: 0;
}
.c-college__section-title-pill.is-red { background: #d85b2d; color: #fff; box-shadow: 0 4px 0 rgba(120,35,15,0.3); }
.c-college__section-title-pill.is-red::after { border-top-color: #d85b2d; }
.c-college__section-title-main {
    font-size: 34px;
    font-weight: bold;
    color: #fff;
    line-height: 1.4;
    margin: 0;
}
.c-college__section-title-main.is-dark { color: #202e42; }
.c-college__section-title-main .is-mark {
    color: #ffd149;
    position: relative;
    display: inline-block;
}
.c-college__section-title-main.is-dark .is-mark { color: #d85b2d; }
@media (max-width: 768px) {
    .c-college__section-title-main { font-size: 24px; }
}

/* ---- ブロック① ヒーロー（クリームパネル） ---- */
.c-college__hero-outer {
    padding: 0 30px;
    margin: 0 0 90px;
}
.c-college__hero {
    text-align: center;
    color: #202e42;
    padding: 72px 60px 88px;
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    background:
        repeating-linear-gradient(to bottom, transparent 0, transparent 35px, rgba(140, 90, 50, 0.07) 35px, rgba(140, 90, 50, 0.07) 36px),
        #fef5e5;
    border-radius: 0;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}

/* 黄色い丸ステッカー（無料） */
.c-college__hero-sticker {
    position: absolute;
    top: -24px;
    left: 40px;
    width: 112px;
    height: 112px;
    background: #ffd149;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    color: #b53c16;
    font-weight: bold;
    transform: rotate(-9deg);
    box-shadow: 0 6px 0 rgba(178,119,0,0.3), 0 10px 20px rgba(0,0,0,0.15);
    z-index: 4;
}
.c-college__hero-sticker-main { font-size: 26px; line-height: 1; }
.c-college__hero-sticker-sub { font-size: 11px; margin-top: 4px; letter-spacing: 0.1em; font-family: "Roboto", "Noto Sans JP", sans-serif; }

/* サブタグ（オレンジピル） */
.c-college__hero-subtag {
    display: inline-block;
    background: #d85b2d;
    color: #fff;
    padding: 8px 26px;
    border-radius: 100px;
    font-size: 15px;
    font-weight: bold;
    margin-bottom: 28px;
    letter-spacing: 0.08em;
    box-shadow: 0 4px 0 rgba(120,35,15,0.25);
}

/* メインタイトル（濃紺） */
.c-college__hero-title {
    font-size: 58px;
    font-weight: bold;
    color: #202e42;
    line-height: 1.15;
    margin: 0 0 14px;
    letter-spacing: 0.04em;
}
.c-college__hero-title-highlight {
    position: relative;
    display: inline-block;
    background: linear-gradient(180deg, transparent 82%, #ffd149 82%);
    padding: 0 8px;
    letter-spacing: -0.04em;
}
.c-college__hero-subtitle {
    font-size: 20px;
    color: #555;
    margin: 20px 0 48px;
    font-weight: 500;
}

/* 悩みの4つ（2列2行） */
.c-college__hero-quotes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px 20px;
    max-width: 860px;
    margin: 0 auto 48px;
}
.c-college__hero-quote {
    background: #fff;
    color: #333;
    padding: 16px 24px 16px 52px;
    font-size: 16px;
    font-weight: 500;
    border-radius: 100px;
    position: relative;
    text-align: left;
    box-shadow: 0 4px 12px rgba(120,35,15,0.08);
    display: flex;
    align-items: center;
    min-height: 56px;
}
.c-college__hero-quote::before {
    content: "";
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23d85b2d'><path d='M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 9h12v2H6V9zm8 5H6v-2h8v2zm4-6H6V6h12v2z'/></svg>") no-repeat center/contain;
}

/* 本文 */
.c-college__hero-body {
    max-width: 760px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 2;
    color: #333;
    position: relative;
    padding-right: 280px;
    text-align: left;
    line-break: strict;
    word-break: keep-all;
    overflow-wrap: anywhere;
}
.c-college__hero-body strong {
    background: linear-gradient(180deg, transparent 82%, #ffd149 82%);
    color: #d85b2d;
    padding: 0 4px;
    font-weight: bold;
}
.c-college__hero-mascot {
    position: absolute;
    right: -20px;
    bottom: -20px;
    width: 280px;
}
.c-college__hero-mascot img { width: 100%; height: auto; display: block; filter: drop-shadow(0 8px 14px rgba(0,0,0,0.15)); }

@media (max-width: 768px) {
    .c-college__hero-outer { padding: 0; }
    .c-college__hero { padding: 60px 20px 72px; margin: 0; border-radius: 0; }
    .c-college__hero-sticker { width: 84px; height: 84px; left: 14px; top: -12px; }
    .c-college__hero-sticker-main { font-size: 20px; }
    .c-college__hero-sticker-sub { font-size: 10px; }
    .c-college__hero-subtag { font-size: 12px; padding: 6px 18px; letter-spacing: 0.04em; }
    .c-college__hero-title { font-size: 34px; }
    .c-college__hero-subtitle { font-size: 14px; margin: 14px 0 32px; }
    .c-college__hero-quotes { grid-template-columns: 1fr; gap: 10px; margin-bottom: 36px; }
    .c-college__hero-quote { font-size: 13px; padding: 12px 18px 12px 46px; }
    .c-college__hero-quote::before { width: 18px; height: 18px; left: 14px; }
    .c-college__hero-body { padding-right: 0; font-size: 14px; text-align: center; line-height: 1.9; }
    .c-college__hero-mascot { position: static; margin: 24px auto 0; width: 200px; right: auto; bottom: auto; }
}

/* ---- 共通: セクション大見出し（中央寄せ・ラベル上/タイトル下） ---- */
.c-college__section-heading {
    max-width: 1100px;
    margin: 120px auto 20px;
    padding: 0;
    display: block;
    text-align: center;
    scroll-margin-top: 100px;
}
.c-college__section-heading-label {
    display: inline-block;
    background: #fff;
    color: #d85b2d;
    padding: 8px 24px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.18em;
    font-family: "Roboto", "Noto Sans JP", sans-serif;
    box-shadow: 0 4px 0 rgba(120,35,15,0.25);
    margin-bottom: 18px;
}
.c-college__section-heading-main {
    display: block;
    color: #fff;
    font-size: 40px;
    font-weight: bold;
    line-height: 1.4;
    margin: 0;
}
.c-college__section-heading-main .is-mark {
    background: linear-gradient(180deg, transparent 82%, #ffd149 82%);
    color: #fff;
    padding: 0 6px;
}

/* 番号付き見出し（HOMEROOM/CURRICULUM/COUNSELING） */
.c-college__section-heading.is-numbered {
    margin-top: 140px;
}
.c-college__section-heading.is-numbered .c-college__section-heading-num {
    display: block;
    font-family: "Roboto", "Noto Sans JP", sans-serif;
    font-style: italic;
    font-weight: 900;
    font-size: 22px;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 0.04em;
    line-height: 1;
    margin-bottom: 8px;
    position: relative;
}
.c-college__section-heading.is-numbered .c-college__section-heading-num::before {
    content: "";
    display: inline-block;
    width: 36px;
    height: 2px;
    background: rgba(255, 255, 255, 0.55);
    vertical-align: middle;
    margin-right: 12px;
    transform: translateY(-2px);
}
.c-college__section-heading.is-numbered .c-college__section-heading-num::after {
    content: "";
    display: inline-block;
    width: 36px;
    height: 2px;
    background: rgba(255, 255, 255, 0.55);
    vertical-align: middle;
    margin-left: 12px;
    transform: translateY(-2px);
}
.c-college__section-heading.is-numbered .c-college__section-heading-label {
    background: #fff;
    color: #d85b2d;
    padding: 10px 26px 10px 18px;
    display: inline-flex;
    align-items: center;
    gap: 14px;
    line-height: 1;
}
.c-college__section-heading-label-en {
    display: inline-flex;
    align-items: center;
    font-size: 14px;
    letter-spacing: 0.18em;
    line-height: 1;
}
.c-college__section-heading-label-jp {
    display: inline-flex;
    align-items: center;
    font-size: 18px;
    color: #202e42;
    font-weight: bold;
    letter-spacing: 0.06em;
    font-family: "Noto Sans JP", sans-serif;
    position: relative;
    padding-left: 14px;
    line-height: 1;
}
.c-college__section-heading-label-jp::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 1.1em;
    background: #d85b2d;
    opacity: 0.4;
}

@media (max-width: 768px) {
    .c-college__section-heading { margin: 72px auto 16px; }
    .c-college__section-heading-main { font-size: 26px; }
    .c-college__section-heading-label { font-size: 12px; padding: 6px 20px; }
    .c-college__section-heading.is-numbered { margin-top: 88px; }
    .c-college__section-heading.is-numbered .c-college__section-heading-num { font-size: 16px; }
    .c-college__section-heading.is-numbered .c-college__section-heading-num::before,
    .c-college__section-heading.is-numbered .c-college__section-heading-num::after { width: 22px; }
    .c-college__section-heading.is-numbered .c-college__section-heading-label { padding: 8px 18px 8px 14px; gap: 10px; }
    .c-college__section-heading-label-en { font-size: 11px; }
    .c-college__section-heading-label-jp { font-size: 14px; padding-left: 10px; }
}

/* ==== ヒーロー直下のアンカーナビ（sticky） ==== */
.c-college__anchor-nav {
    position: sticky;
    top: 100px; /* 固定ヘッダー（PC: 100px）の真下に張り付く */
    z-index: 10;
    margin: 32px 0 0;
    padding: 12px 0;
    background: rgba(216, 91, 45, 0);
    backdrop-filter: blur(0);
    -webkit-backdrop-filter: blur(0);
    transition: background .25s ease, box-shadow .25s ease, backdrop-filter .25s ease, padding .25s ease;
}
.c-college__anchor-nav.is-stuck {
    background: rgba(216, 91, 45, 0.86);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 8px 18px rgba(80, 20, 5, 0.18);
}
.c-college__anchor-nav-sentinel {
    height: 1px;
    pointer-events: none;
}
.c-college__anchor-nav-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 16px;
}
.c-college__anchor-nav-item {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    background: transparent;
    color: #fff;
    text-decoration: none;
    padding: 12px 4px;
    border: 0;
    border-radius: 0;
    border-bottom: 2px solid transparent;
    font-weight: bold;
    font-size: 14px;
    line-height: 1;
    box-shadow: none;
    transition: color .15s ease, border-color .15s ease, opacity .15s ease;
}
.c-college__anchor-nav-item:hover {
    color: #ffd149;
    border-bottom-color: rgba(255, 209, 73, 0.55);
    background: transparent;
    box-shadow: none;
    transform: none;
}
/* 現在見ているセクションのナビ項目（スクロールスパイ） */
.c-college__anchor-nav-item.is-active {
    color: #ffd149;
    background: transparent;
    border-bottom-color: #ffd149;
    box-shadow: none;
    transform: none;
}
.c-college__anchor-nav-item.is-active .c-college__anchor-nav-num,
.c-college__anchor-nav-item:hover .c-college__anchor-nav-num {
    color: #ffd149;
}
.c-college__anchor-nav-num {
    color: rgba(255, 255, 255, 0.6);
    font-size: 11px;
    font-weight: bold;
    font-family: "Noto Sans JP", "Helvetica Neue", Arial, sans-serif;
    letter-spacing: 0.06em;
    line-height: 1;
    background: transparent;
    width: auto;
    height: auto;
    border-radius: 0;
    flex-shrink: 0;
    transition: color .15s ease;
}
.c-college__anchor-nav-label {
    white-space: nowrap;
}

/* お申し込みへ CTA — フラットボタン */
.c-college__anchor-nav-cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #ffd149;
    color: #b53c16;
    text-decoration: none;
    padding: 10px 18px 10px 14px;
    border: 0;
    border-radius: 8px;
    font-weight: bold;
    line-height: 1.2;
    margin-left: 18px;
    flex-shrink: 0;
    box-shadow: 0 4px 0 rgba(178,119,0,0.5), 0 6px 16px rgba(0,0,0,0.14);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.c-college__anchor-nav-cta:hover,
.c-college__anchor-nav-cta:focus-visible {
    background: #fff;
    color: #b53c16;
    transform: translateY(1px);
    box-shadow: 0 3px 0 rgba(178,119,0,0.5), 0 5px 12px rgba(0,0,0,0.14);
}
.c-college__anchor-nav-cta-tag {
    position: absolute;
    top: -10px;
    left: 10px;
    background: #fff;
    color: #b53c16;
    font-size: 10px;
    letter-spacing: 0.04em;
    padding: 3px 10px;
    border-radius: 100px;
    line-height: 1;
    white-space: nowrap;
    box-shadow: 0 2px 0 rgba(120,35,15,0.25);
}
.c-college__anchor-nav-cta-text {
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    text-align: left;
}
.c-college__anchor-nav-cta-main {
    font-size: 14px;
    letter-spacing: 0.02em;
}
.c-college__anchor-nav-cta-sub {
    font-size: 10px;
    opacity: 0.85;
    font-weight: 500;
    letter-spacing: 0.04em;
}
.c-college__anchor-nav-cta-arrow {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}
@media (max-width: 768px) {
    .c-college__anchor-nav {
        top: 55px; /* SP固定ヘッダー（55px）の真下 */
        margin-top: 16px;
        padding: 8px 0;
    }
    /* SPは1行で横スクロール */
    .c-college__anchor-nav-inner {
        flex-wrap: nowrap;
        justify-content: flex-start;
        gap: 8px;
        padding: 4px 14px;
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        scroll-behavior: smooth;
        scrollbar-width: none;
        -ms-overflow-style: none;
        scroll-snap-type: x proximity;
    }
    .c-college__anchor-nav-inner::-webkit-scrollbar { display: none; }
    .c-college__anchor-nav-item {
        flex-shrink: 0;
        font-size: 12px;
        padding: 10px 4px;
        gap: 6px;
        scroll-snap-align: center;
    }
    .c-college__anchor-nav-num {
        font-size: 10px;
    }
    .c-college__anchor-nav-cta {
        padding: 9px 12px 8px;
        margin-left: 6px;
        gap: 6px;
    }
    .c-college__anchor-nav-cta-main { font-size: 12px; }
    .c-college__anchor-nav-cta-sub { display: none; }
    .c-college__anchor-nav-cta-tag { font-size: 9px; padding: 2px 8px; top: -8px; left: 8px; }
}

/* ==== セクショングループ（紹介・詳細） — 共通パネル ==== */
.c-college__intro,
.c-college__details {
    position: relative;
    max-width: 1240px;
    margin: 96px auto 0;
    padding: 64px 48px 72px;
    background: rgba(255, 248, 230, 0.10);
    border: 3px solid #ffd149;
    border-radius: 36px;
    box-shadow:
        0 0 0 6px rgba(255, 255, 255, 0.22),
        0 18px 44px rgba(80, 20, 5, 0.22);
}

/* 角の「マステ」風アクセント（パネルが「貼られた紙」のように見えるように） */
.c-college__intro::before,
.c-college__details::before {
    content: "";
    position: absolute;
    top: -12px;
    left: 32px;
    width: 96px;
    height: 28px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(216, 91, 45, 0.18);
    transform: rotate(-3deg);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
    border-radius: 2px;
}
.c-college__intro::after,
.c-college__details::after {
    content: "";
    position: absolute;
    top: -10px;
    right: 36px;
    width: 80px;
    height: 26px;
    background: rgba(255, 209, 73, 0.92);
    border: 1px solid rgba(216, 91, 45, 0.18);
    transform: rotate(4deg);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
    border-radius: 2px;
}

/* 各パネルの「最初の見出し」の上余白を抑える（パネル自体のpadding-topで既に空間がある） */
.c-college__intro > .c-college__section-heading:first-child,
.c-college__intro > .c-college__pillars:first-child > .c-college__section-heading:first-child,
.c-college__details > .c-college__pillars:first-of-type > .c-college__section-heading:first-child {
    margin-top: 0;
}

/* 詳細パネル内、CONTENTSピラーの直後に来る最初の番号付き見出し（01）の余白調整 */
.c-college__details .c-college__pillars + .c-college__section-heading.is-numbered,
.c-college__details > .c-college__section-heading.is-numbered:first-of-type {
    margin-top: 96px;
}

/* CONTENTSピラー（移動後）— パネル先頭に置かれた際の見た目調整 */
.c-college__details .c-college__pillars {
    margin-bottom: 40px;
    padding-bottom: 48px;
    border-bottom: 1.5px dashed rgba(255, 255, 255, 0.4);
}
.c-college__details .c-college__pillars .c-college__section-heading {
    margin-top: 0;
}

@media (max-width: 768px) {
    .c-college__intro,
    .c-college__details {
        margin: 64px 12px 0;
        padding: 44px 14px 36px;
        border-radius: 22px;
        border-width: 2px;
    }
    .c-college__intro::before,
    .c-college__details::before {
        top: -10px;
        left: 18px;
        width: 64px;
        height: 22px;
    }
    .c-college__intro::after,
    .c-college__details::after {
        top: -8px;
        right: 22px;
        width: 56px;
        height: 20px;
    }
    .c-college__details .c-college__pillars {
        margin-bottom: 24px;
        padding-bottom: 32px;
    }
    .c-college__details .c-college__pillars + .c-college__section-heading.is-numbered,
    .c-college__details > .c-college__section-heading.is-numbered:first-of-type {
        margin-top: 56px;
    }
}

/* 共通リード文（セクション見出し下の補足・中央寄せ） */
.c-college__section-lead {
    max-width: 1100px;
    margin: 0 auto 32px;
    color: #fff;
    font-size: 17px;
    line-height: 2;
    text-align: center;
}
.c-college__section-lead strong {
    background: linear-gradient(180deg, transparent 82%, #ffd149 82%);
    color: #fff;
    padding: 0 4px;
    font-weight: bold;
}
.c-college__section-desc {
    max-width: 720px;
    margin: -8px auto 36px;
    color: #fff;
    font-size: 15px;
    line-height: 1.9;
    text-align: left;
    background: rgba(255,255,255,0.14);
    border-radius: 12px;
    padding: 18px 28px;
    backdrop-filter: blur(4px);
    position: relative;
    z-index: 2;
}
/* TEACHERS セクション（l-college内へ移動） */
.c-college__teachers-wrap {
    max-width: 1100px;
    margin: 0 auto 40px;
    padding: 0 16px;
    position: relative;
    z-index: 1;
}
.c-college__teachers-wrap .c-teachers__note {
    color: rgba(255,255,255,0.85);
    text-align: right;
    margin-bottom: 10px;
}
.c-college__teachers-wrap .c-teachers__blocks {
    gap: 18px;
}
@media (max-width: 768px) {
    .c-college__teachers-wrap { padding: 0 12px; }
    .c-college__teachers-wrap .c-teachers__block { padding: 20px 18px; }
}
@media (max-width: 768px) {
    .c-college__section-lead { font-size: 12px; line-height: 1.8; margin-bottom: 20px; padding: 0 16px; }
    .c-college__section-desc { font-size: 12.5px; line-height: 1.8; margin: -8px 16px 24px; padding: 14px 16px; }
}

/* 互換エイリアス（従来の concept-heading） */
.c-college__concept-heading { max-width: 1100px; margin: 0 auto 28px; padding: 0; display: flex; align-items: center; gap: 18px; text-align: left; }
.c-college__concept-heading-label { display: inline-block; background: #fff; color: #d85b2d; padding: 8px 20px; border-radius: 100px; font-size: 13px; font-weight: bold; letter-spacing: 0.14em; font-family: "Roboto", "Noto Sans JP", sans-serif; box-shadow: 0 4px 0 rgba(120,35,15,0.25); flex-shrink: 0; }
.c-college__concept-heading-main { color: #fff; font-size: 40px; font-weight: bold; line-height: 1.3; margin: 0; }
@media (max-width: 768px) {
    .c-college__concept-heading { flex-direction: column; align-items: flex-start; gap: 10px; margin-bottom: 18px; }
    .c-college__concept-heading-main { font-size: 26px; }
}

/* ノートペーパー風カード */
.c-college__concept {
    background:
        linear-gradient(to right, transparent 72px, rgba(255,205,210,0.5) 72px, rgba(255,205,210,0.5) 74px, transparent 74px),
        repeating-linear-gradient(to bottom, #fff 0, #fff 35px, #e8f2fa 35px, #e8f2fa 36px);
    background-color: #fff;
    border-radius: 0;
    padding: 48px 56px 48px 96px;
    margin: 0 auto 80px;
    max-width: 1000px;
    position: relative;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}
.c-college__concept-pill {
    position: absolute;
    top: 24px;
    right: 80px;
    background: transparent;
    color: #d85b2d;
    padding: 0;
    border: 0;
    font-size: 15px;
    font-weight: bold;
    font-family: "Yusei Magic", "Noto Sans JP", cursive;
    z-index: 1;
    letter-spacing: 0;
}
.c-college__concept-pill::before {
    content: "";
    display: inline-block;
    width: 24px;
    height: 24px;
    background: #d85b2d;
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34a.9959.9959 0 0 0-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z'/></svg>") no-repeat center/contain;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34a.9959.9959 0 0 0-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z'/></svg>") no-repeat center/contain;
    vertical-align: -6px;
    margin-right: 6px;
}
.c-college__concept-body {
    font-size: 16px;
    line-height: 2.1875; /* 35px rhythm match with ruled lines */
    color: #333;
    margin: 12px 0 0;
    position: relative;
    z-index: 1;
}
.c-college__concept-body strong {
    background: linear-gradient(180deg, transparent 60%, #ffe08a 60%);
    color: #b53c16;
    padding: 0 4px;
    font-weight: bold;
}
@media (max-width: 768px) {
    .c-college__concept {
        padding: 50px 24px 32px 60px;
        margin: 40px auto 60px;
        background:
            linear-gradient(to right, transparent 40px, rgba(255,205,210,0.5) 40px, rgba(255,205,210,0.5) 42px, transparent 42px),
            repeating-linear-gradient(to bottom, #fff 0, #fff 30px, #e8f2fa 30px, #e8f2fa 31px);
        background-color: #fff;
    }
    .c-college__concept-pill { right: 50px; top: 16px; font-size: 13px; }
    .c-college__concept-body { font-size: 14px; line-height: 1.875; }
}

/* ---- ブロック③ 3つの時間（黒板＋チョーク数字） ---- */
.c-college__pillars {
    max-width: 1100px;
    margin: 0 auto 80px;
}
.c-college__blackboard {
    background: linear-gradient(180deg, #2d4a34 0%, #1f3325 100%);
    border: 8px solid #8b6914;
    border-radius: 0;
    padding: 30px 40px 32px;
    max-width: 720px;
    margin: 0 auto 40px;
    position: relative;
    box-shadow: 0 10px 25px rgba(0,0,0,0.25);
    font-family: "Yusei Magic", "Noto Sans JP", cursive;
}
.c-college__blackboard::before,
.c-college__blackboard::after {
    content: "";
    position: absolute;
    bottom: -18px;
    width: 56px;
    height: 10px;
    background: #8b6914;
    border-radius: 3px;
    box-shadow: 0 3px 6px rgba(0,0,0,0.3);
}
.c-college__blackboard::before { left: 40px; background: linear-gradient(90deg, #f5f5f5 50%, #e8c4c4 50%); border-radius: 2px; height: 8px; bottom: -14px; }
.c-college__blackboard::after { right: 40px; background: linear-gradient(90deg, #e8c4c4 50%, #f5f5f5 50%); border-radius: 2px; height: 8px; bottom: -14px; }
.c-college__blackboard-chalk-label {
    display: inline-block;
    color: #fff;
    font-size: 16px;
    padding: 0 10px;
    border-bottom: 2px dashed rgba(255,255,255,0.5);
    margin-bottom: 14px;
}
.c-college__blackboard-title {
    color: #fff;
    font-size: 30px;
    margin: 0;
    line-height: 1.3;
    text-shadow: 0 0 1px rgba(255,255,255,0.3);
}
.c-college__blackboard-title .is-mark {
    color: #ffd149;
    position: relative;
}
.c-college__blackboard-title .is-mark::after {
    content: "";
    position: absolute;
    left: -2px;
    right: -2px;
    bottom: -4px;
    height: 6px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 6' preserveAspectRatio='none'><path d='M2 3 Q 15 0, 30 3 T 60 3 T 90 3 T 118 3' stroke='%23ffffff' stroke-width='2' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
    opacity: 0.8;
}
.c-college__blackboard-sub {
    color: rgba(255,255,255,0.75);
    font-size: 14px;
    margin: 12px 0 0;
}
@media (max-width: 768px) {
    .c-college__blackboard { padding: 24px 24px 28px; border-width: 6px; }
    .c-college__blackboard-title { font-size: 22px; }
}
.c-college__pillars-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    padding-top: 30px;
    align-items: stretch;
}
.c-college__pillar {
    background: #fff;
    border-radius: 0;
    padding: 32px 28px;
    position: relative;
    overflow: visible;
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    transition: transform .3s ease, box-shadow .3s ease;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    height: 100%;
}
.c-college__pillar:hover,
.c-college__pillar:focus-visible {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.22);
    text-decoration: none;
    color: inherit;
}
.c-college__pillar-jump {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-width: 132px;
    margin: 20px auto 0;
    padding: 10px 22px;
    border-radius: 999px;
    background: #d85b2d;
    box-shadow: 0 4px 0 rgba(120,35,15,0.25);
    font-size: 13px;
    font-weight: bold;
    color: #fff;
    line-height: 1;
    letter-spacing: 0.03em;
    transition: transform .3s ease, background .3s ease, box-shadow .3s ease;
}
.c-college__pillar:hover .c-college__pillar-jump {
    background: #b53c16;
    box-shadow: 0 5px 0 rgba(90,25,8,0.3);
    transform: translateY(-1px);
}
.c-college__pillar-chalk {
    position: absolute;
    top: -18px;
    left: 24px;
    width: 70px;
    height: 70px;
    background: #2d4a34;
    border: 4px solid #8b6914;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Yusei Magic", "Noto Sans JP", cursive;
    font-size: 34px;
    color: #fff;
    box-shadow: 0 6px 12px rgba(0,0,0,0.2);
    line-height: 1;
    z-index: 2;
}
.c-college__pillar-chalk-num { text-shadow: 0 0 2px rgba(255,255,255,0.4); padding-top: 6px; }
.c-college__pillar-watermark { display: none; }
/* カード外に浮く吹き出しタグ（黄色×紺字） */
.c-college__pillar-bubble {
    display: inline-block;
    background: #ffd149;
    color: #202e42;
    padding: 10px 24px;
    border-radius: 100px;
    font-size: 14px;
    font-weight: bold;
    position: absolute;
    top: -20px;
    left: 24px;
    box-shadow: 0 5px 0 rgba(178,119,0,0.35), 0 10px 18px rgba(0,0,0,0.12);
    z-index: 3;
    letter-spacing: 0.02em;
}
.c-college__pillar-bubble::after {
    content: "";
    position: absolute;
    bottom: -11px;
    left: 30px;
    width: 16px;
    height: 11px;
    background: #ffd149;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    filter: drop-shadow(0 3px 0 rgba(178,119,0,0.3));
}
.c-college__pillar-img {
    width: 100%;
    aspect-ratio: 5/3;
    background: #fef5e5;
    border-radius: 0;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    overflow: hidden;
    margin: auto 0 8px;
    position: relative;
}
.c-college__pillar-img img { width: 50%; height: auto; display: block; opacity: 0.95; }
.c-college__pillar-title {
    font-size: 24px;
    font-weight: bold;
    color: #202e42;
    line-height: 1.3;
    margin: 18px 0 6px;
    position: relative;
    z-index: 1;
}
.c-college__pillar-tag {
    font-size: 13px;
    color: #d85b2d;
    font-weight: bold;
    display: block;
    margin-top: 2px;
}
.c-college__pillar-divider {
    width: 40px;
    height: 3px;
    background: #d85b2d;
    border-radius: 2px;
    margin: 14px 0;
}
.c-college__pillar-desc {
    font-size: 14px;
    line-height: 1.9;
    color: #555;
    margin: 0 0 18px;
    position: relative;
    z-index: 1;
}
@media (max-width: 959px) {
    .c-college__pillars-grid { grid-template-columns: 1fr; max-width: 480px; margin: 30px auto 0; gap: 28px; }
    .c-college__pillar-img { margin-top: 18px; }
}

/* ---- ブロック④ 授業カリキュラム ---- */
.c-college__curriculum {
    background: #fef5e5;
    background-image:
        url(../images/yume-career/sparkle-gold.png),
        url(../images/yume-career/sparkle-gold.png),
        url(../images/yume-career/sparkle-gold.png);
    background-position: 5% 8%, 95% 40%, 10% 90%;
    background-size: 32px, 48px, 36px;
    background-repeat: no-repeat;
    border-radius: 0;
    padding: 60px 40px 70px;
    margin: 0 auto 80px;
    max-width: 1100px;
    position: relative;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}
.c-college__curriculum-title-main { color: #202e42; }
.c-college__lessons-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
}
.c-college__lesson {
    background: #fff;
    border-radius: 0;
    overflow: hidden;
    box-shadow: 0 6px 20px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    transition: transform .3s ease, box-shadow .3s ease;
    position: relative;
}
.c-college__lesson-number { display: none; }
.c-college__lesson-banner {
    background: linear-gradient(135deg, #d85b2d 0%, #e9703f 100%);
    color: #fff;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.02em;
}
.c-college__lesson-banner svg { width: 24px; height: 24px; flex-shrink: 0; }
.c-college__lesson-body {
    padding: 24px 26px 26px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
}
.c-college__lesson-header {
    display: flex;
    gap: 16px;
    align-items: center;
}
.c-college__lesson-img {
    width: 84px;
    height: 84px;
    flex-shrink: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, #fef5e5 0%, #ffd8b5 100%);
    overflow: hidden;
}
.c-college__lesson-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.c-college__lesson-title {
    font-size: 18px;
    font-weight: bold;
    color: #202e42;
    line-height: 1.4;
    margin: 0;
}
.c-college__lesson-desc {
    font-size: 14px;
    line-height: 1.9;
    color: #555;
    margin: 0;
}
.c-college__lesson-cases {
    background: #fef5e5;
    border-radius: 0;
    padding: 14px 18px;
    font-size: 13px;
    line-height: 1.8;
}
.c-college__lesson-cases-title {
    font-weight: bold;
    color: #d85b2d;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.c-college__lesson-cases-title::before {
    content: "";
    width: 6px;
    height: 6px;
    background: #d85b2d;
    border-radius: 50%;
}
.c-college__lesson-cases ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px 16px;
}
.c-college__lesson-cases li {
    position: relative;
    padding-left: 14px;
    color: #555;
}
.c-college__lesson-cases li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    width: 6px;
    height: 2px;
    background: #d85b2d;
}
.c-college__lesson-themes {
    background: #fef5e5;
    border-radius: 0;
    padding: 14px 18px;
    margin: 0;
}
.c-college__lesson-themes dt {
    font-weight: bold;
    color: #d85b2d;
    font-size: 13px;
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.c-college__lesson-themes dt::before {
    content: "";
    width: 6px;
    height: 6px;
    background: #d85b2d;
    border-radius: 50%;
}
.c-college__lesson-themes dt:first-child { margin-top: 0; }
.c-college__lesson-themes dd {
    margin: 4px 0 0 12px;
    font-size: 12px;
    color: #666;
    line-height: 1.7;
}
/* 講師（簡略版・リンク） */
.c-college__lesson-teacher {
    margin: auto -10px -10px;
    padding: 14px 10px 10px;
    border-top: 1px dashed #e0d4c2;
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: inherit;
    transition: background .2s ease;
    border-radius: 8px;
}
.c-college__lesson-teacher:hover {
    background: #fef5e5;
}
.c-college__lesson-teacher-photo {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    overflow: hidden;
    background: #fef5e5;
    flex-shrink: 0;
    border: 2px solid #d85b2d;
}
.c-college__lesson-teacher-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.c-college__lesson-teacher-text { font-size: 13px; line-height: 1.5; flex: 1; }
.c-college__lesson-teacher-label { color: #d85b2d; font-weight: bold; font-size: 11px; letter-spacing: 0.08em; }
.c-college__lesson-teacher-name { color: #202e42; font-weight: bold; font-size: 15px; }
.c-college__lesson-teacher-title { color: #777; font-size: 11px; line-height: 1.5; display: block; margin-top: 2px; }
.c-college__lesson-teacher-arrow { color: #d85b2d; flex-shrink: 0; }
.c-college__lesson-teacher-arrow svg { width: 16px; height: 16px; fill: currentColor; }
@media (max-width: 768px) {
    .c-college__curriculum { padding: 40px 20px 50px; }
    .c-college__lessons-grid { grid-template-columns: 1fr; gap: 24px; }
    .c-college__lesson-banner { font-size: 16px; padding: 14px 20px; }
    .c-college__lesson-banner svg { width: 20px; height: 20px; }
    .c-college__lesson-cases ul { grid-template-columns: 1fr; }
}

/* ---- ブロック⑥ ホームルーム（派遣のホンネ交換会） ---- */
.c-college__homeroom {
    background: #fef5e5;
    border-radius: 0;
    padding: 48px 50px 52px;
    margin: 0 auto 60px;
    max-width: 1100px;
    position: relative;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}
.c-college__homeroom-mascot {
    position: absolute;
    top: -48px;
    right: 36px;
    width: 120px;
    z-index: 2;
    pointer-events: none;
}
.c-college__homeroom-mascot img { width: 100%; height: auto; display: block; filter: drop-shadow(0 6px 10px rgba(0,0,0,0.15)); }
@media (max-width: 768px) {
    .c-college__homeroom-mascot { width: 78px; top: -36px; right: 18px; }
}
.c-college__homeroom-intro {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 28px;
    align-items: center;
    margin-bottom: 36px;
    padding: 24px 28px;
    background: #fff;
    border-radius: 0;
    box-shadow: 0 4px 14px rgba(120,35,15,0.06);
}
.c-college__homeroom-intro-img {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, #fef5e5 0%, #ffd8b5 100%);
}
.c-college__homeroom-intro-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.c-college__homeroom-intro-text p {
    font-size: 16px;
    line-height: 2;
    color: #333;
    margin: 0 0 8px;
}
.c-college__homeroom-intro-text p:last-child { margin-bottom: 0; }
.c-college__homeroom-intro-text strong {
    background: linear-gradient(180deg, transparent 78%, #ffd149 78%);
    color: #202e42;
    font-weight: bold;
    padding: 0 4px;
}

/* 参加フィーチャー */
.c-college__homeroom-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin: 0 0 40px;
    padding: 0;
    list-style: none;
}
.c-college__homeroom-feature {
    background: #fff;
    border: 2px solid #ffd1a8;
    border-radius: 0;
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center;
}
.c-college__homeroom-feature-icon {
    width: 46px;
    height: 46px;
    background: radial-gradient(circle at 35% 35%, #e9703f, #d85b2d 60%, #b53c16);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.c-college__homeroom-feature-icon svg { width: 24px; height: 24px; fill: #fff; }
.c-college__homeroom-feature-text {
    font-size: 14px;
    font-weight: bold;
    color: #202e42;
    line-height: 1.4;
}

/* スケジュール見出し（セクション内小見出し） */
.c-college__homeroom-subhead {
    font-size: 17px;
    font-weight: bold;
    color: #202e42;
    margin: 0 0 16px;
    padding-left: 14px;
    position: relative;
}
.c-college__homeroom-subhead::before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    bottom: 3px;
    width: 5px;
    background: #d85b2d;
    border-radius: 2px;
}

/* イベントチケット */
.c-college__homeroom-tickets {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}
.c-college__homeroom-ticket {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 22px;
    align-items: center;
    background: #fff;
    border-radius: 0;
    padding: 22px 26px;
    box-shadow: 0 6px 16px rgba(120,35,15,0.1);
    text-decoration: none;
    color: inherit;
    position: relative;
    transition: transform .3s ease, box-shadow .3s ease;
}
.c-college__homeroom-ticket:hover { transform: translateY(-3px); box-shadow: 0 12px 24px rgba(120,35,15,0.16); }
.c-college__homeroom-ticket-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    padding-right: 22px;
    border-right: 2px dashed #ffd1a8;
    min-width: 96px;
}
.c-college__homeroom-ticket-month {
    font-size: 15px;
    font-weight: bold;
    color: #d85b2d;
    letter-spacing: 0.04em;
}
.c-college__homeroom-ticket-day {
    font-size: 38px;
    font-weight: 900;
    color: #d85b2d;
    line-height: 1;
    margin: 6px 0 4px;
    display: flex;
    align-items: baseline;
    gap: 2px;
}
.c-college__homeroom-ticket-day-unit {
    font-size: 18px;
    font-weight: bold;
}
.c-college__homeroom-ticket-dow {
    font-size: 13px;
    color: #b53c16;
    font-weight: bold;
}
.c-college__homeroom-ticket-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.c-college__homeroom-ticket-time {
    font-size: 18px;
    font-weight: bold;
    color: #202e42;
}
.c-college__homeroom-ticket-method {
    font-size: 13px;
    color: #666;
    display: flex;
    align-items: center;
    gap: 4px;
}
.c-college__homeroom-ticket-method svg { width: 14px; height: 14px; fill: #888; }
.c-college__homeroom-ticket-cta {
    width: 44px;
    height: 44px;
    background: #d85b2d;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 0 rgba(120,35,15,0.3);
}
.c-college__homeroom-ticket-cta svg { width: 22px; height: 22px; fill: #fff; }

@media (max-width: 768px) {
    .c-college__homeroom { padding: 32px 20px 36px; }
    .c-college__homeroom-intro { grid-template-columns: 1fr; gap: 16px; padding: 20px; text-align: center; }
    .c-college__homeroom-intro-img { width: 140px; height: 140px; margin: 0 auto; }
    .c-college__homeroom-intro-text p { font-size: 14px; line-height: 1.9; text-align: left; }
    .c-college__homeroom-features { grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .c-college__homeroom-feature { padding: 14px 6px; }
    .c-college__homeroom-feature-icon { width: 38px; height: 38px; }
    .c-college__homeroom-feature-icon svg { width: 18px; height: 18px; }
    .c-college__homeroom-feature-text { font-size: 12px; }
    .c-college__homeroom-tickets { grid-template-columns: 1fr; }
    .c-college__homeroom-ticket { padding: 18px 20px; gap: 14px; }
    .c-college__homeroom-ticket-day { font-size: 34px; }
    .c-college__homeroom-ticket-time { font-size: 16px; }
}

/* ---- ブロック⑧ 相談室 ---- */
.c-college__counseling {
    background: #fef5e5;
    border-radius: 0;
    padding: 48px 50px 52px;
    margin: 0 auto 60px;
    max-width: 1100px;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}
/* イントロ（マスコット+説明） */
.c-college__counseling-intro {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 28px;
    align-items: center;
    margin-bottom: 36px;
    padding: 24px 28px;
    background: #fff;
    border-radius: 0;
    box-shadow: 0 4px 14px rgba(120,35,15,0.06);
}
.c-college__counseling-intro-img {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(135deg, #fef5e5 0%, #ffd8b5 100%);
}
.c-college__counseling-intro-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.c-college__counseling-intro-text p {
    font-size: 15px;
    line-height: 2;
    color: #333;
    margin: 0 0 10px;
}
.c-college__counseling-intro-text p:last-child { margin-bottom: 0; }
.c-college__counseling-intro-text strong {
    background: linear-gradient(180deg, transparent 78%, #ffd149 78%);
    color: #202e42;
    font-weight: bold;
    padding: 0 4px;
}

/* 声パネル */
.c-college__counseling-voices {
    background: #fff;
    border-radius: 0;
    padding: 32px 32px 28px;
    margin-bottom: 36px;
    box-shadow: 0 4px 14px rgba(120,35,15,0.06);
    position: relative;
}
.c-college__counseling-voices-head {
    display: inline-block;
    position: absolute;
    top: -14px;
    left: 28px;
    background: #d85b2d;
    color: #fff;
    padding: 6px 20px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 0.08em;
    box-shadow: 0 3px 0 rgba(120,35,15,0.3);
}
.c-college__counseling-voices-list {
    list-style: none;
    padding: 8px 0 0;
    margin: 0 0 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.c-college__counseling-voices-list li {
    position: relative;
    padding: 14px 22px 14px 60px;
    background: #fef5e5;
    border-radius: 0;
    font-size: 15px;
    color: #333;
    line-height: 1.6;
}
.c-college__counseling-voices-list li::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23d85b2d'><path d='M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 9h12v2H6V9zm8 5H6v-2h8v2zm4-6H6V6h12v2z'/></svg>") no-repeat center/contain;
}
.c-college__counseling-closing {
    font-size: 15px;
    line-height: 2;
    color: #333;
    margin: 0;
    text-align: center;
    padding: 0 16px;
}
.c-college__counseling-closing strong {
    background: linear-gradient(180deg, transparent 78%, #ffd149 78%);
    color: #b53c16;
    padding: 0 4px;
    font-weight: bold;
}

/* コンサルタント紹介 */
.c-college__counseling-subhead {
    font-size: 17px;
    font-weight: bold;
    color: #202e42;
    margin: 0 0 18px;
    padding-left: 14px;
    position: relative;
}
.c-college__counseling-subhead::before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    bottom: 3px;
    width: 5px;
    background: #d85b2d;
    border-radius: 2px;
}
.c-college__counseling-counselors {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 36px;
}
.c-college__counseling-counselor {
    background: #fff;
    border-radius: 0;
    padding: 22px 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    box-shadow: 0 4px 14px rgba(120,35,15,0.06);
    text-decoration: none;
    color: inherit;
    transition: transform .2s ease, box-shadow .2s ease;
}
.c-college__counseling-counselor:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(120,35,15,0.12);
}
.c-college__counseling-counselor-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid #fff;
    box-shadow: 0 0 0 2px #d85b2d;
}
.c-college__counseling-counselor-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.c-college__counseling-counselor-name {
    font-size: 16px;
    font-weight: bold;
    color: #202e42;
}
.c-college__counseling-counselor-title {
    font-size: 11px;
    color: #777;
    line-height: 1.7;
    letter-spacing: 0;
}

/* 申込CTA */
.c-college__counseling-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: #fff;
    border-radius: 0;
    padding: 24px 28px;
    box-shadow: 0 4px 14px rgba(120,35,15,0.06);
}
.c-college__counseling-cta-info {
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
}
.c-college__counseling-cta-info-block {
    display: flex;
    align-items: center;
    gap: 8px;
}
.c-college__counseling-cta-info-label {
    background: #d85b2d;
    color: #fff;
    padding: 5px 14px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.04em;
    flex-shrink: 0;
}
.c-college__counseling-cta-info-value {
    font-size: 18px;
    font-weight: bold;
    color: #202e42;
}
.c-college__counseling-cta-button {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #d85b2d;
    color: #fff !important;
    padding: 16px 26px;
    border-radius: 100px;
    font-weight: bold;
    font-size: 15px;
    text-decoration: none;
    box-shadow: 0 5px 0 rgba(120,35,15,0.3);
    flex-shrink: 0;
    transition: transform .2s ease, box-shadow .2s ease;
}
.c-college__counseling-cta-button:hover {
    transform: translateY(2px);
    box-shadow: 0 3px 0 rgba(120,35,15,0.3);
}
.c-college__counseling-cta-button svg { width: 16px; height: 16px; fill: currentColor; }

@media (max-width: 768px) {
    .c-college__counseling { padding: 32px 20px 36px; }
    .c-college__counseling-intro { grid-template-columns: 1fr; gap: 16px; padding: 20px; text-align: center; }
    .c-college__counseling-intro-img { width: 140px; height: 140px; margin: 0 auto; }
    .c-college__counseling-intro-text p { font-size: 13px; text-align: left; }
    .c-college__counseling-voices { padding: 30px 20px 24px; }
    .c-college__counseling-voices-list li { font-size: 13px; padding: 12px 18px 12px 52px; }
    .c-college__counseling-voices-list li::before { width: 22px; height: 22px; left: 18px; }
    .c-college__counseling-counselors { grid-template-columns: 1fr; gap: 12px; }
    .c-college__counseling-counselor { flex-direction: row; text-align: left; padding: 14px 20px; }
    .c-college__counseling-cta { flex-direction: column; align-items: stretch; gap: 18px; padding: 20px; }
    .c-college__counseling-cta-button { justify-content: center; padding: 14px 22px; font-size: 14px; }
}

/* ---- ブロック④ こんな方に参加してほしい ---- */
.c-college__audience {
    background: #fef5e5;
    border-radius: 0;
    padding: 50px 50px 110px;
    margin: 0 auto 60px;
    max-width: 1100px;
    position: relative;
    box-shadow: .3125rem .3125rem 0 0 rgba(56, 79, 112, .15);
}

/* ---- パネル装飾（学校アイコン） ---- */
.c-college__deco {
    position: absolute;
    pointer-events: none;
    z-index: 1;
    opacity: 0.95;
}
.c-college__deco img { width: 100%; height: auto; display: block; }
@media (max-width: 768px) {
    .c-college__deco { display: none; }
}

/* リスト */
.c-college__audience-list {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px 18px;
    margin: 0 0 40px;
    position: relative;
    z-index: 1;
}
.c-college__audience-list li {
    padding: 20px 22px 20px 82px;
    font-size: 15px;
    color: #333;
    position: relative;
    line-height: 1.55;
    background: #fff;
    border: 0;
    border-radius: 0;
    box-shadow: 0 4px 14px rgba(120,35,15,0.08);
    min-height: 72px;
    display: flex;
    align-items: center;
}
/* チェックサークル＋チェックマーク (SVG一体・フラット) */
.c-college__audience-list li::before {
    content: "";
    position: absolute;
    left: 22px;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 44'><circle cx='22' cy='22' r='22' fill='%23d85b2d'/><path d='M13 22.5 L 19.5 29 L 31.5 15.5' stroke='white' stroke-width='3.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat center/contain;
}

/* 閉じの帯（ハンド＆ハート＋点線＋ハイライト） */
.c-college__audience-closing-wrap {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 0 200px 0 0;
    position: relative;
    z-index: 1;
    max-width: 920px;
    margin: 0 auto;
}
.c-college__audience-closing-icon {
    width: 66px;
    height: 66px;
    background: #d85b2d;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.c-college__audience-closing-icon svg { width: 34px; height: 34px; fill: #fff; }
.c-college__audience-closing {
    font-size: 17px;
    line-height: 2;
    color: #333;
    margin: 0;
    flex: 1;
    text-align: left;
}
.c-college__audience-closing-line:first-child { margin-bottom: 2px; }
.c-college__audience-closing strong {
    background: transparent;
    color: #202e42;
    font-weight: bold;
    font-size: 20px;
    padding: 0;
}
.c-college__audience-closing .hl {
    background: linear-gradient(180deg, transparent 75%, #ffd149 75%);
    padding: 0 4px;
    font-weight: bold;
}

/* マスコット（右下ラビッタ） */
.c-college__audience-mascot {
    position: absolute;
    bottom: -8px;
    right: 20px;
    width: 170px;
    pointer-events: none;
    z-index: 2;
}
/* 動きの集中線（シンプルなSVG） */
.c-college__audience-mascot::before {
    content: "";
    position: absolute;
    top: -10px;
    left: -28px;
    width: 60px;
    height: 70px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 70' fill='none' stroke='%23d85b2d' stroke-width='3' stroke-linecap='round'><path d='M10 20 L 26 24'/><path d='M4 38 L 22 38'/><path d='M14 56 L 28 52'/></svg>") no-repeat center/contain;
}
.c-college__audience-mascot img { width: 100%; height: auto; display: block; filter: drop-shadow(0 6px 8px rgba(0,0,0,0.1)); }

@media (max-width: 768px) {
    .c-college__audience { padding: 44px 20px 90px; }
    .c-college__audience-leaves-right,
    .c-college__audience::after { display: none; }
    .c-college__audience-title { font-size: 24px; border-bottom-width: 3px; }
    .c-college__audience-subtitle { font-size: 12px; }
    .c-college__audience-list { grid-template-columns: 1fr; }
    .c-college__audience-list li { font-size: 14px; padding: 18px 16px 18px 68px; }
    .c-college__audience-list li::before { width: 36px; height: 36px; left: 16px; }
    .c-college__audience-list li::after { left: 30px; width: 8px; height: 14px; }
    .c-college__audience-closing-wrap { gap: 14px; padding: 0 0 110px; }
    .c-college__audience-closing-icon { width: 54px; height: 54px; }
    .c-college__audience-closing-icon svg { width: 26px; height: 26px; }
    .c-college__audience-closing { font-size: 14px; }
    .c-college__audience-closing strong { font-size: 16px; }
    .c-college__audience-mascot { width: 96px; bottom: -4px; right: 6px; }
}

/* ---- ブロック⑧ 訴求バッジ + CTA ---- */
.c-college__benefits {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin: 0 auto 50px;
    max-width: 1000px;
}
.c-college__benefit {
    background: #fff;
    color: #d85b2d;
    border-radius: 0;
    padding: 24px 16px 20px;
    text-align: center;
    font-weight: bold;
    box-shadow: 0 6px 0 rgba(120,35,15,0.3);
    position: relative;
}
.c-college__benefit-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    background: #d85b2d;
    border-radius: 50%;
    margin: 0 auto 10px;
}
.c-college__benefit-icon svg { width: 28px; height: 28px; fill: #fff; }
.c-college__benefit-text { font-size: 18px; line-height: 1.45; color: #202e42; font-weight: bold; }
@media (max-width: 768px) {
    .c-college__benefits { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .c-college__benefit { padding: 20px 12px 18px; }
    .c-college__benefit-icon { width: 44px; height: 44px; }
    .c-college__benefit-icon svg { width: 22px; height: 22px; }
    .c-college__benefit-text { font-size: 14px; }
}

.c-college__final-cta {
    background: #fff;
    border-radius: 0;
    padding: 50px 40px;
    max-width: 1000px;
    margin: 120px auto 0;
    text-align: center;
    position: relative;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}
@media (max-width: 768px) {
    .c-college__final-cta { margin-top: 72px; }
}
.c-college__final-cta-sticker {
    position: absolute;
    top: -30px;
    left: 30px;
    width: 90px;
    height: 90px;
    background: #ffd149;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #b53c16;
    font-weight: bold;
    font-size: 18px;
    transform: rotate(-8deg);
    box-shadow: 0 4px 0 rgba(120,35,15,0.25);
    z-index: 2;
}
.c-college__final-cta-lead {
    font-size: 14px;
    color: #d85b2d;
    font-weight: bold;
    margin: 0 0 12px;
    position: relative;
    display: inline-block;
}
.c-college__final-cta-lead::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    height: 8px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 8' preserveAspectRatio='none'><path d='M2 4 Q 15 1, 30 4 T 60 4 T 90 4 T 118 4' stroke='%23ffaa78' stroke-width='2' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
}
.c-college__final-cta-title {
    font-size: 28px;
    font-weight: bold;
    color: #202e42;
    margin: 0 0 16px;
    line-height: 1.4;
}
.c-college__final-cta-title .is-mark {
    background: linear-gradient(180deg, transparent 60%, #ffd149 60%);
    padding: 0 6px;
    color: #b53c16;
}
.c-college__final-cta-sub {
    font-size: 14px;
    color: #555;
    margin: 0 0 28px;
}
.c-college__final-cta-sub strong { color: #d85b2d; font-size: 18px; }
.c-college__final-cta-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 760px;
    margin: 0 auto;
}
.c-college__final-cta-button {
    position: relative;
    display: block;
    background: #d85b2d;
    color: #fff !important;
    padding: 34px 20px 18px 60px;
    border-radius: 100px;
    font-weight: bold;
    font-size: 17px;
    line-height: 1.3;
    text-decoration: none;
    text-align: left;
    box-shadow: 0 6px 0 rgba(120,35,15,0.35);
    transition: transform .2s ease, box-shadow .2s ease;
}
.c-college__final-cta-button:hover {
    transform: translateY(2px);
    box-shadow: 0 4px 0 rgba(120,35,15,0.35);
}
.c-college__final-cta-button::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M19 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V5a2 2 0 0 0-2-2zm-5 3h2v2h-2V6zm0 4h2v2h-2v-2zM8 6h4v2H8V6zm0 4h4v2H8v-2zm-2 6h12v2H6v-2z'/></svg>") no-repeat center/contain;
}
.c-college__final-cta-button.is-yellow {
    background: #ffd149;
    color: #b53c16 !important;
    box-shadow: 0 6px 0 rgba(178,119,0,0.35);
}
.c-college__final-cta-button.is-yellow:hover {
    box-shadow: 0 4px 0 rgba(178,119,0,0.35);
}
.c-college__final-cta-button.is-yellow::before {
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23b53c16'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8l-6-6zm0 7V3.5L19.5 9H14z'/></svg>") no-repeat center/contain;
}
.c-college__final-cta-button-tag {
    position: absolute;
    top: -14px;
    left: 20px;
    background: #f5e6c8;
    color: #b53c16;
    padding: 6px 18px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.02em;
    border: 1.5px solid #e9d5a8;
    box-shadow: 0 4px 10px rgba(80, 20, 5, 0.14);
}
.c-college__final-cta-button-tag::after {
    content: "";
    position: absolute;
    bottom: -6px;
    left: 22px;
    width: 10px;
    height: 10px;
    background: #f5e6c8;
    border-right: 1.5px solid #e9d5a8;
    border-bottom: 1.5px solid #e9d5a8;
    transform: rotate(45deg);
}
.c-college__final-cta-button.is-yellow .c-college__final-cta-button-tag {
    background: #f5e6c8;
    color: #b53c16;
    border-color: #e9d5a8;
}
.c-college__final-cta-button.is-yellow .c-college__final-cta-button-tag::after {
    background: #f5e6c8;
    border-right-color: #e9d5a8;
    border-bottom-color: #e9d5a8;
}
.c-college__final-cta-button-sub {
    display: block;
    font-size: 11px;
    font-weight: normal;
    margin-top: 2px;
    line-height: 1.4;
    opacity: 0.85;
}
.c-college__final-cta-button-arrow {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,0.25);
    display: flex;
    align-items: center;
    justify-content: center;
}
.c-college__final-cta-button.is-yellow .c-college__final-cta-button-arrow { background: rgba(181,60,22,0.2); }
.c-college__final-cta-button-arrow svg { width: 14px; height: 14px; }

@media (max-width: 768px) {
    .c-college__final-cta { padding: 60px 20px 40px; }
    .c-college__final-cta-sticker { width: 70px; height: 70px; font-size: 14px; left: 10px; top: -20px; }
    .c-college__final-cta-title { font-size: 20px; }
    .c-college__final-cta-buttons { grid-template-columns: 1fr; gap: 28px; }
    .c-college__final-cta-button { font-size: 15px; padding: 30px 16px 16px 54px; }
}

/* ===== ヘッダー: 中間幅でサブテキストをロゴ下に回り込ませる ===== */
@media screen and (max-width: 105em) and (min-width: 48.0625em) {
    .l-header__content {
        height: auto;
        min-height: 4.75rem;
        padding-top: 0.4rem;
        padding-bottom: 1.25rem;
        position: relative;
        align-items: center;
    }
    .l-header__sub {
        position: absolute;
        bottom: 0.2rem;
        left: 1rem;
        margin-left: 0;
        font-size: 0.7rem;
        line-height: 1.25;
        white-space: nowrap;
        color: #1c2f44;
        transform: translateY(-9px);
    }
    .l-header__sub br { display: none; }
    .l-header__button { height: 100%; }
}
/* ナビ縮小は1400px以下から（早すぎる縮小を抑制） */
@media screen and (max-width: 87.5em) and (min-width: 48.0625em) {
    .l-header__mainmenu {
        column-gap: 0.5rem;
        margin-right: 0.75rem;
    }
    .l-header__mainmenu li a {
        font-size: 0.78rem;
        letter-spacing: 0.02em;
        line-height: 1.2;
        white-space: nowrap;
    }
    .l-header__mainmenu li a::after {
        margin-left: 0.25rem;
        width: 0.85rem;
        height: 0.85rem;
    }
    /* お申込みボタンの幅と文字サイズを最適化、高さはヘッダー全体に */
    .l-header__button {
        width: 12rem;
        font-size: 0.8rem;
        letter-spacing: 0;
        column-gap: 0.5rem;
        padding: 0 0.75rem;
        line-height: 1.3;
        align-self: stretch;
        height: auto;
        margin-top: -0.4rem;
        margin-bottom: -1.25rem;
    }
    .l-header__button::before {
        width: 1.1rem;
        height: 1.1rem;
        flex-shrink: 0;
    }
}
