/* ==========================================================================
   Header
   ========================================================================== */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height-mobile);
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(10px);
  z-index: 1000;
  transition: var(--transition-base);
}
@media (min-width: 1024px) { .header { height: var(--header-height); } }
.header.is-scrolled { box-shadow: var(--shadow-md); }

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

.header__logo {
  display: flex;
  align-items: center;
  height: 100%;
  flex-shrink: 0;
}

.header__logo a {
  display: flex;
  align-items: center;
  height: 100%;
}

.header__logo img,
.header__logo .custom-logo,
.custom-logo-link img {
  max-height: 40px;
  width: auto;
  height: auto;
  object-fit: contain;
}

@media (min-width: 1024px) {
  .header__logo img,
  .header__logo .custom-logo,
  .custom-logo-link img {
    max-height: 50px;
  }
}

.header__logo-text {
  font-family: var(--font-english);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-primary);
}

.header__nav { display: none; }
@media (min-width: 1024px) { .header__nav { display: block; } }

.nav-list { display: flex; align-items: center; gap: var(--spacing-xl); }
.nav-list li a { font-size: var(--text-sm); font-weight: 500; color: var(--color-gray-700); }
.nav-list li a:hover { color: var(--color-primary); }

.header__cta { display: none; }
@media (min-width: 1024px) { .header__cta { display: block; } }

.btn--cta { padding: var(--spacing-sm) var(--spacing-lg); font-size: var(--text-sm); min-width: auto; }

.header__menu-btn { display: flex; flex-direction: column; justify-content: center; width: 40px; height: 40px; gap: 6px; }
@media (min-width: 1024px) { .header__menu-btn { display: none; } }
.header__menu-btn-line { display: block; width: 24px; height: 2px; background: var(--color-gray-700); transition: var(--transition-base); }
.header__menu-btn.is-active .header__menu-btn-line:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.header__menu-btn.is-active .header__menu-btn-line:nth-child(2) { opacity: 0; }
.header__menu-btn.is-active .header__menu-btn-line:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* ==========================================================================
   Mobile Menu
   ========================================================================== */
.mobile-menu { position: fixed; top: var(--header-height-mobile); right: -100%; width: 100%; max-width: 400px; height: calc(100vh - var(--header-height-mobile)); background: var(--color-white); z-index: 999; overflow-y: auto; transition: right 0.4s ease; }
.mobile-menu.is-open { right: 0; }
.mobile-menu__inner { padding: var(--spacing-xl); }
.mobile-menu__list { border-top: 1px solid var(--color-gray-200); }
.mobile-menu__list li { border-bottom: 1px solid var(--color-gray-200); }
.mobile-menu__list a { display: block; padding: var(--spacing-md) 0; color: var(--color-gray-700); }
.mobile-menu__artists { margin-top: var(--spacing-xl); padding-top: var(--spacing-xl); border-top: 1px solid var(--color-gray-200); }
.mobile-menu__artists-title { font-size: var(--text-sm); color: var(--color-gray-500); margin-bottom: var(--spacing-md); }
.mobile-menu__artists-list { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); }
.mobile-menu__artist-link { padding: var(--spacing-xs) var(--spacing-md); font-size: var(--text-sm); color: var(--color-primary); border: 1px solid var(--color-primary); border-radius: var(--radius-full); }
.mobile-menu__cta { margin-top: var(--spacing-xl); }
.mobile-menu__phone { margin-top: var(--spacing-md); text-align: center; }
.mobile-menu__phone a { font-size: var(--text-xl); font-weight: 500; color: var(--color-gray-700); }
.mobile-menu__phone-note { display: block; font-size: var(--text-xs); color: var(--color-gray-500); }
.mobile-menu__overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); opacity: 0; visibility: hidden; z-index: 998; transition: var(--transition-base); }
.mobile-menu__overlay.is-visible { opacity: 1; visibility: visible; }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; padding-top: var(--header-height-mobile); }
@media (min-width: 1024px) { .hero { padding-top: var(--header-height); } }
.hero__bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.hero__bg-image { width: 100%; height: 100%; object-fit: cover; }
.hero__bg-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--color-cream) 0%, var(--color-beige) 100%); }
.hero__bg-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to right, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0.4) 100%); }
.hero__content { width: 100%; padding: var(--spacing-3xl) 0; }
.hero__inner { max-width: 600px; }
.hero__subtitle { font-family: var(--font-serif); font-size: var(--text-base); color: var(--color-primary); letter-spacing: 0.2em; margin-bottom: var(--spacing-md); }
@media (min-width: 768px) { .hero__subtitle { font-size: var(--text-lg); } }
.hero__title { font-family: var(--font-serif); font-size: var(--text-3xl); font-weight: 500; line-height: 1.6; color: var(--color-gray-800); }
@media (min-width: 768px) { .hero__title { font-size: var(--text-5xl); } }
.hero__title-accent { color: var(--color-primary); }
.hero__cta { margin-top: var(--spacing-2xl); }

