/* =============================================================
   共 通
============================================================= */
.pc {
    display: block;
}

.sp {
    display: none;
}



/* =============================================================
   Header
============================================================= */
.header {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  box-shadow: 0 1px 12px rgba(0, 0, 0, 0.06);
  height: 64px;
}

.header-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
}

.header-logo {
  display: flex;
  align-items: center;
}

.header-logo-h1 {
    margin: 0;
    padding: 0;
    font-size: inherit;
    line-height: inherit;
}

.header-logo img {
  height: 36px;
  width: auto;
}

.header-nav {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 0;
}

/* ナビ項目（共通ラッパー） */
.header-nav__item {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
}

/* ナビラベル（テキスト部分） */
.header-nav__label {
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  padding: 0 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  transition: color var(--transition);
  cursor: pointer;
  position: relative;
}

.header-nav__label:hover {
  color: var(--color-primary);
}

/* ▾マーク */
.header-nav__item.has-dropdown .header-nav__label::after {
  content: '';
  width: 0;
  height: 0;
  border-left: 3.5px solid transparent;
  border-right: 3.5px solid transparent;
  border-top: 4px solid currentColor;
  margin-left: 0.35rem;
  opacity: 0.3;
  transition: all var(--transition);
}

.header-nav__item.has-dropdown:hover .header-nav__label::after {
  opacity: 0.6;
  transform: rotate(180deg);
}

/* ホバーアンダーライン */
.header-nav__label::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background: var(--color-primary);
  border-radius: 2px;
  transition: width var(--transition);
}

.header-nav__item:hover .header-nav__label::before {
  width: calc(100% - 2rem);
}

/* ドロップダウンパネル */
.header-dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 200px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.10), 0 1px 4px rgba(0, 0, 0, 0.04);
  padding: 0.4rem;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  pointer-events: none;
  z-index: 110;
}

.header-nav__item.has-dropdown:hover .header-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* ドロップダウン内リンク */
.header-dropdown__link {
  display: block;
  padding: 0.6rem 0.85rem;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  border-radius: 6px;
  transition: all var(--transition);
  white-space: nowrap;
}

.header-dropdown__link:hover {
  background: var(--color-primary-pale, #EDF6FC);
  color: var(--color-primary);
}

/* 旧クラス互換（念のため残す） */
.header-nav__link {
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 500;
  transition: color var(--transition);
}

.header-nav__link:hover {
  color: var(--color-primary-dark);
}

.header-cta {
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
  color: #fff !important;
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius-full);
  font-weight: var(--font-weight-en-bold);
  font-size: 0.875rem;
  transition: all var(--transition);
  box-shadow: var(--shadow-button);
}

.header-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(244, 101, 133, 0.5);
}

/* Hamburger (SP) */
.hamburger {
  display: none;
  width: 2.5rem;
  height: 40px;
  background: var(--color-bg);
  border-radius: 12px;
  position: relative;
  transition: all var(--transition);
}

.hamburger:hover {
  background: var(--color-primary-pale);
}

.hamburger__line {
  display: block;
  width: 1.125rem;
  height: 2px;
  background: var(--color-primary-dark);
  border-radius: 2px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  transition: all var(--transition);
}

.hamburger__line:nth-child(1) {
    top: 0.75rem;
}

.hamburger__line:nth-child(2) {
    top: 1.1875rem;
}

.hamburger__line:nth-child(3) {
    top: 1.625rem;
}

.hamburger.is-open .hamburger__line:nth-child(1) {
  top: 1.1875rem;
  transform: translateX(-50%) rotate(45deg);
}

.hamburger.is-open .hamburger__line:nth-child(2) {
  opacity: 0;
}

.hamburger.is-open .hamburger__line:nth-child(3) {
  top: 1.1875rem;
  transform: translateX(-50%) rotate(-45deg);
}

/* Mobile Nav */
.mobile-nav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(83, 148, 190, 0.97);
  backdrop-filter: blur(20px);
  z-index: 99;
  padding: 6.25rem 2rem 2.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
}

.mobile-nav.is-open {
  opacity: 1;
  pointer-events: auto;
}

.mobile-nav__links {
  display: flex;
  flex-direction: column;
}

.mobile-nav__link {
  color: #fff;
  font-size: 1.125rem;
  font-weight: var(--font-weight-bold);
  padding: 1.25rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: padding-left var(--transition);
}

.mobile-nav__link:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.mobile-nav__link:hover {
  padding-left: 0.75rem;
}

.mobile-nav__cta {
  margin-top: 2.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.mobile-nav__cta-primary {
  display: block;
  text-align: center;
  padding: 1rem;
  border-radius: var(--radius-full);
  background: #fff;
  color: var(--color-primary-dark);
  font-weight: var(--font-weight-en-bold);
  font-size: 0.9375rem;
}

.mobile-nav__cta-secondary {
  display: block;
  text-align: center;
  padding: 1rem;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  font-weight: var(--font-weight-en-bold);
  font-size: 0.9375rem;
  border: 1px solid rgba(255, 255, 255, 0.3);
}

/* モバイルナビ: グルーピング */
.mobile-nav__group {
  margin-bottom: 0.75rem;
}

.mobile-nav__group-title {
  font-size: 0.6875rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.1em;
  padding: 0 0.25rem;
  margin-bottom: 0.25rem;
}

.mobile-nav__group-links {
  display: flex;
  flex-direction: column;
}

.mobile-nav__group-links .mobile-nav__link {
  border-top: none;
  padding: 1rem 0.5rem;
  font-size: 1rem;
}

.mobile-nav__group-links .mobile-nav__link:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.mobile-nav__group-links .mobile-nav__link:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}


















/* =============================================================
   1. Hero
============================================================= */
.hero {
  position: relative;
  min-height: 85vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #3A7CA5 0%, #5BA4D9 50%, #7BB8E0 100%);
  background-image: url('../img/hero-pc.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 1;
}

.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(131, 184, 221, 0.6) 0%,
    rgba(131, 184, 221, 0.35) 40%,
    rgba(131, 184, 221, 0.08) 70%,
    transparent 100%
  );
  z-index: 2;
}

/*.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(58, 124, 165, 0.6) 0%,
    rgba(58, 124, 165, 0.35) 40%,
    rgba(58, 124, 165, 0.08) 70%,
    transparent 100%
  );
  z-index: 2;
}*/

.hero__content {
  position: relative;
  z-index: 3;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 7.5rem var(--container-padding) 6.25rem;
  width: 100%;
}

.hero__text {
  max-width: 620px;
}

.hero__badge {
    display: inline-block;
    background: #fff;
    padding: .5rem 1.5rem;
    border-radius: 100px;
    font-size: 1rem;
    font-weight: 600;
    color: #83B8DD;
    border: 1px solid #83B8DD;
    margin-bottom: 1.5rem;
}

.hero__title {
    font-size: 2.75rem;
    font-weight: 600;
    /*color: #fff;*/
    line-height: 1.4;
    margin-bottom: 1.25rem;
    text-shadow: 0 0 20px rgba(255, 255, 255, 0.5);
}

.hero__title span {
    color: #F46585;
    font-size: 3.25rem;
    -webkit-text-stroke: 2px #F46585;
    text-shadow: 0 0 20px rgba(255, 255, 255, 0.5);*/
}

.hero__description {
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    text-shadow: 0 0 20px rgba(107, 153, 178, 0.5);
    line-height: 1.8;
    margin-bottom: 2.25rem;
}

.hero__cta {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 2.5rem;
}

.hero__features {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.hero__feature {
    background: #83B8DD;
    padding: 0.5rem 1.25rem;
    border-radius: 100px;
    font-size: .825rem;
    font-weight: 600;
    color: #fff;
}

.hero__scroll {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    animation: hero-scroll-bounce 2s ease-in-out infinite;
}

.hero__scroll-text {
    font-family: var(--font-en);
    font-size: 0.75rem;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.1em;
}

.hero__scroll-arrow {
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 12px solid #fff;
}

@keyframes hero-scroll-bounce {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
}

  50% {
    transform: translateX(-50%) translateY(8px);
  }
}







/* =============================================================
   2. こんな方へ
============================================================= */
.recommend {
    background: #F0F7FC;
}

.recommend__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.recommend__card {
    background: #fff;
    border-radius: 16px;
    padding: 2.25rem 1.75rem;
    
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    transition: 0.3s ease;
}

.recommend__card:hover {
    transform: translateY(-4px);
}

.recommend__icon {
    margin-bottom: 1rem;
}

.recommend__icon img {
    width: 50%;
    margin: 0 auto;
}

.recommend__card-title {
    text-align: center;
    color: #7aafcc;
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1.6;
    margin-bottom: .5rem;
}

.recommend__card-text {
    font-size: .875rem;
}


/* =============================================================
   3. 特徴
============================================================= */
.features {
    background: #fff;
}

.features__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}

.features__card {
    background: #FAFCFE;
    border-radius: 16px;
    padding: 2.25rem 1.75rem;
    border: 1px solid #E8EDF2;
    box-shadow: 0 4px 20px rgba(131, 184, 221, 0.10);
}

.features__num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #83B8DD;
    color: #fff;
    font-family: "Outfit", sans-serif;
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 auto 1rem;
}

.features__card-ttl {
    text-align: center;
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.6;
    margin-bottom: .75rem;
}

.features__card-img {
    margin: 0 auto 1rem;
}

.features__card-img img {
    border-radius: 16px;
}

.features__card-txt {
    font-size: .875rem;

}

.features__highlight {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    background: #FCFBED;
    padding: 3rem 3.5rem 2rem;
    border-radius: 16px;
}

.features__highlight-img img {
    border-radius: 16px;
}

.features__highlight-txt {
    
}

.features__highlight-txt h3 {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 auto .8rem;
}

.features__highlight-txt p {
    font-size: .875rem;
    margin: 0 auto 1rem;
}





/* =============================================================
   4. 実績数値
============================================================= */
.stats {
    background: #F0F7FC;
}

.stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    margin-bottom: 1rem;
}

.stats__item {
    text-align: center;
    padding: 2.5rem 1rem;
    border-right: 1px solid #E8EDF2;;
}

.stats__item:last-child {
    border-right: none;
}

.stats__value {
    font-family: "Outfit", sans-serif;
    font-size: 2.625rem;
    font-weight: 900;
    color: #5A9AC9;
    line-height: 1.2;
    margin-bottom: .5rem;
}

.stats__value span {
    font-size: 1.25rem;
    font-weight: 500;
}


.stats__label {
    font-size: .875rem;
}

.stats__sub {
    font-size: .75rem;
    opacity: .8;
}

.stats__note {
    text-align: center;
    font-size: .75rem;
}




/* =============================================================
   5. 悩み別
============================================================= */
.concerns {
    background: #FAFCFE;
    
}

.concerns__tabs {
    display: flex;
    gap: .75rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 2rem;
}

.concerns__tab {
    padding: .75rem 1.5rem;
    border-radius: 100px;
    font-size: 0.875rem;
    font-weight: 600;
    background: #EDF6FC;
    border: 2px solid transparent;
    transition: all 0.3s ease;
    cursor: pointer;
}

.concerns__tab.is-active,
.concerns__tab:hover {
    background: #EDF6FC;
    color: #5A9AC9;
    border-color: #83B8DD;
}

.concerns__panel {
    display: none;
}

.concerns__panel.is-active {
    display: block;
}

.concerns__panel .concern-item {
    background: #fff;
    border-radius: 16px;
    padding: 2.5rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.concerns__content {
    background: #fff;
    border-radius:16px;
    padding: 2rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.concerns__keywords {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 2.5rem;
}

.concerns__keyword {
    display: inline-block;
    padding: .35rem 1.25rem;
    background: #fff;
    border: 1px solid #E8EDF2;
    border-radius: 100px;
    font-size: .8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s ease;
}

.concerns__keyword:hover,
.concerns__keyword.is-active {
    background: #fff;
    border-color: #7EB8DD;
}


.container_btn {
    text-align: center;
    margin-top: 2rem;
}







/* トップ: 悩み別カード */
.concerns__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-top: 2rem;
}

.concerns__card {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: var(--color-bg-white);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
  transition: all var(--transition);
  text-decoration: none;
  color: var(--color-text);
}

.concerns__card:hover {
  box-shadow: 0 4px 20px rgba(131, 184, 221, 0.15);
  transform: translateY(-2px);
}

.concerns__card-thumb {
  width: 4.5rem;
  height: 4.5rem;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-primary-pale);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.concerns__card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.concerns__card-icon {
    font-size: 1.5rem;
}

.concerns__card-body {
    flex: 1;
    min-width: 0;
}

.concerns__card-title {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.25rem;
}

.concerns__card-excerpt {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.concerns__card-tags {
  display: flex;
  gap: 0.375rem;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}

.concerns__card-tag {
  font-size: 0.6875rem;
  color: var(--color-primary-dark);
  background: var(--color-primary-pale);
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
}

.concerns__card-arrow {
  color: var(--color-primary);
  font-size: 1.125rem;
  flex-shrink: 0;
}







/* ----------------------------------------
   悩み別: 一覧ページ（1ページ完結型）
---------------------------------------- */
.concern-archive {
  padding: 0 0 5rem;
  background: var(--color-bg-white);
}

.concern-keywords {
  display: flex;
  gap: 0.625rem;
  flex-wrap: wrap;
  justify-content: center;
  padding: 2.5rem 0 0;
}

.concern-keyword {
  display: inline-block;
  padding: 0.5rem 1.125rem;
  background: var(--color-bg);
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  color: var(--color-text);
  border: 1px solid var(--color-border);
  transition: all var(--transition);
}

.concern-keyword:hover {
  background: var(--color-primary-pale);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-light);
}

.concern-list {
  padding: 2.5rem 0 0;
}

.concern-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  padding: 3rem 0;
}

.concern-item:not(:last-child) {
  border-bottom: 1px solid var(--color-border);
}

.concern-item:nth-child(even) {
  direction: rtl;
}

.concern-item:nth-child(even) > * {
  direction: ltr;
}

.concern-item__image {
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-primary-pale) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.concern-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.concern-item__body {
  padding: 0.5rem 0;
}

.concern-item__cat {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-primary-pale);
  padding: 0.1875rem 0.75rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.75rem;
}

.concern-item__title {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 1rem;
}

.concern-item__desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  line-height: 1.9;
  margin-bottom: 1.5rem;
}

.concern-checklist {
  list-style: none;
  margin-bottom: 1.75rem;
}

.concern-checklist li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.9375rem;
  font-weight: 500;
}

.concern-checklist li:first-child {
  border-top: 1px solid var(--color-border);
}

.concern-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.375rem;
  height: 1.375rem;
  border-radius: 50%;
  background: var(--color-primary-dark);
  color: #fff;
  font-size: 0.6875rem;
  flex-shrink: 0;
}

