/*
Theme Name: KIDS PLUS english
Theme URI: https://www.kidsplus.school/
Author: kids plus
Author URI: https://www.kidsplus.me/
Description: 保育園・幼稚園向けオンライン英会話「KIDS PLUS english」のオリジナルテーマ。無料体験予約（enスケジューラ）への導線とSEOを最優先に設計。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kidsplus-english
*/

/* =========================================================
   1. デザイントークン（配色・余白・角丸）
   既存イラストの世界観をそのまま変数化。色を変えたいときは
   ここだけ触れば全ページに反映される。
   ========================================================= */
:root {
  /* ブランドカラー（イラストの世界観） */
  --kp-pink:        #F4A6C0;   /* メインのピンク（リボン帯） */
  --kp-pink-light:  #FCEFF4;   /* 背景用のうすいピンク */
  --kp-pink-deep:   #993556;   /* ピンク系の文字色 */
  --kp-yellow:      #FAC775;   /* アクセントの黄色（帯・見出し） */
  --kp-yellow-deep: #633806;   /* 黄色背景の上に乗せる文字色 */
  --kp-green:       #C0DD97;   /* やわらかいグリーン（丸枠など） */
  --kp-green-deep:  #3B6D11;
  --kp-teal:        #5DCAA5;   /* ティール（対象年齢バッジ等） */
  --kp-teal-deep:   #0F6E56;

  /* CTA（予約ボタン）専用色 — サイト中でこの色は予約だけに使う */
  --kp-cta:         #D85A30;   /* 世界観に馴染むコーラル/オレンジ */
  --kp-cta-hover:   #BE4A24;
  --kp-cta-text:    #FFFFFF;

  /* 補助金バッジ用 */
  --kp-badge-bg:    #FAEEDA;
  --kp-badge-text:  #854F0B;

  /* テキスト・背景の基本色 */
  --kp-text:        #3D3A38;
  --kp-text-muted:  #6E6A66;
  --kp-bg:          #FFFFFF;
  --kp-bg-soft:     #FBF8F2;
  --kp-border:      #ECE6DD;

  /* レイアウト */
  --kp-radius:      12px;
  --kp-radius-pill: 999px;
  --kp-container:   1120px;
  --kp-gap:         24px;

  /* フォント */
  --kp-font: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Yu Gothic", Meiryo, sans-serif;
  --kp-font-pop: "Kosugi Maru", "Hiragino Maru Gothic ProN", sans-serif; /* 見出し用 丸ゴシック */
  --kp-font-deco: "Pacifico", cursive; /* enjoy! などの装飾英字 */
}

/* =========================================================
   2. リセット & ベース
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--kp-font);
  color: var(--kp-text);
  background: var(--kp-bg);
  line-height: 1.8;
  font-size: 16px;
}
img { max-width: 100%; height: auto; vertical-align: bottom; }
a { color: var(--kp-pink-deep); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { line-height: 1.4; font-weight: 700; margin: 0 0 0.5em; }
.kp-section__title,
.kp-hero__title,
.kp-cases__big,
.kp-hero-band p {
  font-family: var(--kp-font-pop);
  font-weight: normal;
}

/* =========================================================
   3. レイアウト共通
   ========================================================= */
.kp-container {
  width: 100%;
  max-width: var(--kp-container);
  margin-inline: auto;
  padding-inline: 20px;
}
.kp-section { padding-block: 64px; }
.kp-section--soft { background: var(--kp-bg-soft); }
.kp-section__title {
  font-size: clamp(22px, 4vw, 30px);
  text-align: center;
  color: var(--kp-pink-deep);
  margin-bottom: 8px;
}
.kp-section__lead {
  text-align: center;
  color: var(--kp-text-muted);
  margin-bottom: 40px;
}

/* =========================================================
   4. ボタン（CTA）
   .kp-btn--cta は予約専用色。サイト中で統一。
   ========================================================= */
.kp-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--kp-radius-pill);
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  transition: background .2s, transform .1s;
  cursor: pointer;
  border: none;
}
.kp-btn:hover { text-decoration: none; transform: translateY(-1px); }
.kp-btn--cta { background: var(--kp-cta); color: var(--kp-cta-text); }
.kp-btn--cta:hover { background: var(--kp-cta-hover); color: #fff; }
.kp-btn--ghost {
  background: #fff;
  color: var(--kp-pink-deep);
  border: 1.5px solid var(--kp-pink);
}
.kp-btn--ghost:hover { background: var(--kp-pink-light); }

/* 補助金バッジ */
.kp-badge {
  display: inline-block;
  background: var(--kp-badge-bg);
  color: var(--kp-badge-text);
  font-size: 13px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: var(--kp-radius-pill);
}

/* =========================================================
   5. ヘッダー
   ========================================================= */
.kp-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: #fff;
  border-bottom: 1px solid var(--kp-border);
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.kp-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-block: 12px;
}
.kp-header__logo img { height: 64px; width: auto; }
.kp-nav { display: flex; align-items: center; gap: 24px; }
.kp-nav a { color: var(--kp-pink-deep); font-weight: 700; }
.kp-header__cta { white-space: nowrap; }

