/* ==========================================================================
   Pages - Hero, Sections, Page-specific Styles
   antena-shuri Theme
   ========================================================================== */

/* --------------------------------------------------------------------------
   Hero Section
   -------------------------------------------------------------------------- */
.hero {
  background: linear-gradient(135deg, rgba(0,47,120,0.75) 0%, rgba(0,30,77,0.8) 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-white);
  padding: var(--sp-64) 0 var(--sp-48);
  position: relative;
  overflow: hidden;
}

.hero[style*="background-image"] {
  background-blend-mode: overlay;
}

.hero::before {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  background: linear-gradient(135deg, rgba(0,47,120,0.7) 0%, rgba(0,30,77,0.75) 100%);
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

@media (min-width: 1024px) {
  .hero { padding: var(--sp-96) 0 var(--sp-80); }
  .hero__inner { text-align: left; display: flex; align-items: center; gap: var(--sp-64); }
  .hero__content { flex: 1; }
  .hero__visual { flex: 0 0 400px; }
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-8);
  padding: var(--sp-8) var(--sp-16);
  background-color: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  font-weight: 600;
  margin-bottom: var(--sp-24);
  backdrop-filter: blur(4px);
}

.hero__title {
  font-size: var(--fs-2xl);
  font-weight: 900;
  line-height: 1.3;
  margin-bottom: var(--sp-16);
}

@media (min-width: 768px) { .hero__title { font-size: var(--fs-4xl); } }
@media (min-width: 1024px) { .hero__title { font-size: 48px; } }

.hero__highlight {
  color: var(--color-accent);
  font-size: 120%;
}

.hero__subtitle {
  font-size: var(--fs-base);
  opacity: 0.9;
  margin-bottom: var(--sp-32);
  line-height: 1.8;
}

@media (min-width: 768px) { .hero__subtitle { font-size: var(--fs-md); } }

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-16);
  margin-bottom: var(--sp-32);
  justify-content: center;
}

@media (min-width: 1024px) { .hero__actions { justify-content: flex-start; } }

/* Hero Trust Signals - 早い×丁寧を強調 */
.hero__stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-16) var(--sp-24);
  justify-content: center;
}

@media (min-width: 1024px) { .hero__stats { justify-content: flex-start; } }

.hero__stat {
  text-align: center;
  padding: var(--sp-12) var(--sp-16);
  background: rgba(255,255,255,0.1);
  border-radius: var(--radius-md);
  backdrop-filter: blur(4px);
  min-width: 100px;
}

.hero__stat-number {
  display: block;
  font-family: var(--font-en);
  font-size: var(--fs-3xl);
  font-weight: 900;
  color: var(--color-accent);
  line-height: 1.1;
}

@media (min-width: 768px) { .hero__stat-number { font-size: var(--fs-4xl); } }

.hero__stat-label {
  font-size: var(--fs-xs);
  opacity: 0.8;
  margin-top: var(--sp-4);
}

/* --------------------------------------------------------------------------
   Mansion Section (集合住宅・管理会社向け)
   -------------------------------------------------------------------------- */
.mansion {
  padding: var(--sp-64) 0;
  background: linear-gradient(135deg, #f8fafc 0%, #e8f0fe 100%);
  position: relative;
  overflow: hidden;
}

@media (min-width: 768px) { .mansion { padding: var(--sp-96) 0; } }

.mansion__inner {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.mansion__content {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.mansion__badge {
  display: inline-block;
  padding: var(--sp-8) var(--sp-24);
  background-color: var(--color-accent);
  color: var(--color-white);
  font-size: var(--fs-sm);
  font-weight: 700;
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-24);
}

.mansion__title {
  font-size: var(--fs-2xl);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1.4;
  margin-bottom: var(--sp-24);
  text-align: center;
}

@media (min-width: 768px) { .mansion__title { font-size: var(--fs-3xl); } }

.mansion__text {
  font-size: var(--fs-base);
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: var(--sp-32);
  text-align: center;
}

.mansion__features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-12);
  margin-bottom: var(--sp-32);
  max-width: 500px;
  width: 100%;
}

.mansion__features li {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-8);
  font-size: var(--fs-sm);
  color: var(--color-text);
  font-weight: 600;
  padding: var(--sp-8) var(--sp-12);
  background-color: var(--color-white);
  border-radius: var(--radius-md);
}

.mansion__features li::before {
  content: '✓';
  color: var(--color-success);
  font-weight: 900;
  font-size: var(--fs-md);
}