/* ==========================================================================
   Campaign
   ========================================================================== */
.campaign__card { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--spacing-2xl); box-shadow: var(--shadow-lg); max-width: 800px; margin: 0 auto; text-align: center; }
.campaign__badge { display: inline-block; background: var(--color-primary); color: var(--color-white); font-size: var(--text-xs); padding: var(--spacing-xs) var(--spacing-md); border-radius: var(--radius-full); margin-bottom: var(--spacing-md); }
.campaign__title { font-family: var(--font-serif); font-size: var(--text-2xl); color: var(--color-gray-800); margin-bottom: var(--spacing-sm); }
.campaign__note { font-size: var(--text-sm); color: var(--color-gray-500); margin-bottom: var(--spacing-xl); }
.campaign__items { display: grid; grid-template-columns: 1fr; gap: var(--spacing-xl); }
@media (min-width: 600px) { .campaign__items { grid-template-columns: repeat(2, 1fr); } }
.campaign__item { padding: var(--spacing-lg); background: var(--color-cream); border-radius: var(--radius-lg); }
.campaign__item-title { font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--spacing-md); }
.campaign__price { display: flex; justify-content: space-between; align-items: center; padding: var(--spacing-sm) 0; border-bottom: 1px dashed var(--color-gray-300); }
.campaign__price:last-child { border-bottom: none; }
.campaign__price-label { font-size: var(--text-sm); color: var(--color-gray-600); }
.campaign__price-value { font-size: var(--text-lg); font-weight: 500; color: var(--color-primary); }
.campaign__price-value small { font-size: var(--text-xs); font-weight: 400; }

/* ==========================================================================
   Artist Card
   ========================================================================== */
.artists__grid { display: grid; grid-template-columns: 1fr; gap: var(--spacing-2xl); }
@media (min-width: 768px) { .artists__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .artists__grid { grid-template-columns: repeat(3, 1fr); } }
.artist-card { background: var(--color-white); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); transition: var(--transition-base); }
.artist-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.artist-card__image { aspect-ratio: 1; overflow: hidden; }
.artist-card__image img { width: 100%; height: 100%; object-fit: cover; }
.artist-card__content { padding: var(--spacing-xl); }
.artist-card__name { font-size: var(--text-xl); font-weight: 500; margin-bottom: var(--spacing-sm); }
.artist-card__description { font-size: var(--text-sm); color: var(--color-gray-600); line-height: 1.8; margin-bottom: var(--spacing-lg); }
.artist-card__meta { margin-bottom: var(--spacing-lg); }
.artist-card__meta-item { display: flex; gap: var(--spacing-md); font-size: var(--text-sm); margin-bottom: var(--spacing-xs); }
.artist-card__meta-item dt { color: var(--color-gray-500); min-width: 100px; }
.artist-card__link { display: inline-flex; align-items: center; gap: var(--spacing-sm); font-size: var(--text-sm); color: var(--color-primary); font-weight: 500; }

/* ==========================================================================
   Problems
   ========================================================================== */
.problems__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--spacing-lg); }
@media (min-width: 768px) { .problems__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .problems__grid { grid-template-columns: repeat(5, 1fr); } }
.problem-item { background: var(--color-white); border-radius: var(--radius-lg); padding: var(--spacing-xl); text-align: center; box-shadow: var(--shadow-sm); }
.problem-item__text { font-size: var(--text-sm); color: var(--color-gray-700); line-height: 1.8; }

/* ==========================================================================
   Features
   ========================================================================== */