/* スマホ用メニューボタン（初期は隠す） */
.kp-nav-toggle { display: none; background: none; border: none; cursor: pointer; font-size: 28px; color: var(--kp-pink-deep); }

/* =========================================================
   6. ヒーロー（ファーストビュー）
   ========================================================= */
.kp-hero {
  background: var(--kp-pink-light);
  overflow: hidden;
  position: relative;
  min-height: calc(100vh - 80px);
  display: flex;
  flex-direction: column;
}
/* 背景の斜めリボン（右側を大きく覆う） */
.kp-hero__ribbon {
  position: absolute;
  top: -100px;
  right: -60px;
  width: 60%;
  height: 130%;
  background: var(--kp-pink);
  opacity: .85;
  transform: rotate(8deg);
  border-radius: 80px;
  z-index: 0;
}
/* 装飾文字 enjoy!（手書き風フォント・テキスト） */
.kp-hero__enjoy {
  position: absolute;
  top: 4%;
  right: 6%;
  font-family: var(--kp-font-deco);
  font-size: clamp(80px, 13vw, 170px);
  color: #fff;
  opacity: .55;
  z-index: 1;
  pointer-events: none;
  line-height: 1;
}
.kp-hero__body {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  align-items: center;
}
.kp-hero__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 32px;
  align-items: center;
  width: 100%;
  padding-block: 48px;
}
.kp-hero__title {
  font-size: clamp(34px, 6.5vw, 60px);
  font-weight: normal;
  color: var(--kp-pink-deep);
  margin-block: 16px 16px;
  line-height: 1.3;
}
.kp-hero__sub {
  color: var(--kp-pink-deep);
  font-size: clamp(15px, 2.5vw, 19px);
  font-weight: 700;
  line-height: 1.8;
  margin-bottom: 28px;
}
.kp-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.kp-hero__actions .kp-btn--cta { font-size: 18px; padding: 18px 32px; }
.kp-hero__actions .kp-btn--ghost { font-size: 15px; padding: 18px 22px; }
.kp-hero__note { font-size: 14px; color: var(--kp-pink-deep); margin: 0; font-weight: 700; }

