/* ================================================
   Privacy Policy Page Styles - Mobile First
   すべてCSS変数を使用
   ================================================ */

/* ================================================
   Policy Content Section
   ================================================ */
.policy-content-section {
  padding: var(--section-padding-mobile);
  background: var(--color-white);
}

.policy-content {
  max-width: 900px;
  margin: 0 auto;
}

.policy-intro {
  margin-bottom: var(--spacing-2xl);
  padding: var(--spacing-lg);
  background: var(--color-bg-light);
  border-left: 4px solid var(--color-accent-01);
  border-radius: var(--border-radius-sm);
}

.policy-intro p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-primary);
  margin: 0;
}

.policy-article {
  margin-bottom: var(--spacing-2xl);
  padding-bottom: var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
}

.policy-article:last-of-type {
  border-bottom: none;
}

.policy-heading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-black);
  color: var(--color-black-pure);
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-sm);
  border-bottom: 2px solid var(--color-accent-01);
}

.policy-text {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-md);
}

.policy-text:last-child {
  margin-bottom: 0;
}

.policy-list {
  margin: var(--spacing-lg) 0;
  padding-left: var(--spacing-lg);
}

.policy-list li {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-md);
}

.policy-sublist {
  margin: var(--spacing-md) 0;
  padding-left: var(--spacing-xl);
  list-style-type: lower-alpha;
}

.policy-sublist li {
  margin-bottom: var(--spacing-sm);
}

.contact-info {
  margin-top: var(--spacing-lg);
  padding: var(--spacing-lg);
  background: var(--color-bg-light);
  border-radius: var(--border-radius-sm);
}

.contact-info p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-sm);
}

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

.policy-footer {
  margin-top: var(--spacing-3xl);
  padding-top: var(--spacing-2xl);
  border-top: 2px solid var(--color-border);
  text-align: right;
}

.effective-date {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-bold);
  margin: 0;
}

@media (min-width: 768px) {
  .policy-content-section {
    padding: var(--section-padding);
  }

  .policy-intro p {
    font-size: var(--font-size-md);
  }

  .policy-heading {
    font-size: var(--font-size-2xl);
  }

  .policy-text {
    font-size: var(--font-size-md);
  }

  .policy-list li {
    font-size: var(--font-size-md);
  }

  .contact-info p {
    font-size: var(--font-size-md);
  }
}