.mansion__image {
  width: 100%;
  max-width: 600px;
  margin-bottom: var(--sp-32);
}

.mansion__image img {
  width: 100%;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.mansion__images {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-16);
  width: 100%;
  max-width: 800px;
  margin-bottom: var(--sp-32);
}

@media (min-width: 768px) {
  .mansion__images {
    grid-template-columns: 1fr 1fr;
  }
}

.mansion__images img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.mansion__actions {
  text-align: center;
}

/* --------------------------------------------------------------------------
   Logo Image (for header)
   -------------------------------------------------------------------------- */
.site-header__logo-img {
  height: 40px;
  width: auto;
  display: block;
}

@media (min-width: 1024px) {
  .site-header__logo-img {
    height: 50px;
  }
}

.site-footer__logo-img {
  height: 50px;
  width: auto;
  display: block;
  margin-bottom: var(--sp-16);
}

/* --------------------------------------------------------------------------
   Representative Photo (greeting section)
   -------------------------------------------------------------------------- */
.greeting__photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
}

/* --------------------------------------------------------------------------
   Gallery Section (Auto-scrolling)
   -------------------------------------------------------------------------- */
.gallery {
  overflow: hidden;
  padding: var(--sp-32) 0;
  background-color: var(--color-bg-dark);
}

.gallery__track {
  display: flex;
  gap: var(--sp-12);
  animation: gallery-scroll 30s linear infinite;
  width: max-content;
}

.gallery__track:hover {
  animation-play-state: paused;
}

.gallery__item {
  flex-shrink: 0;
  width: 280px;
  height: 200px;
  border-radius: var(--radius-md);
  overflow: hidden;
}

@media (min-width: 768px) {
  .gallery__item {
    width: 360px;
    height: 250px;
  }
}

.gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.gallery__item:hover img {
  transform: scale(1.05);
}

@keyframes gallery-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* --------------------------------------------------------------------------
   Problems Section
   -------------------------------------------------------------------------- */
.problems__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-16);
}

@media (min-width: 768px) { .problems__grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-24); } }
@media (min-width: 1024px) { .problems__grid { grid-template-columns: repeat(3, 1fr); } }

.problems__card {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-16);
  padding: var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.problems__card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.problems__icon {
  flex-shrink: 0;
  width: 48px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-accent-light);
  border-radius: var(--radius-md);
  font-size: var(--fs-xl);
}

.problems__text { font-size: var(--fs-sm); font-weight: 600; line-height: 1.6; }

@media (min-width: 768px) { .problems__text { font-size: var(--fs-base); } }

.problems__solution {
  text-align: center;
  margin-top: var(--sp-48);
  padding: var(--sp-32);
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  border-radius: var(--radius-lg);
  color: var(--color-white);
}

.problems__solution-title { font-size: var(--fs-xl); font-weight: 900; margin-bottom: var(--sp-8); }
.problems__solution-text { font-size: var(--fs-base); opacity: 0.9; }

/* --------------------------------------------------------------------------
   Service Section
   -------------------------------------------------------------------------- */
.service__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .service__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .service__grid { grid-template-columns: repeat(3, 1fr); } }

.service__card {
  padding: var(--sp-32) var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.service__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.service__card-icon {
  width: 64px; height: 64px;
  margin: 0 auto var(--sp-16);
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  border-radius: var(--radius-lg);
  font-size: 28px;
  color: var(--color-white);
}

.service__card-title { font-size: var(--fs-md); font-weight: 700; margin-bottom: var(--sp-12); color: var(--color-text); }
.service__card-text { font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text-light); }

/* --------------------------------------------------------------------------
   Reasons Section (選ばれる理由) - 早い×丁寧を強調
   -------------------------------------------------------------------------- */
.reasons__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .reasons__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .reasons__grid { grid-template-columns: repeat(3, 1fr); } }

.reasons__card {
  padding: var(--sp-32) var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border-top: 4px solid var(--color-primary);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.reasons__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.reasons__card--featured {
  border-top-color: var(--color-accent);
  background: linear-gradient(180deg, var(--color-accent-light) 0%, var(--color-white) 30%);
}

.reasons__number {
  font-family: var(--font-en);
  font-size: var(--fs-4xl);
  font-weight: 900;
  color: var(--color-primary);
  opacity: 0.15;
  line-height: 1;
  margin-bottom: var(--sp-8);
}

.reasons__card--featured .reasons__number { color: var(--color-accent); }

.reasons__card-title { font-size: var(--fs-md); font-weight: 700; margin-bottom: var(--sp-12); }
.reasons__card-text { font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text-light); }