/* ビジュアル領域：写真とキャラを重ねて配置 */
.kp-hero__visual {
  position: relative;
  min-height: 660px;
}
.kp-hero__photo {
  position: absolute;
  border-radius: 50%;
  overflow: hidden;
  border: 8px solid #fff;
  box-shadow: 0 10px 28px rgba(153,53,86,.20);
}
.kp-hero__photo img,
.kp-hero__photo .kp-ph { width: 100%; height: 100%; object-fit: cover; display: block; }
.kp-hero__photo--1 { width: 300px; height: 300px; top: 20px;  left: -10px; border-color: var(--kp-green); z-index: 3; }
.kp-hero__photo--2 { width: 290px; height: 290px; top: 0;     right: 4%;   border-color: #fff;          z-index: 3; }
.kp-hero__photo--3 { width: 190px; height: 190px; top: 270px; left: 22%;   border-color: var(--kp-pink); z-index: 4; }
/* キャラクター群（下部中央に大きく・写真の前面に重ねる） */
.kp-hero__chars {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 112%;
  max-width: 820px;
  height: 420px;
  z-index: 5;
  pointer-events: none;
}
.kp-hero__chars img { width: 100%; height: 100%; object-fit: contain; object-position: center bottom; }
/* 対象年齢バッジ */
.kp-hero__age {
  position: absolute;
  top: 14px;
  right: -2%;
  z-index: 6;
  width: 108px; height: 108px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid var(--kp-teal);
  color: var(--kp-teal-deep);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; text-align: center;
  box-shadow: 0 4px 12px rgba(15,110,86,.15);
}
.kp-hero__age strong { font-size: 17px; }

/* 仮枠（画像未配置時のプレースホルダ） */
.kp-ph {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  background: repeating-linear-gradient(45deg, #f3e6ec, #f3e6ec 10px, #f7eef2 10px, #f7eef2 20px);
  color: var(--kp-pink-deep);
  font-weight: 700; gap: 4px; text-align: center;
}
.kp-ph span { font-size: 14px; }
.kp-ph small { font-size: 10px; opacity: .6; font-weight: 400; }
.kp-hero__chars .kp-ph {
  aspect-ratio: 16/7;
  border-radius: var(--kp-radius);
}

/* 黄色の帯（ヒーロー直後の独立セクション） */
.kp-hero-band {
  position: relative;
  z-index: 1;
  background: var(--kp-yellow);
  text-align: center;
  padding-block: 22px;
}
.kp-hero-band p {
  margin: 0;
  font-size: clamp(15px, 3vw, 21px);
  font-weight: 700;
  color: var(--kp-yellow-deep);
}

/* =========================================================
   7. 「不安に答える」カード
   ========================================================= */
.kp-reasons__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.kp-reason {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: #fff;
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  padding: 20px;
}
.kp-reason__icon {
  flex-shrink: 0;
  width: 48px; height: 48px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--kp-pink-light);
  color: var(--kp-pink-deep);
  font-size: 24px;
}
.kp-reason__q { font-weight: 700; margin: 0 0 4px; }
.kp-reason__a { margin: 0; color: var(--kp-text-muted); font-size: 14px; }

/* =========================================================
   8. セブのX発信セクション
   ========================================================= */
.kp-cebu { text-align: center; }
.kp-cebu__x {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  padding: 12px 24px;
  border-radius: var(--kp-radius-pill);
  background: #000;
  color: #fff;
  font-weight: 700;
}
.kp-cebu__x:hover { color: #fff; text-decoration: none; opacity: .85; }

/* =========================================================
   9. 予約（enスケジューラ埋め込み）
   ========================================================= */
.kp-booking { text-align: center; }
.kp-booking__embed {
  margin-top: 24px;
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  overflow: hidden;
  background: #fff;
}
.kp-booking__embed iframe {
  width: 100%;
  border: 0;
  display: block;
  height: 720px; /* enスケジューラの実ロード時サイズに合わせた予約値（レイアウトシフト防止）。フォーム展開時はJSで自動追従 */
}

/* =========================================================
   10. ブログ（投稿一覧・個別）
   ========================================================= */
.kp-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.kp-post-card {
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  overflow: hidden;
  background: #fff;
  transition: transform .15s;
}
.kp-post-card:hover { transform: translateY(-3px); }
.kp-post-card__thumb { aspect-ratio: 16/9; object-fit: cover; width: 100%; }
.kp-post-card__body { padding: 16px; }
.kp-post-card__cat { font-size: 12px; color: var(--kp-teal-deep); font-weight: 700; }
.kp-post-card__title { font-size: 16px; margin: 4px 0; }
.kp-post-card__date { font-size: 12px; color: var(--kp-text-muted); }

.kp-article { max-width: 760px; margin-inline: auto; }
.kp-article__title { font-size: clamp(22px, 4vw, 30px); color: var(--kp-pink-deep); }
.kp-article__meta { color: var(--kp-text-muted); font-size: 13px; margin-bottom: 24px; }
.kp-article__body { line-height: 2; }
.kp-article__body h2 { border-left: 5px solid var(--kp-yellow); padding-left: 12px; margin-top: 2em; }
.kp-article__body img { border-radius: var(--kp-radius); }

/* =========================================================
   11. フッター
   ========================================================= */
/* ===================================
   料金プラン要約（トップページ）
=================================== */
.kp-price-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 720px;
  margin: 24px auto 16px;
}
.kp-price-card {
  background: #fff;
  border: 2px solid var(--kp-pink-light);
  border-radius: var(--kp-radius);
  padding: 28px 24px;
  text-align: center;
  position: relative;
}
.kp-price-card--recommended { border: 3px solid var(--kp-cta); }
.kp-price-card__badge {
  position: absolute;
  top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--kp-cta);
  color: #fff;
  font-size: 12px; font-weight: 700;
  padding: 4px 16px;
  border-radius: var(--kp-radius-pill);
  white-space: nowrap;
}
.kp-price-card__name { margin: 0 0 4px; font-weight: 700; color: var(--kp-pink-deep); font-size: 17px; }
.kp-price-card__sub { margin: 0 0 8px; font-size: 12px; color: var(--kp-text-muted); }
.kp-price-card__price {
  margin: 8px 0 14px;
  font-size: 30px;
  font-weight: 700;
  color: var(--kp-pink-deep);
  font-family: var(--kp-font-pop);
  line-height: 1.1;
}
.kp-price-card__price span { font-size: 16px; }
.kp-price-card__price--cta { color: var(--kp-cta); }
.kp-price-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
  font-size: 13px;
  line-height: 1.9;
}
.kp-price-card__list li::before { content: '◎ '; color: var(--kp-teal-deep); font-weight: 700; }
.kp-price-summary__note {
  text-align: center;
  margin: 12px 0 20px;
  font-size: 12px;
  color: var(--kp-text-muted);
}

