/*
Theme Name: Nakaioue LP
Theme URI: https://example.com
Author: Nakaioue Shoten
Description: 中井上商店FC募集用LPテーマ
Version: 1.0
Requires at least: 6.4
Tested up to: 6.4
Requires PHP: 7.4
*/

/* ここから下はCursorが書きます */

/* ========================================
   Google Fonts
   ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Zen+Old+Mincho:wght@400;700&display=swap');

/* ========================================
   カラーパレット & ベース設定
   ======================================== */
:root {
  --color-off-white: #FAFAF7;
  --color-deep-green: #2D5016;
  --color-candy-red: #C41E3A;
  --color-wood-brown: #8B6F47;
  --color-text-dark: #2C2C2C;
  --color-text-gray: #666666;
}

/* ========================================
   タイポグラフィ - グローバル設定
   ======================================== */
/* 見出しのデフォルトフォントをZen Old Minchoに設定 */
h1, h2, h3, h4, h5, h6,
.wp-block-heading,
.has-heading-font-family {
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #333333;
}

/* 見出しの引き締め - 余白のメリハリ */
h2,
.wp-block-heading[class*="heading"] {
  margin-top: 4rem;
  margin-bottom: 2rem;
  letter-spacing: 0.12em;
  font-size: 1.75rem;
  line-height: 1.5;
  color: #2D5016;
}

h3 {
  margin-top: 3rem;
  margin-bottom: 1.5rem;
  letter-spacing: 0.1em;
  font-size: 1.5rem;
  line-height: 1.6;
  color: #2D5016;
}

/* 最初の見出しは余白を小さく */
.wp-block-group.content-block > .wp-block-heading:first-child,
.wp-block-group.content-block > h2:first-child {
  margin-top: 2rem !important;
}

/* セクション間の大きな余白 */
.wp-block-group.section-organic + .wp-block-group.section-wood-accent,
.wp-block-group.section-wood-accent + .wp-block-group.section-organic {
  margin-top: 0 !important;
}

/* 見出しの直下は少し詰める */
.wp-block-heading.heading-section + .wp-block-paragraph,
h2.heading-section + p,
.heading-section + .body-text {
  margin-top: 0 !important;
  margin-bottom: 2rem !important;
}

/* 本文のデフォルトフォントをNoto Sans JPに設定 */
body,
p,
.wp-block-paragraph,
.has-body-font-family {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  line-height: 2.0;
  letter-spacing: 0.05em;
  color: #333333;
}

/* 段落の黄金比 - 老舗の和モダンな余白 */
p,
.wp-block-paragraph {
  margin-bottom: 2rem;
  line-height: 2.0;
  color: #333333;
}

.hero-catch {
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  letter-spacing: 0.1em;
}

.heading-serif {
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.1em;
  color: #333333;
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (max-width: 768px) {
  .heading-serif {
    font-size: 1.25rem;
    margin-bottom: 1.25rem;
  }
}

.body-sans {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  line-height: 1.8;
}

/* ========================================
   セクション共通スタイル
   ======================================== */
.wp-block-group.section-organic,
.section-organic {
  background-color: var(--color-off-white) !important;
  padding: 80px 0 !important;
}

.wp-block-group.section-wood-accent,
.section-wood-accent {
  background: linear-gradient(135deg, var(--color-off-white) 0%, #F5F5F0 100%) !important;
  position: relative;
  padding: 80px 0 !important;
}

.wp-block-group.section-wood-accent::before,
.section-wood-accent::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 40%;
  height: 100%;
  background: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 2px,
    rgba(139, 111, 71, 0.05) 2px,
    rgba(139, 111, 71, 0.05) 4px
  );
  opacity: 0.3;
}

@media (max-width: 768px) {
  .wp-block-group.section-organic,
  .section-organic,
  .wp-block-group.section-wood-accent,
  .section-wood-accent {
    padding: 40px 0 !important;
  }
}

/* ========================================
   ヒーローセクション
   ======================================== */
.hero-cover {
  min-height: 70vh;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-overlay {
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.3) 0%,
    rgba(0,0,0,0.5) 100%
  );
}

/* Hero Section内のテキストはデフォルトで白、ただしエディタでの個別調整を可能にする */
.wp-block-cover.hero-cover .wp-block-cover__inner-container {
  color: #FFFFFF;
}

.wp-block-cover.hero-cover .wp-block-cover__inner-container > * {
  color: #FFFFFF;
}