/* --------------------------------------------------------------------------
   Price Table Section
   -------------------------------------------------------------------------- */
.price-table__grid {
  display: flex;
  gap: var(--sp-16);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--sp-16);
}

.price-card {
  flex: 0 0 280px;
  min-width: 260px;
  scroll-snap-align: start;
  padding: var(--sp-32) var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-align: center;
  border: 2px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.price-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.price-card--recommended {
  border-color: var(--color-accent);
  position: relative;
  padding-top: var(--sp-16);
}

.price-card__badge {
  display: inline-block;
  margin-bottom: var(--sp-12);
}

.price-card__name { font-size: var(--fs-md); font-weight: 700; margin-bottom: var(--sp-8); color: var(--color-text); }
.price-card__price { margin-bottom: var(--sp-24); }
.price-card__price-number {
  font-family: var(--font-en);
  font-size: var(--fs-4xl);
  font-weight: 900;
  color: var(--color-accent);
  line-height: 1;
}
.price-card__price-unit { font-size: var(--fs-sm); color: var(--color-text-light); }
.price-card__price-note { font-size: var(--fs-xs); color: var(--color-text-muted); margin-top: var(--sp-4); }

.price-card__features { text-align: left; margin-bottom: var(--sp-24); }
.price-card__feature {
  display: flex; align-items: baseline; gap: var(--sp-8);
  font-size: var(--fs-sm); padding: var(--sp-4) 0;
  color: var(--color-text-light);
}
.price-card__feature::before {
  content: '✓';
  color: var(--color-success);
  font-weight: 700;
  flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   Works Gallery Section
   -------------------------------------------------------------------------- */
.works-gallery__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .works-gallery__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .works-gallery__grid { grid-template-columns: repeat(3, 1fr); } }

.works-card {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.works-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.works-card__thumb {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
}

.works-card__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.works-card:hover .works-card__thumb img { transform: scale(1.05); }

.works-card__body { padding: var(--sp-16) var(--sp-24) var(--sp-24); }
.works-card__area { font-size: var(--fs-xs); color: var(--color-primary); font-weight: 600; margin-bottom: var(--sp-4); }
.works-card__title { font-size: var(--fs-base); font-weight: 700; line-height: 1.4; margin-bottom: var(--sp-8); }
.works-card__type { font-size: var(--fs-xs); color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   Testimonials Section
   -------------------------------------------------------------------------- */
.testimonials__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .testimonials__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .testimonials__grid { grid-template-columns: repeat(3, 1fr); } }

.testimonial-card {
  padding: var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border-left: 4px solid var(--color-primary);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.testimonial-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.testimonial-card__header {
  display: flex;
  align-items: center;
  gap: var(--sp-16);
  margin-bottom: var(--sp-16);
}

.testimonial-card__avatar {
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  background-color: var(--color-bg-gray);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-xl);
  flex-shrink: 0;
  overflow: hidden;
}

.testimonial-card__avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
}

.testimonial-card__info { flex: 1; }
.testimonial-card__name { font-size: var(--fs-sm); font-weight: 700; }
.testimonial-card__meta { font-size: var(--fs-xs); color: var(--color-text-muted); }
.testimonial-card__text { font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text-light); margin-bottom: var(--sp-16); }

.testimonial-card__reply {
  padding: var(--sp-16);
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-md);
  font-size: var(--fs-xs);
  line-height: 1.8;
  color: var(--color-text-light);
}

.testimonial-card__reply-label {
  font-weight: 700;
  color: var(--color-primary);
  display: block;
  margin-bottom: var(--sp-4);
}

/* --------------------------------------------------------------------------
   Flow Steps Section
   -------------------------------------------------------------------------- */
.flow-steps__timeline {
  max-width: 700px;
  margin: 0 auto;
}

.flow-steps__item {
  position: relative;
  padding-left: 80px;
  padding-bottom: var(--sp-48);
}

.flow-steps__item:last-child { padding-bottom: 0; }

.flow-steps__item::before {
  content: '';
  position: absolute;
  left: 24px;
  top: 56px;
  bottom: 0;
  width: 2px;
  background-color: var(--color-border);
}

.flow-steps__item:last-child::before { display: none; }