.features__intro { text-align: center; max-width: 700px; margin: 0 auto var(--spacing-3xl); }
.features__intro-title { font-family: var(--font-serif); font-size: var(--text-xl); margin-bottom: var(--spacing-md); }
@media (min-width: 768px) { .features__intro-title { font-size: var(--text-2xl); } }
.features__intro-text { font-size: var(--text-sm); color: var(--color-gray-600); line-height: 2; }
.features__list { display: grid; grid-template-columns: 1fr; gap: var(--spacing-xl); }
@media (min-width: 768px) { .features__list { grid-template-columns: repeat(3, 1fr); } }
.feature-card { background: var(--color-cream); border-radius: var(--radius-xl); padding: var(--spacing-2xl); position: relative; }
.feature-card__number { font-family: var(--font-english); font-size: var(--text-4xl); font-weight: 300; color: var(--color-primary); opacity: 0.3; position: absolute; top: var(--spacing-lg); right: var(--spacing-lg); }
.feature-card__title { font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--spacing-md); }
.feature-card__text { font-size: var(--text-sm); color: var(--color-gray-600); line-height: 1.8; }

/* ==========================================================================
   Cases Gallery
   ========================================================================== */
.cases__filter { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--spacing-sm); margin-bottom: var(--spacing-2xl); }
.cases__filter-btn { padding: var(--spacing-sm) var(--spacing-lg); font-size: var(--text-sm); color: var(--color-gray-600); background: var(--color-white); border: 1px solid var(--color-gray-300); border-radius: var(--radius-full); transition: var(--transition-base); }
.cases__filter-btn:hover, .cases__filter-btn.is-active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.cases__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--spacing-md); }
@media (min-width: 768px) { .cases__grid { grid-template-columns: repeat(3, 1fr); gap: var(--spacing-lg); } }
@media (min-width: 1024px) { .cases__grid { grid-template-columns: repeat(4, 1fr); } }
.cases__cta { text-align: center; margin-top: var(--spacing-2xl); }

/* Case Card */
.case-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; background: var(--color-white); box-shadow: var(--shadow-sm); transition: var(--transition-base); }
.case-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.case-card__link { display: block; width: 100%; text-align: left; cursor: pointer; background: none; border: none; padding: 0; }
.case-card__image { aspect-ratio: 1; overflow: hidden; background: var(--color-gray-200); }
.case-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.case-card:hover .case-card__image img { transform: scale(1.05); }
.case-card__info { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-md); }
.case-card__artist-photo { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background: var(--color-gray-200); }
.case-card__artist-photo img { width: 100%; height: 100%; object-fit: cover; }
.case-card__artist-name { font-size: var(--text-sm); font-weight: 500; color: var(--color-gray-700); }
@media (min-width: 768px) {
  .case-card__artist-photo { width: 40px; height: 40px; }
}

/* Case Popup */
.case-popup { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 2000; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: var(--transition-base); }
.case-popup.is-open { opacity: 1; visibility: visible; }
.case-popup__overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.8); }
.case-popup__content { position: relative; width: 90%; max-width: 900px; max-height: 90vh; background: var(--color-white); border-radius: var(--radius-xl); overflow: hidden; transform: scale(0.9); transition: transform 0.3s ease; }
.case-popup.is-open .case-popup__content { transform: scale(1); }
.case-popup__close { position: absolute; top: var(--spacing-md); right: var(--spacing-md); width: 40px; height: 40px; background: var(--color-white); border: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 10; box-shadow: var(--shadow-md); transition: var(--transition-base); }
.case-popup__close:hover { background: var(--color-gray-100); }
.case-popup__inner { display: flex; flex-direction: column; max-height: 90vh; overflow-y: auto; }
@media (min-width: 768px) { .case-popup__inner { flex-direction: row; } }
.case-popup__image { flex-shrink: 0; background: var(--color-gray-100); }
.case-popup__image img { width: 100%; height: auto; display: block; max-height: 40vh; object-fit: contain; }
@media (min-width: 768px) { 
  .case-popup__image { width: 50%; }
  .case-popup__image img { max-height: none; height: 100%; object-fit: cover; }
}
.case-popup__details { flex: 1; padding: var(--spacing-xl); overflow-y: auto; }
.case-popup__artist { display: flex; align-items: center; gap: var(--spacing-md); margin-bottom: var(--spacing-xl); padding-bottom: var(--spacing-lg); border-bottom: 1px solid var(--color-gray-200); }
.case-popup__artist-photo { width: 50px; height: 50px; border-radius: 50%; overflow: hidden; background: var(--color-gray-200); }
.case-popup__artist-photo img { width: 100%; height: 100%; object-fit: cover; }
.case-popup__artist-name { font-size: var(--text-lg); font-weight: 500; }
.case-popup__info { display: flex; flex-direction: column; gap: var(--spacing-md); }
.case-popup__info-item { display: none; }
.case-popup__info-item.is-visible { display: block; }
.case-popup__info-item dt { font-size: var(--text-xs); color: var(--color-gray-500); margin-bottom: var(--spacing-xs); }
.case-popup__info-item dd { font-size: var(--text-sm); color: var(--color-gray-700); line-height: 1.8; }