.concern-item__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.75rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
  box-shadow: 0 4px 15px rgba(244, 101, 133, 0.3);
}

.concern-item__cta:hover {
  background: var(--color-accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.4);
}

.concern-item__cta-arrow {
  font-size: 1rem;
  transition: transform var(--transition);
}

.concern-item__cta:hover .concern-item__cta-arrow {
  transform: translateX(3px);
}

.concern-bottom-cta {
  background: var(--color-bg-blue);
  padding: 3.5rem 2rem;
  text-align: center;
  border-radius: var(--radius-lg);
  margin-top: 3rem;
}

.concern-bottom-cta__title {
  font-size: 1.375rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.concern-bottom-cta__desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  margin-bottom: 1.5rem;
  line-height: 1.8;
}

.concern-bottom-cta .concern-item__cta {
  padding: 1rem 2.5rem;
  font-size: 1rem;
}

.concern-empty {
  text-align: center;
  padding: 3rem 0;
  color: var(--color-text-light);
}






/* =============================================================
   ファーストステップ
============================================================= */
.first-step {
    background: #fff;
}

.first-step__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.75rem;
    text-align: center;
}

.first-step__card {
    background: #fff;
    border-radius: 16px;
    padding: 2.5rem 2rem;
    border: 2px solid #E8EDF2;
    margin-bottom: 1rem;
}

.first-step__card.is-recommended {
    border-color: #F46585;
    position: relative;
}

.first-step__card .sub-ttl {
    display: inline-block;
    font-size: .875rem;
    font-weight: 600;
    padding: .25rem 1rem;
    border-radius: 100px;
    margin-bottom: .8rem;
}

.is-recommended .sub-ttl {
    background: #FFF0F3!important;
    color: #F46585!important;
}

.first-step__card .sub-ttl {
    background: #EDF6FC;
    color: #5A9AC9;
}


.first-step__card h3 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: .5rem;
}

.first-step__card-txt {
    margin-bottom: 1rem;
}

.first-step__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .3rem;
}

.first-step__list {
    margin-bottom: 1rem;
}

.first-step__list span {
    background: #EDF6FC;
    color: #5A9AC9;
    display: inline-block;
    font-size: .75rem;
    font-weight: 600;
    padding: .25rem .3rem;
    border-radius: 100px;
}

.is-recommended .first-step__list span {
    background: #FFF0F3!important;
    color: #F46585!important;
}




.first-step__price {
    font-size: 1.25rem;
    margin-bottom: .2rem;
}

.first-step__price span {
    color: #5A9AC9;
    font-size: 2.5rem;
    font-weight: 700;
}

.is-recommended .first-step__price span {
    color: #F46585!important;
}

.first-step_note {
    text-align: center;
    font-size: .75rem;
}


/* =============================================================
   体験の流れ
============================================================= */
.flow {
    background: #FAFCFE;
}

.flow__cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}

.flow__card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.flow__photo {
    /*aspect-ratio: 4/3;*/
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.flow__body {
    padding: 1.5rem;
}

.flow__step-num {
    font-family: "Outfit", sans-serif;
    font-size: .875rem;
    font-weight: 600;
    color: #83B8DD;
    margin-bottom: 0.5rem;
}

.flow__body h4 {
    font-size: 1.15rem;
    font-weight: 600;
    margin-bottom: .5rem;
}

.flow__body p {
    font-size: .875rem;
}






/* =============================================================
   プラン
============================================================= */
.plans {
    background: #F0F7FC;
}

.plans__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    max-width: 820px;
    margin: 0 auto;
}

.plans__card {
    background: #fff;
    border-radius: 16px;
    padding: 2.5rem 2rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    border: 2px solid #E8EDF2;
    text-align: center;
    display: flex;
    flex-direction: column;
    position: relative;
}

.plans__card.is-recommended {
    border-color: #F46585;
}

.plans__card-badge {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, var(--color-accent) 0%, #E05275 100%);
    color: white;
    padding: 8px 24px;
    border-radius: var(--radius-full);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}


.plans__card-name {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.plans__card-catch {
    font-size: 0.825rem;
    margin-bottom: 1.25rem;
}

.plans__card-price {
    margin-bottom: 1.75rem;
}

.plans__price-value {
    font-family: var(--font-en);
    font-size: 2.75rem;
    font-weight: 800;
    color: var(--color-text);
    line-height: 1;
}

.plans__price-unit {
    font-size: 0.875rem;
    color: var(--color-text-light);
}

.plans__card-list {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem;
    text-align: left;
    flex-grow: 1;
}

.plans__card-list li {
    font-size: .875rem;
    padding: 0.625rem 0;
    padding-left: 1.5rem;
    position: relative;
    line-height: 1.6;
    border-bottom: 1px solid #E8EDF2;
}

.plans__card-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #83B8DD;
}

.plans__card-cta {
    margin-top: auto;
}

.plans__card-btn {
    display: block;
    width: 100%;
    padding: 1rem;
    border-radius: 100px;
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: all 0.3s ease;
}

.plans__card-btn--primary {
    background: var(--color-accent);
    color: #fff;
}

.plans__card-btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.plans__card-btn--secondary {
    color: #fff;
    background: #83B8DD
}

.plans__card-btn--secondary:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}













/* ----------------------------------------
   8. お客様の声 (Voice)
---------------------------------------- */
.voice {
  background: var(--color-bg-white);
}

.voice__widget {
  background: var(--color-bg);
  border-radius: var(--radius);
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
}




/* =============================================================
   カウンセリング
============================================================= */
#counseling {
    background: #fff;
    margin: 0 auto;
}

#counseling section {
    padding: 0 0 5em;
}

#counseling .content-box {
    max-width: 920px;
    margin: 0 auto;
}

#counseling .bg {
    line-height: 0;
    margin-bottom: -3px;
    /*position: relative;
    z-index: 0;*/
}

#counseling .bg img {
    width: 100%;
}

#counseling .wave01 {
    background: #D6F1F3;
}

#counseling .wave02 {
    background: #fafafa;
}

#counseling .wave03 {
    background: #fdf0f6;
}

#counseling h2 {
    max-width: 920px;
    font-size: 2.25em;
    margin: 0 auto 1.5em;
}

#counseling h2 img {
    width: 75%;
    margin: 0 auto;
}

#counseling h2 span {
    font-size: 0.5em;
}

#counseling img {
    margin: 0 auto;
}

#counseling .mv-box {
    width: 100%;
    text-align: center;
    padding-top: 3rem;
    margin: 0 auto -3em;
}





#counseling .problems  {
    width: 100%;
    background: #fafafa;
    /*position: relative;
    z-index: 1;*/
}

#counseling .problems-box {
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
}

#counseling .problems-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 0 auto 5em;
    padding: 3em;
    background: #fff;
    border: 4px solid #9BE3E8;
    box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    position: relative;
    z-index: 1;
}

#counseling .problems-list-txt {
    width: 100%;
    flex: 1.3;
}

#counseling .problems-list-txt h2 {
    font-size: 2em;
    margin: 0 auto 0.5em;
}

#counseling .problems-list-txt h2 img {
    width: 100%;
}

#counseling .problems-list ul {
    list-style: none;
    margin: 0;
}

#counseling .problems-list ul li {
	padding-left: 1.6em;
	position: relative;
    padding-bottom: 0.1em;
    border-bottom: 1px dashed #999;
}

#counseling .problems-list ul li span {
    font-weight: 700;
    color: #3BC3D3;
}

#counseling .problems-list ul li:before,
#counseling .problems-list ul li:after{
	content: "";
	display: block;
	position: absolute;
}

#counseling .problems-list ul li:before{
	width: 16px;
	height: 16px;
	border-radius: 3px;
	background: #fff;
	border: 1px solid #000;
	left: 0;
    top: 8px;
}

#counseling .problems-list ul li:after{
	border-left: 2px solid #fc86a9;
    border-bottom: 2px solid #fc86a9;
    width: 18px;
    height: 7px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    left: 2px;
    top: 8px;
}

#counseling .problems-list-img {
    width: 100%;
    flex: 1;
    text-align: right;
}

#counseling .problems-list-img img {
    width: 90%;
}




#counseling .problems-txt {
    text-align: center;
    margin: 0 auto;
}

#counseling .problems-txt h2 {
    margin: 0 auto 1em;
}

#counseling .problems-txt h2 img {
    width: 75%;
}

#counseling .problems-txt p {
    margin: 0 auto 1em;
}

#counseling .problems-txt h3 {
    margin: 0 auto 0.5em;
}

#counseling .problems-txt h3 img {
    width: 55%;
}

#counseling .problems-txt img {
    width: 60%;
}








#counseling .message {
    display: flex;
    flex-wrap: wrap;
}


#counseling .message-img {
    width: 100%;
    flex: 1;
    padding-right: 6em;
}

#counseling .message-txt {
    width: 100%;
    flex: 1;
}




/*　話してみませんか？　*/
#counseling .point {
    max-width: 920px;
    margin: 0 auto;
}

#counseling .point-img {
    text-align: center;
    margin: 0 auto 3em;
}

#counseling .point-img img {
    width: 30%;
}

#counseling .point-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    padding: 0 0 5em;
}

#counseling .point-item {
    width: 32.5%;
    border: 4px solid #9BE3E8;
    box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.08);
    padding: 2em 1.5em;
    border-radius: 10px;
}

#counseling .point-item img {
    width: 60%;
}

#counseling .point-item p.num {
    font-size: 2em;
    color: #fff;
    background: #3BC3D3;
    width: 60px;
    height: 60px;
    line-height: 60px!important;
    border-radius: 50%;
    text-align: center;
    margin: 0 auto 0.2em!important;
}

#counseling .point-item h3 {
    font-size: 1.3em;
    color: #3BC3D3;
    margin: 0 auto 0.5em!important;
}

#counseling .point-item p.point-txt {
    line-height: 1.8!important;
}







/*　カウンセリング方法　*/
#counseling .how {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto 8em;
}

#counseling .how-box {
    width: 48%;
    background: #fafafa;
    border-radius: 20px;
    box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.08);
}

#counseling .how-img img {
    border-radius: 20px 20px 0 0 ; 
}

#counseling .how-txt {
    padding: 1em 2.5em 2em;
}

#counseling .how-txt h3 {
    color: #3BC3D3;
    font-size: 1.6em;
    margin-bottom: 0.5em;
}

#counseling .icon-box {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 auto 1em;
    padding: 0 3.2em;
}

#counseling .icon-box .icon {
    width: 100%;
    flex: 1;
    text-align: center;
    border-right: 1px solid #3BC3D3;
}

#counseling .icon-box .icon img {
    width: 50%;
}

#counseling .icon-box .txt {
    width: 100%;
    flex: 2;
    color: #3BC3D3;
    margin-left: 1em;
    line-height: 1.7;
}




/*　カウンセリングの特徴　*/
#counseling .select-box {
}

#counseling .select-item {
    background: #fff;
    border: 4px solid #9be3e8;
    border-radius: 10px;
    margin: 0 auto 2em;
    overflow: hidden;
}

#counseling .select-ttl {
    color: #fff;
    background: #9be3e8;
    padding: 0.7em 1.5em;
    font-size: 1.2em;
    font-weight: 600;
    width: fit-content;
}

#counseling .select-txt {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 2em 2em 0;
}

#counseling .select-txt h3 {
    font-size: 1.5em;
    text-align: left;
    color: #3BC3D3;
}

#counseling .select-txt-l {
    width: 100%;
    flex: 1;
}

#counseling .select-txt-r {
    width: 100%;
    flex: 1;
    text-align: right;
}

#counseling .select-txt-r img {
    width: 80%;
}

#counseling .hearing {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 2em;
}

#counseling .hearing-box01,
#counseling .hearing-box02 {
    width: 100%;
    flex: 1;
    padding: 1em;
    text-align: center;
}

#counseling .hearing-box01 p,
#counseling .hearing-box02 p {
    color: #fff;
    background: #999;
    border-radius: 20px;
    width: fit-content;
    padding: 0.1em 3em 0;
    margin: 0 auto 0.3em;
}

#counseling .hearing-box01 h3,
#counseling .hearing-box02 h3 {
    font-size: 2em;
    margin: 0 auto;
}


#counseling .hearing-box01 {
    background: #f6f6f6;
    border-radius: 10px 0 0 10px;
}

#counseling .hearing-box02 {
    background: #d6f1f3;
    border-radius: 0 10px 10px 0;
}






/*　カウンセリングのメリット　*/
#counseling .effect {}
#counseling .effect-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto 5em;
}

#counseling .effect-list {
    width: 32%;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.08);
}

#counseling .effect-item {

}

#counseling .effect-item  img {
    border-radius: 10px 10px 0 0;
}

#counseling .effect-item-txt {
    padding: 1em 2em 2em;
}

#counseling .effect-item-txt h3 {
    color: #3BC3D3;
    font-size: 1.25em;
    margin: 0 auto 0.5em;
}




/*　カウンセリングのアプローチ　*/
#counseling .step {
    background: #D6F1F3;
}

#counseling .step-box {
    max-width: 920px;
    background: #fff;
    padding: 5em;
    border-radius: 10px;
    margin: 0 auto;
}


#counseling .step-box ul {
    padding: 0;
}

#counseling .step-box .flow {
    padding-left: 120px;
    position: relative;
    margin: 0 auto;
}

#counseling .step-box .flow::before {
    content: "";
    width: 1px;
    height: 100%;
    background: #3BC3D3;
    margin-left: -8px;
    display: block;
    position: absolute;
    top: 0;
    left: 120px;
}

#counseling .step-box .flow li {
    list-style-type: none;
    position: relative;
}

#counseling .step-box .flow li:not(:last-child) {
    margin-bottom: 3em;
}

#counseling .step-box .flow li .icon {
    font-size: 0.8em;
    font-weight: 600;
    color: #fff;
    background: #3BC3D3;
    padding: 8px 20px;
    display: block;
    position: absolute;
    top: 0;
    left: -120px;
    /*z-index: 100;*/
}

#counseling .step-box .flow li .icon::after {
    content: "";
    border-style: solid;
    border-width: 5px 0 5px 10px;
    border-color: transparent transparent transparent #3BC3D3;
    position: absolute;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

#counseling .step-box .flow li dl {
    display: flex;
    flex-wrap: wrap;
    padding-left: 1em;
    position: relative;
}

#counseling .step-box .flow li dl::before,
#counseling .step-box .flow li dl::after {
    content: "";
    display: block;
    position: absolute;
    top: 15px;
}

#counseling .step-box .flow li dl::before {
    width: 10px;
    height: 10px;
    margin-top: 1px;
    background: #333;
    border-radius: 50%;
    left: -12px;
}