/* ===================================
   特徴カード（比較表の下のサマリー）
   AI生成でよくある「左に縦カラーライン」を避け、
   柔らかい影と微グラデーションで立体感を出す
=================================== */
.kp-feature-card {
  max-width: 760px;
  margin: 32px auto 0;
  padding: 26px 30px;
  background: linear-gradient(155deg, #fff 0%, #FFF8FB 100%);
  border-radius: 18px;
  box-shadow:
    0 10px 28px rgba(153, 53, 86, 0.10),
    0 2px 6px rgba(0, 0, 0, 0.03),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  position: relative;
}
.kp-feature-card__title {
  margin: 0 0 10px;
  font-weight: 700;
  color: var(--kp-pink-deep);
  font-size: 15px;
  letter-spacing: 0.02em;
}
.kp-feature-card__title span {
  margin-right: 4px;
  filter: drop-shadow(0 2px 3px rgba(153, 53, 86, 0.18));
}
.kp-feature-card__body {
  margin: 0;
  font-size: 14px;
  color: var(--kp-text);
  line-height: 1.9;
}

/* ===================================
   競合他社との比較表（/price/）
=================================== */
.kp-compare-wrap {
  max-width: 1080px;
  margin: 28px auto 0;
  overflow-x: auto; /* スマホで横スクロール */
  -webkit-overflow-scrolling: touch;
}
.kp-compare {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  background: #fff;
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  overflow: hidden;
  font-size: 13px;
}
.kp-compare thead th {
  background: var(--kp-bg-soft);
  color: var(--kp-text);
  font-weight: 700;
  padding: 14px 8px;
  text-align: center;
  border-bottom: 2px solid var(--kp-border);
  font-size: 12px;
  line-height: 1.3;
  white-space: nowrap;
}
.kp-compare thead th.kp-compare__feat-col {
  text-align: left;
  background: #fff;
  min-width: 130px;
}
.kp-compare thead th.kp-compare__us {
  background: var(--kp-pink-deep);
  color: #fff;
  font-size: 13px;
  position: relative;
}
.kp-compare tbody th {
  background: var(--kp-bg-soft);
  text-align: left;
  font-weight: 700;
  padding: 12px 12px;
  color: var(--kp-text);
  border-bottom: 1px solid var(--kp-border);
  white-space: nowrap;
}
.kp-compare tbody td {
  padding: 12px 8px;
  text-align: center;
  border-bottom: 1px solid var(--kp-border);
  color: var(--kp-text);
  vertical-align: middle;
}
.kp-compare tbody td.kp-compare__us {
  background: #FFF8FB;
  font-weight: 700;
  color: var(--kp-pink-deep);
}
.kp-compare tbody tr:last-child th,
.kp-compare tbody tr:last-child td { border-bottom: none; }
.kp-compare__ok {
  color: var(--kp-teal-deep);
  font-weight: 700;
}
.kp-compare__ng {
  color: var(--kp-text-muted);
}
.kp-compare__note {
  max-width: 1080px;
  margin: 14px auto 0;
  font-size: 12px;
  color: var(--kp-text-muted);
  line-height: 1.8;
}

/* ===================================
   料金プラン詳細（/price/ 専用）3カード+価格テーブル
=================================== */
.kp-price-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1080px;
  margin: 32px auto 0;
}
@media (max-width: 900px) {
  .kp-price-detail-grid { grid-template-columns: 1fr; max-width: 520px; }
}
.kp-price-detail {
  background: #fff;
  border: 2px solid var(--kp-pink-light);
  border-radius: var(--kp-radius);
  padding: 28px 22px;
  position: relative;
  display: flex;
  flex-direction: column;
}
.kp-price-detail--featured { border-color: var(--kp-teal); }
.kp-price-detail--recommended { border: 3px solid var(--kp-cta); }
.kp-price-detail__badge {
  position: absolute;
  top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--kp-teal-deep);
  color: #fff;
  font-size: 12px; font-weight: 700;
  padding: 4px 14px;
  border-radius: var(--kp-radius-pill);
  white-space: nowrap;
}
.kp-price-detail__badge--cta { background: var(--kp-cta); }
.kp-price-detail__name {
  margin: 0 0 4px;
  font-weight: 700;
  color: var(--kp-pink-deep);
  font-size: 18px;
  text-align: center;
}
.kp-price-detail__sub {
  margin: 0 0 14px;
  font-size: 12px;
  color: var(--kp-text-muted);
  text-align: center;
}
.kp-price-detail__features {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--kp-text);
}
.kp-price-detail__features li {
  padding-left: 1.2em;
  position: relative;
  margin-bottom: 4px;
}
.kp-price-detail__features li::before {
  content: '◎';
  position: absolute;
  left: 0;
  color: var(--kp-teal-deep);
  font-weight: 700;
}
.kp-price-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: auto; /* カード下部に寄せて、カード間で価格表の位置を揃える */
  margin-bottom: 8px;
}
.kp-price-table th {
  text-align: left;
  font-weight: 700;
  font-size: 13px;
  color: var(--kp-text-muted);
  padding: 8px 6px;
  border-bottom: 1px solid var(--kp-border);
  white-space: nowrap;
}
.kp-price-table td {
  text-align: right;
  font-weight: 700;
  color: var(--kp-pink-deep);
  font-size: 20px;
  padding: 8px 6px;
  border-bottom: 1px solid var(--kp-border);
  font-family: var(--kp-font-pop);
  white-space: nowrap;
}
.kp-price-detail--recommended .kp-price-table td { color: var(--kp-cta); }
.kp-price-table thead th {
  text-align: right;
  color: var(--kp-text);
  font-size: 11px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--kp-border);
}
.kp-price-table thead th:first-child { text-align: left; }
.kp-price-table--two-col td { font-size: 16px; }
.kp-price-table__unit { font-size: 12px; font-weight: 400; margin-left: 2px; }
.kp-price-detail__note {
  margin: 4px 0 0;
  font-size: 11px;
  color: var(--kp-text-muted);
  line-height: 1.6;
}