.hero-catch-text {
  color: #FFFFFF;
  text-shadow: 2px 2px 8px rgba(0,0,0,0.5);
  font-size: clamp(2rem, 5vw, 3.5rem);
  text-align: center;
  margin-bottom: 1.5rem;
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 1.4;
}

.hero-lead-text {
  color: #FFFFFF;
  font-size: clamp(1rem, 2vw, 1.25rem);
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.8;
  text-shadow: 1px 1px 4px rgba(0,0,0,0.5);
}

.hero-sub-text {
  color: #FFFFFF;
  font-size: clamp(0.9rem, 1.8vw, 1.1rem);
  text-align: center;
  max-width: 700px;
  margin: 1rem auto;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.8;
  font-style: italic;
  text-shadow: 1px 1px 4px rgba(0,0,0,0.5);
}

.hero-offer-text {
  color: #FFFFFF;
  font-size: clamp(1.1rem, 2.2vw, 1.3rem);
  text-align: center;
  max-width: 800px;
  margin: 2rem auto 0;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  line-height: 1.8;
  text-shadow: 1px 1px 4px rgba(0,0,0,0.5);
}

@media (max-width: 768px) {
  .hero-cover {
    min-height: 60vh;
  }
  
  .hero-catch-text {
    font-size: 1.75rem;
    margin-bottom: 1rem;
  }
  
  .hero-lead-text,
  .hero-sub-text,
  .hero-offer-text {
    font-size: 0.95rem;
  }
}

/* ========================================
   コンテンツブロック
   ======================================== */
.wp-block-group.content-block,
.content-block {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* メインテキストのコンテンツ幅を840pxに制限 */
.wp-block-group.content-text-narrow,
.content-text-narrow {
  max-width: 840px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

@media (max-width: 768px) {
  .wp-block-group.content-block,
  .content-block {
    padding: 0 16px !important;
  }
  
  .wp-block-group.content-text-narrow,
  .content-text-narrow {
    padding: 0 16px !important;
  }
}

.wp-block-heading.heading-section,
h2.heading-section,
.heading-section {
  font-size: 1.75rem;
  color: #2D5016;
  margin-top: 4rem;
  margin-bottom: 2rem;
  text-align: center;
  position: relative;
  padding-bottom: 1rem;
  font-family: 'Zen Old Mincho', serif;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.12em;
}

.wp-block-heading.heading-section::after,
h2.heading-section::after,
.heading-section::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  background: var(--color-candy-red);
}

@media (max-width: 768px) {
  h2,
  .wp-block-heading[class*="heading"] {
    font-size: 1.375rem;
    margin-top: 3rem;
    margin-bottom: 1.5rem;
  }
  
  h3 {
    font-size: 1.25rem;
    margin-top: 2rem;
    margin-bottom: 1.25rem;
  }
  
  .wp-block-heading.heading-section,
  h2.heading-section,
  .heading-section {
    font-size: 1.375rem;
    margin-top: 3rem;
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
  }
}

.wp-block-paragraph.body-text,
p.body-text,
.body-text {
  font-size: 1.125rem;
  color: #333333;
  line-height: 2.0;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
}

@media (max-width: 768px) {
  .wp-block-paragraph.body-text,
  p.body-text,
  .body-text {
    font-size: 1rem;
    line-height: 2.0;
    margin-bottom: 1.5rem;
  }
}

.sub-text {
  font-size: 1rem;
  color: #333333;
  font-style: italic;
  margin-bottom: 1rem;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 2.0;
  letter-spacing: 0.05em;
}

@media (max-width: 768px) {
  .sub-text {
    font-size: 0.9rem;
  }
}

/* ========================================
   ハイライトボックス
   ======================================== */
.wp-block-group.highlight-box,
.highlight-box {
  background: #FFFFFF !important;
  border-left: 4px solid var(--color-candy-red) !important;
  padding: 2rem !important;
  margin: 2rem 0 !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
  border-radius: 4px !important;
}

@media (max-width: 768px) {
  .wp-block-group.highlight-box,
  .highlight-box {
    padding: 1.5rem !important;
    margin: 1.5rem 0 !important;
  }
}

/* ベネフィットセクション - カードデザイン */
.wp-block-group.benefit-card,
.benefit-card {
  background: #F0F0EE !important;
  padding: 3rem !important;
  border-radius: 8px !important;
  margin: 2rem 0 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
}

@media (max-width: 768px) {
  .wp-block-group.benefit-card,
  .benefit-card {
    padding: 2rem 1.5rem !important;
    margin: 1.5rem 0 !important;
  }
}

.wp-block-list.benefit-list,
ul.benefit-list,
.benefit-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.wp-block-list.benefit-list li,
ul.benefit-list li,
.benefit-list li {
  display: flex;
  align-items: baseline;
  gap: 0.75em;
  padding: 1.25rem 0 !important;
  padding-left: 0 !important;
  text-indent: 0 !important;
  border-bottom: 1px solid rgba(45, 80, 22, 0.1) !important;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.125rem;
  line-height: 2.0;
  margin-bottom: 1.5rem !important;
  color: #333333;
  letter-spacing: 0.05em;
}

.wp-block-list.benefit-list li:last-child,
ul.benefit-list li:last-child,
.benefit-list li:last-child {
  border-bottom: none !important;
}

.wp-block-list.benefit-list li::before,
ul.benefit-list li::before,
.benefit-list li::before {
  content: '✓' !important;
  position: static !important;
  flex-shrink: 0;
  color: #2D5016 !important;
  font-weight: bold !important;
  font-size: 1.5rem !important;
  line-height: inherit;
  transform: translateY(0.1em);
}

@media (max-width: 768px) {
  .wp-block-list.benefit-list li,
  ul.benefit-list li,
  .benefit-list li {
    font-size: 1rem;
    padding: 0.75rem 0 !important;
    padding-left: 1.5em !important;
  }
}

/* ========================================
   CTAボタン
   ======================================== */
.cta-button-primary {
  background: var(--color-deep-green);
  color: #FFFFFF;
  padding: 1.25rem 3rem;
  border: none;
  border-radius: 4px;
  font-size: 1.125rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-block;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(45, 80, 22, 0.3);
  font-family: 'Noto Sans JP', sans-serif;
  text-align: center;
}

.cta-button-primary:hover {
  background: var(--color-candy-red);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(196, 30, 58, 0.4);
}

.cta-button-line {
  background: #06C755;
  color: #FFFFFF;
  padding: 1.5rem 4rem;
  font-size: 1.25rem;
  font-weight: 700;
  border-radius: 8px;
  display: inline-block;
  text-decoration: none;
  box-shadow: 0 6px 20px rgba(6, 199, 85, 0.4);
  font-family: 'Noto Sans JP', sans-serif;
  text-align: center;
  transition: all 0.3s ease;
}

.cta-button-line:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(6, 199, 85, 0.5);
}