#counseling .step-box .flow li dl::after {
    width: 50px;
    border-bottom: 1px dashed #333;
    position: absolute;
    left: 5px;
    top: 20px;
}

#counseling .step-box .flow li dl dt {
    width: 100%;
    flex: 1;
    text-align: center;
    margin-bottom: 1vh;
}

#counseling .step-box .flow li dl dt img {
    width: 50%;
}

#counseling .step-box .flow li dl dt h3 {
    font-size: 1.1em;
}

#counseling .step-box .flow li dl dd {
    width: 100%;
    flex: 2;
    margin-left: 1em;
}



/*　コンディション　*/
#counseling .condition {
    max-width: 920px;
    margin: 0 auto;
}

#counseling .condition-check-box {
    display: flex;
    flex-wrap: wrap;
    background: #fff;
    padding: 2em 1.5em;
    border-radius: 10px;
    margin: 0 auto 1em;
}


#counseling .condition-check,
#counseling .condition-method {
    width: 100%;
    flex: 1;
    padding: 0 0.5em;
}

#counseling .condition-method {
    border-left: 1px dashed #999;
}


#counseling .condition-check .condition-check-box {
    display: flex;
    flex-wrap: wrap;
    background: #fff;
    padding: 2em 1.5em 1em;
    border-radius: 10px;
}


#counseling .condition-check .condition-check-list {
    display: flex;
    flex-wrap: wrap;
}

#counseling .condition-check-img {
    width: 100%;
    flex: 1;
    text-align: center;
}

#counseling .condition-check-img img {
    width: 85%;
}


#counseling .condition-check-txt {
    width: 100%;
    flex: 2;
    padding-right: 1em;
}

#counseling .condition-check-txt h3 {
    color: #fff;
    padding: 0.5em;
    line-height: 1 !important;
    margin: 0 auto 0.5em;
    border-radius: 35px;
}

#counseling .condition-check-txt h3.type01 {
    background: #f58cab;
}

#counseling .condition-check-txt h3.type02 {
    background: #f0bb00;
}

#counseling .condition-check-txt h3.type03 {
    background: #3bc3d3;
}



#counseling .condition-method .method01 {
    padding: 1em 1.5em;
    margin: 0 1em 1em 2.5em;
    border-radius: 10px;
    background: #f6f6f6;
}

#counseling .condition-method .method-ttl .theme,
#counseling .condition-method .method-ttl .goals {
    text-align: center;
    line-height: 0;
}

#counseling .condition-method .method-ttl .theme img {
    width: 30%;
}

#counseling .condition-method .method-ttl .goals img {
    width: 30%;
}


#counseling .condition-method .method-ttl h3 {
    margin: 0 auto 0.5em;
}

#counseling .condition-method .method02-1,
#counseling .condition-method .method02-2,
#counseling .condition-method .method02-3 {
    padding: 1em 1.5em;
    margin: 0 1em 0 2.5em;
    border-radius: 10px;
}

#counseling .condition-method .method02-1 {
    border: 2px solid #f58cab;
}

#counseling .condition-method .method02-2 {
    border: 2px solid #f0bb00;
}

#counseling .condition-method .method02-3 {
    border: 2px solid #3bc3d3;
}

#counseling .condition-method .method02-1 h3 {
    color: #f58cab;
}

#counseling .condition-method .method02-2 h3 {
    color: #f0bb00;
}

#counseling .condition-method .method02-3 h3 {
    color: #3bc3d3;
}



#counseling .condition-method .method01 ul {
    list-style: none;
    margin-left: 0;
}

#counseling .condition-method .method01 li {
    line-height: 2;
    padding-left: 1.6em;
    position: relative;
}

#counseling .condition-method .method01 li:before {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    background: #fff;
    border: 1px solid #000;
    left: 0;
    top: 8px;
	content: "";
	display: block;
	position: absolute;
}















/*　カウンセリングの効果　*/
#counseling .effect-note {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    padding: 3em;
    border-radius: 10px;
    margin: 0 auto;
}

#counseling .effect-note ul {
    width: 100%;
    flex: 3;
    list-style: none;
    margin: 0;
}

#counseling .effect-note ul li {
    line-height: 1.8;
    margin: 0 auto 0.8em;
    padding: 0 0 0.3em 1.6em;
    position: relative;
    border-bottom: 1px dashed #999;
}

#counseling .effect-note ul li:before,
#counseling .effect-note ul li:after{
	content: "";
	display: block;
	position: absolute;
}

#counseling .effect-note ul li:before{
	width: 16px;
	height: 16px;
	border-radius: 3px;
	background: #ffffff;
	border: 1px solid #000000;
	left: 0;
    top: 8px;
}

#counseling .effect-note ul li:after{
	border-left: 1px solid #ff0000;
    border-bottom: 1px solid #ff0000;
    width: 8px;
    height: 4px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    left: 4px;
    top: 13px;
}

#counseling .effect-img {
    width: 100%;
    flex: 1;
    text-align: right;
}

#counseling .effect-img img {
    width: 100%;
}





/*　カウンセリング料金　*/
#counseling .price {
    background: #D6F1F3;
    border-radius: 10px;
    padding: 3em;
    margin: 3em auto 8em;
}

#counseling .price h2 {
    margin: 0 auto 0.5em;
}

#counseling .price-box {
    background: #fff;
    border-radius: 10px;
    padding: 3em;
}

#counseling .price-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background: #3BC3D3;
    border: 2px solid #3BC3D3;
    border-radius: 10px;
    margin: 0 auto 2em;
}

#counseling .price-box .price-note {
    margin: 0 auto 3em;
}

#counseling .cause-name {
    width: 100%;
    flex: 1;
    background: #3BC3D3;
    border: 2px solid #3BC3D3;
    border-radius: 10px;
    text-align: center;
    padding: 1em;
}

#counseling .cause-name h3 {
    color: #fff;
    font-size: 1.2em;
    margin-bottom: 0;
}

#counseling .cause-name p.time {
    background: #fff;
    width: fit-content;
    padding: 0 3em;
    margin: 0 auto;
    border-radius: 15px;
}



#counseling .cause-price {
    width: 100%;
    flex: 2;
    padding: 1em 0 1em 5em;
    background: #fff;
    border-radius: 0 8px 8px 0;
}

#counseling .cause-price p {
    margin-bottom: 0;
    line-height: 1.6!important;
}

#counseling .cause-price p span.value {
    font-size: 2em;
    font-weight: 600;
    padding-left: 0.1em;
}

#counseling .cause-price p span.yen {
    padding-left: 0.2em;
}

#counseling .cause-price p img {
    width: 8%;
}


#counseling .cause-price p span.normal {
    font-size: 1.5em;
    font-weight: 500;
    text-decoration: line-through; 
    text-decoration-color: red;
}

#counseling .cause-price p span.marker-y {
    background:linear-gradient(transparent 60%, #ff6 60%);
}



/*　ご利用の流れ　*/
#counseling .flow {
    margin: 0 auto 8em;
}

#counseling .flow-real {
    margin: 0 auto 5em;
}

#counseling .flow-online {
    margin: 0 auto;
}

#counseling .flow-real h2,
#counseling .flow-online h2 {
    font-size: 1.8em;
    padding: 0.5em 0.7em;
    margin-bottom: 1em;
    background: #fff;
}

#counseling .flow-real h2 {
    color: #3BC3D3;
    border: 2px solid #3BC3D3;
    box-shadow: 5px 5px #9BE3E8;
}

#counseling .flow-online h2 {
    color: #EE87B4;
    border: 2px solid #FAC8DC;
    box-shadow: 5px 5px #FAC8DC;
}





#counseling .flow-real .flow-box,
#counseling .flow-online .flow-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: space-between;
    -ms-flex-pack: space-between;
    justify-content: space-between;
    list-style: none;
}

#counseling .flow-real .flow-box li,
#counseling .flow-online .flow-box li {
    -ms-flex-preferred-size: 22%;
    flex-basis: 22%;
}

#counseling .flow-real .flow-box li .icon,
#counseling .flow-online .flow-box li .icon {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    line-height: 50px;
    width: 50px;
    color: #fff;
    margin: 0 auto 20px;
    display: block;
    border-radius: 50%;
    text-align: center;
    position: relative;
    letter-spacing: 2px;
}

#counseling .flow-real .flow-box li .icon {
    background: #3BC3D3;
}

#counseling .flow-online .flow-box li .icon {
    background: #F19EC2;
}


#counseling .flow-real .flow-box li .icon::before,
#counseling .flow-online .flow-box li .icon::before {
    content: "";
    border: solid transparent;
    border-width: 8px;
    position: absolute;
    top: calc(100% - 2px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

#counseling .flow-real .flow-box li .icon::before {
    border-top-color: #3BC3D3;
}

#counseling .flow-online .flow-box li .icon::before {
    border-top-color: #F19EC2;
}




#counseling .flow-real .flow-box li dl,
#counseling .flow-online .flow-box li dl {
    padding: 30px 20px;
    margin: 0;
    position: relative;
    background: #fff;
}

#counseling .flow-real .flow-box li dl {
    border: 3px solid #3BC3D3;
}

#counseling .flow-online .flow-box li dl {
    border: 3px solid #FAC8DC;
}

#counseling .flow-real .flow-box li:not(:last-child) dl::before,
#counseling .flow-online .flow-box li:not(:last-child) dl::before {
    content: "";
    width: 14px;
    height: 14px;
    margin-right: 10px;
    display: inline-block;
    position: absolute;
    top: calc(50% - 14px);
    left: 104%;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

#counseling .flow-real .flow-box li:not(:last-child) dl::before {
    border-top: 4px solid #3BC3D3;
    border-right: 4px solid #3BC3D3;
}

#counseling .flow-online .flow-box li:not(:last-child) dl::before {
    border-top: 4px solid #F19EC2;
    border-right: 4px solid #F19EC2;
}



#counseling .flow-real .flow-box li dl dt,
#counseling .flow-online .flow-box li dl dt {
    font-size: 1.2em;
    font-weight: 600;
    -ms-flex-preferred-size: 20%;
    flex-basis: 20%;
    margin-bottom: 1vh;
    text-align: center;
}

#counseling .flow-real .flow-box li dl dt {
    color: #3BC3D3;
}

#counseling .flow-online .flow-box li dl dt {
    color: #EE87B4;
}

#counseling .flow-real .flow-box li dl dd,
#counseling .flow-online .flow-box li dl dd {
    line-height: 1.8!important;
}



/*---------------　主な相談内容　---------------*/
#counseling .consult {
    max-width: 920px;
    margin: 0 auto;
}


#counseling .consult-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#counseling .consult-item {
    width: 32.5%;
    background: #fff;
    padding: 2em 1.5em;
    border-radius: 10px;
    margin-bottom: 1em;
}

#counseling .consult-item .icon {
    text-align: center;
}

#counseling .consult-item .icon img {
    width: 40%;
}

#counseling .consult-item ul {
    list-style: none;
    margin-left: 0;
}

#counseling .consult-item li {
    line-height: 2;
    padding-left: 1.6em;
    position: relative;
}

#counseling .consult-item li:before {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    background: #fff;
    border: 1px solid #000;
    left: 0;
    top: 8px;
	content: "";
	display: block;
	position: absolute;
}

/*---------------　ご利用者の声　---------------*/
#counseling .counseling-voice-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#counseling .counseling-voice-list {
    padding: 1em 3em 2em;
    margin: 0 auto 1em;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.08);
}

#counseling .voice-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 auto 1em;
}

#counseling .voice-icon {
    width: 15%;
}

#counseling .voice-icon img {
    width: 100%;
}

#counseling .voice-prof {
    width: 20%;
    padding-left: 1em;
}

#counseling .voice-prof p.name {
    margin: 0;
}

#counseling .voice-prof p.job {
    margin: 0 auto 0.5em;
}

#counseling .voice-prof p.industry {
    background: #fafafa;
    border: 1px solid #ccc;
    width: fit-content;
    padding: 0 1em;
}




#counseling .voice-note {
    width: 65%;
    padding-left: 1em;
}

#counseling .voice-note ul {
    margin-left: 0;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
}

#counseling .voice-note li {
    text-align: center;
    margin: 0 0.5em 0.5em 0;
    padding: 1em 1.5em;
    line-height: 0!important;
    width: fit-content;
    color: #3bc3d3;
    border: 1px solid #3bc3d3;
    border-radius: 20px;
}






.faq_list .desc {
    background: #fafafa;
}



























/* =============================================================
   カウンセラー
============================================================= */
.trainer {
    background: #fff;
}

.trainer__card {
    display: grid;
    grid-template-columns: 22rem 1fr;
    gap: 3rem;
    background: var(--color-bg);
    border-radius: 24px;
    padding: 3rem;
    margin-bottom: 2rem;
}

.trainer__card:last-of-type {
    margin-bottom: 0;
}

.trainer__photo {
    border-radius:16px;
    overflow: hidden;
    aspect-ratio: 3/4;
    background: #EDF6FC;
    display: flex;
    align-items: center;
    justify-content: center;
}

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

.trainer__photo-placeholder {
    font-size: .875rem;
}

.trainer__position {
    background: #EDF6FC;
    color: #5A9AC9;
    font-size: .875rem;
    padding: .3rem .8rem;
    border-radius: 100px;
}

.trainer__name {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.5;
}

.trainer__name-en {
    font-size: .875rem;
    margin-bottom: 1.25rem;
}

.trainer__qual {
    display: flex;
    flex-wrap: wrap;
    gap: .375rem;
    margin-bottom: 1.5rem;
}

.trainer__qual-tag {
    font-size: .75rem;
    color: var(--color-primary-dark);
    background: var(--color-primary-pale);
    padding: 0.2rem 0.625rem;
    border-radius: var(--radius-full);
}

.trainer__message {
    font-size: 1rem;
    line-height: 1.8;
}

.trainer__message p + p {
    margin-top: .8rem;
}


/* チームメンバー */
.trainer__team {
    margin-top: 3rem;
    text-align: center;
}

.trainer__team-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: .5rem;
}

.trainer__team-desc {
    font-size: .875rem;
    margin-bottom: 2rem;
}

.trainer__members {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.trainer__member {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    width: 7.5rem;
}

.trainer__avatar {
    width: 5rem;
    height: 5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
}

.trainer__avatar--photo {
    overflow: hidden;
    background: var(--color-primary-pale);
}

.trainer__avatar--photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.trainer__member-role {
    font-size: 0.6875rem;
    color: var(--color-text-muted);
}

.trainer__member-name {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.3;
}

/* 安心メッセージ */
.trainer__trust {
    margin-top: 2.5rem;
    background: #FFF0F3;
    border-radius: 16px;
    padding: 1.5rem 2rem;
    text-align: center;
}

.trainer__trust h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: .2rem;
}

.trainer__trust p {
  font-size: .875rem;
  line-height: 1.8;
}

