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

/* ページヒーロー */
.page-hero {
  background-color: var(--primary-pink);
  background-image: linear-gradient(135deg, rgba(232,84,122,0.82) 0%, rgba(214,63,104,0.88) 100%);
  color: white;
  padding: var(--spacing-xl) 0;
  text-align: center;
}

.page-hero__label {
  font-family: var(--font-serif-en);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.82);
  margin-bottom: var(--spacing-xs);
}

.page-hero__title {
  font-size: 40px;
  font-weight: var(--font-weight-h1);
  margin-bottom: var(--spacing-sm);
  color: white;
}

.page-hero__subtitle {
  font-size: var(--font-size-large);
  opacity: 0.95;
}

/* コンテンツグリッド */
.content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
  align-items: center;
}

.content-grid__image {
  width: 100%;
}

.content-grid__text .lead-text {
  font-size: var(--font-size-large);
  line-height: 1.9;
  margin-bottom: var(--spacing-md);
}

/* 画像プレースホルダー */
.image-placeholder {
  width: 100%;
  height: 400px;
  background: linear-gradient(135deg, #E8547A 0%, #F4A7B9 100%);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.5);
  font-size: 18px;
}

.image-placeholder.small {
  height: 200px;
}

/* コンポーネントセクション */
.component-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-lg);
  box-shadow: var(--box-shadow);
}

.component-card__header {
  text-align: center;
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 2px solid var(--border-light);
}

.component-card__title {
  font-size: 32px;
  color: var(--primary-pink);
  margin-bottom: var(--spacing-xs);
}

.component-card__subtitle {
  font-size: var(--font-size-large);
  color: var(--text-gray);
}

.component-card__description h4 {
  font-size: 20px;
  margin-bottom: var(--spacing-sm);
  color: var(--primary-purple);
}

/* 機能リスト */
.feature-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.feature-list__item {
  display: flex;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background: var(--bg-light);
  border-radius: var(--border-radius);
}

.feature-list__icon {
  width: 28px;
  height: 28px;
  background: var(--primary-pink);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 600;
}

.feature-list__text {
  flex: 1;
}

/* 効果カード */
.effects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--spacing-md);
}

.effect-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-md);
  box-shadow: var(--box-shadow);
  transition: var(--transition);
}

.effect-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.effect-card__number {
  display: inline-block;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--primary-pink), var(--primary-purple));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: var(--spacing-sm);
}

.effect-card__title {
  font-size: 20px;
  margin-bottom: var(--spacing-sm);
  color: var(--text-dark);
}

.effect-card__image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: calc(var(--border-radius) / 2);
  margin-bottom: var(--spacing-sm);
}

.effect-card__text {
  color: var(--text-gray);
  line-height: 1.7;
}

/* メリット・デメリット */
.pros-cons-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}

.pros-card,
.cons-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-lg);
  box-shadow: var(--box-shadow);
}

.pros-card__title,
.cons-card__title {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: 24px;
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: 2px solid var(--border-light);
}

.pros-card__icon {
  font-size: 32px;
}

.cons-card__icon {
  font-size: 32px;
}

.pros-card__list,
.cons-card__list {
  list-style: none;
  padding: 0;
}

.pros-card__list li,
.cons-card__list li {
  padding: var(--spacing-xs) 0;
  padding-left: var(--spacing-md);
  position: relative;
}

.pros-card__list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--primary-pink);
  font-weight: 700;
}

.cons-card__list li::before {
  content: '!';
  position: absolute;
  left: 0;
  color: #FF9800;
  font-weight: 700;
}

/* 実績セクション */
.achievements-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-md);
}

.achievement-item {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-md);
  text-align: center;
  box-shadow: var(--box-shadow);
}

.achievement-item__icon {
  font-size: 48px;
  margin-bottom: var(--spacing-sm);
}

.achievement-item__title {
  font-size: 20px;
  margin-bottom: var(--spacing-sm);
  color: var(--primary-pink);
}

.achievement-item__text {
  color: var(--text-gray);
  line-height: 1.7;
}

/* 安全性セクション */
.safety-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-lg);
  box-shadow: var(--box-shadow);
}

.safety-card__item {
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-md);
  border-left: 4px solid var(--primary-pink);
  background: var(--bg-light);
}

.safety-card__item:last-child {
  margin-bottom: 0;
}

.safety-card__title {
  font-size: 18px;
  margin-bottom: var(--spacing-sm);
  color: var(--primary-purple);
}

/* 料金プラン */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-lg);
  max-width: 900px;
  margin: 0 auto var(--spacing-lg);
}

.pricing-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-lg);
  box-shadow: var(--box-shadow);
  position: relative;
  transition: var(--transition);
}

.pricing-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.pricing-card--featured {
  border: 3px solid var(--primary-pink);
}

.pricing-card__badge {
  display: inline-block;
  background: var(--text-gray);
  color: white;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: var(--font-size-small);
  margin-bottom: var(--spacing-sm);
}

.pricing-card__badge--popular {
  background: linear-gradient(135deg, var(--primary-pink), var(--primary-purple));
}

.pricing-card__title {
  font-size: 24px;
  margin-bottom: var(--spacing-md);
  text-align: center;
}

.pricing-card__price {
  text-align: center;
  margin-bottom: var(--spacing-sm);
}

.pricing-card__amount {
  font-size: 48px;
  font-weight: 700;
  color: var(--primary-pink);
}

.pricing-card__unit {
  font-size: 18px;
  color: var(--text-gray);
}

.pricing-card__volume {
  text-align: center;
  color: var(--text-gray);
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--border-light);
}