.flow-steps__marker {
  position: absolute;
  left: 0; top: 0;
  width: 50px; height: 50px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  color: var(--color-white);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-en);
  font-size: var(--fs-md);
  font-weight: 900;
  z-index: 1;
}

.flow-steps__content h3 { font-size: var(--fs-md); font-weight: 700; margin-bottom: var(--sp-8); }
.flow-steps__content p { font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text-light); }

/* --------------------------------------------------------------------------
   Area Section (対応エリア)
   -------------------------------------------------------------------------- */
.area__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .area__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .area__grid { grid-template-columns: repeat(4, 1fr); } }

.area__card {
  padding: var(--sp-24);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.area__card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.area__card--main {
  border: 2px solid var(--color-primary);
  background: linear-gradient(180deg, rgba(0,71,171,0.03) 0%, var(--color-white) 100%);
}

.area__card-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  margin-bottom: var(--sp-12);
  color: var(--color-primary);
}

.area__card--main .area__card-title { font-size: var(--fs-xl); }

.area__card-badge {
  display: inline-block;
  padding: var(--sp-4) var(--sp-12);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--fs-xs);
  font-weight: 700;
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-12);
}

.area__cities {
  font-size: var(--fs-sm);
  line-height: 2;
  color: var(--color-text-light);
}

/* --------------------------------------------------------------------------
   News Section
   -------------------------------------------------------------------------- */
.news__list { max-width: 800px; margin: 0 auto; }

.news__item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-16);
  padding: var(--sp-16) 0;
  border-bottom: 1px solid var(--color-border);
}

.news__item:last-child { border-bottom: none; }

.news__date {
  font-family: var(--font-en);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

.news__title { font-size: var(--fs-base); font-weight: 500; line-height: 1.6; }
.news__title a { color: var(--color-text); }
.news__title a:hover { color: var(--color-primary); }

/* --------------------------------------------------------------------------
   Blog Latest Section
   -------------------------------------------------------------------------- */
.blog-latest__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
}

@media (min-width: 768px) { .blog-latest__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .blog-latest__grid { grid-template-columns: repeat(3, 1fr); } }

.blog-card {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.blog-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.blog-card__thumb {
  overflow: hidden;
  aspect-ratio: 16/9;
}

.blog-card__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.blog-card:hover .blog-card__thumb img { transform: scale(1.05); }

.blog-card__body { padding: var(--sp-16) var(--sp-24) var(--sp-24); }
.blog-card__date { font-size: var(--fs-xs); color: var(--color-text-muted); font-family: var(--font-en); margin-bottom: var(--sp-8); }
.blog-card__title { font-size: var(--fs-base); font-weight: 700; line-height: 1.5; margin-bottom: var(--sp-8); }
.blog-card__title a { color: var(--color-text); }
.blog-card__title a:hover { color: var(--color-primary); }
.blog-card__excerpt { font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text-light); }

/* --------------------------------------------------------------------------
   CTA Section
   -------------------------------------------------------------------------- */
.cta-section {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: var(--color-white);
  padding: var(--sp-64) 0;
  text-align: center;
}

@media (min-width: 768px) { .cta-section { padding: var(--sp-96) 0; } }

.cta-section__title { font-size: var(--fs-xl); font-weight: 900; margin-bottom: var(--sp-16); }
@media (min-width: 768px) { .cta-section__title { font-size: var(--fs-3xl); } }

.cta-section__text { font-size: var(--fs-base); opacity: 0.9; margin-bottom: var(--sp-32); line-height: 1.8; }

.cta-section__phone {
  font-family: var(--font-en);
  font-size: var(--fs-xl);
  font-weight: 900;
  color: var(--color-white);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-12);
  margin-bottom: var(--sp-8);
}

@media (min-width: 768px) { .cta-section__phone { font-size: var(--fs-4xl); } }

.cta-section__phone,
.cta-section__phone:link,
.cta-section__phone:visited {
  color: #ffffff !important;
}

.cta-section__phone:hover { color: var(--color-accent) !important; }

.cta-section__phone svg {
  width: 32px; height: 32px;
  flex-shrink: 0;
}

.cta-section__hours {
  font-size: var(--fs-sm);
  opacity: 0.7;
  margin-bottom: var(--sp-32);
}

.cta-section__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-16);
}

@media (min-width: 768px) {
  .cta-section__actions { flex-direction: row; justify-content: center; gap: var(--sp-24); }
}

