body {
  background-color: #ffffff;
  -webkit-font-smoothing: antialiased;
}

.page-container {
  max-width: 62.5rem;
  margin: 0 auto;
  padding: 0 clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .page-container {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}

.svc-section-header {
  text-align: center;
  margin-bottom: clamp(48px, 5.5555555556vw, 80px);
}
@media screen and (max-width: 768px) {
  .svc-section-header {
    margin-bottom: clamp(32px, 10.2325581395vw, 79px);
  }
}

.svc-section-title {
  font-family: "Noto Serif JP", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(22px, 2.2222222222vw, 32px);
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: clamp(12px, 1.1111111111vw, 16px);
}
@media screen and (max-width: 768px) {
  .svc-section-title {
    font-size: clamp(18px, 5.1162790698vw, 39px);
    line-height: 1.6;
    margin-bottom: clamp(10px, 3.2558139535vw, 25px);
  }
}

.svc-section-subtitle {
  display: block;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  font-family: "Garamond", "Times New Roman", Georgia, serif;
  font-style: italic;
  color: #888888;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: clamp(10px, 0.8333333333vw, 12px);
}
@media screen and (max-width: 768px) {
  .svc-section-subtitle {
    font-size: clamp(11px, 3.2558139535vw, 25px);
    margin-bottom: clamp(8px, 2.7906976744vw, 21px);
  }
}

.faq-list {
  max-width: 50rem;
  margin: 0 auto;
}

.faq-item {
  background: #ffffff;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
  padding: clamp(20px, 2.0833333333vw, 30px);
  border: 1px solid #eeeeee;
}
@media screen and (max-width: 768px) {
  .faq-item {
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
    padding: clamp(21px, 6.976744186vw, 54px);
  }
}
.faq-item__question {
  font-weight: 700;
  margin-bottom: clamp(12px, 1.1111111111vw, 16px);
  display: flex;
  align-items: flex-start;
  color: #333333;
}
@media screen and (max-width: 768px) {
  .faq-item__question {
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.faq-item__question::before {
  content: "Q.";
  color: #888888;
  margin-right: clamp(8px, 0.6944444444vw, 10px);
  font-family: "Garamond", Georgia, serif;
  font-style: italic;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .faq-item__question::before {
    margin-right: clamp(7px, 2.3255813953vw, 18px);
  }
}
.faq-item__answer {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #555555;
  display: flex;
  align-items: flex-start;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .faq-item__answer {
    font-size: clamp(11px, 3.488372093vw, 27px);
  }
}
.faq-item__answer::before {
  content: "A.";
  color: #333333;
  margin-right: clamp(8px, 0.6944444444vw, 10px);
  font-family: "Garamond", Georgia, serif;
  font-style: italic;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .faq-item__answer::before {
    margin-right: clamp(7px, 2.3255813953vw, 18px);
  }
}

.service-contact__message {
  margin-bottom: clamp(28px, 2.7777777778vw, 40px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 1.8;
  color: #dddddd;
}
@media screen and (max-width: 768px) {
  .service-contact__message {
    margin-bottom: clamp(28px, 9.3023255814vw, 71px);
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}
.service-contact__btn {
  display: inline-block;
  padding: clamp(14px, 1.25vw, 18px) clamp(48px, 5.5555555556vw, 80px);
  border: 1px solid #ffffff;
  color: #ffffff;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease;
}
@media screen and (max-width: 768px) {
  .service-contact__btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: clamp(14px, 4.1860465116vw, 32px) clamp(20px, 6.511627907vw, 50px);
    font-size: clamp(13px, 3.488372093vw, 27px);
    letter-spacing: 0.05em;
  }
}
.service-contact__btn:hover {
  background-color: #ffffff;
  color: #333333;
}

.cpt-hero {
  position: relative;
  background-color: #000000;
  color: #ffffff;
  display: flex;
  align-items: center;
  min-height: 60vh;
  padding-top: clamp(100px, 9.7222222222vw, 140px);
  padding-bottom: clamp(80px, 8.3333333333vw, 120px);
  overflow: hidden;
}
.cpt-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(255, 255, 255, 0.03) 0%, transparent 60%);
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .cpt-hero {
    padding-top: clamp(96px, 27.9069767442vw, 214px);
    padding-bottom: clamp(64px, 18.6046511628vw, 143px);
    min-height: 50vh;
    min-height: 50svh;
  }
}
.cpt-hero__inner {
  max-width: 72rem;
  margin: 0 auto;
  padding: 0 clamp(24px, 3.3333333333vw, 48px);
  width: 100%;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .cpt-hero__inner {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}
.cpt-hero__eyebrow {
  display: block;
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 700;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: clamp(20px, 1.9444444444vw, 28px);
}
@media screen and (max-width: 768px) {
  .cpt-hero__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.cpt-hero__title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(32px, 3.8888888889vw, 56px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.02em;
  margin-bottom: clamp(24px, 2.2222222222vw, 32px);
}
@media screen and (max-width: 768px) {
  .cpt-hero__title {
    font-size: clamp(20px, 6.0465116279vw, 46px);
    line-height: 1.55;
    margin-bottom: clamp(18px, 5.5813953488vw, 43px);
  }
}
.cpt-hero__lead {
  font-size: clamp(12px, 1.0416666667vw, 15px);
  color: #9ca3af;
  line-height: 1.9;
  max-width: 38rem;
}
@media screen and (max-width: 768px) {
  .cpt-hero__lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    line-height: 1.8;
  }
}

.cpt-purpose {
  background-color: #ffffff;
}

.cpt-pm-item {
  max-width: 50rem;
  margin: 0 auto;
}
.cpt-pm-item + .cpt-pm-item {
  margin-top: clamp(40px, 4.4444444444vw, 64px);
}
@media screen and (max-width: 768px) {
  .cpt-pm-item + .cpt-pm-item {
    margin-top: clamp(32px, 11.1627906977vw, 86px);
  }
}
.cpt-pm-item .svc-section-header {
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cpt-pm-item .svc-section-header {
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
}
.cpt-pm-item__body {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #666666;
  line-height: 1.9;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .cpt-pm-item__body {
    font-size: clamp(12px, 3.488372093vw, 27px);
    text-align: justify;
  }
}

.cpt-core {
  background-color: #f9f9f9;
}
.cpt-core__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 1.9444444444vw, 28px);
}
@media screen and (max-width: 768px) {
  .cpt-core__grid {
    grid-template-columns: 1fr;
    gap: clamp(16px, 5.5813953488vw, 43px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1024px) {
  .cpt-core__grid {
    gap: clamp(16px, 1.6666666667vw, 24px);
  }
}
.cpt-core__item {
  position: relative;
  padding-top: clamp(32px, 2.7777777778vw, 40px);
  padding-right: clamp(20px, 2.2222222222vw, 32px);
  padding-bottom: clamp(32px, 2.7777777778vw, 40px);
  padding-left: clamp(20px, 2.2222222222vw, 32px);
  background: #ffffff;
  border: none;
}
@media screen and (max-width: 768px) {
  .cpt-core__item {
    padding-top: clamp(28px, 8.3720930233vw, 64px);
    padding-right: clamp(16px, 5.5813953488vw, 43px);
    padding-bottom: clamp(28px, 8.3720930233vw, 64px);
    padding-left: clamp(16px, 5.5813953488vw, 43px);
  }
}
.cpt-core__num {
  position: absolute;
  top: clamp(8px, 0.8333333333vw, 12px);
  right: clamp(8px, 0.8333333333vw, 12px);
  font-size: clamp(48px, 4.4444444444vw, 64px);
  font-family: "Garamond", Georgia, serif;
  color: #e5e7eb;
  opacity: 0.5;
  line-height: 1;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media screen and (max-width: 768px) {
  .cpt-core__num {
    font-size: clamp(44px, 13.023255814vw, 100px);
  }
}
.cpt-core__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(14px, 1.1805555556vw, 17px);
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-bottom: clamp(4px, 0.4166666667vw, 6px);
  color: #111111;
  display: block;
  border-bottom: none;
  padding-bottom: 0;
}
@media screen and (max-width: 768px) {
  .cpt-core__title {
    font-size: clamp(14px, 3.7209302326vw, 29px);
  }
}
.cpt-core__sub {
  font-size: clamp(10px, 0.7638888889vw, 11px);
  font-weight: 700;
  color: #9ca3af;
  letter-spacing: 0.1em;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cpt-core__sub {
    font-size: clamp(10px, 2.5581395349vw, 20px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
}
.cpt-core__lead {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  font-weight: 500;
  color: #111111;
  line-height: 1.8;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cpt-core__lead {
    font-size: clamp(13px, 3.488372093vw, 27px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
}
.cpt-core__detail {
  border-top: 1px solid #e5e7eb;
  padding-top: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cpt-core__detail {
    padding-top: clamp(14px, 4.6511627907vw, 36px);
  }
}
.cpt-core__detail-label {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  font-weight: 700;
  color: #111111;
  letter-spacing: 0.04em;
  margin-bottom: clamp(8px, 0.8333333333vw, 12px);
}
@media screen and (max-width: 768px) {
  .cpt-core__detail-label {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}
.cpt-core__detail-body {
  font-size: clamp(12px, 0.9027777778vw, 13px);
  color: #4b5563;
  line-height: 2.2;
  background: transparent;
  padding: 0;
  border-left: none;
}
@media screen and (max-width: 768px) {
  .cpt-core__detail-body {
    font-size: clamp(12px, 3.023255814vw, 23px);
  }
}

.cpt-vision {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cpt-vision .svc-section-title br {
    display: none;
  }
}
.cpt-vision__body-wrap {
  max-width: 45rem;
  margin: 0 auto;
}
.cpt-vision__body {
  font-size: clamp(14px, 1.1111111111vw, 16px);
  color: #333333;
  line-height: 1.9;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .cpt-vision__body {
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}

.cpt-assoc {
  background-color: #f9f9f9;
}
.cpt-assoc__list {
  max-width: 50rem;
  margin: 0 auto;
}
.cpt-assoc__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #ffffff;
  border: 1px solid #eeeeee;
  padding: clamp(20px, 2.0833333333vw, 30px) clamp(20px, 2.0833333333vw, 30px);
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
  text-decoration: none;
  transition: border-color 0.4s ease;
}
@media screen and (max-width: 768px) {
  .cpt-assoc__item {
    padding: clamp(20px, 6.511627907vw, 50px) clamp(16px, 4.6511627907vw, 36px);
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.cpt-assoc__item:last-child {
  margin-bottom: 0;
}
.cpt-assoc__item:hover {
  border-color: #333333;
}
.cpt-assoc__item:hover .cpt-assoc__icon {
  color: #333333;
}
.cpt-assoc__body {
  flex: 1;
}
.cpt-assoc__eyebrow {
  font-size: clamp(10px, 0.8333333333vw, 12px);
  color: #888888;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: clamp(6px, 0.6944444444vw, 10px);
}
@media screen and (max-width: 768px) {
  .cpt-assoc__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
  }
}
.cpt-assoc__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(14px, 1.25vw, 18px);
  color: #333333;
  letter-spacing: 0.08em;
  font-weight: 400;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .cpt-assoc__title {
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}
.cpt-assoc__icon {
  width: clamp(16px, 1.3888888889vw, 20px);
  height: clamp(16px, 1.3888888889vw, 20px);
  color: #cccccc;
  transition: color 0.4s ease;
  flex-shrink: 0;
  margin-left: clamp(16px, 1.6666666667vw, 24px);
  display: none;
}
@media screen and (min-width: 769px) {
  .cpt-assoc__icon {
    display: block;
  }
}

.cpt-service {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cpt-service .svc-section-title br {
    display: none;
  }
}
.cpt-service__intro-wrap {
  max-width: 45rem;
  margin: 0 auto clamp(40px, 4.1666666667vw, 60px);
}
@media screen and (max-width: 768px) {
  .cpt-service__intro-wrap {
    margin-bottom: clamp(40px, 13.023255814vw, 100px);
  }
}
.cpt-service__intro {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #333333;
  line-height: 1.9;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .cpt-service__intro {
    font-size: clamp(12px, 3.488372093vw, 27px);
  }
}
.cpt-service__intro-strong {
  display: block;
  font-weight: 700;
  margin-bottom: clamp(10px, 0.9722222222vw, 14px);
  padding-bottom: clamp(10px, 0.9722222222vw, 14px);
  border-bottom: 1px solid #eeeeee;
}
.cpt-service__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 2.7777777778vw, 40px);
}
@media screen and (max-width: 768px) {
  .cpt-service__grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}
.cpt-service__card {
  background: #ffffff;
  padding: clamp(40px, 4.1666666667vw, 60px) clamp(28px, 2.7777777778vw, 40px);
  border: 1px solid #eeeeee;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .cpt-service__card {
    padding: clamp(24px, 7.4418604651vw, 57px) clamp(20px, 6.511627907vw, 50px);
  }
}
.cpt-service__unit {
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-family: "Garamond", "Times New Roman", Georgia, serif;
  font-style: italic;
  color: #888888;
  letter-spacing: 0.1em;
  margin-bottom: clamp(10px, 0.9722222222vw, 14px);
}
@media screen and (max-width: 768px) {
  .cpt-service__unit {
    font-size: clamp(10px, 2.7906976744vw, 21px);
  }
}
.cpt-service__card-title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(14px, 1.3194444444vw, 19px);
  font-weight: 400;
  letter-spacing: 0.08em;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
  border-bottom: 1px solid #000000;
  padding-bottom: clamp(12px, 1.1111111111vw, 16px);
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .cpt-service__card-title {
    font-size: clamp(14px, 4.4186046512vw, 34px);
    padding-bottom: clamp(10px, 3.2558139535vw, 25px);
  }
}
.cpt-service__card-lead {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  font-weight: 700;
  color: #333333;
  line-height: 1.8;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
}
@media screen and (max-width: 768px) {
  .cpt-service__card-lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
  .cpt-service__card-lead br {
    display: none;
  }
}
.cpt-service__card-body {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #666666;
  line-height: 1.8;
  text-align: justify;
  flex: 1;
  margin-bottom: clamp(20px, 2.2222222222vw, 32px);
}
@media screen and (max-width: 768px) {
  .cpt-service__card-body {
    font-size: clamp(11px, 3.2558139535vw, 25px);
  }
}
.cpt-service__more {
  display: flex;
  align-items: center;
  gap: clamp(6px, 0.5555555556vw, 8px);
  font-size: clamp(11px, 0.9027777778vw, 13px);
  font-family: "Garamond", Georgia, serif;
  letter-spacing: 0.1em;
  color: #333333;
  margin-top: auto;
  text-decoration: none;
}
.cpt-service__more:hover {
  opacity: 0.6;
}
@media screen and (max-width: 768px) {
  .cpt-service__more {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
}
.cpt-service__more svg {
  width: clamp(13px, 1.1111111111vw, 16px);
  height: clamp(13px, 1.1111111111vw, 16px);
}

.cpt-cases {
  background-color: #f7f7f7;
}
.cpt-cases__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 2.7777777778vw, 40px);
}
@media screen and (max-width: 768px) {
  .cpt-cases__grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}
.cpt-cases__item {
  cursor: pointer;
  display: block;
  text-decoration: none;
  color: inherit;
}
.cpt-cases__item:hover .cpt-cases__title {
  opacity: 0.6;
}
.cpt-cases__thumb {
  aspect-ratio: 4/3;
  background: #e0e0e0;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .cpt-cases__thumb {
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.cpt-cases__thumb-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.cpt-cases__item:hover .cpt-cases__thumb-img {
  transform: scale(1.03);
}
.cpt-cases__thumb-placeholder {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  color: #999999;
  letter-spacing: 0.1em;
  font-family: "Garamond", Georgia, serif;
}
.cpt-cases__cat {
  font-size: clamp(10px, 0.8333333333vw, 12px);
  color: #888888;
  letter-spacing: 0.1em;
  margin-bottom: clamp(6px, 0.5555555556vw, 8px);
}
@media screen and (max-width: 768px) {
  .cpt-cases__cat {
    font-size: clamp(10px, 2.7906976744vw, 21px);
  }
}
.cpt-cases__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  color: #333333;
  line-height: 1.8;
  letter-spacing: 0.04em;
  font-weight: 400;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 768px) {
  .cpt-cases__title {
    font-size: clamp(13px, 3.488372093vw, 27px);
  }
}

.cpt-faq {
  background-color: #f9f9f9;
}

.section-cpt-contact {
  background-color: #000000;
  color: #ffffff;
  text-align: center;
}
.section-cpt-contact .svc-section-title {
  color: #ffffff;
}/*# sourceMappingURL=concept-page.css.map */