@media (max-width: 768px) {
  .cta-button-primary {
    padding: 1rem 2rem;
    font-size: 1rem;
    width: 100%;
    display: block;
  }
  
  .cta-button-line {
    padding: 1.25rem 2.5rem;
    font-size: 1.1rem;
    width: 100%;
    display: block;
  }
}

.wp-block-group.cta-container,
.cta-container {
  text-align: center !important;
  margin: 3rem 0 !important;
}

@media (max-width: 768px) {
  .wp-block-group.cta-container,
  .cta-container {
    margin: 2rem 0 !important;
  }
}

/* ========================================
   引用・証言ブロック
   ======================================== */
.testimonial-block {
  background: var(--color-off-white);
  border: 2px solid var(--color-wood-brown);
  padding: 2.5rem;
  margin: 2rem 0;
  border-radius: 8px;
  position: relative;
}

.testimonial-block::before {
  content: '"';
  position: absolute;
  top: -20px;
  left: 30px;
  font-size: 5rem;
  color: var(--color-deep-green);
  opacity: 0.2;
  font-family: 'Zen Old Mincho', serif;
  line-height: 1;
}

.testimonial-text {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.125rem;
  line-height: 2.0;
  letter-spacing: 0.05em;
  color: #333333;
  margin: 0;
}

.testimonial-author {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 0.9rem;
  color: #333333;
  margin-top: 1rem;
  text-align: right;
  line-height: 2.0;
  letter-spacing: 0.05em;
}

@media (max-width: 768px) {
  .testimonial-block {
    padding: 1.5rem;
    margin: 1.5rem 0;
  }
  
  .testimonial-block::before {
    font-size: 3rem;
    top: -10px;
    left: 20px;
  }
  
  .testimonial-text {
    font-size: 1rem;
  }
}

/* ========================================
   リストスタイル - グローバル設定
   ======================================== */
