@charset "UTF-8";
/*
 * ======================================
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * Ako's Conversational English（ACE）site.css
 * ======================================
 *
 * .ace-header / __inner / __nav / __right   - 常時表示sticky+blurヘッダー（単行ナビ）
 * .ace-header-sns / .ace-line-btn           - ヘッダー内SNSアイコン / 緑のLINE登録ピルボタン
 * .ace-sns-rail / __label                   - 画面右端の固定SNSサイドレール
 * .ace-spnav-sns                            - SPナビ下部のSNSアイコン
 * .ace-footer / __grid / __brand / __col …  - ダーク3カラムフッター
 * .ace-cta-band / __tag / __title / __lead  - LINE登録CTA帯（赤グラデ＋ロゴ透かし）
 * .ace-line-float / .ace-line-reopen        - 全ページ追従LINEポップアップ
 * .ace-eyebrow / .ace-title / .ace-lead     - 見出し補助（英ラベル＋日本語タイトル＋リード）
 * .ace-btn / --primary / --ghost / --gold   - pill型ボタン（矢印スライド）
 * .ace-page-hero / __en / __sub             - 下層ページ用グラデヒーロー（波形下端）
 * .ace-bubbles / .ace-bubble                - 共感セクションの吹き出し
 * .ace-cause / .ace-ci-row …                - 解決策セクションの原因リスト図
 * .ace-ba-card / .ace-voice-card            - ビフォーアフター/受講生の声カード（再生ボタン）
 * .ace-timeline / .ace-creed                - 沿革タイムライン / 理念カード
 * .ace-faq / .ace-form …                    - FAQアコーディオン / お問い合わせフォーム
 * .ace-flow / .ace-support / .ace-custom …  - メソッド/コースの図解
 * .ace-post-card / .ace-sidebar / .ace-article - ブログ一覧・記事・サイドバー
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類）
 * ======================================
 * ・構造不足: 「英ラベル＋日本語見出し（左揃え）」のeyebrow+title型／単行テキストナビ
 *            ／グラデーション背景＋波形下端のページヒーロー
 * ・装飾パターン不足: 吹き出し（しっぽ付き）／原因リスト図／円形リング図／再生ボタン重ね
 *            ／全ページ追従ポップアップ／固定SNSサイドレール
 * ・状態不足: pillボタンhoverで矢印が右スライドする演出（共通btnは角丸10px固定幅で非対応）
 * ・値の粒度不足: ブランド配色のグラデ（赤→赤深）はCSS変数で個別指定
 */

/* ============================================================
   ブランドトークン（参考デザインの色・タイポを変数化）
============================================================ */
:root {
  --red: #b13c4a;
  --red-deep: #913040;
  --red-soft: #c96673;
  --brown: #9b8d77;
  --brown-deep: #7c6f5b;
  --beige: #f5f0e8;
  --beige-deep: #ece3d5;
  --cream: #faf7f1;
  --ink: #2c2622;
  --ink-soft: #5d564f;
  --line: #e4ddd2;
  --serif: "Montserrat", sans-serif;
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --shadow-sm: 0 4px 18px rgba(60, 45, 35, 0.06);
  --shadow-md: 0 14px 40px rgba(90, 60, 45, 0.10);
  --shadow-lg: 0 30px 70px rgba(90, 60, 45, 0.14);
  --ace-header-h: 88px;
}

/* 本文の行間・字間を参考デザインに寄せる */
body { line-height: 1.9; }

/* 汎用センタリング（共通は .text-center のみのため補助） */
.center { text-align: center; }

/* 英字ラベル（共通は .font-en utility のみ。短縮ヘルパー） */
.en { font-family: var(--serif); letter-spacing: 0.1em; }

/* ============================================================
   タイポグラフィ補助（eyebrow / title / lead）
============================================================ */
.ace-eyebrow {
  font-family: var(--serif);
  font-size: 1.3rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
}
.ace-eyebrow::before {
  content: "";
  width: 2.4em;
  height: 1px;
  background: var(--red);
  opacity: 0.6;
}
.ace-eyebrow--center { justify-content: center; }
.ace-eyebrow--center::after {
  content: "";
  width: 2.4em;
  height: 1px;
  background: var(--red);
  opacity: 0.6;
}