/* ==========================================================================
   Price Cards
   ========================================================================== */
.prices__grid { display: grid; grid-template-columns: 1fr; gap: var(--spacing-xl); }
@media (min-width: 768px) { .prices__grid { grid-template-columns: repeat(2, 1fr); } }
.price-card { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--spacing-2xl); box-shadow: var(--shadow-sm); }
.price-card__title { font-size: var(--text-xl); font-weight: 500; text-align: center; margin-bottom: var(--spacing-sm); }
.price-card__note { font-size: var(--text-xs); color: var(--color-gray-500); text-align: center; margin-bottom: var(--spacing-lg); }
.price-card__item { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-md) 0; border-bottom: 1px solid var(--color-gray-200); }
.price-card__label { font-size: var(--text-sm); color: var(--color-gray-600); }
.price-card__badge { font-size: var(--text-xs); color: var(--color-white); background: var(--color-primary); padding: 2px 8px; border-radius: var(--radius-sm); }
.price-card__value { font-size: var(--text-lg); font-weight: 500; }
.price-card__link { display: block; text-align: center; font-size: var(--text-sm); color: var(--color-primary); padding-top: var(--spacing-md); }

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq__filter { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--spacing-sm); margin-bottom: var(--spacing-2xl); }
.faq__filter-btn { padding: var(--spacing-sm) var(--spacing-lg); font-size: var(--text-sm); color: var(--color-gray-600); background: var(--color-white); border: 1px solid var(--color-gray-300); border-radius: var(--radius-full); transition: var(--transition-base); }
.faq__filter-btn:hover, .faq__filter-btn.is-active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.faq__section { margin-bottom: var(--spacing-3xl); }
.faq__section:last-child { margin-bottom: 0; }
.faq__section-title { font-size: var(--text-xl); font-weight: 500; margin-bottom: var(--spacing-lg); padding-bottom: var(--spacing-sm); border-bottom: 2px solid var(--color-primary); }
.faq__list { max-width: 800px; margin: 0 auto; }
.faq-item { background: var(--color-white); border-radius: var(--radius-lg); margin-bottom: var(--spacing-md); overflow: hidden; box-shadow: var(--shadow-sm); }
.faq-item__question { display: flex; align-items: center; width: 100%; padding: var(--spacing-lg); text-align: left; gap: var(--spacing-md); }
.faq-item__icon { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; background: var(--color-primary); color: var(--color-white); border-radius: 50%; font-family: var(--font-english); font-size: var(--text-sm); flex-shrink: 0; }
.faq-item__icon--answer { background: var(--color-gray-300); color: var(--color-gray-700); }
.faq-item__title { flex: 1; font-size: var(--text-base); font-weight: 500; }
.faq-item__toggle { width: 24px; height: 24px; position: relative; flex-shrink: 0; }
.faq-item__toggle::before, .faq-item__toggle::after { content: ''; position: absolute; background: var(--color-gray-400); transition: var(--transition-base); }
.faq-item__toggle::before { top: 50%; left: 4px; width: 16px; height: 2px; transform: translateY(-50%); }
.faq-item__toggle::after { top: 4px; left: 50%; width: 2px; height: 16px; transform: translateX(-50%); }
.faq-item__question[aria-expanded="true"] .faq-item__toggle::after { transform: translateX(-50%) rotate(90deg); opacity: 0; }
.faq-item__answer { display: none; gap: var(--spacing-md); padding: 0 var(--spacing-lg) var(--spacing-lg); }
.faq-item__answer[hidden] { display: none; }
.faq-item__answer:not([hidden]) { display: flex; }
.faq-item__content { flex: 1; font-size: var(--text-sm); color: var(--color-gray-600); line-height: 1.8; }
.faq__cta { text-align: center; margin-top: var(--spacing-2xl); }

/* ==========================================================================
   Clinic
   ========================================================================== */
.clinic__content { max-width: 800px; margin: 0 auto; }
.clinic__name { font-size: var(--text-xl); font-weight: 500; margin-bottom: var(--spacing-lg); }
.clinic__address { font-style: normal; font-size: var(--text-base); line-height: 1.8; margin-bottom: var(--spacing-lg); }
.clinic__address small { font-size: var(--text-sm); color: var(--color-gray-500); display: block; }
.clinic__phone { margin-bottom: var(--spacing-xl); }
.clinic__phone a { font-size: var(--text-2xl); font-weight: 500; }
.clinic__phone-hours { display: block; font-size: var(--text-sm); color: var(--color-gray-500); margin-top: var(--spacing-xs); }
.clinic__access-title { font-size: var(--text-base); font-weight: 500; margin-bottom: var(--spacing-sm); }
.clinic__access ul { font-size: var(--text-sm); color: var(--color-gray-600); line-height: 2; }