/* ===================================
   導入の流れ 4ステップ（トップページ）
=================================== */
.kp-flow {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 12px;
  flex-wrap: wrap;
  margin: 28px auto 24px;
  max-width: 1020px;
}
.kp-flow__step {
  background: #fff;
  border: 2px solid var(--kp-pink-light);
  border-radius: var(--kp-radius);
  padding: 24px 18px;
  flex: 1 1 200px;
  max-width: 230px;
  position: relative;
  text-align: center;
}
.kp-flow__step--final { border-color: var(--kp-cta); background: #FFF7F3; }
.kp-flow__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--kp-pink-deep);
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  font-family: var(--kp-font-pop);
  margin-bottom: 8px;
}
.kp-flow__step--final .kp-flow__num { background: var(--kp-cta); }
.kp-flow__title { margin: 4px 0 8px; font-weight: 700; color: var(--kp-pink-deep); font-size: 14px; }
.kp-flow__desc { margin: 0; font-size: 13px; color: var(--kp-text); line-height: 1.6; }
.kp-flow__arrow {
  display: flex;
  align-items: center;
  font-size: 24px;
  color: var(--kp-pink);
  font-weight: 700;
}
@media (max-width: 768px) {
  .kp-flow__arrow { transform: rotate(90deg); }
  .kp-flow__step { max-width: 100%; flex: 1 1 100%; }
}