.ace-title {
  font-size: clamp(2.2rem, 3.2vw, 3.6rem);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  color: var(--ink);
}
.ace-title .accent { color: var(--red); }
.ace-title--lg { font-size: clamp(2.6rem, 4vw, 4.4rem); }

.ace-lead {
  font-size: 1.6rem;
  color: var(--ink-soft);
  line-height: 2.1;
}

/* ============================================================
   ボタン（pill型・矢印スライド）
============================================================ */
.ace-btn {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  font-weight: 700;
  font-size: 1.6rem;
  padding: 1.6rem 3.4rem;
  border-radius: 999px;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: transform 0.24s var(--ease), box-shadow 0.24s, background 0.24s, color 0.24s, border-color 0.24s;
}
.ace-btn .ace-arr { transition: transform 0.24s var(--ease); }
.ace-btn:hover { opacity: 1; }
.ace-btn:hover .ace-arr { transform: translateX(4px); }
.ace-btn--lg { padding: 1.9rem 4.4rem; font-size: 1.7rem; }
.ace-btn--primary {
  background: var(--red);
  color: #fff;
  box-shadow: 0 10px 26px rgba(177, 60, 74, 0.3);
}
.ace-btn--primary:hover {
  background: var(--red-deep);
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(177, 60, 74, 0.4);
}
.ace-btn--ghost {
  background: #fff;
  color: var(--ink);
  border: 1.5px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.ace-btn--ghost:hover { border-color: var(--red); color: var(--red); transform: translateY(-2px); }
.ace-btn--gold {
  background: linear-gradient(135deg, #cba455, #b48f38);
  color: #fff;
  box-shadow: 0 12px 30px rgba(90, 65, 20, 0.4);
}
.ace-btn--gold:hover { background: linear-gradient(135deg, #d4af60, #bd9740); transform: translateY(-2px); box-shadow: 0 16px 36px rgba(90, 65, 20, 0.5); }

/* LINE登録ボタン（緑ピル） */
.ace-line-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  background: #06c755;
  color: #fff;
  font-weight: 700;
  font-size: 1.4rem;
  padding: 1.1rem 2rem;
  border-radius: 999px;
  box-shadow: 0 8px 20px rgba(6, 199, 85, 0.28);
  transition: transform 0.22s var(--ease), box-shadow 0.22s, background 0.22s;
  white-space: nowrap;
  text-decoration: none;
}
.ace-line-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(6, 199, 85, 0.4); opacity: 1; }
.ace-line-btn svg { width: 1.8rem; height: 1.8rem; }
.ace-line-btn--lg { padding: 1.7rem 3.6rem; font-size: 1.7rem; }
.ace-line-btn--lg svg { width: 2rem; height: 2rem; }
.ace-line-btn--block { width: 100%; justify-content: center; }

/* ============================================================
   HEADER（常時表示 sticky + blur）
============================================================ */
.ace-header {
  position: sticky;
  top: 0;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.ace-header__inner {
  max-width: 1400px;
  height: var(--ace-header-h);
  padding: 0 clamp(18px, 3vw, 36px);
  gap: 28px;
}
.ace-header__logo img { height: 70px; width: auto; }
.ace-header__nav { margin-left: auto; margin-right: 0; gap: clamp(2px, 0.7vw, 12px); }
.ace-header__nav .header__nav-item a { padding: 6px 4px; flex-direction: row; }
.ace-header__nav .header__nav-ja {
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--ink-soft);
  margin-top: 0;
  white-space: nowrap;
}
.ace-header__nav .header__nav-item a::after { background: var(--red); height: 2px; }
.ace-header__nav .header__nav-item a:hover .header__nav-ja { color: var(--red); }
.ace-header__nav .header__nav-item--current a .header__nav-ja { color: var(--red); }
.ace-header__nav .header__nav-item--current a::after { width: 50%; left: 25%; }

.ace-header__right { gap: 18px; }
.ace-header-sns { display: flex; align-items: center; gap: 10px; }
.ace-header-sns a {
  width: 30px; height: 30px;
  display: grid; place-items: center;
  color: var(--brown-deep);
  transition: color 0.2s, transform 0.2s;
}
.ace-header-sns a:hover { color: var(--red); transform: translateY(-2px); opacity: 1; }
.ace-header-sns svg { width: 17px; height: 17px; }

/* ※ ヘッダーは position:sticky で通常フローに場所を取るため、body への padding は不要 */

@media (max-width: 1100px) {
  .ace-header__inner { height: 64px; }
  .ace-header__logo img { height: 46px; }
}

/* ============================================================
   固定SNSサイドレール
============================================================ */
.ace-sns-rail {
  position: fixed;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 95;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line);
  border-right: none;
  border-radius: 16px 0 0 16px;
  padding: 12px 9px;
  box-shadow: var(--shadow-md);
}
.ace-sns-rail a {
  width: 42px; height: 42px;
  display: grid; place-items: center;
  color: var(--brown-deep);
  border-radius: 11px;
  transition: color 0.2s var(--ease), background 0.2s var(--ease), transform 0.2s var(--ease);
}
.ace-sns-rail a:hover { color: #fff; background: var(--red); transform: translateX(-2px); opacity: 1; }
.ace-sns-rail svg { width: 19px; height: 19px; }
.ace-sns-rail__label {
  font-family: var(--serif);
  font-size: 1rem;
  letter-spacing: 0.2em;
  font-weight: 600;
  color: var(--brown-deep);
  writing-mode: vertical-rl;
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}
@media (max-width: 1100px) { .ace-sns-rail { display: none; } }

/* ============================================================
   SPナビ追加（SNSアイコン）
============================================================ */
.ace-spnav-sns { display: flex; justify-content: center; gap: 18px; margin-top: 20px; }
.ace-spnav-sns a { width: 40px; height: 40px; display: grid; place-items: center; color: #fff; border: 1px solid rgba(255,255,255,0.4); border-radius: 50%; }
.ace-spnav-sns a:hover { background: rgba(255,255,255,0.15); opacity: 1; }
.ace-spnav-sns svg { width: 18px; height: 18px; }
.sp-nav__bottom .ace-line-btn { margin-bottom: 4px; }

/* ============================================================
   LINE登録CTA帯
============================================================ */
.ace-cta-band {
  background:
    radial-gradient(120% 140% at 85% -20%, rgba(255,255,255,0.16), transparent 60%),
    linear-gradient(135deg, var(--red) 0%, var(--red-deep) 100%);
  color: #fff;
  text-align: center;
  padding-block: clamp(56px, 8vw, 96px);
  position: relative;
  overflow: hidden;
}
.ace-cta-band::after {
  content: "";
  position: absolute;
  right: clamp(-70px, -4vw, -24px);
  bottom: clamp(-80px, -5vw, -36px);
  width: clamp(300px, 42vw, 600px);
  height: clamp(300px, 42vw, 600px);
  background: #fff;
  -webkit-mask: url("https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28206/logo-mark.png") right bottom / contain no-repeat;
          mask: url("https://ros-cdn.s3.ap-northeast-1.amazonaws.com/hp/img/ros_keiyaku/28206/logo-mark.png") right bottom / contain no-repeat;
  opacity: 0.06;
  pointer-events: none;
}
.ace-cta-band__inner { position: relative; z-index: 1; }
.ace-cta-band__tag {
  display: inline-block;
  font-size: 1.2rem;
  letter-spacing: 0.28em;
  background: rgba(255,255,255,0.16);
  padding: 8px 18px;
  border-radius: 999px;
  margin-bottom: 22px;
}
.ace-cta-band__title {
  font-size: clamp(2rem, 2.8vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 14px;
}
.ace-cta-band__lead { opacity: 0.92; margin-bottom: 30px; font-size: 1.5rem; }
.ace-cta-band .ace-line-btn { margin: 0 auto; }

/* ============================================================
   FOOTER（ダーク3カラム）
============================================================ */
.ace-footer {
  background: var(--ink);
  color: rgba(255,255,255,0.72);
  padding-block: clamp(48px, 6vw, 72px) 32px;
  font-size: 1.4rem;
}
.ace-footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.ace-footer__logo {
  display: inline-block;
  background: #fff;
  border-radius: 12px;
  padding: 12px 16px;
}
.ace-footer__logo img { width: 210px; height: auto; }
.ace-footer__brand p { margin-top: 18px; line-height: 2; font-size: 1.35rem; }
.ace-footer__sns { display: flex; gap: 14px; margin-top: 18px; }
.ace-footer__sns a {
  width: 40px; height: 40px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50%;
  display: grid; place-items: center;
  color: rgba(255,255,255,0.72);
  transition: background 0.22s, border-color 0.22s, transform 0.22s, color 0.22s;
}
.ace-footer__sns a:hover { background: var(--red); border-color: var(--red); color: #fff; transform: translateY(-2px); opacity: 1; }
.ace-footer__sns svg { width: 18px; height: 18px; }
.ace-footer__col h4 {
  font-size: 1.15rem;
  letter-spacing: 0.22em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 18px;
  font-weight: 600;
}
.ace-footer__col ul { display: flex; flex-direction: column; gap: 11px; }
.ace-footer__col a { color: rgba(255,255,255,0.72); transition: color 0.2s; }
.ace-footer__col a:hover { color: #fff; opacity: 1; }
.ace-footer__hours { margin-top: 18px; font-size: 1.25rem; line-height: 1.9; }
.ace-footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; font-size: 1.2rem; color: rgba(255,255,255,0.45);
  flex-wrap: wrap; gap: 10px;
}
.ace-footer__bottom .en { letter-spacing: 0.1em; }
@media (max-width: 896px) {
  .ace-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  /* タブレット以下ではフッターのナビ（リンク一覧）は不要 */
  .ace-footer__col:nth-of-type(2) { display: none; }      /* Menu 列ごと非表示 */
  .ace-footer__col:nth-of-type(3) ul { display: none; }   /* Information のリンクのみ非表示（受付時間は残す） */
  .ace-footer__col:nth-of-type(3) .ace-footer__hours { margin-top: 0; }
  .ace-footer__hours { text-align: center; }
  .ace-footer__brand { text-align: center; }
  .ace-footer__brand .ace-footer__sns { justify-content: center; }
}

/* ============================================================
   追従 LINE ポップアップ
============================================================ */
.ace-line-float {
  position: fixed;
  right: clamp(14px, 2vw, 26px);
  bottom: clamp(14px, 2vw, 26px);
  z-index: 200;
  width: 300px;
  max-width: calc(100vw - 28px);
  background: #fff;
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--line);
  overflow: hidden;
  transform: translateY(20px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.5s var(--ease), opacity 0.5s var(--ease);
}
/* SPナビ（z:200）より下、ヘッダー（z:100）より上に重ねる */
.ace-line-float { z-index: 190; }
.ace-line-float.show { transform: translateY(0); opacity: 1; pointer-events: auto; }
.ace-line-float__head {
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  color: #fff;
  padding: 14px 18px;
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 1.4rem;
  position: relative;
}
.ace-line-float__ico { font-size: 1.6rem; }
.ace-line-float__close {
  position: absolute; top: 8px; right: 8px;
  width: 26px; height: 26px;
  border: none; background: rgba(255,255,255,0.18); color: #fff;
  border-radius: 50%; cursor: pointer; font-size: 1.6rem; line-height: 1;
  display: grid; place-items: center;
  transition: background 0.2s;
}
.ace-line-float__close:hover { background: rgba(255,255,255,0.34); }
.ace-line-float__body { padding: 16px 18px 18px; text-align: center; }
.ace-line-float__title { font-size: 1.3rem; color: var(--ink-soft); margin-bottom: 4px; }
.ace-line-float__gift { font-weight: 700; font-size: 1.6rem; color: var(--red); line-height: 1.5; margin-bottom: 14px; }

.ace-line-reopen {
  position: fixed;
  right: clamp(14px, 2vw, 26px);
  bottom: clamp(14px, 2vw, 26px);
  z-index: 199;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: #06c755;
  color: #fff; border: none; cursor: pointer;
  display: none; place-items: center;
  box-shadow: 0 10px 26px rgba(6,199,85,0.4);
  animation: ace-lf-pulse 2.4s infinite;
}
.ace-line-reopen.show { display: grid; }
.ace-line-reopen svg { width: 28px; height: 28px; }
@keyframes ace-lf-pulse {
  0%, 100% { box-shadow: 0 10px 26px rgba(6,199,85,0.4); }
  50% { box-shadow: 0 10px 26px rgba(6,199,85,0.4), 0 0 0 12px rgba(6,199,85,0); }
}

/* ============================================================
   下層ページ用ヒーロー（グラデ背景＋波形下端）
============================================================ */
.ace-page-hero {
  background:
    radial-gradient(130% 120% at 78% 8%, var(--red-soft) 0%, transparent 58%),
    linear-gradient(120deg, var(--red-soft) 0%, var(--red) 42%, var(--red-deep) 100%);
  padding-block: clamp(56px, 8vw, 110px) clamp(74px, 10vw, 140px);
  position: relative;
  overflow: hidden;
  color: #fff;
}
.ace-page-hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: clamp(44px, 6vw, 96px);
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,92 C380,150 1020,34 1440,86 L1440,120 L0,120 Z'/%3E%3C/svg%3E") no-repeat,
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath fill='%23e7c7cd' d='M0,58 C420,134 1000,4 1440,54 L1440,120 L0,120 Z'/%3E%3C/svg%3E") no-repeat;
  background-size: 100% 100%, 100% 100%;
  background-position: bottom, bottom;
  pointer-events: none;
}
.ace-page-hero__inner { position: relative; z-index: 2; }
.ace-breadcrumb {
  font-size: 1.2rem;
  color: rgba(255,255,255,0.78);
  display: flex; gap: 8px; align-items: center;
  margin-bottom: 26px; flex-wrap: wrap;
}
.ace-breadcrumb a { color: rgba(255,255,255,0.78); }
.ace-breadcrumb a:hover { color: #fff; opacity: 1; }
.ace-breadcrumb .sep { opacity: 0.5; }
.ace-page-hero__en {
  font-family: var(--serif);
  font-size: clamp(2rem, 2.6vw, 2.6rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.45);
  line-height: 1;
  margin-bottom: 8px;
  display: block;
}
.ace-page-hero__title {
  font-size: clamp(2.6rem, 4vw, 3.6rem);
  line-height: 1.4;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 2px 24px rgba(120,30,45,0.22);
}
.ace-page-hero__sub { color: rgba(255,255,255,0.9); margin-top: 16px; max-width: 640px; font-size: 1.6rem; }

/* ============================================================
   reveal アニメーション（スクロール表示）
============================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
  will-change: opacity, transform;
}
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal][data-delay="1"] { transition-delay: 0.1s; }
[data-reveal][data-delay="2"] { transition-delay: 0.2s; }
[data-reveal][data-delay="3"] { transition-delay: 0.3s; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   スマホ表示の全体調整（フォント縮小・本文は左揃え）
============================================================ */
/* スマホ専用の改行（PC等では無効） */
.br-sp { display: none; }
/* PC・タブレット用の改行（スマホでは無効） */
.br-pc { display: inline; }

@media (max-width: 639px) {
  /* ルートを縮小して全体のフォント・rem余白を一段小さく（1rem ≒ 9px） */
  html { font-size: 56.25%; }
  /* タイトル以外の「文章」は左揃え（見出し h2/h3・英ラベルは中央のまま） */
  .ace-lead,
  .ace-empathy__text,
  .ace-page-hero__sub,
  .center p { text-align: left; }
  /* スマホ専用改行を有効化／PC用改行は無効化 */
  .br-sp { display: inline; }
  .br-pc { display: none; }
}