/* ==========================================================================
   CTA Section
   ========================================================================== */
.cta-section { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%); padding: var(--spacing-4xl) 0; }
.cta-section__inner { text-align: center; }
.cta-section__title { margin-bottom: var(--spacing-lg); }
.cta-section__title-en { display: block; font-family: var(--font-english); font-size: var(--text-sm); letter-spacing: 0.2em; color: rgba(255,255,255,0.7); margin-bottom: var(--spacing-sm); }
.cta-section__title-ja { display: block; font-family: var(--font-serif); font-size: var(--text-2xl); color: var(--color-white); }
.cta-section__text { color: rgba(255,255,255,0.9); margin-bottom: var(--spacing-xl); line-height: 1.8; }

/* ==========================================================================
   Footer
   ========================================================================== */
.footer { background: var(--color-gray-900); color: var(--color-gray-400); padding: var(--spacing-4xl) 0 var(--spacing-xl); }
.footer__top { display: grid; grid-template-columns: 1fr; gap: var(--spacing-2xl); margin-bottom: var(--spacing-3xl); }
@media (min-width: 768px) { .footer__top { grid-template-columns: 2fr 1fr 1fr; } }
.footer__logo-text { font-family: var(--font-english); font-size: var(--text-xl); color: var(--color-white); }
.footer__clinic-info { margin-top: var(--spacing-lg); }
.footer__clinic-name { font-size: var(--text-sm); color: var(--color-white); margin-bottom: var(--spacing-sm); }
.footer__clinic-address, .footer__clinic-phone { font-size: var(--text-sm); line-height: 1.8; }
.footer__clinic-phone a { color: var(--color-white); }
.footer__clinic-hours { display: block; font-size: var(--text-xs); }
.footer__nav-list { display: flex; flex-direction: column; gap: var(--spacing-sm); }
.footer__nav-list a { font-size: var(--text-sm); color: var(--color-gray-400); }
.footer__nav-list a:hover { color: var(--color-white); }
.footer__artists-title { font-size: var(--text-sm); color: var(--color-white); margin-bottom: var(--spacing-md); }
.footer__artists-list { display: flex; flex-direction: column; gap: var(--spacing-sm); }
.footer__artists-item a { font-size: var(--text-sm); color: var(--color-gray-400); }
.footer__artists-item a:hover { color: var(--color-white); }
.footer__bottom { padding-top: var(--spacing-xl); border-top: 1px solid var(--color-gray-800); text-align: center; }
.footer__copyright { font-size: var(--text-xs); color: var(--color-gray-500); }

/* ==========================================================================
   Fixed CTA (Mobile)
   ========================================================================== */
.fixed-cta { position: fixed; bottom: 0; left: 0; right: 0; padding: var(--spacing-md); background: var(--color-white); box-shadow: 0 -4px 20px rgba(0,0,0,0.1); z-index: 900; }
@media (min-width: 1024px) { .fixed-cta { display: none; } }
.fixed-cta__btn { display: flex; align-items: center; justify-content: center; gap: var(--spacing-sm); width: 100%; padding: var(--spacing-md); background: #06C755; color: var(--color-white); border-radius: var(--radius-lg); font-weight: 500; }

/* ==========================================================================
   Page Top Button
   ========================================================================== */
.page-top { position: fixed; bottom: 100px; right: var(--spacing-lg); width: 48px; height: 48px; background: var(--color-white); border: 1px solid var(--color-gray-300); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--color-gray-600); opacity: 0; visibility: hidden; transition: var(--transition-base); z-index: 800; }
.page-top.is-visible { opacity: 1; visibility: visible; }
.page-top:hover { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-white); }
@media (min-width: 1024px) { .page-top { bottom: var(--spacing-xl); } }

/* ==========================================================================
   Page Header
   ========================================================================== */
.page-header { padding: calc(var(--header-height-mobile) + var(--spacing-3xl)) 0 var(--spacing-3xl); background: var(--color-cream); text-align: center; }
@media (min-width: 1024px) { .page-header { padding: calc(var(--header-height) + var(--spacing-4xl)) 0 var(--spacing-4xl); } }
.page-header__title { font-family: var(--font-serif); font-size: var(--text-3xl); font-weight: 500; }
@media (min-width: 768px) { .page-header__title { font-size: var(--text-4xl); } }