/* --------------------------------------------------------------------------
   Page Header (下層ページ共通)
   -------------------------------------------------------------------------- */
.page-header {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: var(--color-white);
  padding: var(--sp-64) 0;
  text-align: center;
}

@media (min-width: 768px) { .page-header { padding: var(--sp-80) 0; } }

.page-header__title {
  font-size: var(--fs-2xl);
  font-weight: 900;
  margin-bottom: var(--sp-8);
}

@media (min-width: 768px) { .page-header__title { font-size: var(--fs-3xl); } }

.page-header__subtitle {
  font-size: var(--fs-sm);
  opacity: 0.8;
}

/* Content Area */
.content-area {
  padding: var(--sp-48) 20px;
}

@media (min-width: 768px) { .content-area { padding: var(--sp-64) 20px; } }

/* --------------------------------------------------------------------------
   404 Page
   -------------------------------------------------------------------------- */
.error-404 {
  text-align: center;
  padding: var(--sp-96) 0;
}

.error-404__number {
  font-family: var(--font-en);
  font-size: 120px;
  font-weight: 900;
  color: var(--color-primary);
  opacity: 0.1;
  line-height: 1;
}

.error-404__title {
  font-size: var(--fs-2xl);
  font-weight: 700;
  margin-bottom: var(--sp-16);
}

.error-404__text {
  font-size: var(--fs-base);
  color: var(--color-text-light);
  margin-bottom: var(--sp-32);
  line-height: 1.8;
}

/* --------------------------------------------------------------------------
   Greeting / Representative Section
   -------------------------------------------------------------------------- */
.greeting__inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-32);
  align-items: center;
  max-width: 900px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .greeting__inner { flex-direction: row; align-items: flex-start; gap: var(--sp-48); }
}

.greeting__photo {
  flex-shrink: 0;
  width: 200px;
}

.greeting__photo-placeholder {
  width: 200px;
  height: 240px;
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.greeting__photo-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.greeting__content { flex: 1; }

.greeting__name {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-16);
  padding-bottom: var(--sp-12);
  border-bottom: 2px solid var(--color-primary);
}

.greeting__name-value { font-size: var(--fs-xl); }

.greeting__text p {
  font-size: var(--fs-sm);
  line-height: 2;
  color: var(--color-text-light);
  margin-bottom: var(--sp-16);
}

@media (min-width: 768px) {
  .greeting__text p { font-size: var(--fs-base); }
}

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

/* --------------------------------------------------------------------------
   Makers Section
   -------------------------------------------------------------------------- */
.makers__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-12);
  max-width: 800px;
  margin: 0 auto;
}

.makers__item {
  padding: var(--sp-12) var(--sp-24);
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-text);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.makers__item:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

/* --------------------------------------------------------------------------
   LINE Button Styles
   -------------------------------------------------------------------------- */
a.btn--line,
.btn--line {
  background-color: #06C755;
  color: #ffffff;
  border-color: #06C755;
}

a.btn--line:hover,
.btn--line:hover {
  background-color: #05b34c;
  border-color: #05b34c;
  color: #ffffff;
  box-shadow: 0 4px 16px rgba(6, 199, 85, 0.35);
}

/* CTA Bar LINE - handled in layout.css via .cta-bar__line */

/* ==========================================================================
   Sub Pages - Service, Price, Area, FAQ, Flow, About, Contact, Legal
   ========================================================================== */

/* --------------------------------------------------------------------------
   Common Sub Page Styles
   -------------------------------------------------------------------------- */
.service-page__lead,
.price-page__lead,
.area-page__lead,
.faq-page__lead,
.flow-page__lead,
.contact-page__lead {
  font-size: var(--fs-md);
  line-height: 2;
  color: var(--color-text-light);
  text-align: center;
  max-width: 800px;
  margin: 0 auto var(--sp-48);
}

/* --------------------------------------------------------------------------
   Service Detail Page
   -------------------------------------------------------------------------- */
.service-page__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-32);
  margin-bottom: var(--sp-64);
}

.service-detail {
  display: flex;
  gap: var(--sp-24);
  padding: var(--sp-32);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border-left: 4px solid var(--color-primary);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.service-detail:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.service-detail__icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  border-radius: var(--radius-lg);
  color: var(--color-white);
}

.service-detail__body {
  flex: 1;
}

.service-detail__title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-12);
}

.service-detail__text {
  font-size: var(--fs-base);
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: var(--sp-16);
}

