@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/*投稿日・更新日を非表示*/
.page .date-tags {
 display: none;
}
/*投稿者名を非表示*/
.page .footer-meta {
 display: none;
}
/*サイトロゴ上部スペース調整*/
.tagline {
    margin: 0.06em 1em;
}
/*サイトメイントピック上下左右余白スペース調整*/
.main {
    padding: 1px 10px;
}
/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}

/* ============================================
   TOEIC Academy LP Final v2 (3列価格表・目次なし)
   ============================================ */

/* --- 0. Cocoon固有設定の無効化 --- */
/* 自動生成される目次を非表示にする */
.entry-content .toc {
  display: none !important;
}

/* --- 1. ベース設定 --- */
.lp-wrapper {
  width: 100%;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: #333;
  line-height: 1.8;
}

.lp-section {
  padding: 60px 20px;
  max-width: 1000px;
  margin: 0 auto;
}

/* 共通見出しスタイル */
.lp-heading {
  font-size: 28px;
  text-align: center;
  margin-bottom: 40px;
  font-weight: bold;
  position: relative;
  padding-bottom: 15px;
}

.lp-heading::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background-color: #0056b3;
  margin: 15px auto 0;
}

/* --- 2. ヒーローセクション --- */
.lp-hero {
  background-color: #f4f9ff;
  padding: 60px 20px;
  text-align: center;
}

.hero-title {
  font-size: 32px;
  font-weight: bold;
  color: #0056b3;
  margin-bottom: 20px;
  line-height: 1.4;
}

.hero-subtitle {
  font-size: 16px;
  margin-bottom: 30px;
  font-weight: bold;
}

/* 画像プレースホルダー */
.img-placeholder, .img-placeholder-sm, .img-placeholder-circle {
  background-color: #ddd;
  color: #666;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  border: 2px dashed #aaa;
}
.img-placeholder { width: 100%; height: 250px; max-width: 600px; }
.img-placeholder-sm { width: 100%; height: 180px; }
.img-placeholder-circle { width: 100px; height: 100px; border-radius: 50%; }

/* ボタン共通 */
.lp-btn {
  display: inline-block;
  padding: 15px 40px;
  border-radius: 50px;
  text-decoration: none !important;
  font-weight: bold;
  transition: all 0.3s;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}
.lp-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0,0,0,0.15);
}
.lp-btn-main {
  background-color: #ff8c00;
  color: #fff !important;
  font-size: 18px;
}
.lp-btn-sub {
  background-color: #0056b3;
  color: #fff !important;
}
.lp-btn-large {
  width: 100%;
  max-width: 400px;
  text-align: center;
}

/* --- 3. 悩みセクション --- */
.lp-problem {
  background-color: #fff;
}
.problem-list {
  list-style: none;
  padding: 0;
  margin: 0 auto 30px;
  max-width: 600px;
}
.problem-list li {
  background: #f9f9f9;
  margin-bottom: 15px;
  padding: 15px;
  border-radius: 8px;
  font-weight: bold;
}
.check-icon {
  color: #ff0000;
  margin-right: 10px;
}
.problem-message {
  text-align: center;
  font-size: 18px;
}

/* --- 4. 特徴セクション --- */
.lp-features {
  background-color: #f4f9ff;
  display: block;
}

.features-container {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.feature-card {
  background: #fff;
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.05);
  text-align: center;
}
.feature-card h3 {
  color: #0056b3;
  margin: 20px 0;
  font-size: 20px;
}

/* --- 5. Storyセクション --- */
.lp-story {
  background-color: #ffffff !important;
  color: #333333 !important;
  padding: 80px 20px;
}
.lp-story .lp-heading-story {
  color: #333333 !important;
  font-size: 32px;
  font-family: serif;
  text-align: center;
  margin-bottom: 10px;
  font-weight: bold;
}
.story-sub {
  text-align: center;
  color: #666 !important;
  margin-bottom: 50px;
  font-size: 16px;
}
.story-content {
  max-width: 800px;
  margin: 0 auto;
}
.story-img {
  margin-bottom: 40px;
}
.story-highlight {
  font-size: 20px;
  font-weight: bold;
  color: #ff8c00 !important;
  text-align: center;
  margin-top: 40px;
  line-height: 1.6;
}
/* プロフィール枠 */
.instructor-profile {
  margin-top: 60px;
  background: #f4f4f4 !important;
  padding: 30px;
  border-radius: 10px;
  color: #333 !important;
}
.profile-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.profile-text {
  margin-top: 15px;
}
.instructor-profile h4, 
.instructor-profile p {
  color: #333 !important;
}