/* ==========================================================================
   Breadcrumb
   ========================================================================== */
.breadcrumb { padding: var(--spacing-md) 0; background: var(--color-gray-100); }
.breadcrumb__list { display: flex; flex-wrap: wrap; align-items: center; gap: var(--spacing-sm); max-width: var(--container-max); margin: 0 auto; padding: 0 var(--spacing-lg); font-size: var(--text-xs); color: var(--color-gray-500); }
.breadcrumb__item:not(:last-child)::after { content: '>'; margin-left: var(--spacing-sm); }
.breadcrumb__item a:hover { color: var(--color-primary); }

/* ==========================================================================
   Main Content
   ========================================================================== */
.main { padding-top: var(--header-height-mobile); }
@media (min-width: 1024px) { .main { padding-top: var(--header-height); } }
.main:has(.hero) { padding-top: 0; }

/* ==========================================================================
   Price Table
   ========================================================================== */
.price-section { margin-bottom: var(--spacing-3xl); }
.price-section__title { font-size: var(--text-xl); font-weight: 500; margin-bottom: var(--spacing-sm); padding-bottom: var(--spacing-sm); border-bottom: 2px solid var(--color-primary); }
.price-section__note { font-size: var(--text-sm); color: var(--color-gray-500); margin-bottom: var(--spacing-lg); }
.price-table { background: var(--color-white); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.price-table table { width: 100%; border-collapse: collapse; }
.price-table th, .price-table td { padding: var(--spacing-md) var(--spacing-lg); text-align: left; border-bottom: 1px solid var(--color-gray-200); }
.price-table th { background: var(--color-cream); font-weight: 500; width: 120px; }
.price-table__price { font-weight: 500; color: var(--color-primary); text-align: right; }
.price-table__note-row td { background: var(--color-gray-100); font-size: var(--text-sm); color: var(--color-gray-600); }
.price-table__tax { padding: var(--spacing-md) var(--spacing-lg); font-size: var(--text-sm); color: var(--color-gray-500); text-align: right; }

/* ==========================================================================
   News List
   ========================================================================== */
.news-list { max-width: 800px; margin: 0 auto; }
.news-item { border-bottom: 1px solid var(--color-gray-200); }
.news-item:first-child { border-top: 1px solid var(--color-gray-200); }
.news-item__link { display: flex; align-items: center; gap: var(--spacing-lg); padding: var(--spacing-lg) 0; transition: var(--transition-base); }
.news-item__link:hover { opacity: 0.7; }
.news-item__date { font-size: var(--text-sm); color: var(--color-gray-500); flex-shrink: 0; }
.news-item__title { font-size: var(--text-base); font-weight: 500; }

/* ==========================================================================
   News Single
   ========================================================================== */
.news-single { max-width: 800px; margin: 0 auto; }
.news-single__header { margin-bottom: var(--spacing-2xl); padding-bottom: var(--spacing-xl); border-bottom: 1px solid var(--color-gray-200); }
.news-single__date { font-size: var(--text-sm); color: var(--color-gray-500); display: block; margin-bottom: var(--spacing-sm); }
.news-single__title { font-size: var(--text-2xl); font-weight: 500; }
.news-single__thumbnail { margin-bottom: var(--spacing-2xl); }
.news-single__thumbnail img { width: 100%; height: auto; border-radius: var(--radius-lg); }
.news-single__content { line-height: 2; }
.news-single__content p { margin-bottom: var(--spacing-lg); }
.news-single__content h2 { font-size: var(--text-xl); font-weight: 500; margin: var(--spacing-2xl) 0 var(--spacing-lg); }
.news-single__content h3 { font-size: var(--text-lg); font-weight: 500; margin: var(--spacing-xl) 0 var(--spacing-md); }
.news-single__content ul, .news-single__content ol { margin-bottom: var(--spacing-lg); padding-left: var(--spacing-xl); }
.news-single__content li { margin-bottom: var(--spacing-sm); }
.news-single__footer { margin-top: var(--spacing-3xl); padding-top: var(--spacing-2xl); border-top: 1px solid var(--color-gray-200); text-align: center; }

/* ==========================================================================
   No Posts
   ========================================================================== */
.no-posts { text-align: center; color: var(--color-gray-500); padding: var(--spacing-3xl) 0; }