.trainer__trust strong {
    font-weight: 700;
}

/* ----------------------------------------
   11. コラム (Column)
---------------------------------------- */
.column__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.column__card {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.column__thumbnail {
  aspect-ratio: 16/9;
  background: var(--color-primary-pale);
}

.column__body {
  padding: 1.25rem;
}

/* ----------------------------------------
   12. FAQ
---------------------------------------- */
.faq__tabs {
  display: flex;
  gap: 0.625rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.faq__tab {
  padding: 0.625rem 1.25rem;
  border-radius: var(--radius-full);
  font-size: 0.8125rem;
  font-weight: var(--font-weight-bold);
  background: var(--color-bg);
  color: var(--color-text-light);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
}

.faq__tab.is-active,
.faq__tab:hover {
  background: var(--color-primary-pale);
  color: var(--color-primary-dark);
  border-color: var(--color-primary);
}

.faq__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.faq__item {
  background: var(--color-bg-white);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
}

.faq__item summary {
  padding: 1.25rem 1.5rem;
  cursor: pointer;
  font-weight: var(--font-weight-bold);
  font-size: 0.9375rem;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.faq__item summary::-webkit-details-marker {
  display: none;
}

.faq__answer {
  padding: 0 1.5rem 1.25rem;
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.8;
}

.faq__answer strong,
.faq-answer strong {
  color: var(--color-primary-dark);
  font-weight: 700;
}

.faq__arrow {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-primary);
  transition: transform var(--transition);
  margin-left: auto;
}

.faq__item[open] .faq__arrow {
  transform: rotate(180deg);
}

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

/* =============================================================
   アクセス
============================================================= */
.access__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    background: #fff;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.access__map {
  min-height: 400px;
  background: var(--color-primary-pale);
  position: relative;
  overflow: hidden;
}

.access__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.access__info {
  padding: 2.5rem 2.25rem;
}

.access__info h3 {
    font-size: 1.25rem;
    font-weight: 600;
}

.access__info p {
    font-size: .875rem;
}


.access__info dt {
    font-size: .875rem;
    font-weight: 600;
    color: #549AC9;
    margin-top: 1.25rem;
}

.access__info dd {
    font-size: 1rem;
    margin-top: .25rem;
}



/* =============================================================
   お知らせ
============================================================= */
.news {
    background: #fff;
}

.news__list {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.news__item {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
  transition: background var(--transition);
  text-decoration: none;
  color: var(--color-text);
}

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

.news__item:hover {
  background: var(--color-bg);
}

.news__date {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  white-space: nowrap;
  min-width: 5.625rem;
}

.news__title {
  font-size: 0.9375rem;
  font-weight: 500;
}

/* =============================================================
   パンくず
============================================================= */
.breadcrumb {
    background: #fff;
    /*border-bottom: 1px solid #E8EDF2;*/
    font-size: .75rem;
    color: #2D3748;
    padding-top: 5rem;
}

.breadcrumb .container {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.breadcrumb a {
    color: #2D3748;
    text-decoration: none;
}

.breadcrumb a:hover {
    color: #2D3748;
}

.breadcrumb span {
    margin: 0 0.5rem;
}


/* =============================================================
   ページ（下層共通）
============================================================= */
.page-hero {
    background: #fff;
    /*background: var(--color-bg-blue);*/
    padding: 3.5rem 1.5rem;
    text-align: center;
}

.page-hero__tag {
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-primary-pale);
  padding: 0.25rem 1rem;
  border-radius: var(--radius-full);
  margin-bottom: 1rem;
  letter-spacing: 0.05em;
}

.page-hero__title {
  font-size: 1.75rem;
  font-weight: 600;
  line-height: 1.4;
}

.page-hero__desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  margin-top: 1rem;
  line-height: 1.8;
}

/* ----------------------------------------
   お知らせ一覧 (News Archive)
---------------------------------------- */
.news-archive {
  padding: 3rem 0 5rem;
}

.news-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.news-tab {
  display: inline-block;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-full);
  border: 1.5px solid var(--color-border);
  background: var(--color-bg-white);
  font-size: 0.875rem;
  font-family: var(--font-ja);
  color: var(--color-text-light);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
}

.news-tab:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}

.news-tab.is-active {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: #fff;
}

.news-list {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.news-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem 1.75rem;
  border-bottom: 1px solid var(--color-border);
  text-decoration: none;
  color: var(--color-text);
  transition: background var(--transition);
}

.news-item:last-child {
  border-bottom: none;
}

.news-item:hover {
  background: var(--color-bg-blue);
}

.news-item__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.news-item__date {
  font-family: var(--font-en);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  white-space: nowrap;
  min-width: 5.375rem;
}

.news-item__cat {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-primary-pale);
  padding: 0.125rem 0.625rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.news-item__cat.is-hours {
  color: #B8860B;
  background: #FFF8E7;
}

.news-item__title {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.6;
}

/* ページネーション */
.nav-links {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 2.5rem;
}

.nav-links a,
.nav-links span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 40px;
  padding: 0 0.25rem;
  border-radius: 50%;
  font-family: var(--font-en);
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition);
}

.nav-links a {
  background: var(--color-bg-white);
  color: var(--color-text-light);
  border: 1px solid var(--color-border);
}

.nav-links a:hover {
  background: var(--color-primary-pale);
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}

.nav-links .current {
  background: var(--color-primary-dark);
  color: #fff;
  border: none;
}

/* ----------------------------------------
   お知らせ詳細 (News Single)
---------------------------------------- */
.news-single {
  padding: 3rem 0 5rem;
}

.news-single__header {
  margin-bottom: 2.5rem;
}

.news-single__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.news-single__title {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
}

.news-single__body {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 3rem 2.5rem;
  line-height: 2;
  font-size: 0.9375rem;
}

.news-single__body p {
  margin-bottom: 1.5em;
}

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

.news-single__body h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 2em 0 0.8em;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--color-primary-pale);
}

.news-single__body h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 1.5em 0 0.5em;
  padding-left: 0.875rem;
  border-left: 3px solid var(--color-primary);
}

.news-single__body ul,
.news-single__body ol {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.news-single__body li {
  margin-bottom: 0.5em;
}

.news-single__body a {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

.news-single__body strong {
  font-weight: 600;
  color: var(--color-text);
}

.news-single__body blockquote {
  background: var(--color-bg-blue);
  border-left: 4px solid var(--color-primary);
  padding: 1.25rem 1.5rem;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 1.5em 0;
  font-style: italic;
  color: var(--color-text-light);
}

/* 前後ナビ */
.news-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 3rem;
  gap: 1rem;
}

.news-nav__link {
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  transition: color var(--transition);
}

.news-nav__link:hover {
  color: var(--color-primary-dark);
}

.news-nav__back {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  padding: 0.5rem 1.5rem;
  border: 1.5px solid var(--color-primary);
  border-radius: var(--radius-full);
  transition: all var(--transition);
}

.news-nav__back:hover {
  background: var(--color-primary-dark);
  color: #fff;
}

/* ----------------------------------------
   Sitemap
---------------------------------------- */
.sitemap h3 {
  font-size: 1.125rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-dark);
  margin: 2rem 0 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-primary-pale);
}

.sitemap h3:first-child {
  margin-top: 0;
}

.sitemap ul {
  padding-left: 0;
}

.sitemap li {
  margin-bottom: 0.5rem;
}

.sitemap a {
  color: var(--color-text);
  font-size: 0.9375rem;
  transition: color var(--transition);
}

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

.sitemap ul ul {
  padding-left: 1.25rem;
  margin-top: 0.5rem;
}

/* ----------------------------------------
   SP Fixed Footer
---------------------------------------- */
.sp-fixed-footer {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 98;
  background: #fff;
  box-shadow: 0 -2px 16px rgba(0, 0, 0, 0.08);
  padding: 0.625rem 1rem;
  padding-bottom: max(0.625rem, env(safe-area-inset-bottom));
  transition: transform var(--transition), opacity var(--transition);
}

.sp-fixed-footer__btn {
  display: block;
  text-align: center;
  padding: 0.875rem;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
  color: #fff;
  font-weight: var(--font-weight-en-bold);
  font-size: 0.9375rem;
  box-shadow: var(--shadow-button);
  transition: all var(--transition);
}

.sp-fixed-footer.is-hidden {
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
}

/* ----------------------------------------
   Footer
---------------------------------------- */
.footer {
  background: var(--color-text);
  color: #fff;
  padding: 3.75rem 0 1.875rem;
}

.footer__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  margin-bottom: 1.875rem;
}

.footer__logo {
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.05em;
}

.footer__nav {
  display: flex;
  gap: 3rem;
}

.footer__nav-column h4 {
  font-size: 0.8125rem;
  font-weight: var(--font-weight-en-bold);
  margin-bottom: 1rem;
  opacity: 0.6;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.footer__nav-column a {
  display: block;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.875rem;
  margin-bottom: 0.625rem;
  transition: color var(--transition);
}

.footer__nav-column a:hover {
  color: #fff;
}

.footer__bottom {
  text-align: center;
}

.footer__bottom small {
  color: rgba(255, 255, 255, 0.4);
  font-size: 0.75rem;
}

/* ----------------------------------------
   コラム一覧ページ
---------------------------------------- */
.column-archive {
  padding: 2.5rem 0 4rem;
  background: var(--color-bg-white);
}

.column-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.column-tab {
  display: inline-block;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-full);
  border: 1.5px solid var(--color-border);
  background: var(--color-bg-white);
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  transition: all var(--transition);
}

.column-tab:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}

.column-tab.is-active {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: #fff;
}

.column-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.column-card {
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
}

.column-card__thumb {
  aspect-ratio: 3 / 2;
  background: var(--color-bg-blue);
  overflow: hidden;
  position: relative;
}

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

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

.column-card__cat-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.125rem 0.75rem;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(4px);
}

.column-card__cat-badge.is-kokoro {
  color: var(--color-accent);
}

.column-card__cat-badge.is-karada {
  color: #2B9A5E;
}

.column-card__body {
  padding: 1.25rem;
}

.column-card__title {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0.5rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.column-card__meta {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

.column-card__excerpt {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  margin-top: 0.5rem;
  line-height: 1.7;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.column-empty {
  text-align: center;
  padding: 4rem 0;
  color: var(--color-text-muted);
}

/* ----------------------------------------
   コラム詳細ページ
---------------------------------------- */
.column-single {
  padding: 2.5rem 0 4rem;
  background: var(--color-bg-white);
}

.column-single__layout {
  display: grid;
  grid-template-columns: 1fr 15rem;
  gap: 3rem;
  align-items: start;
}

.column-single__header {
  margin-bottom: 2rem;
}

.column-single__cat {
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.25rem 1rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.75rem;
  text-decoration: none;
  transition: opacity var(--transition);
}

.column-single__cat:hover {
  opacity: 0.8;
}

.column-single__cat.is-kokoro {
  color: var(--color-accent);
  background: var(--color-accent-light);
}

.column-single__cat.is-karada {
  color: #2B9A5E;
  background: #EEFBF3;
}

.column-single__title {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.75rem;
}

.column-single__date {
  font-family: var(--font-en);
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

.column-single__eyecatch {
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 2.5rem;
  aspect-ratio: 16 / 9;
  background: var(--color-bg-blue);
}

.column-single__eyecatch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 目次（TOC） */
.toc {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  margin-bottom: 2.5rem;
  overflow: hidden;
}

.toc__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1rem 1.5rem;
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--transition);
}

.toc__toggle:hover {
  background: var(--color-bg-blue);
}

.toc__toggle-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.toc__icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-primary-dark);
  flex-shrink: 0;
}

.toc__heading {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: 0.03em;
}

.toc__arrow {
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
  transition: transform var(--transition);
  flex-shrink: 0;
}

.toc.is-open .toc__arrow {
  transform: rotate(180deg);
}

.toc__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}

.toc.is-open .toc__body {
  max-height: 600px;
}

.toc__list {
  list-style: none;
  padding: 0 1.5rem 1.25rem;
}

.toc__item--h2 {
  margin-top: 0.25rem;
}

.toc__item--h3 {
  padding-left: 1.25rem;
}

.toc__link {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 0.4rem 0.75rem;
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  line-height: 1.5;
}

.toc__link:hover {
  background: var(--color-bg-blue);
  color: var(--color-primary-dark);
}

.toc__item--h2 > .toc__link {
  font-weight: 600;
  color: var(--color-text);
}

.toc__item--h3 > .toc__link {
  font-size: 0.8125rem;
}

.toc__number {
  font-family: var(--font-en);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  min-width: 1.25rem;
  padding-top: 0.1em;
  flex-shrink: 0;
}

.toc__item--h3 .toc__number {
  color: var(--color-text-muted);
  font-weight: 400;
}

.toc__separator {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: 0.25rem 0.75rem;
}

.column-single__body {
  line-height: 2;
  font-size: 1rem;
}

.column-single__body p {
  margin-bottom: 1.5em;
}

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

.column-single__body h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 2.5em 0 0.8em;
  padding: 0.75rem 1.25rem;
  background: var(--color-bg-blue);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.column-single__body h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 1.5em 0 0.5em;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-primary-pale);
}

.column-single__body ul,
.column-single__body ol {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.column-single__body li {
  margin-bottom: 0.5em;
}

.column-single__body a {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

.column-single__body strong {
  font-weight: 600;
}

.column-single__body blockquote {
  background: var(--color-bg-blue);
  border-left: 4px solid var(--color-primary);
  padding: 1.25rem 1.5rem;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 1.5em 0;
  color: var(--color-text-light);
}

.column-single__body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  margin: 1.5em 0;
}

/* サイドバー */
.column-sidebar {
  position: sticky;
  top: 6rem;
}

.sidebar-section {
  margin-bottom: 2rem;
}

.sidebar-section__title {
  font-size: 0.875rem;
  font-weight: 600;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-primary-pale);
  margin-bottom: 1rem;
  color: var(--color-text);
}

.sidebar-cat-list {
  list-style: none;
  padding: 0;
}

.sidebar-cat-list li {
  margin-bottom: 0.25rem;
}

.sidebar-cat-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
}

.sidebar-cat-list a:hover {
  background: var(--color-bg-blue);
  color: var(--color-primary-dark);
}

.sidebar-cat-count {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  background: var(--color-bg-blue);
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
}

.sidebar-related {
  list-style: none;
  padding: 0;
}

.sidebar-related li {
  margin-bottom: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}

.sidebar-related li:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.sidebar-related a {
  display: flex;
  gap: 0.75rem;
  text-decoration: none;
  color: var(--color-text);
}

.sidebar-related__thumb {
  width: 4.5rem;
  height: 3rem;
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-bg-blue);
}

.sidebar-related__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-related__title {
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.5;
}