/* すべてのリストの基本設定 */
.wp-block-list,
ul,
ol {
  padding-left: 0 !important;
  list-style: none !important;
}

/* リストアイテムの基本設定 - Flexboxレイアウトでピクセルパーフェクト */
.wp-block-list li,
ul li,
ol li {
  display: flex;
  align-items: baseline;
  gap: 0.75em;
  padding-left: 0 !important;
  text-indent: 0 !important;
  margin-bottom: 1.5rem !important;
  line-height: 2.0 !important;
  color: #333333;
}

/* デフォルトのリストマーカー - Flexboxアイテムとして配置 */
.wp-block-list li::before,
ul li::before,
ol li::before {
  content: '✓' !important;
  color: #2D5016 !important;
  font-weight: bold !important;
  position: static !important;
  flex-shrink: 0;
  font-size: 1.25rem !important;
  line-height: inherit;
  transform: translateY(0.1em);
}

/* ========================================
   リストスタイル - 特定リスト
   ======================================== */
.wp-block-list.condition-list,
ul.condition-list,
.condition-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 1.5rem 0 !important;
  counter-reset: list-counter;
}

.wp-block-list.condition-list li,
ul.condition-list li,
.condition-list li {
  display: flex;
  align-items: baseline;
  gap: 0.75em;
  padding: 1.25rem 0 !important;
  padding-left: 0 !important;
  text-indent: 0 !important;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.125rem;
  line-height: 2.0;
  margin-bottom: 1.5rem !important;
  color: #333333;
  letter-spacing: 0.05em;
}

.wp-block-list.condition-list li::before,
ul.condition-list li::before,
.condition-list li::before {
  content: counter(list-counter) !important;
  counter-increment: list-counter;
  position: static !important;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  background: var(--color-deep-green) !important;
  color: #FFFFFF !important;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700 !important;
  font-size: 1rem !important;
  line-height: 1;
  transform: translateY(0.1em);
}

@media (max-width: 768px) {
  .wp-block-list.condition-list li,
  ul.condition-list li,
  .condition-list li {
    font-size: 1rem;
    padding: 0.75rem 0 !important;
    padding-left: 0 !important;
  }
  
  .wp-block-list.condition-list li::before,
  ul.condition-list li::before,
  .condition-list li::before {
    width: 1.75rem;
    height: 1.75rem;
    min-width: 1.75rem;
    font-size: 0.9rem;
  }
}

.wp-block-list.step-list,
ul.step-list,
.step-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 1.5rem 0 !important;
  counter-reset: step-counter;
}

.wp-block-list.step-list li,
ul.step-list li,
.step-list li {
  display: flex;
  align-items: baseline;
  gap: 0.75em;
  padding: 1.25rem 0 !important;
  padding-left: 0 !important;
  text-indent: 0 !important;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.125rem;
  line-height: 2.0;
  margin-bottom: 1.5rem !important;
  color: #333333;
  letter-spacing: 0.05em;
}

.wp-block-list.step-list li::before,
ul.step-list li::before,
.step-list li::before {
  content: counter(step-counter) !important;
  counter-increment: step-counter;
  position: static !important;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  background: var(--color-candy-red) !important;
  color: #FFFFFF !important;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700 !important;
  font-size: 1rem !important;
  line-height: 1;
  transform: translateY(0.1em);
}

@media (max-width: 768px) {
  .wp-block-list.step-list li,
  ul.step-list li,
  .step-list li {
    font-size: 1rem;
    padding: 0.75rem 0 !important;
    padding-left: 0 !important;
  }
  
  .wp-block-list.step-list li::before,
  ul.step-list li::before,
  .step-list li::before {
    width: 1.75rem;
    height: 1.75rem;
    min-width: 1.75rem;
    font-size: 0.9rem;
  }
}

/* ========================================
   フッター
   ======================================== */
.footer-organic {
  background: var(--color-text-dark);
  color: #FFFFFF;
  padding: 3rem 0 1.5rem;
  text-align: center;
}

.wp-block-paragraph.footer-signature,
p.footer-signature,
.footer-signature {
  font-family: 'Zen Old Mincho', serif !important;
  font-size: 1.25rem !important;
  margin-top: 2rem !important;
  color: var(--color-off-white) !important;
}

.wp-block-paragraph.footer-profile,
p.footer-profile,
.footer-profile {
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: 0.95rem !important;
  color: #CCCCCC !important;
  margin-top: 1rem !important;
  line-height: 1.8 !important;
}