.service-detail__features {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}

@media (min-width: 768px) {
  .service-detail__features {
    grid-template-columns: repeat(2, 1fr);
  }
}

.service-detail__features li {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  font-size: var(--fs-sm);
  color: var(--color-text);
  padding: var(--sp-4) 0;
}

.service-detail__features li::before {
  content: '✓';
  color: var(--color-success);
  font-weight: 700;
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .service-detail {
    flex-direction: column;
    gap: var(--sp-16);
  }
  .service-detail__icon {
    width: 56px;
    height: 56px;
  }
}

.service-detail__photo {
  flex-shrink: 0;
  width: 200px;
  height: 200px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.service-detail__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 767px) {
  .service-detail__photo {
    width: 100%;
    height: 240px;
  }
}

/* --------------------------------------------------------------------------
   Price Detail Page
   -------------------------------------------------------------------------- */
.price-detail {
  margin-bottom: var(--sp-48);
  padding: var(--sp-32);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.price-detail__title {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-12);
  border-bottom: 2px solid var(--color-primary);
}

.price-detail__desc {
  font-size: var(--fs-sm);
  color: var(--color-text-light);
  margin-bottom: var(--sp-24);
  line-height: 1.8;
}

.price-detail__table {
  width: 100%;
  border-collapse: collapse;
}

.price-detail__table th,
.price-detail__table td {
  padding: var(--sp-12) var(--sp-16);
  text-align: left;
  font-size: var(--fs-sm);
  border-bottom: 1px solid var(--color-border);
}

.price-detail__table thead th {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 600;
}

.price-detail__table thead th:first-child {
  border-radius: var(--radius-sm) 0 0 0;
}

.price-detail__table thead th:last-child {
  border-radius: 0 var(--radius-sm) 0 0;
  text-align: right;
}

.price-detail__table tbody td:last-child {
  text-align: right;
  font-weight: 700;
  color: var(--color-accent);
  font-family: var(--font-en);
  white-space: nowrap;
}

.price-detail__table tbody tr:hover {
  background-color: var(--color-bg-gray);
}

.price-page__note {
  padding: var(--sp-32);
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-lg);
  margin-bottom: var(--sp-48);
}

.price-page__note-title {
  font-size: var(--fs-md);
  font-weight: 700;
  margin-bottom: var(--sp-16);
  color: var(--color-text);
}

.price-page__note-list {
  list-style: none;
}

.price-page__note-list li {
  font-size: var(--fs-sm);
  color: var(--color-text-light);
  padding: var(--sp-4) 0;
  padding-left: var(--sp-24);
  position: relative;
  line-height: 1.8;
}

.price-page__note-list li::before {
  content: '※';
  position: absolute;
  left: 0;
  color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   Area Detail Page
   -------------------------------------------------------------------------- */
.area-detail {
  padding: var(--sp-32);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-24);
}

.area-detail--main {
  border: 2px solid var(--color-primary);
  background: linear-gradient(180deg, rgba(0,71,171,0.03) 0%, var(--color-white) 100%);
}

.area-detail__badge {
  display: inline-block;
  padding: var(--sp-4) var(--sp-16);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--fs-xs);
  font-weight: 700;
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-12);
}

.area-detail__title {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-12);
}

.area-detail__desc {
  font-size: var(--fs-base);
  color: var(--color-text-light);
  margin-bottom: var(--sp-16);
  line-height: 1.8;
}

.area-detail__subtitle {
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--color-text);
  margin-top: var(--sp-16);
  margin-bottom: var(--sp-12);
}

.area-detail__cities {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-8);
}

.area-detail__city {
  padding: var(--sp-4) var(--sp-16);
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  color: var(--color-text);
  transition: background-color var(--transition-fast);
}

.area-detail__city:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.area-page__note {
  text-align: center;
  padding: var(--sp-24);
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  color: var(--color-text-light);
  margin-bottom: var(--sp-48);
}

/* --------------------------------------------------------------------------
   FAQ Page
   -------------------------------------------------------------------------- */
.faq-page__category {
  margin-bottom: var(--sp-48);
}

.faq-page__category-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-24);
  padding-bottom: var(--sp-12);
  border-bottom: 2px solid var(--color-primary);
}

/* --------------------------------------------------------------------------
   Flow Page
   -------------------------------------------------------------------------- */
.flow-page__timeline {
  max-width: 800px;
  margin: 0 auto var(--sp-64);
}

