/* ===============================================
 * ページ共通スタイル
 * ============================================= */

.p-page {
  background-color: #fff;
  min-height: 100vh;
  padding-top: 70px;
}

/* ===============================================
 * ヒーローセクション
 * ============================================= */
.p-page-hero {
  background: linear-gradient(180deg, #FFFDF0 0%, #FFFFFF 100%);
  padding: 40px 20px 40px;
  position: relative;
}

.p-page-hero-container {
  max-width: 900px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .p-page-hero {
    padding: 60px 40px 60px;
  }
  
  .p-page-hero::before {
    width: 200px;
    height: 200px;
  }
  
  .p-page-hero::after {
    width: 150px;
    height: 150px;
  }
}

/* ===============================================
 * パンくずリスト
 * ============================================= */
.p-breadcrumb-wrapper {
  background-color: #fff;
  padding: 0 20px 16px;
}

.p-breadcrumb-container {
  max-width: 900px;
  margin: 0 auto;
}

.p-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  margin-bottom: 0;
  flex-wrap: wrap;
}

.p-breadcrumb a {
  color: #333;
  text-decoration: none;
  transition: color 0.2s;
}

.p-breadcrumb a:hover {
  color: #5FC279;
}

.p-breadcrumb-separator {
  color: #999;
}

.p-breadcrumb-current {
  color: #666;
}

@media (min-width: 768px) {
  .p-breadcrumb-wrapper {
    padding: 30px 40px 20px;
  }
  
  .p-breadcrumb {
    font-size: 16px;
  }
}

/* ===============================================
 * ページタイトル
 * ============================================= */
.p-page-title {
  font-size: clamp(24px, 5vw, 40px);
  font-weight: 700;
  color: #000;
  line-height: 1.4;
  margin: 0;
  text-align: center;
  letter-spacing: 0.05em;
}

/* ===============================================
 * コンテンツエリア
 * ============================================= */
.p-page-content {
  padding: 40px 20px 80px;
  background-color: #fff;
}

.p-page-container {
  max-width: 900px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .p-page-content {
    padding: 60px 40px 100px;
  }
}

/* ===============================================
 * セクション
 * ============================================= */
.p-section {
  margin-bottom: 48px;
}

.p-section:last-child {
  margin-bottom: 0;
}

.p-lead {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  color: #333;
  margin-bottom: 48px;
  padding: 24px;
  background-color: #F7F1DF;
  border-radius: 8px;
}

.p-section-title {
  font-size: clamp(20px, 4vw, 28px);
  font-weight: 700;
  color: #000;
  line-height: 1.4;
  margin: 0 0 24px;
  padding-bottom: 16px;
  border-bottom: 3px solid #5FC279;
  position: relative;
}

.p-section-title::before {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 60px;
  height: 3px;
  background-color: #FCCD64;
}

.p-section p {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  color: #333;
  margin-bottom: 16px;
}

.p-section p:last-child {
  margin-bottom: 0;
}

.p-subsection-title {
  font-size: clamp(18px, 0.5vw + 17.17px, 20px);
  font-weight: 700;
  color: #000;
  margin: 32px 0 16px;
  padding-left: 12px;
  border-left: 4px solid #5FC279;
  line-height: 1.5;
}

.p-subsection-title:first-of-type {
  margin-top: 24px;
}

/* ===============================================
 * リスト
 * ============================================= */
.p-list {
  list-style: none;
  padding: 0;
  margin: 24px 0;
}

.p-list li {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  color: #333;
  margin-bottom: 12px;
  padding-left: 1.5em;
  position: relative;
}

.p-list li::before {
  content: '・';
  position: absolute;
  left: 0;
  color: #5FC279;
  font-weight: 700;
}

.p-list li:last-child {
  margin-bottom: 0;
}

.p-list-number {
  list-style: none;
  padding: 0;
  margin: 24px 0;
  counter-reset: item;
}

.p-list-number li {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  color: #333;
  margin-bottom: 12px;
  padding-left: 2em;
  position: relative;
  counter-increment: item;
}

.p-list-number li::before {
  content: counter(item) ".";
  position: absolute;
  left: 0;
  color: #5FC279;
  font-weight: 700;
}

.p-list-number li:last-child {
  margin-bottom: 0;
}

.p-list-circle {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  counter-reset: circle;
}

.p-list-circle li {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  color: #333;
  margin-bottom: 12px;
  padding-left: 2em;
  position: relative;
  counter-increment: circle;
}

.p-list-circle li::before {
  content: "①";
  position: absolute;
  left: 0;
  color: #5FC279;
  font-weight: 700;
}

.p-list-circle li:nth-child(1)::before { content: "①"; }
.p-list-circle li:nth-child(2)::before { content: "②"; }
.p-list-circle li:nth-child(3)::before { content: "③"; }
.p-list-circle li:nth-child(4)::before { content: "④"; }
.p-list-circle li:nth-child(5)::before { content: "⑤"; }
.p-list-circle li:nth-child(6)::before { content: "⑥"; }
.p-list-circle li:nth-child(7)::before { content: "⑦"; }
.p-list-circle li:nth-child(8)::before { content: "⑧"; }
.p-list-circle li:nth-child(9)::before { content: "⑨"; }
.p-list-circle li:nth-child(10)::before { content: "⑩"; }

.p-list-circle li:last-child {
  margin-bottom: 0;
}

/* ===============================================
 * テーブル
 * ============================================= */
.p-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: clamp(14px, 0.5vw + 13.17px, 16px);
}

.p-table th,
.p-table td {
  padding: 16px;
  text-align: left;
  border: 1px solid #E0E0E0;
}

.p-table th {
  background-color: #F7F1DF;
  font-weight: 700;
  color: #000;
  width: 30%;
}

.p-table td {
  background-color: #fff;
  color: #333;
  line-height: 1.8;
}

.p-table td .p-list {
  margin: 0;
}

.p-table td .p-list li {
  margin-bottom: 8px;
}

.p-table td .p-list li:last-child {
  margin-bottom: 0;
}

.p-table td p {
  margin-bottom: 16px;
}

.p-table td p:last-child {
  margin-bottom: 0;
}

.p-table td a {
  color: #5FC279;
  text-decoration: underline;
  word-break: break-all;
}

.p-table td a:hover {
  opacity: 0.7;
}

@media (max-width: 767px) {
  .p-table th,
  .p-table td {
    display: block;
    width: 100%;
  }
  
  .p-table th {
    border-bottom: none;
  }
  
  .p-table td {
    border-top: none;
    margin-bottom: 16px;
  }
}

/* ===============================================
 * お問い合わせ
 * ============================================= */
.p-contact {
  background-color: #F7F1DF;
  padding: 24px;
  border-radius: 8px;
  margin-top: 16px;
}

.p-contact p {
  font-size: clamp(16px, 0.5vw + 15.17px, 18px);
  line-height: 1.8;
  margin-bottom: 12px;
}

.p-contact p:last-child {
  margin-bottom: 0;
}