/* ===================================
   FAQ（よくあるご質問）
=================================== */
.kp-faq {
  max-width: 760px;
  margin: 24px auto 0;
}
.kp-faq__item {
  background: #fff;
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  margin-bottom: 12px;
  overflow: hidden;
  transition: box-shadow .2s;
}
.kp-faq__item[open] { box-shadow: 0 4px 12px rgba(153,53,86,.08); }
.kp-faq__q {
  cursor: pointer;
  list-style: none;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 700;
  color: var(--kp-pink-deep);
  font-size: 15px;
}
.kp-faq__q::-webkit-details-marker { display: none; }
.kp-faq__q::after {
  content: '+';
  margin-left: auto;
  font-size: 22px;
  color: var(--kp-pink);
  transition: transform .2s;
  font-weight: 400;
  line-height: 1;
}
.kp-faq__item[open] .kp-faq__q::after { content: '−'; }
.kp-faq__qmark,
.kp-faq__amark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}
.kp-faq__qmark { background: var(--kp-pink-light); color: var(--kp-pink-deep); }
.kp-faq__amark { background: var(--kp-teal-deep); color: #fff; }
.kp-faq__a {
  display: flex;
  gap: 12px;
  padding: 0 20px 18px;
  align-items: flex-start;
}
.kp-faq__a p { margin: 4px 0 0; font-size: 14px; line-height: 1.8; color: var(--kp-text); }

/* ===================================
   現場で使えるフレーズ集
=================================== */
.kp-phrases {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  max-width: 880px;
  margin: 28px auto 16px;
  text-align: left;
}
.kp-phrase {
  background: #fff;
  border: 2px solid var(--kp-pink-light);
  border-radius: var(--kp-radius);
  padding: 22px 24px 20px;
  position: relative;
  transition: transform .15s, box-shadow .15s;
}
.kp-phrase:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(153,53,86,.10);
}
.kp-phrase__no {
  display: inline-block;
  font-family: var(--kp-font-pop);
  font-size: 14px;
  font-weight: 700;
  color: var(--kp-pink-deep);
  background: var(--kp-pink-light);
  padding: 2px 12px;
  border-radius: var(--kp-radius-pill);
  margin-bottom: 12px;
}
.kp-phrase__en {
  font-family: var(--kp-font-pop);
  font-size: clamp(20px, 3vw, 26px);
  font-weight: 700;
  color: var(--kp-text);
  margin: 0 0 6px;
  line-height: 1.3;
}
.kp-phrase__ja {
  font-size: 15px;
  color: var(--kp-pink-deep);
  font-weight: 700;
  margin: 0 0 10px;
}
.kp-phrase__hint {
  margin: 0;
  padding-top: 10px;
  border-top: 1px dashed var(--kp-border);
  font-size: 12px;
  color: var(--kp-text-muted);
  line-height: 1.6;
}
.kp-phrases__note {
  margin: 12px 0 0;
  font-size: 12px;
  color: var(--kp-text-muted);
}
@media (max-width: 768px) {
  .kp-phrases { grid-template-columns: 1fr; max-width: 480px; }
}

/* ===================================
   レッスンツール紹介セクション（Google Meet）
=================================== */
.kp-tool-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 980px;
  margin: 28px auto 16px;
  text-align: left;
}
.kp-tool-card {
  background: #fff;
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  padding: 24px 22px;
  transition: transform .15s, box-shadow .15s;
}
.kp-tool-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(15,110,86,.08);
}
.kp-tool-card__icon {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--kp-pink-light);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  margin-bottom: 14px;
}
.kp-tool-card__title {
  font-weight: 700;
  color: var(--kp-pink-deep);
  margin: 0 0 8px;
  font-size: 16px;
  line-height: 1.5;
}
.kp-tool-card__desc {
  margin: 0;
  color: var(--kp-text);
  font-size: 14px;
  line-height: 1.8;
}
.kp-tool__note {
  margin: 16px 0 0;
  font-size: 12px;
  color: var(--kp-text-muted);
}
@media (max-width: 768px) {
  .kp-tool-grid { grid-template-columns: 1fr; max-width: 480px; }
}

/* ===================================
   /app/ ポータルページ（直接アクセス時の警告画面）
=================================== */
.kp-header--minimal { background: #fff; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.kp-header--minimal .kp-header__inner { justify-content: center; }

.kp-app-page { background: var(--kp-bg-soft); }
.kp-app-denied__icon {
  font-size: 56px;
  color: #d9534f;
  line-height: 1;
  margin-bottom: 18px;
}
.kp-app-denied__title {
  font-size: 24px;
  font-weight: 700;
  color: var(--kp-text);
  margin: 0 0 20px;
}
.kp-app-denied__text {
  line-height: 1.9;
  color: var(--kp-text-muted);
  margin: 0;
  font-size: 15px;
}

/* ===================================
   法務系ページ（プライバシー・利用規約）
=================================== */
.kp-legal__h2 {
  font-size: 18px;
  color: var(--kp-pink-deep);
  margin: 32px 0 12px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--kp-pink-light);
}
.kp-legal__list { padding-left: 1.4em; margin: 8px 0; }
.kp-legal__list li { margin-bottom: 4px; }
.kp-legal__box {
  background: var(--kp-bg-soft);
  border: 1px solid var(--kp-border);
  border-radius: var(--kp-radius);
  padding: 18px 22px;
  margin-top: 14px;
}

