@charset "UTF-8";
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;
}

.service-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;
}
.service-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) {
  .service-hero {
    padding-top: clamp(96px, 27.9069767442vw, 214px);
    padding-bottom: clamp(64px, 18.6046511628vw, 143px);
    min-height: 50vh;
    min-height: 50svh;
  }
}
.service-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) {
  .service-hero__inner {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}
.service-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) {
  .service-hero__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.service-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) {
  .service-hero__title {
    font-size: clamp(20px, 6.0465116279vw, 46px);
    line-height: 1.55;
    margin-bottom: clamp(18px, 5.5813953488vw, 43px);
  }
  .service-hero__title br {
    display: none;
  }
}
.service-hero__lead {
  font-size: clamp(12px, 1.0416666667vw, 15px);
  color: #9ca3af;
  line-height: 1.9;
  max-width: 38rem;
}
@media screen and (max-width: 768px) {
  .service-hero__lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    line-height: 1.8;
  }
}

.section-concept {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .section-concept .svc-section-title br {
    display: none;
  }
}

.concept-inner {
  max-width: 45rem;
  margin: 0 auto;
}

.concept-head {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(18px, 1.8055555556vw, 26px);
  font-weight: 400;
  text-align: center;
  margin-bottom: clamp(40px, 4.1666666667vw, 60px);
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .concept-head {
    font-size: clamp(16px, 4.6511627907vw, 36px);
    margin-bottom: clamp(28px, 9.3023255814vw, 71px);
    line-height: 1.65;
  }
  .concept-head br {
    display: none;
  }
}

.concept-body p {
  margin-bottom: clamp(20px, 2.2222222222vw, 32px);
  text-align: justify;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #333;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .concept-body p {
    margin-bottom: clamp(16px, 5.5813953488vw, 43px);
    font-size: clamp(12px, 3.2558139535vw, 25px);
    text-align: left;
  }
}
.concept-body p:last-child {
  margin-bottom: 0;
}

.section-service {
  background-color: #f7f7f7;
}

.service-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 2.7777777778vw, 40px);
}
@media screen and (max-width: 768px) {
  .service-grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}

.service-card {
  background: #ffffff;
  padding: clamp(40px, 4.1666666667vw, 60px) clamp(28px, 2.7777777778vw, 40px);
  border: 1px solid #eeeeee;
}
@media screen and (max-width: 768px) {
  .service-card {
    padding: clamp(24px, 7.4418604651vw, 57px) clamp(20px, 6.511627907vw, 50px);
  }
}
.service-card__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(16px, 1.5277777778vw, 22px);
  font-weight: 400;
  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) {
  .service-card__title {
    font-size: clamp(16px, 5.1162790698vw, 39px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
    padding-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.service-card__desc {
  font-size: clamp(13px, 1.0416666667vw, 15px);
  font-weight: 700;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
  line-height: 1.8;
  color: #333333;
}
@media screen and (max-width: 768px) {
  .service-card__desc {
    font-size: clamp(11px, 3.023255814vw, 23px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
  .service-card__desc br {
    display: none;
  }
}
.service-card__list {
  list-style: none;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #666666;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .service-card__list {
    font-size: clamp(11px, 3.2558139535vw, 25px);
    margin-bottom: clamp(16px, 5.5813953488vw, 43px);
  }
}
.service-card__list li {
  margin-bottom: clamp(6px, 0.5555555556vw, 8px);
  padding-left: 1em;
  text-indent: -1em;
}
@media screen and (max-width: 768px) {
  .service-card__list li {
    margin-bottom: clamp(6px, 1.8604651163vw, 14px);
  }
}
.service-card__list li::before {
  content: "・";
}
.service-card__point {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  background: #f9f9f9;
  padding: clamp(10px, 1.0416666667vw, 15px);
  color: #555555;
  border-left: 3px solid #cccccc;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .service-card__point {
    font-size: clamp(10px, 3.2558139535vw, 25px);
    padding: clamp(10px, 3.488372093vw, 27px);
  }
}

.section-strength {
  background-color: #ffffff;
}

.strength-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 2.7777777778vw, 40px);
}
@media screen and (max-width: 768px) {
  .strength-grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}

.strength-item {
  text-align: left;
}
.strength-item__num {
  font-size: clamp(32px, 3.3333333333vw, 48px);
  font-family: "Garamond", Georgia, serif;
  color: #e0e0e0;
  line-height: 1;
  margin-bottom: clamp(8px, 0.6944444444vw, 10px);
}
@media screen and (max-width: 768px) {
  .strength-item__num {
    font-size: clamp(33px, 11.1627906977vw, 86px);
    margin-bottom: clamp(7px, 2.3255813953vw, 18px);
  }
}
.strength-item__title {
  font-size: clamp(14px, 1.3194444444vw, 19px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  margin-bottom: clamp(12px, 1.1111111111vw, 16px);
}
@media screen and (max-width: 768px) {
  .strength-item__title {
    font-size: clamp(14px, 4.4186046512vw, 34px);
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
  }
}
.strength-item__text {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #666666;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .strength-item__text {
    font-size: clamp(11px, 3.2558139535vw, 25px);
  }
}

.section-process {
  background-color: #ffffff;
  border-top: 1px solid #f0f0f0;
}

.process-flow {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
}
.process-flow::before {
  content: "";
  position: absolute;
  top: 25px;
  left: 50px;
  right: 50px;
  height: 1px;
  background: #dddddd;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .process-flow {
    flex-direction: column;
    align-items: center;
  }
  .process-flow::before {
    width: 1px;
    height: 100%;
    left: 50%;
    top: 0;
    right: auto;
  }
}