.sidebar-no-posts {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

/* 前後ナビ */
.column-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border);
  gap: 1rem;
}

.column-nav__link {
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  transition: color var(--transition);
}

.column-nav__link:hover {
  color: var(--color-primary-dark);
}

.column-nav__back {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  padding: 0.5rem 1.5rem;
  border: 1.5px solid var(--color-primary);
  border-radius: var(--radius-full);
  transition: all var(--transition);
}

.column-nav__back:hover {
  background: var(--color-primary-dark);
  color: #fff;
}

/* ----------------------------------------
   FAQ一覧ページ
---------------------------------------- */
/* カウンセラー一覧ページ */
.counselor-archive {
  padding: 3rem 0 5rem;
  background: var(--color-bg-white);
}

.faq-archive {
  padding: 2.5rem 0 4rem;
  background: var(--color-bg-white);
}

.faq-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}

.faq-tab {
  display: inline-block;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-full);
  border: 1.5px solid var(--color-border);
  background: var(--color-bg-white);
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-decoration: none;
  transition: all var(--transition);
}

.faq-tab:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}

.faq-tab.is-active {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: #fff;
}

.faq-category-heading {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  margin-top: 2.5rem;
}

.faq-category-heading:first-child {
  margin-top: 0;
}

.faq-category-heading__icon {
  width: 2rem;
  height: 2rem;
  background: var(--color-primary-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-dark);
  font-size: 0.875rem;
  font-weight: 600;
  flex-shrink: 0;
}

.faq-category-heading__text {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-text);
}

.faq-category-heading__count {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  margin-bottom: 1rem;
}

.faq-item {
  background: var(--color-bg-white);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  transition: border-color var(--transition);
}

.faq-item[open] {
  border-color: var(--color-primary-light);
}

.faq-item summary {
  padding: 1.125rem 1.5rem;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9375rem;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: background var(--transition);
}

.faq-item summary:hover {
  background: var(--color-bg-blue);
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item__q {
  color: var(--color-primary-dark);
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
}

.faq-item__text {
  flex: 1;
  line-height: 1.5;
}

.faq-item__arrow {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--transition);
}

.faq-item[open] .faq-item__arrow {
  transform: rotate(180deg);
}

.faq-answer {
  padding: 1rem 1.5rem 1.25rem 3.5rem;
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.9;
  border-top: 1px solid var(--color-border);
  margin: 0 1rem;
}

.faq-answer__label {
  color: var(--color-accent);
  font-weight: 700;
  font-size: 1rem;
  margin-right: 0.5rem;
}

.faq-empty {
  text-align: center;
  padding: 4rem 0;
  color: var(--color-text-muted);
}

/* ----------------------------------------
   固定ページ（汎用）
---------------------------------------- */
.page-single {
  padding: 3rem 0 5rem;
}

.page-body {
  max-width: 780px;
  margin: 0 auto;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 3rem 2.5rem;
  line-height: 2;
  font-size: 0.9375rem;
}

.page-body p {
  margin-bottom: 1.5em;
}

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

.page-body h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 2.5em 0 0.8em;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--color-primary-pale);
}

.page-body h2:first-child {
  margin-top: 0;
}

.page-body h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 1.5em 0 0.5em;
  padding-left: 0.875rem;
  border-left: 3px solid var(--color-primary);
}

.page-body ul,
.page-body ol {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.page-body li {
  margin-bottom: 0.5em;
}

.page-body a {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

.page-body a:hover {
  color: var(--color-primary);
}

.page-body strong {
  font-weight: 600;
  color: var(--color-text);
}

.page-body blockquote {
  background: var(--color-bg-blue);
  border-left: 4px solid var(--color-primary);
  padding: 1.25rem 1.5rem;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 1.5em 0;
  font-style: italic;
  color: var(--color-text-light);
}

.page-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5em 0;
  font-size: 0.875rem;
}

.page-body th,
.page-body td {
  border: 1px solid var(--color-border);
  padding: 0.75rem 1rem;
  text-align: left;
}

.page-body th {
  background: var(--color-bg-blue);
  font-weight: 600;
  white-space: nowrap;
  width: 30%;
}

.page-body td {
  color: var(--color-text-light);
}

.page-body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  margin: 1.5em 0;
}

/* ----------------------------------------
   ご利用の流れ (Flow)
---------------------------------------- */
.flow-page {
  padding: 4rem 0 5rem;
}

.flow-page .container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.flow-steps {
  position: relative;
}

.flow-steps::before {
  content: '';
  position: absolute;
  top: 40px;
  bottom: 40px;
  left: 28px;
  width: 2px;
  background: linear-gradient(to bottom, var(--color-primary-light), var(--color-primary-pale));
}

.flow-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 1.5rem;
  position: relative;
  margin-bottom: 3rem;
}

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

.flow-step__number {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}

.flow-step__number-label {
  font-family: var(--font-en);
  font-size: 0.5rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  opacity: 0.85;
}

.flow-step__number-num {
  font-family: var(--font-en);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
}

.flow-step__card {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.flow-step__image {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--color-bg-blue);
  overflow: hidden;
}

.flow-step__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.flow-step__body {
  padding: 1.5rem 1.75rem;
}

.flow-step__title {
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  line-height: 1.5;
}

.flow-step__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.9;
}

.flow-step__link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  margin-top: 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color var(--transition);
}

.flow-step__link:hover {
  color: var(--color-primary);
}

.flow-step__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
  padding: 0.625rem 1.5rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.flow-step__cta:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
}

/* ボトムCTA */
.flow-bottom-cta {
  margin-top: 4rem;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2.5rem 2rem;
  text-align: center;
}

.flow-bottom-cta__badge {
  display: inline-block;
  background: var(--color-accent-light);
  color: var(--color-accent);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.875rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.75rem;
}

.flow-bottom-cta__title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.flow-bottom-cta__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  margin-bottom: 1.5rem;
  line-height: 1.8;
}

.flow-bottom-cta__price {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.flow-bottom-cta__price-old {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.flow-bottom-cta__price-arrow {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

.flow-bottom-cta__price-new {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-accent);
  font-family: var(--font-en);
}

.flow-bottom-cta__price-unit {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
}

.flow-bottom-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2.5rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.flow-bottom-cta__btn:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.flow-bottom-cta__note {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 0.75rem;
}

/* ----------------------------------------
   COCOTOREとは (About)
---------------------------------------- */
.about-section {
  padding: 5rem 0;
}

.about-container {
  max-width: 960px;
  margin: 0 auto;
}

.about-section--alt {
  background: var(--color-bg-blue);
}



.section-heading {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
  line-height: 1.6;
}

.section-desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  line-height: 1.9;
}

/* ① 不調の正体 */
.stress-intro {
  text-align: center;
}

.stress-intro__body {
  max-width: 680px;
  margin: 0 auto 2.5rem;
}

.stress-intro__visual {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2rem 2.5rem;
  max-width: 700px;
  margin: 0 auto;
}

.stress-cycle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.stress-cycle__step {
  text-align: center;
  flex: 1;
  max-width: 150px;
}

.stress-cycle__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-primary-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0.5rem;
  font-size: 1.5rem;
}

.stress-cycle__icon img {
  width: 32px;
  height: 32px;
}

.stress-cycle__label {
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.5;
}

.stress-cycle__sub {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.125rem;
}

.stress-cycle__arrow {
  font-size: 1.25rem;
  color: var(--color-primary-light);
  flex-shrink: 0;
}

.stress-intro__note {
  text-align: center;
  margin-top: 1.75rem;
  font-size: 0.875rem;
  color: var(--color-accent);
  font-weight: 600;
}

/* ② アプローチ 3カラム */
.approach-intro {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.approach-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}

.approach-card {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  text-align: center;
}

.approach-card__img {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: var(--color-primary-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  position: relative;
  overflow: hidden;
}

.approach-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.approach-card__num {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-en);
  font-size: 0.75rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.approach-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
}

.approach-card__title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.approach-card__desc {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.8;
}

/* ③〜⑤ 交互レイアウト */
.feature-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.feature-row--reverse .feature-row__img {
  order: 2;
}

.feature-row--reverse .feature-row__body {
  order: 1;
}

.feature-row__img {
  aspect-ratio: 4 / 3;
  background: var(--color-primary-pale);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.feature-row__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.feature-row__tag {
  display: inline-block;
  font-family: var(--font-en);
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.375rem;
}

.feature-row__title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
  line-height: 1.6;
}

.feature-row__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.9;
}

.feature-row__point {
  margin-top: 1.25rem;
  padding: 1rem 1.25rem;
  background: var(--color-primary-pale);
  border-radius: var(--radius-sm);
  font-size: 0.8125rem;
  line-height: 1.8;
}

.feature-row__point strong {
  color: var(--color-primary-dark);
}

/* ⑥ 比較テーブル */
.compare-section {
  text-align: center;
}

.compare-section .section-desc {
  max-width: 600px;
  margin: 0 auto 2.5rem;
}

.compare-table-wrap {
  overflow-x: auto;
  padding-top: 0.75rem;
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  text-align: center;
  font-size: 0.875rem;
}

.compare-table th,
.compare-table td {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
}

.compare-table thead th {
  background: var(--color-primary-pale);
  font-weight: 600;
  font-size: 0.8125rem;
  color: var(--color-text);
}

.compare-table thead th:first-child {
  background: transparent;
}

.compare-table thead th.highlight {
  background: var(--color-primary);
  color: #fff;
  position: relative;
}

.compare-table thead th.highlight::before {
  content: '★ おすすめ';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-accent);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 600;
  padding: 0.125rem 0.625rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
  z-index: 1;
}

.compare-table tbody th {
  text-align: left;
  font-weight: 600;
  font-size: 0.8125rem;
  background: var(--color-bg);
  white-space: nowrap;
}

.compare-table tbody td {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.6;
}

.compare-table td.highlight-col {
  background: rgba(131, 184, 221, 0.06);
  color: var(--color-text);
  font-weight: 500;
}

.compare-table tr:last-child th,
.compare-table tr:last-child td {
  border-bottom: none;
}

/* ⑦ ボトムCTA */
.about-bottom-cta {
  padding: 5rem 0;
  text-align: center;
}

.about-cta-card {
  max-width: 640px;
  margin: 0 auto;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2.5rem 2rem;
}

.about-cta-card__badge {
  display: inline-block;
  background: var(--color-accent-light);
  color: var(--color-accent);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.875rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.75rem;
}

.about-cta-card__title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.about-cta-card__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  margin-bottom: 1.5rem;
  line-height: 1.8;
}

.about-cta-card__price {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.about-cta-card__price-old {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.about-cta-card__price-arrow {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

.about-cta-card__price-new {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-accent);
  font-family: var(--font-en);
}

.about-cta-card__price-unit {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
}

.about-cta-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2.5rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.about-cta-card__btn:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.about-cta-card__note {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 0.75rem;
}

/* ----------------------------------------
   スタッフ募集 (Recruit)
---------------------------------------- */
.recruit-container {
  max-width: 960px;
  margin: 0 auto;
}

/* ① メッセージ */
.recruit-message {
  padding: 5rem 0;
  text-align: center;
}

.recruit-message__heading {
  font-size: 1.375rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
  line-height: 1.6;
}

.recruit-message__body {
  max-width: 680px;
  margin: 0 auto;
  font-size: 0.9375rem;
  color: var(--color-text-light);
  line-height: 2;
}

/* ② 職種ナビカード */
.recruit-positions {
  padding: 0 0 5rem;
}

.recruit-positions__nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-bottom: 3.5rem;
}

.recruit-nav-card {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem;
  text-decoration: none;
  color: var(--color-text);
  transition: all var(--transition);
  border: 2px solid transparent;
}

.recruit-nav-card:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(131, 184, 221, 0.15);
}

.recruit-nav-card__img {
  width: 88px;
  height: 88px;
  border-radius: var(--radius-sm);
  background: var(--color-primary-pale);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
}

.recruit-nav-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recruit-nav-card__badge {
  display: inline-block;
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-primary-pale);
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.25rem;
}

.recruit-nav-card__title {
  font-size: 1.0625rem;
  font-weight: 600;
}

.recruit-nav-card__arrow {
  margin-left: auto;
  font-size: 0.875rem;
  color: var(--color-primary);
}

/* エントリー誘導ヒント */
.recruit-entry-hint {
  text-align: center;
  margin-bottom: 1rem;
}

.recruit-entry-hint__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  padding: 0.5rem 1.25rem;
  background: var(--color-primary-pale);
  border-radius: var(--radius-full);
  transition: all var(--transition);
}

.recruit-entry-hint__btn:hover {
  background: var(--color-primary-light);
  color: #fff;
}

/* ③ 職種詳細 */
.recruit-detail {
  padding: 4rem 0;
}

.recruit-detail + .recruit-detail {
  border-top: 1px solid var(--color-border);
}

.recruit-detail__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.recruit-detail__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.recruit-detail__icon svg {
  width: 24px;
  height: 24px;
  fill: #fff;
}

.recruit-detail__badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  background: var(--color-accent-light);
  color: var(--color-accent);
  padding: 0.125rem 0.625rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.25rem;
}

.recruit-detail__title {
  font-size: 1.25rem;
  font-weight: 600;
}

.recruit-detail__desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  line-height: 1.9;
  margin-bottom: 2rem;
  max-width: 720px;
}

/* 募集要項テーブル */
.recruit-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.recruit-table th,
.recruit-table td {
  padding: 1rem 1.5rem;
  text-align: left;
  font-size: 0.875rem;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
  line-height: 1.8;
}

.recruit-table tr:last-child th,
.recruit-table tr:last-child td {
  border-bottom: none;
}

.recruit-table th {
  width: 160px;
  font-weight: 600;
  background: var(--color-bg-blue);
  white-space: nowrap;
  font-size: 0.8125rem;
}

.recruit-table td {
  color: var(--color-text-light);
}

/* 各職種テーブル下CTAボタン */
.recruit-detail__entry {
  text-align: center;
  margin-top: 1.5rem;
}

.recruit-detail__entry-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2.5rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.recruit-detail__entry-btn:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

/* ④ エントリーフォーム */
.recruit-entry {
  padding: 5rem 0;
  background: var(--color-bg-blue);
}

.recruit-entry__inner {
  max-width: 680px;
  margin: 0 auto;
}

.recruit-entry__header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.recruit-entry__tag {
  font-family: var(--font-en);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 0.5rem;
}

.recruit-entry__heading {
  font-size: 1.375rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.recruit-entry__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
}

.recruit-form {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2.5rem;
}

/* CF7 フォームスタイル */
.recruit-form .form-group {
  margin-bottom: 1.5rem;
}

.recruit-form .form-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.recruit-form .form-label__required {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--color-accent);
  background: var(--color-accent-light);
  padding: 0.0625rem 0.375rem;
  border-radius: var(--radius-full);
}