.kp-footer { background: var(--kp-teal-deep); color: #fff; padding-block: 40px; }
.kp-footer a { color: #fff; }
.kp-footer__inner { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 24px; }
.kp-footer__nav { display: flex; gap: 20px; flex-wrap: wrap; }
.kp-footer__social a { font-size: 24px; }
.kp-footer__copy { font-size: 12px; opacity: .8; margin-top: 24px; text-align: center; }

/* 関連サービス（フッター内） */
.kp-footer__related {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.15);
}
.kp-footer__related-title {
  font-size: 13px;
  font-weight: 700;
  margin: 0 0 14px;
  opacity: .85;
  letter-spacing: .05em;
}
.kp-footer__related-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}
.kp-footer__related-list a {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  text-decoration: none;
}
.kp-footer__related-list a:hover { text-decoration: underline; }
.kp-footer__related-list strong { font-weight: 700; font-size: 15px; }
.kp-footer__related-list span { font-size: 12px; opacity: .75; }

/* 法務リンク列 */
.kp-footer__legal {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.15);
  text-align: center;
  font-size: 13px;
}
.kp-footer__legal a { opacity: .85; margin: 0 14px; }
.kp-footer__legal a:hover { opacity: 1; }

/* スマホ追従の予約ボタン */
.kp-sticky-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 200;
  padding: 10px 16px;
  background: rgba(255,255,255,.95);
  border-top: 1px solid var(--kp-border);
}
.kp-sticky-cta .kp-btn { width: 100%; justify-content: center; }

/* =========================================================
   12. レスポンシブ
   ========================================================= */
@media (max-width: 900px) {
  .kp-hero { min-height: 0; }
  .kp-hero__body { flex: none; display: block; }
  .kp-hero__grid { grid-template-columns: 1fr; gap: 16px; padding-block: 28px; }
  .kp-hero__visual { order: -1; min-height: 340px; }
  .kp-hero__enjoy { font-size: 80px; top: 2%; }
  .kp-hero__photo--1 { width: 180px; height: 180px; top: 10px;  left: 4%; }
  .kp-hero__photo--2 { width: 150px; height: 150px; top: 50px;  right: 4%; }
  .kp-hero__photo--3 { display: none; }
  .kp-hero__chars { width: 70%; height: auto; left: auto; right: 0; transform: none; max-width: none; }
  .kp-hero__age { width: 78px; height: 78px; font-size: 11px; }
  .kp-hero__age strong { font-size: 13px; }
  .kp-posts { grid-template-columns: repeat(2, 1fr); }
  .kp-hero__ribbon { width: 90%; opacity: .6; }
}
@media (max-width: 680px) {
  .kp-section { padding-block: 40px; }
  .kp-header__logo img { height: 52px; }
  .kp-nav {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column;
    background: var(--kp-pink-light);
    padding: 16px 20px;
    border-bottom: 1px solid var(--kp-border);
  }
  .kp-nav.is-open { display: flex; }
  .kp-nav-toggle { display: block; }
  .kp-header__cta { display: none; }
  .kp-reasons__grid { grid-template-columns: 1fr; }
  .kp-posts { grid-template-columns: 1fr; }
  .kp-sticky-cta { display: block; }
  body { padding-bottom: 72px; }
}

/* =========================================================
   13. にぎやか化（完成度アップ）
   既存の世界観を強める装飾。素材なしで効く部分を中心に。
   ========================================================= */

/* --- セクションの斜め区切り --- */
.kp-section--slant-top {
  position: relative;
  margin-top: -1px;
}
.kp-section--slant-top::before {
  content: "";
  position: absolute;
  top: -40px; left: 0; right: 0;
  height: 40px;
  background: inherit;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
}

/* --- 背景のうっすら水玉模様 --- */
.kp-dots {
  background-image: radial-gradient(var(--kp-pink) 1.5px, transparent 1.5px);
  background-size: 24px 24px;
  background-position: 0 0;
}
.kp-dots--soft {
  background-image: radial-gradient(rgba(244,166,192,.25) 2px, transparent 2px);
  background-size: 28px 28px;
}

/* --- 見出しの飾り（下に丸い点々） --- */
.kp-section__title { position: relative; }
.kp-section__title::after {
  content: "";
  display: block;
  width: 56px; height: 5px;
  margin: 12px auto 0;
  border-radius: var(--kp-radius-pill);
  background: var(--kp-yellow);
}