.process-step {
  position: relative;
  z-index: 1;
  background: #ffffff;
  width: 22%;
  text-align: center;
  padding: 0 clamp(8px, 0.6944444444vw, 10px);
}
@media screen and (max-width: 768px) {
  .process-step {
    width: 100%;
    margin-bottom: clamp(28px, 9.3023255814vw, 71px);
    padding-bottom: clamp(14px, 4.6511627907vw, 36px);
    padding-left: 0;
    padding-right: 0;
  }
}
.process-step__circle {
  width: 50px;
  height: 50px;
  background: #333333;
  color: #ffffff;
  border-radius: 50%;
  line-height: 50px;
  margin: 0 auto clamp(14px, 1.3888888889vw, 20px) auto;
  font-family: "Garamond", Georgia, serif;
  font-style: italic;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  display: block;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .process-step__circle {
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}
.process-step__title {
  font-weight: 700;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  margin-bottom: clamp(8px, 0.6944444444vw, 10px);
}
@media screen and (max-width: 768px) {
  .process-step__title {
    font-size: clamp(13px, 3.7209302326vw, 29px);
    margin-bottom: clamp(7px, 2.3255813953vw, 18px);
  }
}
.process-step__desc {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  color: #666666;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .process-step__desc {
    font-size: clamp(11px, 3.023255814vw, 23px);
  }
  .process-step__desc br {
    display: none;
  }
}
.process-step--highlight .process-step__circle {
  background: #000000;
  border: 2px solid #000000;
}
.process-step--highlight .process-step__title {
  text-decoration: underline;
  text-underline-offset: 4px;
}

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

.section-service-contact {
  background-color: #000000;
  color: #ffffff;
  text-align: center;
}
.section-service-contact .svc-section-title {
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .section-service-contact .service-contact__message br {
    display: none;
  }
}