.recruit-form .form-label__optional {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-bg);
  padding: 0.0625rem 0.375rem;
  border-radius: var(--radius-full);
}

.recruit-form input[type="text"],
.recruit-form input[type="email"],
.recruit-form input[type="tel"],
.recruit-form input[type="number"],
.recruit-form select,
.recruit-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-family: var(--font-main);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition);
  line-height: 1.6;
}

.recruit-form input:focus,
.recruit-form select:focus,
.recruit-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background: var(--color-bg-white);
}

.recruit-form textarea {
  min-height: 120px;
  resize: vertical;
}

.recruit-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.recruit-form .form-radio-group {
  display: flex;
  gap: 1.5rem;
  padding-top: 0.25rem;
}

.recruit-form .form-radio-group label {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.875rem;
  cursor: pointer;
}

.recruit-form input[type="radio"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary);
}

/* ファイルアップロード */
.recruit-form .form-file-wrap {
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-sm);
  padding: 1.25rem;
  text-align: center;
  background: var(--color-bg);
  transition: all var(--transition);
}

.recruit-form .form-file-wrap:hover {
  border-color: var(--color-primary-light);
  background: var(--color-primary-pale);
}

.recruit-form .form-file-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.375rem;
}

/* 同意チェック */
.recruit-form .form-agreement {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  margin: 2rem 0;
  padding: 1rem 1.25rem;
  background: var(--color-bg);
  border-radius: var(--radius-sm);
}

.recruit-form .form-agreement input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
  flex-shrink: 0;
}

.recruit-form .form-agreement a {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* 送信ボタン */
.recruit-form .form-submit {
  text-align: center;
}

.recruit-form input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 3rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  font-family: var(--font-main);
}

.recruit-form input[type="submit"]:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.recruit-form .form-submit-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.75rem;
}

/* CF7 バリデーション */
.recruit-form .wpcf7-not-valid-tip {
  color: var(--color-accent);
  font-size: 0.75rem;
  margin-top: 0.25rem;
}

.recruit-form .wpcf7-response-output {
  border-radius: var(--radius-sm);
  padding: 1rem;
  font-size: 0.8125rem;
  margin-top: 1rem;
}

/* ⑤ 電話 */
.recruit-contact {
  padding: 4rem 0;
  text-align: center;
}

.recruit-contact__heading {
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.recruit-contact__tel {
  font-family: var(--font-en);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.recruit-contact__tel-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-primary-pale);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
}

.recruit-contact__note {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 0.5rem;
}

/* ----------------------------------------
   料金一覧 (Price)
---------------------------------------- */
.price-container {
  max-width: 960px;
  margin: 0 auto;
}

.price-section-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  text-align: center;
  margin-bottom: 0.25rem;
}

.price-section-title {
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 1rem;
}

.price-section-desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-align: center;
  line-height: 1.9;
  margin-bottom: 2.5rem;
}

/* 体験コース */
.price-trial {
  padding: 5rem 0;
}

/* プランカード共通 */
.price-card {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2.5rem;
  position: relative;
}

.price-card--recommended {
  border: 2px solid var(--color-primary);
}

.price-card__recommend-tag {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-primary);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.25rem 1.25rem;
  border-radius: var(--radius-full);
}

.price-card__badge {
  display: inline-block;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
  margin-bottom: 1rem;
}

.price-card__catch {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin-bottom: 0.5rem;
  line-height: 1.6;
}

.price-card__name {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.price-card__plan-desc {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.8;
  margin-bottom: 1.5rem;
}

/* 価格エリア */
.price-card__price-area {
  text-align: center;
  padding: 1.5rem;
  background: var(--color-bg-blue);
  border-radius: var(--radius-sm);
  margin-bottom: 1.5rem;
}

.price-card__price-old {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
  display: block;
  margin-bottom: 0.25rem;
}

.price-card__price-sub {
  font-size: 0.75rem;
  color: var(--color-text-light);
  display: block;
  margin-bottom: 0.25rem;
}

.price-card__price,
.price-card__price-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.25rem;
}

.price-card__price-label {
  font-size: 0.875rem;
  font-weight: 600;
  margin-right: 0.25rem;
}

.price-card__price-num {
  font-family: var(--font-en);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--color-accent);
  line-height: 1;
}

.price-card__price-unit {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
}

/* 入会金テーブル */
.price-card__fee-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 0.75rem;
}

.price-card__fee-table th,
.price-card__fee-table td {
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  border: 1px solid var(--color-border);
}

.price-card__fee-table th {
  background: var(--color-bg);
  font-weight: 600;
  width: 140px;
}

.price-card__fee-notes {
  margin-bottom: 1.5rem;
}

.price-card__fee-notes p {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* 含まれる内容 */
.price-card__includes {
  padding: 1.5rem;
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  margin-bottom: 1.5rem;
}

.price-card__includes-title {
  font-size: 0.8125rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 1rem;
}

.price-card__includes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-bottom: 0.75rem;
}

.price-card__includes-grid--3col {
  grid-template-columns: repeat(3, 1fr);
}

.price-card__includes-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 600;
  text-align: center;
}

.price-card__includes-item small {
  font-weight: 400;
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  display: block;
}

.price-card__includes-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-bg-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.price-card__includes-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.8;
}

.price-card__includes-point {
  font-size: 0.6875rem;
  color: var(--color-primary-dark);
  text-align: center;
  font-weight: 600;
}

/* 詳細テーブル */
.price-card__table {
  width: 100%;
  border-collapse: collapse;
}

.price-card__table th,
.price-card__table td {
  padding: 0.625rem 0.75rem;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.price-card__table tr:last-child th,
.price-card__table tr:last-child td {
  border-bottom: none;
}

.price-card__table th {
  width: 120px;
  font-weight: 600;
  white-space: nowrap;
}

.price-card__table td {
  color: var(--color-text-light);
}

.price-card__table-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.5rem;
}

/* 体験CTA */
.price-card__cta {
  text-align: center;
  margin-top: 1.5rem;
}

.price-card__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2.5rem;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.price-card__cta-btn:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.price-card__cta-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.5rem;
}

/* ② プラン比較 */
.price-plans {
  padding: 5rem 0;
  background: var(--color-bg-blue);
}

.price-plans__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  align-items: start;
}

/* ③ カウンセリングプラン */
.price-counseling {
  padding: 5rem 0;
}

/* ④ お支払い方法 */
.price-payment {
  padding: 5rem 0;
  background: var(--color-bg-blue);
}

.price-payment__table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 2rem;
}

.price-payment__table th,
.price-payment__table td {
  padding: 0.875rem 1.25rem;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
  line-height: 1.7;
}

.price-payment__table thead th {
  background: var(--color-bg-blue);
  font-weight: 600;
  font-size: 0.75rem;
}

.price-payment__info {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.price-payment__block h4 {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.price-payment__block p {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.8;
}

.price-payment__brands {
  margin: 0.75rem 0;
}

.price-payment__brands img {
  max-width: 320px;
  height: auto;
}

.price-payment__small {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* ⑤ 料金FAQ */
.price-faq {
  padding: 4rem 0;
}

.price-faq__item {
  background: var(--color-bg-white);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow);
  margin-bottom: 0.75rem;
  overflow: hidden;
}

.price-faq__q {
  padding: 1rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.price-faq__q::before {
  content: 'Q';
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-en);
  font-size: 0.75rem;
  font-weight: 700;
  flex-shrink: 0;
}

.price-faq__q::after {
  content: '';
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--color-text-muted);
  border-bottom: 2px solid var(--color-text-muted);
  transform: rotate(45deg);
  transition: transform var(--transition);
  margin-left: auto;
  flex-shrink: 0;
}

.price-faq__item[open] .price-faq__q::after {
  transform: rotate(-135deg);
}

.price-faq__q::-webkit-details-marker {
  display: none;
}

.price-faq__a {
  padding: 0 1.5rem 1.25rem 4rem;
  font-size: 0.8125rem;
  color: var(--color-text-light);
  line-height: 1.8;
}

/* ⑥ 料金CTA */
.price-cta {
  padding: 5rem 0;
  background: var(--color-bg-blue);
}

.price-cta__card {
  max-width: 600px;
  margin: 0 auto;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 3rem 2.5rem;
  text-align: center;
}

.price-cta__title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.price-cta__desc {
  font-size: 0.875rem;
  color: var(--color-text-light);
  margin-bottom: 2rem;
  line-height: 1.8;
}

.price-cta__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.price-cta__btn {
  padding: 0.875rem 2rem;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.price-cta__btn--primary {
  background: var(--color-accent);
  color: #fff;
}

.price-cta__btn--primary:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(244, 101, 133, 0.3);
}

.price-cta__btn--secondary {
  background: var(--color-bg);
  color: var(--color-primary-dark);
  border: 1px solid var(--color-border);
}

.price-cta__btn--secondary:hover {
  background: var(--color-border);
}

.price-cta__note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.75rem;
}

/* ----------------------------------------
   確認モーダル
---------------------------------------- */
.confirm-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
}

.confirm-modal.is-open {
  display: flex;
  align-items: center;
  justify-content: center;
}

.confirm-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}

.confirm-modal__dialog {
  position: relative;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.15);
  padding: 2.5rem;
  max-width: 600px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
}

.confirm-modal__title {
  font-size: 1.25rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 0.5rem;
}

.confirm-modal__desc {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  text-align: center;
  margin-bottom: 1.5rem;
}

.confirm-modal__table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 2rem;
}

.confirm-modal__table th,
.confirm-modal__table td {
  padding: 0.625rem 0.75rem;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--color-border);
  text-align: left;
  vertical-align: top;
  line-height: 1.7;
}

.confirm-modal__table th {
  width: 120px;
  font-weight: 600;
  white-space: nowrap;
  color: var(--color-text);
}

.confirm-modal__table td {
  color: var(--color-text-light);
  word-break: break-all;
}

.confirm-modal__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
}

.confirm-modal__btn {
  padding: 0.75rem 2rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  font-family: var(--font-main);
}

.confirm-modal__btn--back {
  background: var(--color-bg);
  color: var(--color-text-light);
  border: 1px solid var(--color-border);
}

.confirm-modal__btn--back:hover {
  background: var(--color-border);
}

.confirm-modal__btn--submit {
  background: var(--color-accent);
  color: #fff;
}

.confirm-modal__btn--submit:hover {
  background: var(--color-accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(244, 101, 133, 0.3);
}

/* ----------------------------------------
   サンクスページ
---------------------------------------- */
.thanks-section {
  padding: 5rem 0;
}

.thanks-card {
  max-width: 600px;
  margin: 0 auto;
  background: var(--color-bg-white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 3rem 2.5rem;
  text-align: center;
}

.thanks-card__icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
}

.thanks-card__heading {
  font-size: 1.375rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
}

.thanks-card__body {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  line-height: 1.9;
  margin-bottom: 0.75rem;
}

.thanks-card__note {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-border);
  line-height: 1.8;
}

.thanks-card__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-top: 2rem;
}

.thanks-card__btn {
  padding: 0.75rem 2rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--transition);
}

.thanks-card__btn--primary,
.thanks-card__btn:first-child {
  background: var(--color-primary);
  color: #fff;
}

.thanks-card__btn--primary:hover,
.thanks-card__btn:first-child:hover {
  background: var(--color-primary-dark);
  transform: translateY(-2px);
}

.thanks-card__btn--secondary,
.thanks-card__btn:last-child {
  background: var(--color-bg);
  color: var(--color-text-light);
  border: 1px solid var(--color-border);
}

.thanks-card__btn--secondary:hover,
.thanks-card__btn:last-child:hover {
  background: var(--color-border);
}

.thanks-card__tel {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
}

.thanks-card__tel-label {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.5rem;
}

.thanks-card__tel-number {
  font-family: var(--font-en);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  text-decoration: none;
}

.thanks-card__tel-note {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.25rem;
}



/* =============================================================
   404 Not Found
============================================================= */
.not-found {
    background: #fff;
}

.not-found {
  padding: 3rem 0 5rem;
  text-align: center;
  min-height: 60vh;
  display: flex;
  align-items: center;
}

.not-found .container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.not-found__illust {
  width: 220px;
  height: 220px;
  margin-bottom: 2rem;
}

.not-found__illust-bg {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary-pale) 0%, var(--color-bg-blue) 50%, rgba(244,101,133,0.06) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.illust-person {
  position: relative;
  width: 80px;
  height: 140px;
}

.illust-person__head {
  width: 44px;
  height: 44px;
  background: #F5D5C8;
  border-radius: 50%;
  margin: 0 auto;
  position: relative;
}

.illust-person__head::after {
  content: '';
  position: absolute;
  top: -6px;
  left: 4px;
  width: 36px;
  height: 28px;
  background: #6B4C3B;
  border-radius: 50% 50% 0 0;
}

.illust-person__body {
  width: 50px;
  height: 56px;
  background: var(--color-primary-light);
  border-radius: 20px 20px 16px 16px;
  margin: 4px auto 0;
}

.illust-person__legs {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 2px;
}

.illust-person__leg {
  width: 14px;
  height: 28px;
  background: #5A8AAE;
  border-radius: 0 0 8px 8px;
}

.illust-question {
  position: absolute;
  top: 30px;
  right: 28px;
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 2.5rem;
  color: var(--color-primary);
  opacity: 0.6;
  animation: illust-float 3s ease-in-out infinite;
}

.illust-question-sm {
  position: absolute;
  top: 55px;
  right: 16px;
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--color-accent);
  opacity: 0.4;
  animation: illust-float 3s ease-in-out infinite 0.5s;
}

.illust-dot {
  position: absolute;
  border-radius: 50%;
  background: var(--color-primary-light);
  opacity: 0.5;
}

.illust-dot--1 {
    width: 8px;
    height: 8px;
    top: 20px;
    left: 30px;
}

.illust-dot--2 {
    width: 6px;
    height: 6px;
    bottom: 40px;
    left: 20px;
    background: var(--color-accent);
    opacity: 0.3;
}

.illust-dot--3 {
    width: 10px;
    height: 10px;
    bottom: 30px;
    right: 25px;
}

@keyframes illust-float {
  0%, 100% {
    transform: translateY(0);
}

  50% {
    transform: translateY(-8px);
  }
}

.not-found__code {
  font-size: 4.5rem;
  font-weight: 700;
  color: var(--color-primary-light);
  letter-spacing: 0.1em;
  line-height: 1;
  margin-bottom: 1rem;
}

.not-found__title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  line-height: 1.5;
}

.not-found__desc {
  font-size: 0.9375rem;
  color: var(--color-text-light);
  margin-bottom: 2.5rem;
  line-height: 1.9;
}

.not-found__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  max-width: 640px;
  margin-bottom: 2.5rem;
}