/* --- カードに影とホバーの動き --- */
.kp-reason {
  box-shadow: 0 3px 0 rgba(153,53,86,.06);
  transition: transform .15s, box-shadow .15s;
}
.kp-reason:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 18px rgba(153,53,86,.10);
}
/* 4カードのアイコンを色違いに */
.kp-reason:nth-child(1) .kp-reason__icon { background: #FBEAF0; color: #993556; }
.kp-reason:nth-child(2) .kp-reason__icon { background: #FAEEDA; color: #854F0B; }
.kp-reason:nth-child(3) .kp-reason__icon { background: #E1F5EE; color: #0F6E56; }
.kp-reason:nth-child(4) .kp-reason__icon { background: #E6F1FB; color: #0C447C; }

/* --- セブのXセクションをティール帯に --- */
.kp-cebu {
  background: #E1F5EE;
}
.kp-cebu .kp-section__title { color: var(--kp-teal-deep); }
/* セブのX風カード（自前実装。本物のXに似せたデザイン） */
.kp-cebu__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 980px;
  margin: 8px auto 28px;
  text-align: left;
}
.kp-xcard {
  background: #fff;
  border: 1px solid var(--kp-border);
  border-radius: 16px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  transition: transform .15s, box-shadow .15s;
}
.kp-xcard:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(15,110,86,.10);
}
.kp-xcard__head { display: flex; align-items: center; gap: 10px; }
.kp-xcard__avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--kp-teal-deep);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px;
  flex-shrink: 0;
}
.kp-xcard__id { display: flex; flex-direction: column; flex: 1; min-width: 0; line-height: 1.3; }
.kp-xcard__id strong { font-size: 14px; color: var(--kp-text); }
.kp-xcard__id span { font-size: 12px; color: var(--kp-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kp-xcard__brand { font-size: 18px; color: #000; font-weight: 700; }
.kp-xcard__body {
  font-size: 14px;
  line-height: 1.7;
  color: var(--kp-text);
  word-wrap: break-word;
  white-space: pre-line;
  flex: 1;
}
.kp-xcard__media img {
  width: 100%;
  border-radius: 12px;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.kp-xcard__foot {
  display: flex;
  align-items: center;
  gap: 14px;
  border-top: 1px solid var(--kp-border);
  padding-top: 10px;
  font-size: 12px;
  color: var(--kp-text-muted);
}
.kp-xcard__metric { display: inline-flex; align-items: center; gap: 4px; }
.kp-xcard__link {
  margin-left: auto;
  color: var(--kp-teal-deep);
  font-weight: 700;
  font-size: 12px;
}
.kp-xcard__link:hover { text-decoration: underline; }
@media (max-width: 768px) {
  .kp-cebu__cards { grid-template-columns: 1fr; max-width: 480px; }
}

/* --- 導入事例：大きな数字＋園の声カード --- */
.kp-cases__big {
  font-size: clamp(48px, 10vw, 80px);
  font-weight: normal;
  color: var(--kp-cta);
  line-height: 1;
}
.kp-cases__big small { font-size: .35em; color: var(--kp-text); font-weight: 700; }
.kp-voices {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 32px 0;
  text-align: left;
}
.kp-voice {
  background: #fff;
  border-radius: var(--kp-radius);
  padding: 20px;
  box-shadow: 0 3px 0 rgba(186,117,23,.10);
  position: relative;
}
.kp-voice::before {
  content: "\201C";
  font-size: 48px;
  color: var(--kp-yellow);
  line-height: 1;
  position: absolute;
  top: 8px; left: 14px;
  opacity: .6;
}
.kp-voice__text { margin: 16px 0 12px; font-size: 14px; }
.kp-voice__who { display: flex; align-items: center; gap: 10px; }
.kp-voice__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--kp-pink-light); color: var(--kp-pink-deep);
  display: flex; align-items: center; justify-content: center; font-size: 20px;
  flex-shrink: 0;
}
.kp-voice__name { font-size: 13px; color: var(--kp-text-muted); margin: 0; }

/* --- 予約セクション：流れ3ステップ＋楽しいバッジ --- */
.kp-booking__badges {
  display: flex; justify-content: center; gap: 10px; flex-wrap: wrap;
  margin: 16px 0 8px;
}
.kp-booking__badges span {
  background: var(--kp-yellow);
  color: var(--kp-yellow-deep);
  font-weight: 700; font-size: 13px;
  padding: 6px 16px; border-radius: var(--kp-radius-pill);
}
.kp-steps {
  display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
  margin: 24px 0;
}
.kp-step {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  width: 130px;
}
.kp-step__num {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--kp-cta); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.kp-step__label { font-size: 13px; color: var(--kp-text); }
.kp-step__arrow { color: var(--kp-pink); align-self: center; font-size: 20px; }

@media (max-width: 680px) {
  .kp-voices { grid-template-columns: 1fr; }
  .kp-step__arrow { transform: rotate(90deg); }
  .kp-steps { flex-direction: column; align-items: center; }
}