.cxp-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;
}
.cxp-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) {
  .cxp-hero {
    padding-top: clamp(96px, 27.9069767442vw, 214px);
    padding-bottom: clamp(64px, 18.6046511628vw, 143px);
    min-height: 50vh;
    min-height: 50svh;
  }
}
.cxp-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) {
  .cxp-hero__inner {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}
.cxp-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) {
  .cxp-hero__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.cxp-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) {
  .cxp-hero__title {
    font-size: clamp(20px, 6.0465116279vw, 46px);
    line-height: 1.55;
    margin-bottom: clamp(18px, 5.5813953488vw, 43px);
  }
  .cxp-hero__title br {
    display: none;
  }
}
.cxp-hero__lead {
  font-size: clamp(12px, 1.0416666667vw, 15px);
  color: #9ca3af;
  line-height: 1.9;
  max-width: 38rem;
}
@media screen and (max-width: 768px) {
  .cxp-hero__lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    line-height: 1.8;
  }
}

.cxp-stance {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cxp-stance .svc-section-title br {
    display: none;
  }
}
.cxp-stance__body {
  max-width: 45rem;
  margin: 0 auto;
}
.cxp-stance__body p {
  margin-bottom: clamp(20px, 2.2222222222vw, 32px);
  text-align: justify;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #333;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .cxp-stance__body p {
    margin-bottom: clamp(16px, 5.5813953488vw, 43px);
    font-size: clamp(12px, 3.2558139535vw, 25px);
    text-align: left;
  }
  .cxp-stance__body p br {
    display: none;
  }
}
.cxp-stance__body p:last-child {
  margin-bottom: 0;
}
.cxp-stance__body p strong {
  font-weight: 700;
  color: #000000;
}

.cxp-service {
  background-color: #f7f7f7;
}
.cxp-service__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 2.7777777778vw, 40px);
}
@media screen and (max-width: 768px) {
  .cxp-service__grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 9.3023255814vw, 71px);
  }
}