.not-found__nav-card {
  background: var(--color-bg-white);
  border-radius: var(--radius);
  padding: 1.75rem 1.25rem;
  text-decoration: none;
  color: var(--color-text);
  box-shadow: var(--shadow);
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.not-found__nav-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(131, 184, 221, 0.18);
}

.not-found__nav-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.375rem;
}

.not-found__nav-icon--home {
    background: var(--color-primary-pale);
}

.not-found__nav-icon--concern {
    background: var(--color-accent-light);
}

.not-found__nav-icon--column {
    background: #FFF8E7;
}

.not-found__nav-label {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.4;
}

.not-found__nav-sub {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.not-found__back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-primary-dark);
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition);
}

.not-found__back:hover {
  color: var(--color-primary);
}

.not-found__back-arrow {
  transition: transform var(--transition);
}

.not-found__back:hover .not-found__back-arrow {
  transform: translateX(-3px);
}

/* ----------------------------------------
   Responsive - SP (max-width: 900px)
---------------------------------------- */
@media (max-width: 900px) {
    .pc {
    display: none;
}

    .sp {
    display: block;
    }
    
    
    
  /* Header */
  .header-nav {
    display: none;
  }
  .hamburger {
    display: block;
  }
  .mobile-nav {
    display: block;
  }
  .sp-fixed-footer {
    display: block;
  }

  /* Hero */
  .hero {
    min-height: auto;
  }
  .hero__bg {
    background-image: url('../img/hero-sp.jpg');
  }
  .hero__content {
    padding: 6.25rem var(--container-padding-sp) 3.75rem;
  }
  .hero__text {
    max-width: 100%;
  }
  .hero__title {
    font-size: 1.75rem;
  }
  .hero__description {
    font-size: 0.875rem;
  }
  .hero__features {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .hero__feature {
    font-size: 0.75rem;
    padding: 0.375rem 0.75rem;
  }

  /* Recommend */
  .recommend__cards {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .recommend__card {
    padding: 1.5rem 1.25rem;
  }

  /* Features */
  .features__grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  /* Stats */
  .stats__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .stats__item {
    border-bottom: 1px solid var(--color-border);
    padding: 28px 12px;
  }
  .stats__item:nth-child(2n) {
    border-right: none;
  }
  .stats__item:nth-child(n+3) {
    border-bottom: none;
  }
  .stats__value {
    font-size: 2rem;
  }

  /* Concerns */
  .concerns__tabs {
    gap: 0.5rem;
  }
  .concerns__tab {
    padding: 0.625rem 1.125rem;
    font-size: 0.8125rem;
  }
  .concerns__content {
    padding: 1.5rem 1.25rem;
  }
  .concerns__panel .concern-item {
    padding: 1.5rem;
  }
  .concerns__cards {
    grid-template-columns: 1fr;
  }
  .concerns__card-thumb {
    width: 3.5rem;
    height: 3.5rem;
  }
  .concern-item {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 2rem 0;
  }
  .concern-item:nth-child(even) {
    direction: ltr;
  }
  .concern-item__image {
    aspect-ratio: 16/10;
  }
  .concern-item__title {
    font-size: 1.25rem;
  }
  .concern-checklist li {
    font-size: 0.875rem;
    padding: 0.625rem 0;
  }
  .concern-bottom-cta {
    padding: 2.5rem 1.5rem;
  }
  .concern-bottom-cta__title {
    font-size: 1.125rem;
  }

  /* First Step */
  .first-step__cards {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  /* Plans */
  .plans__cards {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    max-width: 400px;
  }
  .plans__card {
    padding: 2rem 1.5rem;
  }
  .plans__price-value {
    font-size: 2.25rem;
  }

  /* Flow */
  .flow__cards {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .flow__card {
    display: grid;
    grid-template-columns: 7.5rem 1fr;
  }
  .flow__photo {
    aspect-ratio: 1;
  }
  .flow__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  /* Trainer */
  .trainer__card {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 2rem 1.5rem;
    gap: 2rem;
  }
  .trainer__photo {
    max-width: 200px;
    margin: 0 auto;
    aspect-ratio: 1;
  }
  .trainer__qual {
    justify-content: center;
  }
  .trainer__members {
    gap: 1.5rem;
  }
  .trainer__member {
    width: 6rem;
  }
  .trainer__avatar {
    width: 4rem;
    height: 4rem;
    font-size: 1rem;
  }
  .trainer__trust {
    padding: 1.25rem;
  }

  /* Column */
  .column__cards {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .column__card {
    display: grid;
    grid-template-columns: 7.5rem 1fr;
  }
  .column__thumbnail {
    aspect-ratio: 1;
  }
  .column__body {
    padding: 0.875rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  /* FAQ */
  .faq__list {
    grid-template-columns: 1fr;
    gap: 0.625rem;
  }
  .faq__item summary .faq__cat {
    display: none;
  }

  /* Access */
  .access__content {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .access__map {
    height: 220px;
    min-height: auto;
  }

  /* Footer */
  .footer__top {
    flex-direction: column;
    gap: 2rem;
  }
  .footer__nav {
    flex-wrap: wrap;
    gap: 1.5rem;
  }
  .footer {
    padding-bottom: 5rem;
  }

  /* Page Hero */
  .page-hero {
    padding: 2.5rem 1.25rem;
  }
  .page-hero__title {
    font-size: 1.375rem;
  }

  /* News Archive */
  .news-item {
    flex-direction: column;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
  }
  .news-item__meta {
    gap: 0.625rem;
  }

  /* News Single */
  .news-single__body {
    padding: 2rem 1.25rem;
  }
  .news-single__title {
    font-size: 1.25rem;
  }
  .news-nav {
    flex-direction: column;
    gap: 0.75rem;
  }

  /* Column Archive */
  .column-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .column-card {
    display: grid;
    grid-template-columns: 7.5rem 1fr;
  }
  .column-card__thumb {
    aspect-ratio: 1;
  }
  .column-card__cat-badge {
    display: none;
  }
  .column-card__body {
    padding: 0.875rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .column-card__title {
    font-size: 0.875rem;
  }
  .column-card__excerpt {
    display: none;
  }

  /* Column Single */
  .column-single__layout {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .column-single__title {
    font-size: 1.25rem;
  }
  .column-sidebar {
    position: static;
  }
  .column-nav {
    flex-direction: column;
    gap: 0.75rem;
  }
  .toc__toggle {
    padding: 0.875rem 1.25rem;
  }
  .toc__list {
    padding: 0 1.25rem 1rem;
  }
  .toc__link {
    font-size: 0.8125rem;
    padding: 0.35rem 0.5rem;
  }
  .toc__item--h3 > .toc__link {
    font-size: 0.75rem;
  }

  /* FAQ Archive */
  .faq-item summary {
    padding: 1rem 1.25rem;
    font-size: 0.875rem;
  }
  .faq-answer {
    padding-left: 2.75rem;
    margin: 0 0.5rem;
  }
  .faq-category-heading {
    margin-top: 2rem;
  }

  /* 固定ページ */
  .page-body {
    padding: 2rem 1.25rem;
  }
  .page-body h2 {
    font-size: 1.125rem;
  }
  .page-body th {
    width: auto;
    display: block;
    border-bottom: none;
  }
  .page-body td {
    display: block;
  }

  /* ご利用の流れ */
  .flow-page {
    padding: 3rem 0 4rem;
  }
  .flow-steps::before {
    left: 20px;
  }
  .flow-step {
    grid-template-columns: 40px 1fr;
    gap: 1rem;
    margin-bottom: 2rem;
  }
  .flow-step__number {
    width: 40px;
    height: 40px;
  }
  .flow-step__number-label {
    font-size: 0.4375rem;
  }
  .flow-step__number-num {
    font-size: 1rem;
  }
  .flow-step__body {
    padding: 1.25rem;
  }
  .flow-step__title {
    font-size: 1rem;
  }
  .flow-bottom-cta {
    padding: 2rem 1.25rem;
    margin-top: 3rem;
  }
  .flow-bottom-cta__title {
    font-size: 1.125rem;
  }
  .flow-bottom-cta__price-new {
    font-size: 1.5rem;
  }

  /* COCOTOREとは */
  .about-section {
    padding: 3.5rem 0;
  }
  .section-heading {
    font-size: 1.25rem;
  }

  /* ①不調 2×2 */
  .stress-intro__visual {
    padding: 1.5rem 1rem;
  }
  .stress-cycle {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: auto auto;
    gap: 0.75rem 0.5rem;
    align-items: center;
  }
  .stress-cycle__icon {
    width: 44px;
    height: 44px;
    font-size: 1.25rem;
  }
  .stress-cycle__icon img {
    width: 24px;
    height: 24px;
  }
  .stress-cycle__label {
    font-size: 0.6875rem;
  }
  .stress-cycle__sub {
    font-size: 0.5625rem;
  }
  .stress-cycle__arrow {
    font-size: 0.875rem;
  }
  .stress-intro__note {
    font-size: 0.8125rem;
  }

  /* ②アプローチ横並びカード */
  .approach-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .approach-card {
    display: grid;
    grid-template-columns: 100px 1fr;
  }
  .approach-card__img {
    aspect-ratio: 1;
    font-size: 2rem;
  }
  .approach-card__num {
    width: 22px;
    height: 22px;
    font-size: 0.625rem;
    top: 0.5rem;
    left: 0.5rem;
  }
  .approach-card__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .approach-card__title {
    font-size: 0.9375rem;
  }
  .approach-card__desc {
    font-size: 0.75rem;
  }

  /* ③〜⑤ 縦積み */
  .feature-row {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .feature-row--reverse .feature-row__img {
    order: 0;
  }
  .feature-row--reverse .feature-row__body {
    order: 0;
  }
  .feature-row__img {
    aspect-ratio: 16 / 9;
  }
  .feature-row__title {
    font-size: 1.0625rem;
  }
  .feature-row__desc {
    font-size: 0.8125rem;
  }
  .feature-row__point {
    font-size: 0.75rem;
    padding: 0.875rem 1rem;
  }

  /* ⑥比較テーブル */
  .compare-table-wrap {
    margin: 0 -1rem;
    padding: 0.75rem 1rem 0;
  }
  .compare-table {
    min-width: 480px;
    font-size: 0.75rem;
  }
  .compare-table th,
  .compare-table td {
    padding: 0.75rem;
  }
  .compare-table thead th {
    font-size: 0.6875rem;
  }
  .compare-table tbody th {
    font-size: 0.6875rem;
  }
  .compare-table tbody td {
    font-size: 0.6875rem;
  }

  /* ⑦CTA */
  .about-bottom-cta {
    padding: 3.5rem 0;
  }
  .about-cta-card {
    padding: 2rem 1.25rem;
  }
  .about-cta-card__title {
    font-size: 1.125rem;
  }
  .about-cta-card__price-new {
    font-size: 1.5rem;
  }
    
    
    
    
    
    
    
    
    /*---------------------------　カウンセリング New　---------------------------*/
    #counseling section {padding: 0 0 3em;}
    
    
    
    
    #counseling h2 {font-size: 1.5em!important;}
    #counseling h2 span {font-size: 0.7em;}
    #counseling h2 img {width: 100%;}
    
    
    
    #counseling .mv-box {
        margin: 0 auto;
    }
    
    #counseling .problems-box {
        max-width: 100%;
        padding: 3em 1.5em;
    }
    #counseling .problems-list {
        display: block;
        margin: 0 auto 5em;
        padding: 2em 1.5em;
    }
    
    #counseling .problems-txt h2 img {width: 100%;}
    
    
    #counseling .problems-list-txt h2 {margin: 0 auto 1.5em;}
    #counseling .problems-list ul {margin: 0 auto 1em;}
    #counseling .problems-list ul li {
        padding-left: 2.1em;
        padding-bottom: 0.3em;
        margin: 0 auto 0.5em;
    }
    #counseling .problems-list-img img {width: 100%;}
    #counseling .problems-txt h3 {font-size: 1.5em!important;}
    #counseling .problems-txt h3 img {width: 100%;}
    #counseling .problems-txt img {width: 100%;}
    
    #counseling .message {
        display: block;
        padding: 0 1.5em;
    }
    #counseling .message-img {
        padding-right: 0;
        margin: 0 auto 1em;
    }
    
    
    #counseling .point {
        max-width: 100%;
        padding: 0 1.5em;
    }
    #counseling .point-img img {width: 80%;}
    
    
    #counseling .point-box {
        display: block;
    }
    #counseling .point-item {
        width: 100%;
        padding: 2em;
        margin: 0 auto 1em;
        box-shadow: 0px 5px 24px rgba(0, 0, 0, 0.08);
    }
    
    #counseling .point-item img {width: 45%;}
    
    
    #counseling .step {padding: 2em 1.5em;}
    #counseling .step-box {
        max-width: 100%;
        padding: 3em 1.35em 2em 1em;
    }
    #counseling .step-box .flow {
        margin-left: 0;
    }
    #counseling .step-box .flow::before {left: 95px;}
    
    #counseling .step-box .flow li .icon {
        font-size: 12px;
        padding: 8px 10px;
    }
    
    
    #counseling .step-box .flow li dl {
        display: block;
        padding-left: 0;
    }
    #counseling .step-box .flow li dl::before {left: -38px;}
    #counseling .step-box .flow li dl::after {left: -18px;}
    
    #counseling .step-box .flow li dl dd {
        margin-left: 0;
    }
    #counseling .step-box .flow li dl dt h3 {margin: 0 auto 0.5em;}
    #counseling .step-box .flow li dl dt img {width: 50%;}
    
    #counseling .condition {padding: 0 1.5em;}
    #counseling .condition-check-box {
        display: block;
    }
    #counseling .condition-method {
        border-left: none;
    }
    
    #counseling .condition-check,
    #counseling .condition-method {
        padding: 0;
    }
    #counseling .condition-method .method01 {margin: 0 auto 1em;}
    #counseling .condition-method .method02-1,
    #counseling .condition-method .method02-2,
    #counseling .condition-method .method02-3 {margin: 0 auto;}
    
    
    
    
    
    
    
    #counseling .how {
        display: block;
        padding: 0 1.5em;
        margin: 0 auto;
    }
    #counseling .how-box {
        width: 100%;
        margin: 0 auto 2em;
    }
    #counseling .how-txt {padding: 1em 1.5em 1.5em;}
    
    
    #counseling .select-box {padding: 0 1.5em;}
    #counseling .select-txt {
        display: block;
    }
    #counseling .select-txt h3 {line-height: 1.6!important;}
    #counseling .select-txt-r img {width: 100%;}
    
    #counseling .hearing {
        display: block;
        padding: 2em 1.5em;
    }
    #counseling .hearing-box01,
    #counseling .hearing-box02 {padding: 1em 0;}
    #counseling .hearing-box01 {border-radius: 8px 8px 0 0;}
    #counseling .hearing-box02 {border-radius: 0 0 8px 8px;}
    
    
    #counseling .effect-box {
        display: block;
        padding: 0 1.5em;
        margin: 0 auto;
    }
    #counseling .effect-list {
        width: 100%;
        margin: 0 auto 2em;
        box-shadow: 0px 5px 24px rgba(0, 0, 0, 0.08);
    }
    #counseling .effect-item-txt h3 {font-size: 1.5em;}
    
    
    #counseling .price {
        padding: 3em 1.5em;
        border-radius: 0;
        margin: 0 auto;
    }
    #counseling .price-box {
        padding: 1.5em 1.5em 5em;
    }
    #counseling .price-list {display: block;}
    #counseling .cause-price {
        text-align: center;
        padding: 1em 0;
        border-radius: 0 0 8px 8px;
    }
    
    #counseling .flow {
        padding: 0 1.5em;
        margin: 0 auto;
    }
    
    #counseling .flow-real .flow-box,
    #counseling .flow-online .flow-box {
        display: block;
        margin-left: 0;
    }
    #counseling .flow-real .flow-box li:not(:last-child) dl::before,
    #counseling .flow-online .flow-box li:not(:last-child) dl::before {
        display: none;
    }
    
    #counseling .flow-real .flow-box li,
    #counseling .flow-online .flow-box li {
        margin: 0 auto 1em;
    }
    
    #counseling .consult {
        padding: 2em 1.5em;
    }
    #counseling .consult-item {
        width: 100%;
        padding: 1em 2.5em 2em;
        margin: 0 auto 0.5em;
    }
    #counseling .consult-item h3 {
        font-size: 1.5em;
        margin: 0 auto 0.5em;
    }
    #counseling .consult-item .icon img {
        width: 32%;
    }
    
    #counseling section h2 {margin: 0 auto 0.5em;}
    
    #counseling .sec04 h2 {margin: 0 auto 0.5em;}
    #counseling .sec04 {padding: 2em 0 1em;}
    
    
    #counseling .counseling-voice {
        padding: 2em 0 0;
    }
    #counseling .counseling-voice h2 {margin: 0 auto 0.5em;}
    
    
    #counseling .counseling-voice-list {
        margin: 0 1.5em 1em;
        padding: 1em 1.5em 1.8em;
    }
    
    
    
    #counseling .voice-icon {width: 40%;}
    #counseling .voice-prof {width: 60%;}
    #counseling .voice-note {
        width: 100%;
        padding-left: 0;
        margin: 1em 0 0;
    }
    
    #counseling .counseling-faq {
        margin: 2em 1.5em 0;
    }
    #counseling .counseling-faq h2 {margin: 0 auto 0.5em;}
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    

  /* スタッフ募集 */
  .recruit-message {
    padding: 3.5rem 0;
  }
  .recruit-message__heading {
    font-size: 1.125rem;
  }
  .recruit-message__body {
    font-size: 0.8125rem;
  }
  .recruit-positions {
    padding: 0 0 3.5rem;
  }
  .recruit-positions__nav {
    grid-template-columns: 1fr;
    gap: 0.75rem;
    margin-bottom: 2.5rem;
  }
  .recruit-nav-card {
    padding: 1rem;
    gap: 1rem;
  }
  .recruit-nav-card__img {
    width: 64px;
    height: 64px;
    font-size: 1.75rem;
  }
  .recruit-nav-card__badge {
    font-size: 0.5625rem;
  }
  .recruit-nav-card__title {
    font-size: 0.9375rem;
  }
  .recruit-entry-hint__btn {
    font-size: 0.75rem;
    padding: 0.4375rem 1rem;
  }
  .recruit-detail {
    padding: 2.5rem 0;
  }
  .recruit-detail__header {
    gap: 0.75rem;
    margin-bottom: 1.25rem;
  }
  .recruit-detail__icon {
    width: 40px;
    height: 40px;
  }
  .recruit-detail__icon svg {
    width: 20px;
    height: 20px;
  }
  .recruit-detail__badge {
    font-size: 0.5625rem;
  }
  .recruit-detail__title {
    font-size: 1.0625rem;
  }
  .recruit-detail__desc {
    font-size: 0.8125rem;
    margin-bottom: 1.5rem;
  }
  .recruit-table tr {
    display: flex;
    flex-direction: column;
  }
  .recruit-table th {
    width: 100%;
    display: block;
    padding: 0.75rem 1rem 0.25rem;
    white-space: normal;
  }
  .recruit-table td {
    display: block;
    padding: 0.5rem 1rem 0.75rem;
    font-size: 0.8125rem;
  }
  .recruit-detail__entry-btn {
    padding: 0.75rem 2rem;
    font-size: 0.8125rem;
  }
  .recruit-entry {
    padding: 3.5rem 0;
  }
  .recruit-entry__heading {
    font-size: 1.125rem;
  }
  .recruit-entry__desc {
    font-size: 0.75rem;
  }
  .recruit-form {
    padding: 1.5rem 1.25rem;
  }
  .recruit-form .form-row {
    grid-template-columns: 1fr;
  }
  .recruit-form .form-label {
    font-size: 0.8125rem;
  }
  .recruit-form input[type="text"],
  .recruit-form input[type="email"],
  .recruit-form input[type="tel"],
  .recruit-form input[type="number"],
  .recruit-form select,
  .recruit-form textarea {
    font-size: 0.8125rem;
    padding: 0.625rem 0.875rem;
  }
  .recruit-form .form-radio-group {
    gap: 1rem;
  }
  .recruit-form .form-radio-group label {
    font-size: 0.8125rem;
  }
  .recruit-form .form-agreement {
    font-size: 0.75rem;
    padding: 0.875rem 1rem;
    align-items: flex-start;
  }
  .recruit-form .form-agreement input[type="checkbox"] {
    margin-top: 0.125rem;
  }
  .recruit-form input[type="submit"] {
    padding: 0.875rem 2rem;
    font-size: 0.875rem;
  }
  .recruit-contact {
    padding: 3rem 0;
  }
  .recruit-contact__heading {
    font-size: 1rem;
  }
  .recruit-contact__tel {
    font-size: 1.375rem;
  }

  /* 料金一覧 */
  .price-trial {
    padding: 3.5rem 0;
  }
  .price-section-title {
    font-size: 1.125rem;
  }
  .price-section-desc {
    font-size: 0.75rem;
    margin-bottom: 1.75rem;
  }
  .price-section-label {
    font-size: 0.75rem;
  }
  .price-card {
    padding: 1.75rem 1.25rem;
  }
  .price-card__name {
    font-size: 1.0625rem;
  }
  .price-card__plan-desc {
    font-size: 0.75rem;
  }
  .price-card__price-area {
    padding: 1.25rem 1rem;
  }
  .price-card__price-num {
    font-size: 2rem;
  }
  .price-card__includes {
    padding: 1.25rem 1rem;
  }
  .price-card__includes-grid {
    gap: 0.75rem;
  }
  .price-card__includes-grid--3col {
    grid-template-columns: repeat(3, 1fr);
  }
  .price-card__includes-icon {
    width: 40px;
    height: 40px;
    font-size: 1.25rem;
  }
  .price-card__includes-item {
    font-size: 0.75rem;
  }
  .price-card__cta-btn {
    padding: 0.75rem 2rem;
    font-size: 0.8125rem;
  }
  .price-plans {
    padding: 3.5rem 0;
  }
  .price-plans__grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .price-counseling {
    padding: 3.5rem 0;
  }
  .price-payment {
    padding: 3.5rem 0;
  }
  .price-payment__table th,
  .price-payment__table td {
    padding: 0.625rem 0.75rem;
    font-size: 0.75rem;
  }
  .price-payment__brands img {
    max-width: 240px;
  }
  .price-faq {
    padding: 3rem 0;
  }
  .price-faq__q {
    font-size: 0.8125rem;
    padding: 0.875rem 1rem;
  }
  .price-faq__a {
    font-size: 0.75rem;
    padding: 0 1rem 1rem 3.25rem;
  }
  .price-cta {
    padding: 3.5rem 0;
  }
  .price-cta__card {
    padding: 2rem 1.25rem;
  }
  .price-cta__title {
    font-size: 1.0625rem;
  }
  .price-cta__desc {
    font-size: 0.75rem;
  }
  .price-cta__actions {
    flex-direction: column;
    gap: 0.75rem;
  }
  .price-cta__btn {
    width: 100%;
    text-align: center;
  }

  /* 確認モーダル */
  .confirm-modal__dialog {
    padding: 1.5rem 1.25rem;
  }
  .confirm-modal__title {
    font-size: 1.0625rem;
  }
  .confirm-modal__table th {
    width: 90px;
    font-size: 0.75rem;
  }
  .confirm-modal__table td {
    font-size: 0.75rem;
  }
  .confirm-modal__actions {
    flex-direction: column-reverse;
    gap: 0.75rem;
  }
  .confirm-modal__btn {
    width: 100%;
    text-align: center;
  }

  /* サンクスページ */
  .thanks-section {
    padding: 3.5rem 0;
  }
  .thanks-card {
    padding: 2rem 1.25rem;
  }
  .thanks-card__heading {
    font-size: 1.125rem;
  }
  .thanks-card__body {
    font-size: 0.8125rem;
  }
  .thanks-card__actions {
    flex-direction: column;
    gap: 0.75rem;
  }
  .thanks-card__btn {
    width: 100%;
    text-align: center;
  }

  /* 404 */
  .not-found__illust {
    width: 180px;
    height: 180px;
  }
  .not-found__illust-bg {
    width: 180px;
    height: 180px;
  }
  .illust-person {
    width: 64px;
    height: 112px;
  }
  .illust-person__head {
    width: 36px;
    height: 36px;
  }
  .illust-person__head::after {
    width: 28px;
    height: 22px;
    top: -4px;
    left: 4px;
  }
  .illust-person__body {
    width: 42px;
    height: 44px;
  }
  .illust-person__leg {
    width: 12px;
    height: 22px;
  }
  .illust-question {
    font-size: 2rem;
    top: 24px;
    right: 20px;
  }
  .illust-question-sm {
    font-size: 1rem;
    top: 46px;
    right: 10px;
  }
  .not-found__code {
    font-size: 3.5rem;
  }
  .not-found__title {
    font-size: 1.25rem;
  }
  .not-found__nav {
    grid-template-columns: 1fr;
    max-width: 320px;
  }
  .not-found__nav-card {
    flex-direction: row;
    padding: 1.25rem;
    text-align: left;
  }
  .not-found__nav-icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
  }
}