.flow-page__step {
  display: flex;
  gap: var(--sp-24);
  margin-bottom: var(--sp-48);
  position: relative;
}

.flow-page__step:last-child {
  margin-bottom: 0;
}

.flow-page__step::after {
  content: '';
  position: absolute;
  left: 28px;
  top: 64px;
  bottom: -48px;
  width: 2px;
  background-color: var(--color-border);
}

.flow-page__step:last-child::after {
  display: none;
}

.flow-page__step-marker {
  flex-shrink: 0;
}

.flow-page__step-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-family: var(--font-en);
  font-size: var(--fs-xl);
  font-weight: 900;
  position: relative;
  z-index: 1;
}

.flow-page__step-content {
  flex: 1;
  padding-top: var(--sp-8);
}

.flow-page__step-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--sp-12);
}

.flow-page__step-text {
  font-size: var(--fs-base);
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: var(--sp-12);
}

.flow-page__step-point {
  padding: var(--sp-12) var(--sp-16);
  background-color: var(--color-accent-light);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  color: var(--color-text);
  border-left: 3px solid var(--color-accent);
}

/* --------------------------------------------------------------------------
   About Page
   -------------------------------------------------------------------------- */
.about-greeting {
  margin-bottom: var(--sp-64);
}

.about-greeting__title,
.about-info__title,
.about-map__title {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-24);
  padding-bottom: var(--sp-12);
  border-bottom: 2px solid var(--color-primary);
}

.about-greeting__body p {
  font-size: var(--fs-base);
  line-height: 2;
  color: var(--color-text-light);
  margin-bottom: var(--sp-16);
}

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

.about-info {
  margin-bottom: var(--sp-64);
}

.about-info__table {
  width: 100%;
  border-collapse: collapse;
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.about-info__table th,
.about-info__table td {
  padding: var(--sp-16) var(--sp-24);
  text-align: left;
  font-size: var(--fs-base);
  border-bottom: 1px solid var(--color-border);
}

.about-info__table th {
  background-color: var(--color-bg-gray);
  font-weight: 600;
  color: var(--color-text);
  width: 30%;
  white-space: nowrap;
}

.about-info__table td {
  color: var(--color-text-light);
  line-height: 1.8;
}

.about-info__table tr:last-child th,
.about-info__table tr:last-child td {
  border-bottom: none;
}

.about-map {
  margin-bottom: var(--sp-64);
}

.about-map__embed {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.about-map__placeholder {
  background-color: var(--color-bg-gray);
  padding: var(--sp-48);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  border-radius: var(--radius-lg);
}

/* --------------------------------------------------------------------------
   Contact Page
   -------------------------------------------------------------------------- */
.contact-page__info {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-24);
  margin-bottom: var(--sp-48);
}

@media (min-width: 768px) {
  .contact-page__info {
    grid-template-columns: repeat(2, 1fr);
  }
}

.contact-page__info-card {
  padding: var(--sp-32);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-align: center;
}

.contact-page__info-card h3 {
  font-size: var(--fs-md);
  font-weight: 700;
  margin-bottom: var(--sp-12);
  color: var(--color-primary);
}

.contact-page__form {
  padding: var(--sp-48);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.contact-page__form h2 {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-32);
  text-align: center;
}

.contact-page__phone-area {
  text-align: center;
  padding: var(--sp-32);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-32);
}

.contact-page__phone-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-16);
}

.contact-page__phone-number {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-12);
  font-family: var(--font-en);
  font-size: var(--fs-3xl);
  font-weight: 900;
  color: var(--color-primary) !important;
  margin-bottom: var(--sp-8);
}

@media (min-width: 768px) {
  .contact-page__phone-number { font-size: 48px; }
}

.contact-page__phone-number:hover {
  color: var(--color-accent) !important;
}

.contact-page__hours {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

.contact-page__form-area {
  padding: var(--sp-48);
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-48);
}

.contact-page__form-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-16);
}

.contact-page__form-note {
  font-size: var(--fs-sm);
  color: var(--color-text-light);
  line-height: 1.8;
  margin-bottom: var(--sp-32);
}

/* Contact Form 7 Styles */
.wpcf7 .wpcf7-form-control-wrap {
  display: block;
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
.wpcf7 select {
  width: 100%;
  padding: var(--sp-12) var(--sp-16);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--fs-base);
  transition: border-color var(--transition-fast);
}

.wpcf7 input:focus,
.wpcf7 textarea:focus,
.wpcf7 select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 71, 171, 0.15);
}