.cxp-card {
  background: #ffffff;
  padding: clamp(40px, 4.1666666667vw, 60px) clamp(28px, 2.7777777778vw, 40px);
  border: 1px solid #eeeeee;
  position: relative;
  overflow: hidden;
}
.cxp-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #000000;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
}
.cxp-card:hover::before {
  transform: scaleX(1);
}
@media screen and (max-width: 768px) {
  .cxp-card {
    padding: clamp(24px, 7.4418604651vw, 57px) clamp(20px, 6.511627907vw, 50px);
  }
}
.cxp-card__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(15px, 1.3888888889vw, 20px);
  font-weight: 400;
  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) {
  .cxp-card__title {
    font-size: clamp(14px, 4.1860465116vw, 32px);
    margin-bottom: clamp(12px, 3.7209302326vw, 29px);
    padding-bottom: clamp(10px, 3.2558139535vw, 25px);
  }
}
.cxp-card__desc {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  font-weight: 700;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
  line-height: 1.8;
  color: #333333;
}
@media screen and (max-width: 768px) {
  .cxp-card__desc {
    font-size: clamp(11px, 3.023255814vw, 23px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
  .cxp-card__desc br {
    display: none;
  }
}
.cxp-card__list {
  list-style: none;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #666666;
  margin-bottom: clamp(16px, 1.6666666667vw, 24px);
}
@media screen and (max-width: 768px) {
  .cxp-card__list {
    font-size: clamp(11px, 3.023255814vw, 23px);
    margin-bottom: clamp(14px, 4.6511627907vw, 36px);
  }
}
.cxp-card__list li {
  margin-bottom: clamp(6px, 0.5555555556vw, 8px);
  padding-left: 1em;
  text-indent: -1em;
}
@media screen and (max-width: 768px) {
  .cxp-card__list li {
    margin-bottom: clamp(6px, 1.8604651163vw, 14px);
  }
}
.cxp-card__list li::before {
  content: "・";
}
.cxp-card__point {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  background: #f9f9f9;
  padding: clamp(10px, 1.0416666667vw, 15px);
  color: #555555;
  border-left: 3px solid #cccccc;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .cxp-card__point {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    padding: clamp(10px, 3.2558139535vw, 25px);
  }
}

.cxp-why {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .cxp-why .strength-item__title br {
    display: none;
  }
}
.cxp-why__lead {
  margin-top: clamp(-8px, -0.8333333333vw, -12px);
  font-size: clamp(12px, 0.9722222222vw, 14px);
  color: #4b5563;
  font-weight: 300;
}
@media screen and (max-width: 768px) {
  .cxp-why__lead {
    font-size: clamp(12px, 3.023255814vw, 23px);
    margin-top: clamp(-6px, -1.8604651163vw, -14px);
  }
}
.cxp-why__tag {
  font-size: clamp(10px, 0.7638888889vw, 11px);
  font-weight: 700;
  color: #b91c1c;
  letter-spacing: 0.1em;
  margin-bottom: clamp(10px, 1.1111111111vw, 16px);
}
@media screen and (max-width: 768px) {
  .cxp-why__tag {
    font-size: clamp(10px, 2.5581395349vw, 20px);
  }
}

.section-process .process-step__title span {
  display: block;
  font-size: clamp(10px, 0.8333333333vw, 12px);
  font-weight: 400;
  color: #6b7280;
  margin-top: clamp(4px, 0.4166666667vw, 6px);
}
@media screen and (max-width: 768px) {
  .section-process .process-step__title span {
    font-size: clamp(10px, 2.5581395349vw, 20px);
  }
}

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

.section-cxp-contact {
  background-color: #000000;
  color: #ffffff;
  text-align: center;
}
.section-cxp-contact .svc-section-title {
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .section-cxp-contact .service-contact__message br {
    display: none;
  }
}

.mgd-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;
}
.mgd-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) {
  .mgd-hero {
    padding-top: clamp(96px, 27.9069767442vw, 214px);
    padding-bottom: clamp(64px, 18.6046511628vw, 143px);
    min-height: 50vh;
    min-height: 50svh;
  }
}
.mgd-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) {
  .mgd-hero__inner {
    padding: 0 clamp(16px, 5.5813953488vw, 43px);
  }
}
.mgd-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) {
  .mgd-hero__eyebrow {
    font-size: clamp(10px, 2.7906976744vw, 21px);
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.mgd-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) {
  .mgd-hero__title {
    font-size: clamp(20px, 6.0465116279vw, 46px);
    line-height: 1.55;
    margin-bottom: clamp(18px, 5.5813953488vw, 43px);
  }
  .mgd-hero__title br {
    display: none;
  }
}
.mgd-hero__lead {
  font-size: clamp(12px, 1.0416666667vw, 15px);
  color: #9ca3af;
  line-height: 1.9;
  max-width: 38rem;
}
@media screen and (max-width: 768px) {
  .mgd-hero__lead {
    font-size: clamp(11px, 3.023255814vw, 23px);
    line-height: 1.8;
  }
}

.mgd-concept {
  background-color: #ffffff;
}
@media screen and (max-width: 768px) {
  .mgd-concept .svc-section-title br {
    display: none;
  }
}
.mgd-concept__body {
  max-width: 45rem;
  margin: 0 auto;
}
.mgd-concept__body p {
  margin-bottom: clamp(20px, 2.2222222222vw, 32px);
  text-align: justify;
  font-size: clamp(13px, 1.0416666667vw, 15px);
  color: #333;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .mgd-concept__body p {
    margin-bottom: clamp(16px, 5.5813953488vw, 43px);
    font-size: clamp(12px, 3.2558139535vw, 25px);
    text-align: left;
  }
  .mgd-concept__body p br {
    display: none;
  }
}
.mgd-concept__body p:last-child {
  margin-bottom: 0;
}