/* ========================================
   悩みタグ個別ページ（taxonomy-concern_tag）
======================================== */

/* Hero */
.ct-hero {
  padding: 3rem 0 2.5rem;
  text-align: center;
  background: linear-gradient(180deg, var(--color-primary-pale) 0%, var(--color-bg) 100%);
}

.ct-hero__inner {
  max-width: 600px;
  margin: 0 auto;
}

.ct-hero__icon {
  width: 64px;
  height: 64px;
  background: var(--color-bg-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  font-size: 1.75rem;
  box-shadow: 0 2px 12px rgba(131,184,221,0.15);
  overflow: hidden;
}

.ct-hero__icon--img {
  width: 72px;
  height: 72px;
}

.ct-hero__icon--img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ct-hero__title {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 0.75rem;
}

.ct-hero__title span {
  color: var(--color-primary-dark);
}

.ct-hero__lead {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.8;
}

/* Section */
.ct-main-image {
  padding: 0 0 0.5rem;
}

.ct-main-image img {
  width: 100%;
  border-radius: 0.75rem;
  display: block;
}

.ct-section {
  padding: 2rem 0;
}

.ct-section--alt {
  background: var(--color-primary-pale);
}

.ct-section__heading {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 1rem;
  padding-left: 0.75rem;
  border-left: 3px solid var(--color-primary);
}

/* Checklist */
.ct-checklist {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ct-checklist li {
  font-size: 0.875rem;
  padding: 0.75rem 1rem;
  background: var(--color-primary-pale);
  border-radius: 0.5rem;
  line-height: 1.6;
}

.ct-checklist li::before {
  content: '✓ ';
  color: var(--color-primary-dark);
  font-weight: 600;
}

.ct-section--alt .ct-checklist li {
  background: var(--color-bg-white);
}

/* Approach */
.ct-approach {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  margin-bottom: 0.75rem;
}

.ct-section--alt .ct-approach {
  border-color: transparent;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}

.ct-approach__num {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 0.25rem;
}

.ct-approach__title {
  font-size: 0.9375rem;
  font-weight: 600;
  margin-bottom: 0.375rem;
}

.ct-approach__desc {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* Voice */
.ct-voice {
  background: var(--color-primary-pale);
  border-radius: 0.75rem;
  padding: 1.25rem;
  position: relative;
  margin-bottom: 0.75rem;
}

.ct-voice:last-child {
  margin-bottom: 0;
}

.ct-voice::before {
  content: '\201C';
  font-size: 2rem;
  color: var(--color-primary);
  opacity: 0.25;
  position: absolute;
  top: 0.5rem;
  left: 0.75rem;
  font-family: Georgia, serif;
  line-height: 1;
}

.ct-voice__text {
  font-size: 0.8125rem;
  line-height: 1.8;
  padding-left: 0.5rem;
}

.ct-voice__attr {
  display: block;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 0.5rem;
  padding-left: 0.5rem;
}

/* CTA */
.ct-cta {
  padding: 2rem 0;
}

.ct-cta__inner {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-radius: 0.75rem;
  padding: 2rem 1.5rem;
  text-align: center;
  color: #fff;
}

.ct-cta__title {
  font-size: 1.0625rem;
  font-weight: 600;
  margin-bottom: 0.375rem;
  line-height: 1.6;
}

.ct-cta__sub {
  font-size: 0.75rem;
  opacity: 0.8;
  margin-bottom: 1rem;
}

.ct-cta__btn {
  display: inline-block;
  background: #fff;
  color: var(--color-primary-dark);
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.75rem 2rem;
  border-radius: 0.5rem;
  text-decoration: none;
  transition: transform var(--transition), box-shadow var(--transition);
}

.ct-cta__btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* Related tags */
.ct-related {
  padding: 1.5rem 0 2rem;
  border-top: 1px solid var(--color-border);
}

.ct-related__heading {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.5rem;
  font-weight: 500;
}

.ct-related__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
}

.ct-related__tag {
  font-size: 0.75rem;
  padding: 0.25rem 0.75rem;
  background: var(--color-primary-pale);
  color: var(--color-primary-dark);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background var(--transition);
}

.ct-related__tag:hover {
  background: var(--color-primary-light);
}

/* archive concern-keyword as link */
a.concern-keyword {
  text-decoration: none;
  cursor: pointer;
}