.wpcf7 .wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-16) var(--sp-48);
  background-color: var(--color-accent);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-full);
  font-size: var(--fs-md);
  font-weight: 700;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.wpcf7 .wpcf7-submit:hover {
  background-color: var(--color-accent-hover);
}

/* --------------------------------------------------------------------------
   Legal Pages (Privacy Policy, Tokushoho)
   -------------------------------------------------------------------------- */
.legal-content {
  max-width: 900px;
  margin: 0 auto;
}

.legal-content h2 {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin-top: var(--sp-48);
  margin-bottom: var(--sp-16);
  padding-bottom: var(--sp-8);
  border-bottom: 2px solid var(--color-primary);
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p {
  font-size: var(--fs-base);
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: var(--sp-16);
}

.legal-content ul {
  margin-bottom: var(--sp-16);
  padding-left: var(--sp-24);
}

.legal-content ul li {
  font-size: var(--fs-base);
  line-height: 1.8;
  color: var(--color-text-light);
  list-style: disc;
  padding: var(--sp-4) 0;
}

.legal-content__table {
  width: 100%;
  border-collapse: collapse;
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.legal-content__table th,
.legal-content__table td {
  padding: var(--sp-16) var(--sp-24);
  text-align: left;
  font-size: var(--fs-base);
  border-bottom: 1px solid var(--color-border);
  line-height: 1.8;
}

.legal-content__table th {
  background-color: var(--color-bg-gray);
  font-weight: 600;
  color: var(--color-text);
  width: 25%;
  white-space: nowrap;
  vertical-align: top;
}

.legal-content__table td {
  color: var(--color-text-light);
}

.legal-content__table tr:last-child th,
.legal-content__table tr:last-child td {
  border-bottom: none;
}

@media (max-width: 767px) {
  .legal-content__table th,
  .legal-content__table td,
  .about-info__table th,
  .about-info__table td {
    display: block;
    width: 100%;
    padding: var(--sp-12) var(--sp-16);
  }
  .legal-content__table th,
  .about-info__table th {
    border-bottom: none;
    padding-bottom: var(--sp-4);
  }
}

/* --------------------------------------------------------------------------
   Single Navigation (single-news / single-works / single-testimonials / single)
   -------------------------------------------------------------------------- */
.single-nav {
  margin-top: var(--sp-48);
  margin-bottom: var(--sp-48);
}

.single-nav__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-16);
  margin-bottom: var(--sp-32);
}

.single-nav__link {
  flex: 1 1 calc(50% - var(--sp-8));
  min-width: 250px;
  padding: var(--sp-16) var(--sp-24);
  background-color: var(--color-bg-gray);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  color: var(--color-text-light);
  text-decoration: none;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.single-nav__link:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.single-nav__link--prev {
  text-align: left;
}

.single-nav__link--next {
  text-align: right;
}

.single-nav__back {
  text-align: center;
  margin-top: var(--sp-24);
}

/* --------------------------------------------------------------------------
   Category Buttons (Blog/Column page)
   -------------------------------------------------------------------------- */
.category-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-12);
  margin-bottom: var(--sp-48);
}

.category-button {
  display: inline-flex;
  align-items: center;
  padding: var(--sp-8) var(--sp-24);
  background-color: var(--color-white);
  color: var(--color-text);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.category-button:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
  transform: translateY(-1px);
}

.category-button.is-active {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   Sitemap Page
   -------------------------------------------------------------------------- */
.sitemap-page__section {
  margin-bottom: var(--sp-32);
}

.sitemap-page__heading {
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--sp-12);
  padding-bottom: var(--sp-8);
  border-bottom: 1px solid var(--color-border);
}

.sitemap-page__list {
  padding-left: var(--sp-8);
}

.sitemap-page__list li {
  padding: var(--sp-8) 0;
  border-bottom: 1px solid var(--color-bg-gray);
}

.sitemap-page__list li:last-child {
  border-bottom: none;
}

.sitemap-page__list a {
  font-size: var(--fs-base);
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  transition: color var(--transition-fast);
}

.sitemap-page__list a::before {
  content: '';
  width: 6px;
  height: 6px;
  background-color: var(--color-primary);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.sitemap-page__list a:hover {
  color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   Scroll Animation
   -------------------------------------------------------------------------- */
[data-animate] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

[data-animate].is-visible {
  opacity: 1;
  transform: translateY(0);
}
