@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@100;300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@100;300;400;500;700&display=swap");

/* ===================================
   基本スタイル
   =================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
    line-height: 1.7;
    color: #333;
    background-color: #fff;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    text-decoration: none;
    color: inherit;
    transition: opacity 0.3s;
}

a:hover {
    opacity: 0.7;
}

.l-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}
.color-red {
    color:#F74611;
}
/* ===================================
   ヘッダー
   =================================== */
.p-header {
    background-color: #5e7bbc;
    padding: 15px 0;
    width: 100%;
    position: fixed;
    z-index: 9999;
}

.p-header__logo {
    display: flex;
}

.p-header__logo img {
    display: block;
    max-width: 240px;
    height: auto;
}



/* ===================================
   メインビジュアル
   =================================== */
/* .p-hero {
    background: linear-gradient(135deg, #ffe5f5 0%, #fff 100%);
    padding: 60px 20px;
    position: relative;
} */
.p-hero {
    width: 100%;
    padding-top: 72px;

}

.p-hero__inner {
    line-height: 0; /* 画像下の隙間防止 */
}

.p-hero__img {
    width: 100%;
    height: auto;
    display: block;
}

.is-pc {
    display: block !important;
}
.is-sp {
    display: none !important;
}
.u-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* 親要素：中央配置の設定 */
.p-flyer-link {
    padding: 30px 20px;
    background-color: #f9f9f9;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* ボタンのデザイン */
.c-btn-flyer {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    /* 指定色 #F74611 をベースにしたグラデーション */
    background: linear-gradient(to bottom, #f74611, #d63a0a);
    color: #fff;
    text-decoration: none;
    padding: 16px 40px;
    border-radius: 50px;
    font-weight: bold;
    font-size: 1.1rem;
    box-shadow: 0 4px 15px rgba(247, 70, 17, 0.3);
    transition: all 0.3s ease;
    margin: 0 auto;
}

/* アイコン部分 */
.c-btn-flyer__icon {
    background: #fff;
    color: #f74611; /* 文字色に指定色を適用 */
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 4px;
    margin-right: 15px;
    font-weight: 900;
}

/* ホバー時の挙動 */
.c-btn-flyer:hover {
    transform: translateY(-3px);
    /* ホバー時は少し明るく、またはシャドウを強く */
    box-shadow: 0 8px 25px rgba(247, 70, 17, 0.5);
    opacity: 0.9;
    color: #fff;
}

/* スマホ用の調整 */
@media screen and (max-width: 768px) {
    .p-flyer-link {
        padding: 20px 15px;
    }
    
    .c-btn-flyer {
        width: 100%;
        max-width: 400px;
        font-size: 0.9rem;
        padding: 14px 15px;
    }
}
/* .p-hero__content {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 40px;
    align-items: center;
}

.p-hero__start-date {
    font-size: 24px;
    font-weight: bold;
    color: #FE47B4;
    margin-bottom: 20px;
}

.p-hero__title {
    margin-bottom: 20px;
}

.p-hero__title-sub {
    display: block;
    font-size: 36px;
    color: #FE47B4;
    font-weight: bold;
    line-height: 1.2;
}

.p-hero__title-main {
    display: block;
    font-size: 72px;
    color: #FE47B4;
    font-weight: bold;
    line-height: 1;
    text-shadow: 2px 2px 0 #fff;
}

.p-hero__title-date {
    font-size: 28px;
    color: #FE47B4;
    font-weight: bold;
    margin-bottom: 15px;
}

.p-hero__note {
    font-size: 12px;
    line-height: 1.6;
    color: #666;
}

.p-hero__badge {
    background-color: #4169b0;
    color: #fff;
    padding: 20px;
    border-radius: 10px;
    text-align: center;
}

.p-hero__badge-text {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.4;
} */

/* ===================================
   成績保証セクション
   =================================== */
.p-message {
    padding: 40px 20px;
}

.p-message__inner {
    padding: 30px;
    text-align: center;
}

.p-message__title {
    font-size: 28px;
    color: #FF6F05;
    font-weight: bold;
    margin-bottom: 15px;
}

.p-message__text {
    font-size: 18px;
    color: #333;
}

/* ===================================
   ポイントセクション
   =================================== */
.p-features {
    padding: 60px 20px;
    background-color: #f9f9f9;
}
.p-feature-subtitle {
    display: block;
    font-size: 16px;
    font-weight: 400;
    line-height: 1;
}
.p-feature-card {
    background-color: #fff;
    padding: 30px;
    margin-bottom: 30px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.p-feature-card__badge {
    display: inline-block;
    background-color: #ffd700;
    color: #333;
    padding: 8px 20px;
    border-radius: 20px;
    font-weight: bold;
    font-size: 14px;
    margin-bottom: 15px;
}

.p-feature-card__title {
    font-size: 24px;
    color: #4169b0;
    font-weight: bold;
    margin-bottom: 15px;
}

.p-feature-card__text {
    font-size: 16px;
    line-height: 1.8;
    margin-bottom: 15px;
}

.point-schools {
    margin-top: 20px;
}

.school-badge {
    background-color: #FE47B4;
    color: #fff;
    padding: 15px;
    border-radius: 10px;
    text-align: center;
    margin-bottom: 15px;
}

.school-count {
    font-size: 32px;
    font-weight: bold;
}

.school-list {
    font-size: 14px;
    line-height: 1.8;
}

.p-results-summary{
  border:2px solid #CFCFCF;
  box-sizing:border-box;
  position:relative;
  overflow:hidden;
  border-radius: 10px;
  padding: 12px 18px;
}


/* 合格実績エリア */

/* R7入試実績 */
.p-results-summary__header{
    display:flex;
    align-items:stretch;
    gap:0;
    flex-direction: column;
    margin-bottom: 1.2em;
}

.p-results-summary__era{
    background-color:#C7E1F5;
    padding: 0.5em 1.5em;
    align-content: center;
    font-weight:800;
    border-radius: 4px;
    text-align: center;
}
.p-results-summary__scope {
    text-align: center;
    font-size: 28px;
    font-weight: 700;
    transform: translateY(18px);
    color: #4169b0;
}
.result-unit {
    font-size: 28px;
    display: inline-block;
    margin-left: 5px;
}
.p-results-summary__main-result{
    display:grid;
    grid-template-columns: 1fr auto auto;
    justify-content: space-between;
    align-items: center;
    padding:2px 6px;
    box-sizing:border-box;
}
.p-results-summary__main-schools {
    font-weight:900;
    font-size:1.5em;
    letter-spacing:.02em;
}
.p-results-summary__total{
    box-sizing:border-box;
    font-size: 48px;
    font-weight: 800;
}
.p-results-summary__total span{
    font-weight:1000;
    font-size:20px;
    line-height:1;
    letter-spacing:.02em;
    white-space:nowrap;
}

/* 合格実績例 */
.p-results-list__label {
    background-color:#61C0B5;
    font-weight:800;
    box-sizing:border-box;
    white-space:nowrap;
    width: fit-content;
    padding: 4px 1.5em;
    border-radius: 4px;
    margin-bottom: 12px;
}
.p-results-list__text {
    border-bottom: 1px solid #cfcfcf;
    line-height: 2.5em;
}
/* 本文（行） */
.p-results-list__grid-item{
    display:grid;
    grid-template-columns: 1fr auto auto;
    line-height: 2.5em;
    border-bottom: 1px solid #cfcfcf;
}

.p-feature-card__highlight-title {
  margin-bottom: 8px;
  color: #F74611;
}
.c-definition-list {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px 24px;
}
.c-definition-list dt {
  background-color: #F74611;
  border-radius: 4px;
  height: fit-content;
  padding: 0 8px;
  text-align: center;
  color: #fff;
}
/* ===================================
   合格実績セクション
   =================================== */
.results {
    padding: 60px 20px;
    background-color: #fff;
}

.c-section-title {
    font-size: 32px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 40px;
    color: #333;
    padding: 20px;
    border-bottom: 3px solid #4169b0;
}
.p-achievements__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 30px;
    margin-bottom: 30px;
}
.p-achievement-box {
    padding: 30px;
    border-radius: 10px;
    /* color: #fff; */
}
.p-achievement-box > div:not(:last-child) {
  border-bottom: 2px solid #CFCFCF;
  margin-bottom: 12px;
  padding-bottom: 12px;
}

.p-achievement-box__group {
  margin-bottom: 16px;
}

.c-section-title--pink {
    background-color: #FE47B4;
    color: #fff;
    border: none;
    border-radius: 10px;
}

/* .section-title.gray-bg {
    background-color: #666;
    color: #fff;
    border: none;
    border-radius: 10px;
} */


.p-achievement-box--orange {
    border: 4px solid #F8B72C;
}
.color--orange {
  color: #F8B72C;
}
.p-achievement-box--green {
    border: 4px solid #45B035;
}
.color--green {
  color: #45B035;
}
.p-achievement-box--blue {
    border: 4px solid #3E82B8;
}
.color--blue {
  color: #3E82B8;
}
.p-achievement-box__title {
    text-align: center;
    margin-bottom: 20px;
    border-bottom: 2px solid #CFCFCF;
    font-size: 1.2em;
}
.bg-yellow {
  background-color: #FFFDE4;
  padding: 0.5em 1em;
  border-radius: 8px;
}
.bg-gray {
  background-color: #f4f4f4;
  padding: 0.5em 1em;
  border-radius: 8px;
}
.p-achievement-box__main {
  display: grid;
  grid-template-columns: 1fr auto auto;
  column-gap: 12px;
  align-items: center;
  margin-bottom: 8px;
}
.p-achievement-box__school-name {
  grid-column: 1 / 2;
  text-align: center;
  font-weight: 800;
  line-height: 1.2em;
}
.p-achievement-box__number {
  grid-column: -2 / -1;
  white-space: nowrap;
  font-size: 32px;
  font-weight: bold;
  line-height: 1;
}
.p-achievement-box__note-inline {
  text-orientation: mixed;
  font-size: 12px;
  line-height: 1.2;
  white-space: nowrap;
  text-align: center;
}
.p-achievement-box__note {
  grid-column: 1 / -1;
  /* margin-top: 6px; */
  text-align: center;
  font-size: 12px;
}
.p-achievement-box__unit {
  display: inline-block;
  font-size: 14px;
}
.school-name--wrap {
  font-size: 14px;
}
.c-school-results {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 12px;
  row-gap: 8px;
}
.c-school-results dt{
    background-color: #C7E1F5;
    width: 5em;
    text-align: center;
    height: fit-content;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
}
.c-school-results dd {
  font-size: 12px;
}
.p-achievement-box__target-schools {
  background-color: #C7E1F5;
  text-align: center;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 8px;
}
.p-achievement-box__result-details {
  font-size: 12px;
}
.p-achievement-box__summary > p {
  font-size: 13px;
}
.p-achievement-box__result-lead {
  font-size: 12px;
  text-align: center;
  margin-bottom: 8px;
  line-height: 1.2;
}
.result-number-sub {
    font-size: 48px;
    font-weight: bold;
}

/* ===================================
   開講期間セクション
   =================================== */
.p-schedule {
    padding: 60px 20px;
}

.p-schedule__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    max-width: 800px;
    margin: 0 auto;
}

.p-schedule__box {
    background-color: #fff;
    padding: 40px;
    border-radius: 10px;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.p-schedule__label {
    font-size: 28px;
    color: #FE47B4;
    font-weight: bold;
    margin-bottom: 20px;
}

.p-schedule__date {
    font-size: 32px;
    color: #333;
    font-weight: bold;
}

.u-small-date {
    font-size: 20px;
}

/* ===================================
   受講料金セクション
   =================================== */
.p-pricing {
    padding: 60px 20px;
    background-color: #f9f9f9;
}

.p-pricing__note {
    background-color: #fff;
    padding: 20px;
    border-left: 5px solid #4169b0;
    margin-bottom: 40px;
    margin-top: 40px;
    font-size: 14px;
    line-height: 1.8;
}

.p-pricing__tables {
    margin-bottom: 20px;
    background-color: #fff;
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.p-pricing__category:not(:last-child) {
    margin-bottom: 60px; 
}

.c-table-caption {
    font-size: 24px;
    font-weight: bold;
    color: #FE47B4;
    margin-bottom: 20px;
    text-align: center;
    padding: 10px;
    background-color: #fff3f3;
    border-radius: 5px;
}

.c-price-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.c-price-table th,
.c-price-table td {
    border: 1px solid #ddd;
    padding: 12px 8px;
    text-align: center;
}

.c-price-table th {
    background-color: #4169b0;
    color: #fff;
    font-weight: bold;
}

.c-price-table .price {
    color: #FE47B4;
    font-weight: bold;
    font-size: 16px;
}

.u-note {
    font-size: 12px;
    color: #666;
    text-align: center;
    margin-top: 20px;
}

/* ===================================
   春の3大特典セクション
   =================================== */
.p-benefits {
    padding: 60px 20px;
    background-color: #fff3f3;
    text-align: center;
}

.p-benefits__main {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
}
.p-benefits__big-text {
    font-size: 32px;
    font-weight: bold;
    color: #FE47B4;
    line-height: 1.2;
    text-align: center;
}
.p-benefits__arrow-group {
  text-align: center;
  padding: 24px 0;
}
.p-benefits__arrow {
  padding-right: 24px !important;
}
.p-benefits__arrow::before{
	left: 4px;
	box-sizing: border-box;
	border: 24px solid transparent;
	border-left: 20px solid #FE47B4;
    rotate: 90deg;
}
.p-benefits__free-card {
    background-color: #fff;
    border: 4px solid #FE47B4;
    border-radius: 24px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.2);
    padding: 8px 2em;
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 4em;
    align-items: center
}
.benefit-free {
    text-align: center;
}
.p-benefits__free-title {
    font-size: 42px;
    color: #FE47B4;
    font-weight: bold;
    position: relative;
    z-index: 50;
    text-align: center;
    width: fit-content;
}

.p-benefits__free-sub {
    font-size: 42px;
    color: #FE47B4;
    font-weight: bold;
    position: relative;
    z-index: 50;
    text-align: center;
    width: fit-content;
}

.p-benefits__free-main {
    font-size: 64px;
    color: #FE47B4;
    font-weight: bold;
    margin: 10px 0;
    text-align: center;
    line-height: 1;
}
.p-benefits__free-main > span {
  display: block;
  font-size: 24px;
}
.p-benefits__free-price {
    font-size: 42px;
    color: #FE47B4;
    font-weight: bold;
    position: relative;
    z-index: 50;
    text-align: center;
}
.p-benefits__free-price > span {
  font-size: 28px;
}

.p-benefits__free-title::after,
.p-benefits__free-sub::after,
.p-benefits__free-price::after {
  content: "";
  height: 12px;
  width: 100%;
  background-color: #ffd700;
  position: absolute;
  bottom: 12px;
  left: 0;
  z-index: -10;
}
.p-benefit-item__title,
.p-benefits__arrow {
    position: relative;
    display: inline-block;
}
.p-benefit-item__title::before,
.p-benefit-item__title::after,
.p-benefits__arrow::before,
.p-benefits__arrow::after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.p-benefit-item__title::before{
    width: 42px;
    height: 42px;
    border-radius: 25%;
    background: #61C0B5;
}
.p-benefit-item__title::after{
    left: 16px;
    box-sizing: border-box;
    width: 15px;
    height: 15px;
    border: 10px solid transparent;
    border-left: 14px solid #fff;
}
.p-benefit-item__title {
  padding-left: 60px;
}
.p-benefits__arrow {
  padding-left:42px ;
}
.p-benefits__list {
    display: grid;
    gap: 20px;
}

.p-benefit-item {
    background-color: #fff;
    padding: 25px;
    border-radius: 10px;
    display: flex;
    align-items: flex-start;
    gap: 20px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.p-benefit-item__number {
    background-color: #FE47B4;
    color: #fff;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: bold;
    flex-shrink: 0;
}

.p-benefit-item__content h3 {
    font-size: 20px;
    color: #4169b0;
    font-weight: bold;
    margin-bottom: 10px;
}

.p-benefit-item__content p {
    font-size: 14px;
    line-height: 1.8;
}

/* ===================================
   テスト結果セクション
   =================================== */
.p-test-results {
    padding: 60px 20px;
    background-color: #f9f9f9;
}

.p-test-results__box {
    background-color: #fff;
    border: 3px solid #FE47B4;
    border-radius: 10px;
    padding: 30px;
    /* display: grid;
    grid-template-columns: 300px 1fr;
    gap: 30px; */
    align-items: center;
}
.c-achievement-badge {
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: 12px;
}
.p-test-results__badge-side {
    border-radius: 10px;
    text-align: center;
}

.c-achievement-badge__era {
    font-size: 16px;
    margin-bottom: 10px;
}
.c-achievement-badge__title > span {
  font-size: 18px;
  margin-right: 1em;
}
.c-achievement-badge__number {
    font-size: 42px;
    font-weight: bold;
    line-height: 1;
    margin-bottom: 10px;
}
.p-test-results__lead {
  text-align: center;
}
.c-achievement-badge__unit {
    font-size: 24px;
}

.p-test-results__content {
    font-size: 14px;
    line-height: 1.8;
}
.p-test-room {
    margin-top: 20px;
    padding: 15px;
    background-color: #fff3f3;
    border-radius: 5px;
}
.p-test-room >div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  margin-bottom: 18px;
  background-color: #fff;
  align-items: center;
  padding: 4px 12px;
  border-radius: 4px;
}
.c-achievement-badge__era {
    color: #fff;
    background-color: #FE47B4;
    padding: 4px;
}
.c-achievement-badge__title {
  font-size: 24px;
  font-weight: 700;
}
.c-rank-list {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr;
  gap: 8px 18px;
  margin-bottom: 18px;
}
.c-rank-list > dt {
  background-color: #C7E1F5;
  border-radius: 4px;
  text-align: center;
  padding: 0 8px;
  height: fit-content;
}
/* ===================================
   教室アクセスセクション
   =================================== */
.access {
    padding: 60px 20px;
    background-color: #fff;
}

.p-access__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
}

.p-access__card {
    background-color: #f9f9f9;
    padding: 25px;
    border-radius: 10px;
    text-align: center;
    border: 2px solid #4169b0;
}

.p-access__name {
    font-size: 20px;
    font-weight: bold;
    color: #4169b0;
    margin-bottom: 15px;
}

.p-access__info {
    font-size: 14px;
    margin-bottom: 10px;
    line-height: 1.6;
}

.p-access__tell {
    font-size: 18px;
    font-weight: bold;
    color: #FE47B4;
}
.p-access__time-note {
  text-align: center;
}
/* ===================================
   ctaセクション
   =================================== */
.p-cta {
    padding: 80px 20px;
    background: linear-gradient(135deg, #4169b0 0%, #1e3a8a 100%);
    color: #fff;
    text-align: center;
}

.p-cta__title {
    font-size: 42px;
    font-weight: bold;
    margin-bottom: 20px;
}

.p-cta__text {
    font-size: 18px;
    margin-bottom: 40px;
}

.p-cta__btns {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

.c-btn--primary,
.c-btn--secondary {
    padding: 18px 50px;
    border-radius: 50px;
    font-size: 18px;
    font-weight: bold;
    display: inline-block;
    transition: transform 0.3s, box-shadow 0.3s;
}

.c-btn--primary {
    background-color: #FE47B4;
    color: #fff;
}

.c-btn--secondary {
    background-color: #fff;
    color: #4169b0;
}

.c-btn--primary:hover,
.c-btn--secondary:hover {
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

.p-cta__contact-info {
    font-size: 14px;
}

.p-cta__contact-info-time {
    margin-bottom: 10px;
    font-weight: bold;
}

.p-cta__contact-info-note {
    opacity: 0.9;
}

/* ===================================
   フッター
   =================================== */
.l-footer {
    background-color: #333;
    color: #fff;
    padding: 30px 20px;
    text-align: center;
}

.l-footer__logo {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
}

.l-footer__copy {
    font-size: 12px;
    opacity: 0.7;
}

/* ===================================
   レスポンシブ対応
   =================================== */
@media (max-width: 768px) {
    .l-container {
      padding:0 12px;
    }

    .is-pc {
        display: none !important;
    }
    
    .is-sp {
        display: block !important;
    }
    .p-header {
        padding: 10px 0;
    }
    .p-header__logo {
        justify-content: center;
    }
    .p-header__logo img {
        max-width: 180px;
    }
    .p-hero {
        padding-top: 58px;
    }
    .p-hero__content {
        grid-template-columns: 1fr;
    }

    .p-hero__start-date {
        font-size: 18px;
    }

    .p-hero__title-sub {
        font-size: 32px;
    }

    .p-hero__title-date {
        font-size: 28px;
    }

    .p-hero__title-main {
        font-size: 56px;
    }

    /* .hero-fee {
        font-size: 22px;
    } */

    .p-hero__badge-text {
        font-size: 16px;
    }

    .p-message__title {
        font-size: 22px;
    }

    .p-message__text {
        font-size: 16px;
    }
    .p-features,
    .p-schedule,
    .p-benefits {
      padding: 40px 12px;
    }
    .p-test-results {
      padding: 20px 12px;
    }
    .p-feature-card {
      padding: 12px;
    }
    .p-feature-card__title {
        font-size: 20px;
    }

    .p-feature-card__text {
        font-size: 14px;
    }
    
    .p-results-summary {
      padding: 12px;
    }
    .p-results-summary__era {
      width: 100%;
      align-self: center;
      text-align: center;
    }
    .p-results-summary__scope {
      font-size: 18px;
      transform: translateY(8px);
    }
    .p-results-list__label {
      margin: auto;
    }
    .p-results-summary__main-schools {
      font-size: 16px;
      white-space: unset;
      line-height: 20px;
    }
    .p-results-summary__main-result {
      grid-template-columns: 1fr auto auto;
    }
    .p-results-list__text,
    .p-results-list__school {
      line-height: 1.2em;
      font-size: 14px;
      padding-bottom: 8px;
      padding-top: 8px;
    }
    .p-results-list__grid-item {
      grid-template-columns: 1fr auto auto;
      line-height: 1.2em;
      font-size: 14px;
      align-items: center;
    }
    .p-results-summary__total {
      font-size: 24px;
    }
    .p-results-summary__total span {
      font-size: 12px;
    }
    .c-section-title {
        font-size: 24px;
    }

    .p-achievements__grid {
        grid-template-columns: 1fr;
        
    }
    .p-achievement-box__main {
      grid-template-columns: auto auto auto;
      justify-content: center;
    }
    /* .p-achievement-box__number {
        font-size: 56px;
    } */
    /* .c-school-results {

    } */
    .p-schedule__grid {
        grid-template-columns: 1fr;
        gap: 12px;
        margin-bottom: 18px;
    }
    .p-schedule__box {
        padding: 18px;
    }
    .p-schedule__label {
      margin-bottom: 0;
    }
    /* .p-pricing__category {
      padding: 12px;
    } */
    .p-pricing__tables {
        grid-template-columns: 1fr;
        padding: 12px;
    }
    .p-pricing__category:not(:last-child) {
        margin-bottom: 32px;
    }
    .p-benefits__highlight {
        flex-direction: column;
        text-align: center;
    }

    .p-benefits__big-text {
        writing-mode: horizontal-tb;
        font-size: 28px;
    }
    .p-benefits__free-title,
    .p-benefits__free-sub,
    .p-benefits__free-price {
        font-size: 32px;
    }
    .p-benefits__free-main {
        font-size: 42px;
    }

    .p-benefit-item {
        flex-direction: column;
        /* text-align: center; */
        padding: 12px;
    }
    .p-benefit-item__title::before {
      width: 38px;
      height: 38px;
    }
    .p-benefit-item__title::after {
      left: 14px;
    }
    .p-test-results__box {
        grid-template-columns: 1fr;
        padding: 12px;
    }

    .c-achievement-badge__number {
        font-size: 56px;
    }

    .p-access__grid {
        grid-template-columns: 1fr 1fr;
    }

    .p-cta__title {
        font-size: 32px;
    }

    .p-cta__btns {
        flex-direction: column;
        align-items: stretch;
    }

    .c-btn--primary,
    .c-btn--secondary {
        width: 100%;
    }

    .c-price-table {
        font-size: 12px;
    }

    .c-price-table th,
    .c-price-table td {
        padding: 8px 4px;
    }
}

@media (max-width: 480px) {
    .p-hero__title-sub {
        font-size: 28px;
    }

    .p-hero__title-date {
        font-size: 24px;
    }

    .p-hero__title-main {
        font-size: 48px;
    }
    .p-features, .p-schedule, .p-benefits {
        padding: 20px 12px;
    }
    .c-section-title {
      font-size: 18px;
      padding: 0;
      margin-bottom: 20px;
    }
    .p-feature-subtitle {
      font-size: 14px;
    }
    .p-schedule__box {
      padding: 8px;
    }
    .p-schedule__label {
      font-size: 16px;
    }
    .p-schedule__date {
      font-size: 18px;
    }
    .p-pricing__note {
      padding: 8px;
      font-size: 12px;
    }
    /* .c-price-table {
        font-size: 12px;
        padding: 15px 10px;
    } */
    .c-table-caption {
        font-size: 18px;
        padding: 4px;
    }
    .p-benefits__big-text {
      font-size: 18px;
    }
    .p-benefits__free-card {
      padding: 4px 18px;
          column-gap: 1em;
    }
    .p-benefits__free-title, .p-benefits__free-sub, .p-benefits__free-price {
      font-size: 24px;
    }
    .p-benefits__free-price > span {
      font-size: 16px;
    }
    .p-benefits__free-title::after,
    .p-benefits__free-sub::after,
    .p-benefits__free-price::after {
      height: 4px;
      bottom: 8px;
    }
    /* .p-achievement-box__number {
        font-size: 48px;
    } */
    .c-definition-list {
      display: unset;
    }

    .p-cta__title {
        font-size: 28px;
    }

    .p-benefits__free-main {
        font-size: 28px;
    }
    .p-benefits__free-main > span {
      font-size: 18px;
    }
    .p-benefits__arrow::before {
      border: 18px solid transparent;
      border-left: 16px solid #FE47B4;
    }
    .p-benefits__arrow {
      padding-left: 28px;
    }
    .p-benefit-item__title::before {
        width: 24px;
        height: 24px;
    }
    .p-benefit-item__title::after {
        left: 9px;
        width: 8px;
        height: 8px;
        border: 7px solid transparent;
        border-left: 9px solid #fff;
    }
    .p-benefit-item__title {
        padding-left: 34px;

    }
    .p-benefit-item__content h3 {
        font-size: 16px;
    }
    .c-achievement-badge__number {
      font-size: 28px;
    }
    .c-achievement-badge__title > span {
      font-size: 14px;
    }
    .c-achievement-badge__title {
      font-size: 18px;
    }
    .c-achievement-badge__unit {
      font-size: 16px;
    }
    .p-test-results__lead {
      font-size: 14px;
    }
    .p-test-room >div {
      display: block;
    }
    .p-test-room__name {
      font-size: 14px;
      line-height: 1.2;
    }
    .p-test-room__summary {
      font-size: 12px;
      line-height: 1.5;
    }
    .c-rank-list {
    display: block;
    margin-bottom: 12px;
    }
    .c-rank-list > dd,
    .c-rank-list > dt {
      font-size: 12px;
    }
    .p-access__grid {
    grid-template-columns: 1fr;
    gap:8px;
    }
    .p-access__name {
      font-size: 16px;
    }
    .p-access__card {
      padding: 12px;
    }
}

/* --- 下部追従ボタン --- */
.c-floating-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    background: rgba(255, 255, 255, 0.9);
    padding: 10px 20px;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    display: flex;
    justify-content: center;
    align-items: center;
}

.c-floating-nav__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f74611;
    color: #fff !important;
    text-decoration: none !important;
    font-weight: bold;
    width: 100%;
    max-width: 600px;
    height: 56px;
    border-radius: 8px;
    font-size: 1.2rem;
}

.c-floating-nav__btn:hover {
    background-color: #d63a0a;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(247, 70, 17, 0.4);
}
.p-access {
    margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
    .c-floating-nav {
        padding: 8px 15px;
    }
    .c-floating-nav__btn {
        height: 50px;
        font-size: 1rem;
    }
    .p-access {
    margin-bottom: 70px;
    }
}


/* CTAセクション */
.p-cta-section {
    padding: 60px 20px;
    background-color: #fff3f3;
}
.p-cta-box {
    max-width: 1200px;
    margin: 0 auto;
    background: #fff;
    border: 3px solid #FE47B4;
    border-radius: 20px;
    padding: 50px 30px 40px;
    text-align: center;
    position: relative;
}
.p-cta-box__badge {
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    background: #FE47B4;
    color: #fff;
    padding: 8px 25px;
    border-radius: 50px;
    font-weight: bold;
    font-size: 1.1rem;
    white-space: nowrap;
}
.p-cta-box__title {
    font-size: 1.8rem;
    color: #FE47B4;
    margin-bottom: 25px;
    font-weight: bold;
}
.p-cta-box__benefits {
    display: flex;
    justify-content: center;
    gap: 20px;
    list-style: none;
    margin-bottom: 30px;
    padding: 0;
}
.p-cta-box__benefits li {
    background: #fff3f3;
    padding: 10px 15px;
    border-radius: 5px;
    font-size: 1rem;
    color: #FE47B4;
    font-weight: bold;
}
.p-cta-box__benefits li strong {
    font-size: 1.4rem;
    text-decoration: underline;
}
.p-cta-box__note {
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 30px;
    color: #666;
    text-align: left;
}
.c-btn-main {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 450px;
    padding: 12px 40px;
    background: #FE47B4;
    color: #fff !important;
    text-decoration: none !important;
    font-size: 1.4rem;
    font-weight: bold;
    border-radius: 50px;
    box-shadow: 0 6px 0 #cd3a92;
    transition: all 0.2s ease;
}
.c-btn-main:hover {
    transform: translateY(-3px);
    box-shadow: 0 9px 0 #cd3a92;
}
@media screen and (max-width: 768px) {
    .p-cta-section { padding: 40px 12px; }
    .p-cta-box { padding: 40px 12px 30px; }
    .p-cta-box__title { font-size: 18px; margin-bottom: 12px;}
    .p-cta-box__benefits { gap: 8px; margin-bottom: 18px;}
    .c-btn-main { font-size: 16px; padding: 4px 20px; }
    .p-cta-box__note { font-size: 12px; margin-bottom: 18px;}
    .p-cta-box__benefits li { padding: 4px 12px; font-size: 14px; }
    .p-cta-box__benefits li strong { font-size: 18px; display: block;}
}