@media (max-width: 768px) {
  .footer-organic {
    padding: 2rem 0 1rem;
  }
  
  .footer-signature {
    font-size: 1.1rem;
    margin-top: 1.5rem;
  }
  
  .footer-profile {
    font-size: 0.85rem;
  }
}

/* ========================================
   メディア&テキストブロック（Story Section用）
   ======================================== */
.wp-block-media-text.story-media-text,
.story-media-text {
  align-items: center !important;
  margin: 3rem 0 !important;
}

.wp-block-media-text.story-media-text .wp-block-media-text__media,
.story-media-text .wp-block-media-text__media {
  background: var(--color-off-white) !important;
  overflow: hidden;
}

.wp-block-media-text.story-media-text .wp-block-media-text__media img,
.story-media-text .wp-block-media-text__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.wp-block-media-text.story-media-text .wp-block-media-text__content,
.story-media-text .wp-block-media-text__content {
  padding: 2rem 3rem !important;
}

@media (max-width: 768px) {
  .wp-block-media-text.story-media-text,
  .story-media-text {
    margin: 2rem 0 !important;
  }
  
  .wp-block-media-text.story-media-text .wp-block-media-text__content,
  .story-media-text .wp-block-media-text__content {
    padding: 1.5rem !important;
  }
}

/* ========================================
   ベネフィットカード内のリスト調整
   ======================================== */
.benefit-card .wp-block-list,
.benefit-card ul,
.benefit-card ol {
  padding-left: 0 !important;
  list-style: none !important;
}

.benefit-card .wp-block-list li,
.benefit-card ul li,
.benefit-card ol li {
  display: flex;
  align-items: baseline;
  gap: 0.75em;
  padding-left: 0 !important;
  text-indent: 0 !important;
  margin-bottom: 1.5rem !important;
  line-height: 2.0;
  color: #333333;
  letter-spacing: 0.05em;
}

.benefit-card .wp-block-list li::before,
.benefit-card ul li::before,
.benefit-card ol li::before {
  content: '✓' !important;
  color: #2D5016 !important;
  font-weight: bold !important;
  position: static !important;
  flex-shrink: 0;
  font-size: 1.25rem !important;
  line-height: inherit;
  transform: translateY(0.1em);
}

/* ========================================
   セクション間の余白リズム
   ======================================== */
/* セクション終わりの大きな余白 */
.wp-block-group.section-organic {
  margin-bottom: 0 !important;
}

.wp-block-group.section-wood-accent {
  margin-bottom: 0 !important;
}

/* Media & Textブロック内の余白調整 */
.wp-block-media-text.story-media-text .wp-block-media-text__content {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

/* 段落と見出しの間の余白調整 */
.wp-block-paragraph + .wp-block-heading,
p + h2,
.body-text + .heading-section {
  margin-top: 3rem !important;
}

/* ========================================
   WordPress Editor Compatibility
   ======================================== */
/* エディタで設定された文字色クラスを優先 */
.has-text-color {
  color: var(--wp--preset--color, inherit);
}

/* エディタで設定されたフォントサイズクラスを優先 */
.has-small-font-size {
  font-size: var(--wp--preset--font-size--small, 0.875rem);
}

.has-medium-font-size {
  font-size: var(--wp--preset--font-size--medium, 1rem);
}

.has-large-font-size {
  font-size: var(--wp--preset--font-size--large, 1.5rem);
}

.has-x-large-font-size {
  font-size: var(--wp--preset--font-size--x-large, 2rem);
}

/* インラインスタイル（エディタで直接設定した場合）を最優先 */
[style*="color"] {
  color: inherit;
}

[style*="font-size"] {
  font-size: inherit;
}

/* Hero Section内でもエディタ設定を優先（デフォルトは白） */
.wp-block-cover.hero-cover .wp-block-cover__inner-container {
  color: #FFFFFF;
}

.wp-block-cover.hero-cover .has-text-color,
.wp-block-cover.hero-cover [class*="has-"][class*="-color"],
.wp-block-cover.hero-cover [style*="color"] {
  color: var(--wp--preset--color, #FFFFFF);
}

/* ========================================
   その他ユーティリティ
   ======================================== */
.text-center {
  text-align: center;
}

.mb-large {
  margin-bottom: 3rem;
}

@media (max-width: 768px) {
  .mb-large {
    margin-bottom: 2rem;
  }
}