.mgd-scope {
  background-color: #fafafa;
}
.mgd-scope__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.2222222222vw, 32px);
}
@media screen and (max-width: 768px) {
  .mgd-scope__grid {
    grid-template-columns: 1fr;
    gap: clamp(16px, 5.5813953488vw, 43px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1024px) {
  .mgd-scope__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.mgd-scope__card {
  background: #ffffff;
  padding: clamp(28px, 2.7777777778vw, 40px);
  box-shadow: 0 clamp(6px, 0.6944444444vw, 10px) clamp(24px, 2.7777777778vw, 40px) clamp(-8px, -1.0416666667vw, -15px) rgba(0, 0, 0, 0.05);
}
@media screen and (max-width: 768px) {
  .mgd-scope__card {
    padding: clamp(24px, 7.4418604651vw, 57px);
  }
}
.mgd-scope__card-title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(14px, 1.1805555556vw, 17px);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
  color: #111111;
}
@media screen and (max-width: 768px) {
  .mgd-scope__card-title {
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}
.mgd-scope__card-line {
  width: clamp(20px, 2.2222222222vw, 32px);
  height: 1px;
  background: #d1d5db;
  margin-bottom: clamp(14px, 1.3888888889vw, 20px);
}
.mgd-scope__card-body {
  font-size: clamp(12px, 0.9027777778vw, 13px);
  color: #4b5563;
  line-height: 2.2;
  font-weight: 300;
}
@media screen and (max-width: 768px) {
  .mgd-scope__card-body {
    font-size: clamp(12px, 3.023255814vw, 23px);
  }
}

.mgd-perspective {
  background-color: #ffffff;
}
.mgd-perspective__sub {
  font-size: clamp(13px, 1.1111111111vw, 16px);
  color: #6b7280;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  .mgd-perspective__sub {
    font-size: clamp(13px, 3.7209302326vw, 29px);
  }
}

.mgd-case {
  background-color: #fafafa;
}
.mgd-case__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(32px, 3.3333333333vw, 48px);
}
@media screen and (max-width: 768px) {
  .mgd-case__grid {
    grid-template-columns: 1fr;
    gap: clamp(36px, 11.1627906977vw, 86px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1024px) {
  .mgd-case__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.mgd-case__item {
  cursor: pointer;
}
.mgd-case__item:hover .mgd-case__thumb-inner {
  transform: scale(1.02);
}
.mgd-case__thumb {
  aspect-ratio: 4/3;
  background: #ececec;
  margin-bottom: clamp(20px, 2.2222222222vw, 32px);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .mgd-case__thumb {
    margin-bottom: clamp(16px, 4.6511627907vw, 36px);
  }
}
.mgd-case__thumb-label {
  font-size: clamp(11px, 0.9027777778vw, 13px);
  color: #9ca3af;
  font-family: "Garamond", Georgia, serif;
  font-style: italic;
  letter-spacing: 0.1em;
}
.mgd-case__cat {
  font-size: clamp(10px, 0.7638888889vw, 11px);
  color: #9ca3af;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: clamp(8px, 0.8333333333vw, 12px);
}
@media screen and (max-width: 768px) {
  .mgd-case__cat {
    font-size: clamp(10px, 2.5581395349vw, 20px);
  }
}
.mgd-case__title {
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  font-size: clamp(13px, 1.1111111111vw, 16px);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: clamp(12px, 1.1111111111vw, 16px);
  color: #111111;
}
@media screen and (max-width: 768px) {
  .mgd-case__title {
    font-size: clamp(13px, 3.488372093vw, 27px);
  }
}
.mgd-case__body {
  font-size: clamp(12px, 0.9027777778vw, 13px);
  color: #6b7280;
  line-height: 2.2;
  font-weight: 300;
  margin-bottom: clamp(8px, 0.8333333333vw, 12px);
}
@media screen and (max-width: 768px) {
  .mgd-case__body {
    font-size: clamp(12px, 3.023255814vw, 23px);
  }
}
.mgd-case__point {
  font-size: clamp(11px, 0.8333333333vw, 12px);
  color: #9ca3af;
  line-height: 1.8;
  font-weight: 300;
}
@media screen and (max-width: 768px) {
  .mgd-case__point {
    font-size: clamp(11px, 2.7906976744vw, 21px);
  }
}

.section-mgd-contact {
  background-color: #000000;
  color: #ffffff;
  text-align: center;
}
.section-mgd-contact .svc-section-title {
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .section-mgd-contact .service-contact__message br {
    display: none;
  }
}/*# sourceMappingURL=services.css.map */