/* --- 6. 料金セクション（高さ揃え・3列対応） --- */
.lp-pricing {
  text-align: center;
}
.pricing-desc {
  margin-bottom: 40px;
}
.pricing-container {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.pricing-card {
  border: 1px solid #eee;
  padding: 40px 20px;
  border-radius: 10px;
  position: relative;
  background: #fff;
  /* 中身を上下に引き伸ばして配置するための設定 */
  display: flex;
  flex-direction: column;
}
/* 人気No.1の強調 */
.pricing-card.recommend {
  border: 3px solid #ff8c00;
  background: #fffaf0;
}
/* 保証コースの強調 */
.pricing-card.premium {
  border: 3px solid #d32f2f;
  background: #fff;
}
.badge {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  background: #ff8c00;
  color: #fff;
  padding: 5px 20px;
  border-radius: 20px;
  font-weight: bold;
  white-space: nowrap;
  z-index: 2;
}
.badge.red {
  background: #d32f2f;
}
.plan-name {
  font-size: 22px;
  margin-bottom: 10px;
  color: #333;
  font-weight: bold;
}
.plan-desc {
  /* 説明文の高さをある程度揃える（任意） */
  margin-bottom: 10px;
}
.price {
  font-size: 28px;
  font-weight: bold;
  color: #0056b3;
  margin: 10px 0 20px;
}
.price .yen {
  font-size: 14px;
  color: #666;
}
.plan-features {
  list-style: none;
  padding: 0;
  margin-bottom: 30px;
  flex-grow: 1; /* ★ここが重要：リスト部分が余白を埋めるように伸びる */
}
.plan-features li {
  border-bottom: 1px solid #eee;
  padding: 10px;
}
/* ボタンを常に最下部に配置 */
.pricing-card .lp-btn {
  margin-top: auto; /* 自動で下に押し下げる */
  width: 100%;      /* ボタンの幅を合わせる */
  box-sizing: border-box;
}

/* --- 7. FAQセクション --- */
.lp-faq {
  background: #f9f9f9;
}
.lp-faq-container {
  max-width: 800px;
  margin: 0 auto;
}
.lp-faq-box {
  background: #fff;
  margin-bottom: 20px;
  border-radius: 8px;
  padding: 25px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}
.faq-q {
  font-weight: bold;
  color: #0056b3;
  font-size: 18px;
  margin-bottom: 15px;
  line-height: 1.4;
}
.faq-a {
  font-size: 16px;
  color: #333;
  line-height: 1.8;
  padding-top: 15px;
  border-top: 1px dashed #ddd;
}

/* --- 8. CTAセクション（明るい青グラデーション・黒文字） --- */
.lp-cta {
  background: linear-gradient(135deg, #0056b3, #003d80) !important;
  color: #ffffff !important;
  text-align: center;
  padding: 80px 20px;
  border: none !important;
}
/* 見出し・本文の背景を透明に強制し、グレーの箱を消す */
.lp-cta .cta-heading,
.lp-cta p,
.lp-cta div {
  background-color: transparent !important;
  color: #ffffff !important;
  border: none !important;
}
.cta-heading {
  font-size: 32px;
  margin-bottom: 20px;
  font-weight: bold;
}
.cta-note {
  font-size: 12px;
  opacity: 0.8;
  margin-top: 20px;
  color: #dddddd !important;
}

/* --- PC向けレスポンシブ --- */
@media (min-width: 768px) {
  .lp-hero { padding: 100px 0; }
  .lp-hero-content { max-width: 800px; margin: 0 auto; }
  .hero-title { font-size: 48px; }
  
  /* 特徴セクション */
  .features-container {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px;
  }
  .feature-card {
    width: 100%;
    max-width: 320px;
    margin-bottom: 0;
    flex: 1 1 300px;
  }
  
  /* 料金セクションPC修正：高さ揃え */
  .pricing-container {
    flex-direction: row;
    justify-content: center;
    align-items: stretch; /* ★ここが重要：高さを強制的に揃える */
    gap: 20px;
  }
  .pricing-card {
    width: 31%;
    margin-bottom: 0;
  }
  /* 人気No.1などを少し強調して大きく見せたい場合は以下を追加（今回は揃えるためコメントアウト中）
  .pricing-card.recommend { transform: scale(1.05); z-index: 1; } 
  */

  /* プロフィール */
  .profile-box {
    flex-direction: row;
    text-align: left;
    max-width: 600px;
    margin: 0 auto;
  }
  .profile-text {
    margin-top: 0;
    margin-left: 20px;
  }
}

/* --- 追加修正：赤色ボタンと改行制御 --- */

/* 赤いボタン（800点保証コース用） */
.lp-btn-red {
  background-color: #d32f2f !important; /* 枠線と同じ赤 */
  color: #fff !important;
  font-size: 18px;
}
/* 改行制御用：改行するならこのカタマリで動く */
.u-ib {
  display: inline-block;
}

/* --- 画像調整用CSS --- */

/* プロフィール画像を丸く切り抜く設定 */
.profile-img {
  width: 120px;       /* 幅 */
  height: 120px;      /* 高さ */
  border-radius: 50%; /* 完全な円にする */
  object-fit: cover;  /* 画像が歪まないように調整 */
  border: 3px solid #fff; /* 白いフチをつける */
  box-shadow: 0 2px 5px rgba(0,0,0,0.2); /* 少し影をつける */
}

/* もしスマホで画像が横にはみ出す場合の保険 */
.lp-wrapper img {
  max-width: 100%;
  height: auto;
}

/* プロフィール写真前の謎の四角を消す */
.profile-box::before,
.profile-box::after {
  content: none !important;
  display: none !important;
  border: none !important;
}

/* ============================================
   プロフィール写真の調整（完全版）
   ============================================ */

/* 1. 謎の四角（::before）を完全に消す */
.profile-box::before,
.profile-box::after {
  content: none !important;
  display: none !important;
}

/* 2. 画像自体のスタイル（丸くする・余白調整） */
.profile-img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  
  /* スマホ初期値：上に余白、左右は中央寄せ */
  margin-top: 30px !important;
  margin-bottom: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: block; /* 中央寄せのためにブロック要素化 */
}

/* 3. PC表示（768px以上）での位置修正 */
@media (min-width: 768px) {
  
  /* ボックス全体を中央に配置 */
  .profile-box {
    display: flex !important;
    flex-direction: row !important; /* 横並び */
    align-items: center !important; /* 上下中央揃え */
    justify-content: center !important; /* ★ここ重要：全体を中央寄せ */
    gap: 30px !important; /* ★写真と文字の間隔をここで指定 */
  }

  .profile-img {
    /* PCではマージンをリセットしてgapに任せる */
    margin: 0 !important; 
    
    /* ★ここに「左側の余白」を追加（全体が中央寄りつつ、さらに写真の左を空ける） */
    margin-left: 20px !important; 
  }
  
  /* テキスト側の余白設定をリセット（gapで制御するため） */
  .profile-text {
    margin-left: 0 !important;
    margin-top: 0 !important;
    text-align: left !important;
  }
}

/* PC表示の時だけメイン画像を程よいサイズに制限する */
@media (min-width: 768px) {
  .lp-hero-bg img {
    max-width: 400px !important; /* ここで最大幅を制限（500pxくらいが丁度いいです） */
    width: auto !important;      /* 元の比率を保つ */
    margin: 30px auto 0 !important; /* 上に少し隙間、左右は中央寄せ */
    display: block;
  }
}