.pricing-card__features {
  list-style: none;
  padding: 0;
  margin-bottom: var(--spacing-md);
}

.pricing-card__features li {
  padding: var(--spacing-xs) 0;
  color: var(--text-dark);
}

.pricing-card__recommend {
  font-size: var(--font-size-small);
  color: var(--text-gray);
  text-align: center;
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--border-light);
}

.pricing-note {
  max-width: 700px;
  margin: 0 auto;
  padding: var(--spacing-md);
  background: var(--bg-light);
  border-radius: var(--border-radius);
  text-align: center;
}

.pricing-note h4 {
  font-size: 20px;
  margin-bottom: var(--spacing-sm);
  color: var(--primary-purple);
}

/* セクション背景ユーティリティ */
.section--light-rays {
  background-color: #FFFFFF;
}

.section--bokeh {
  background-color: var(--bg-light);
}

.section--pink-sparkle {
  background-color: var(--bg-beige);
}

/* CTAセクション */
.cta-section {
  background-color: var(--bg-light);
}

.cta-card {
  background: white;
  border-radius: var(--border-radius);
  padding: var(--spacing-xl);
  box-shadow: var(--box-shadow);
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.cta-card__title {
  font-size: 32px;
  margin-bottom: var(--spacing-md);
  background: linear-gradient(135deg, var(--primary-pink), var(--primary-purple));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cta-card__text {
  font-size: var(--font-size-large);
  color: var(--text-gray);
  margin-bottom: var(--spacing-lg);
  line-height: 1.8;
}

.cta-card__buttons {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  max-width: 400px;
  margin: 0 auto;
}

.component-section {
  background-color: var(--bg-light);
}

.effects-section {
  background: linear-gradient(180deg, #FFFFFF 0%, #FDE8EE 40%, #FBDCE6 100%);
}

.pros-cons-section {
  background-color: #FFFFFF;
}

.achievements-section {
  background-color: var(--bg-light);
}

.safety-section {
  background-color: #FFFFFF;
}

.pricing-section {
  background-color: var(--bg-light);
}

/* ===================================
   セラショットページ セクション背景
   =================================== */
.serashot-about {
  background-color: #FFFFFF;
}

.features-section {
  background-color: var(--bg-light);
}

.usage-section {
  background-color: var(--bg-beige);
}

.maintenance-section {
  background-color: #FFFFFF;
}

.spec-section {
  background-color: var(--bg-light);
}

.campaign-section {
  background-color: var(--primary-pink);
  background-image: linear-gradient(135deg, rgba(232,84,122,0.82) 0%, rgba(214,63,104,0.88) 100%);
  color: white;
}

.campaign-section .section__title-main {
  background: none;
  -webkit-text-fill-color: white;
  color: white;
}

.campaign-section .section__title-sub {
  color: rgba(255,255,255,0.85);
}

/* レスポンシブ */
@media (max-width: 768px) {
  .page-hero__title {
    font-size: 28px;
  }
  
  .content-grid {
    grid-template-columns: 1fr;
  }
  
  .effects-grid {
    grid-template-columns: 1fr;
  }
  
  .pros-cons-grid {
    grid-template-columns: 1fr;
  }
  
  .achievements-content {
    grid-template-columns: 1fr;
  }
  
  .pricing-grid {
    grid-template-columns: 1fr;
  }
  
  .cta-card {
    padding: var(--spacing-md);
  }
  
  .cta-card__title {
    font-size: 24px;
  }
}

/* ===================================
   薬剤一覧 (medications.html)
   =================================== */
.medication-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  margin-top: var(--spacing-lg);
}

.medication-card {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--spacing-lg);
  background: #fff;
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.medication-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.12);
}

.medication-card__media {
  background: var(--bg-light, #FDF6F8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-md);
}

.medication-card__media img {
  width: 100%;
  height: auto;
  max-height: 280px;
  object-fit: contain;
  border-radius: 8px;
}

.medication-card__media--placeholder {
  background: linear-gradient(135deg, #F0E8DC 0%, #FDF6F8 100%);
  min-height: 220px;
}

.medication-card__placeholder-label {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: var(--gold, #B8965A);
  opacity: 0.75;
}

.medication-card__body {
  padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-lg) 0;
  display: flex;
  flex-direction: column;
}

.medication-card__tag {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 12px;
  background: var(--primary-pink, #E8547A);
  color: #fff;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.05em;
  margin-bottom: var(--spacing-sm);
}

.medication-card__tag--muted {
  background: var(--mist, #E8DED2);
  color: var(--ink, #1A1614);
}

.medication-card__title {
  font-size: 28px;
  margin: 0 0 6px;
  color: var(--ink, #1A1614);
}

.medication-card__sub {
  font-size: 13px;
  color: var(--text-gray, #6b6b6b);
  margin: 0 0 var(--spacing-sm);
  letter-spacing: 0.02em;
}

.medication-card__desc {
  font-size: 15px;
  line-height: 1.8;
  margin: 0 0 var(--spacing-sm);
}

.medication-card__points {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--spacing-md);
}

.medication-card__points li {
  position: relative;
  padding-left: 20px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-gray, #555);
}

.medication-card__points li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--primary-pink, #E8547A);
  font-weight: 700;
}

.medication-card__btn {
  align-self: flex-start;
  margin-top: auto;
}

@media (max-width: 768px) {
  .medication-card {
    grid-template-columns: 1fr;
  }
  .medication-card__media {
    padding: var(--spacing-sm);
  }
  .medication-card__media img {
    max-height: 220px;
  }
  .medication-card__body {
    padding: 0 var(--spacing-md) var(--spacing-md);
  }
  .medication-card__title {
    font-size: 22px;
  }
}
