#medicaldiet {
  --page-main-color: #1FB087;
  --page-sub-color: #F06292;
  --page-accent-color: #FFF363;
  --grad-start: #63C2EC;
  --grad-end: #A5DFCF;
  --grad-start2: #D9F0FA;
  --grad-end2: #E8FDF3;
  --text-main-color: #65788D;
}

.bg_note_grid {
  background-image: url("../../_img/cp/2008_medicaldiet/bg_note_grid.jpg");
}

.bg_pc {
  background-image: url("../../_img/cp/2008_medicaldiet/bg_pc_lightblue.jpg");
}

.pcLogoArea p {
  font-family: "Noto Serif JP", serif !important;
  font-weight: 600;
}

#first_view {
  background-image: url("../../_img/cp/2008_medicaldiet/first_view.jpg");
}

.p-hero {
  position: relative;
  background-image: url(../../_img/cp/2008_medicaldiet/bg_glitter_gold.jpg);
  background-position: bottom center;
  background-size: cover;
  padding: 50px 20px 80px 20px;
}
.p-hero__title {
  color: var(--page-main-color);
  font-size: clamp(9vmin, 12vw, 4rem);
  margin: 0 auto;
  line-height: 1.2;
}
.p-hero__sub-img {
  display: block;
  margin: 0 auto;
  height: auto;
}
.p-hero__sub-img--large {
  width: 90%;
  max-width: 400px;
}
.p-hero__sub-img--medium {
  width: 60%;
  max-width: 300px;
}

.p-introduction {
  position: relative;
  width: 100%;
  margin-bottom: -43vmin;
}
.p-introduction__item {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
}
.p-introduction__item--worry {
  top: -10.5vmin;
  z-index: 3;
}
.p-introduction__item--aspiration {
  top: -26vmin;
  z-index: 1;
}
.p-introduction__item--proposal {
  top: -38vmin;
  z-index: 1;
}

.p-cta {
  background-image: url(../../_img/cp/2008_medicaldiet/bg_glitter_gold.jpg);
  background-position: bottom center;
  background-size: cover;
  text-align: center;
  padding: 0;
}
.p-cta__img {
  width: 90%;
  max-width: 700px;
  height: auto;
  display: block;
  margin: 0 auto;
}
.p-cta__img--full {
  width: 100%;
  max-width: none;
  margin-bottom: 0;
}
.p-cta__header {
  margin-bottom: 10px;
}
.p-cta__btn-link {
  display: block;
}
.p-cta__footer {
  margin-bottom: 0 !important;
}

.p-diagnose {
  background-color: var(--grad-end);
}
.p-diagnose__title--arrow::before {
  content: "";
  position: absolute;
  bottom: -2rem;
  right: 0;
  left: 0;
  width: 100%;
  height: 1rem;
  margin: auto;
  background: url("../../_img/cp/2008_medicaldiet/arrow_line_under.svg") no-repeat center;
}
.p-diagnose__icon {
  width: 100%;
  height: auto;
  max-width: 2rem;
  margin-right: 10px;
}
.p-diagnose__container,
.p-diagnose .card {
  background-image: url("../../_img/cp/2008_medicaldiet/bg_note_grid.jpg");
}
.p-diagnose__question {
  color: var(--text-main-color);
  margin-left: 10px;
}
.p-diagnose__question::before {
  content: "";
  position: absolute;
  left: -9px;
  top: 0;
  bottom: 0;
  width: 5px;
  height: 110%;
  margin: auto;
  background-color: var(--grad-end);
}
.p-diagnose__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.p-diagnose__item {
  cursor: pointer;
  color: var(--text-main-color);
}
.p-diagnose__item:hover .p-diagnose__box {
  background-color: #e7f0ff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}
.p-diagnose__item.is-active .p-diagnose__box {
  background-color: #FFA47D;
  color: #fff !important;
  border-color: #ff8753;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.25);
  transform: translateY(1px);
}
.p-diagnose__box {
  display: flex;
  justify-content: center;
  width: 100%;
  min-height: 3.5rem;
  max-height: 3rem;
  margin-bottom: 10px;
  padding: 0.75rem 0.5rem;
  background-color: #fff;
  border: 1px solid var(--text-main-color);
  border-radius: 5px;
  box-shadow: 3px 3px 0px 0px rgba(108, 150, 160, 0.25);
  transition: all 0.15s ease;
  text-align: center;
}
.p-diagnose__box span {
  align-self: center;
}
.p-diagnose__select {
  width: 100%;
  min-height: 3.5rem;
  max-height: 3rem;
  padding: 0.4rem 0.6rem;
  color: var(--text-main-color);
  background-color: #fff;
  border: 1px solid var(--text-main-color);
  border-radius: 5px;
  box-shadow: 3px 3px 0px 0px rgba(108, 150, 160, 0.25);
  transition: all 0.15s ease;
  text-align: center;
}
.p-diagnose__select.is-selected {
  background-color: #FFA47D;
  border-color: #ff8753;
  color: #fff !important;
  box-shadow: 0 0 0 2px rgba(15, 127, 227, 0.15);
}
.p-diagnose .c-diagnose-btn {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  outline: none;
  display: block;
  width: 100%;
  max-width: 550px;
  margin: 0 auto;
}
.p-diagnose .c-diagnose-btn__inner {
  display: block;
  transition: all 0.2s ease 0s;
}
.p-diagnose .c-diagnose-btn__inner:hover {
  opacity: 0.5;
}
.p-diagnose .c-diagnose-btn__img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.p-diagnose .p-result--grad-blue {
  background: linear-gradient(-120deg, #58DEA7, #014195);
}
.p-diagnose .p-result__header {
  text-align: center;
  color: #fff;
}
.p-diagnose .p-result__course-icon {
  width: 4rem;
  margin: 0 auto;
}
.p-diagnose .p-result__box--min-h {
  min-height: 90px;
}
.p-diagnose .p-result__close {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  outline: none;
  display: block;
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
}
.p-diagnose .p-result__close img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.p-pickup__card {
  border-bottom: 15px solid var(--grad-end);
}
.p-pickup__card-ttl {
  margin-bottom: 0;
}
.p-pickup__list {
  position: relative;
  height: 5.5rem;
  width: clamp(250px, 50vw, 260px);
  margin: 0 auto;
  list-style: none;
  padding: 0;
}
.p-pickup__list::before, .p-pickup__list::after {
  content: "";
  width: 1rem;
  height: 100%;
  border: solid 2px var(--page-main-color);
  display: block;
  position: absolute;
  top: 0;
  margin: auto;
}
.p-pickup__list::before {
  border-left: none;
  right: clamp(-250px, -25vw, -240px);
  left: 0;
}
.p-pickup__list::after {
  border-right: none;
  left: clamp(-250px, -25vw, -240px);
  right: 0;
}
.p-pickup__list-item {
  position: relative;
  padding-left: 30px;
}
.p-pickup__list-item::before {
  position: absolute;
  content: "";
  background-color: var(--page-main-color);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  top: 12px;
  left: 15px;
}
.p-pickup__movie {
  width: 100%;
  height: auto;
}

.triangle_right {
  background-color: var(--grad-end);
  clip-path: polygon(40% 0, 40% 100%, 80% 50%);
  content: "";
  width: 10rem;
  height: 2.5rem;
  margin: auto;
}

.case_medicaldiet_ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.title_leftline {
  padding-left: 15px !important;
}
.title_leftline::before {
  left: 1px !important;
}

.li_square_brackets {
  display: block;
  position: relative;
  width: 6rem;
  height: 4.5rem;
  color: var(--page-main-color);
}
.li_square_brackets::after {
  content: "";
  width: 1rem;
  height: 100%;
  border-top: solid 2px var(--page-main-color);
  border-left: solid 2px var(--page-main-color);
  border-bottom: solid 2px var(--page-main-color);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.li_square_brackets::before {
  content: "";
  width: 1rem;
  height: 100%;
  border-top: solid 2px var(--page-main-color);
  border-right: solid 2px var(--page-main-color);
  border-bottom: solid 2px var(--page-main-color);
  display: block;
  position: absolute;
  top: 0;
  right: 0;
}

.price-list__header {
  color: var(--page-main-color) !important;
  background-color: var(--grad-end2) !important;
}
.price-list__text--right {
  color: var(--page-main-color) !important;
}
.price-list__header--index {
  background-color: var(--page-main-color) !important;
}
.price-list__container {
  border-color: var(--grad-end) !important;
}
.price-list__header, .price-list__cell {
  border-color: var(--grad-end) !important;
}
.price-list__cell--label {
  background-color: var(--grad-end2) !important;
}

#faq.bdrTp_cLGray_10px_solid {
  border-top: 0 !important;
}
#faq.bg_cLightGray {
  background: linear-gradient(to right, var(--grad-start2), var(--grad-end2));
}
#faq.py-5 {
  padding-top: 0 !important;
}
#faq h2 {
  display: none;
}
#faq h3,
#faq .qa dt {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 10px;
  color: var(--text-main-color) !important;
}
#faq h3 btn,
#faq h3 button,
#faq .qa dt btn,
#faq .qa dt button {
  text-align: left;
  width: 100%;
  padding: 20px 20px 20px 0;
  color: var(--text-main-color) !important;
}
#faq h3 btn::before,
#faq h3 button::before,
#faq .qa dt btn::before,
#faq .qa dt button::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 2px;
  background-color: var(--page-main-color);
  right: 10px;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 2px;
}
#faq h3 btn::after,
#faq h3 button::after,
#faq .qa dt btn::after,
#faq .qa dt button::after {
  content: "";
  position: absolute;
  width: 2px;
  height: 18px;
  background-color: var(--page-main-color);
  right: 18px;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 2px;
  transition: 0.3s;
}
#faq h3 btn[aria-expanded=true]::after,
#faq h3 button[aria-expanded=true]::after,
#faq .qa dt btn[aria-expanded=true]::after,
#faq .qa dt button[aria-expanded=true]::after {
  transform: rotate(90deg);
}
#faq h3 .btn,
#faq h3 button {
  margin-bottom: -1px;
}
#faq h3 .btn::before,
#faq h3 button::before {
  right: 24px;
}
#faq h3 .btn::after,
#faq h3 button::after {
  right: 32px;
}
#faq .qa {
  background-color: #ffffff;
  border-radius: 10px;
}
#faq .qa .card {
  width: 100%;
  height: auto;
  max-width: 700px;
  border: 0;
  margin-top: 10px;
}
#faq .qa dt::before {
  content: "Q";
  font-size: 24px;
  color: var(--page-main-color);
  font-family: futura-pt, sans-serif;
  margin-right: 10px;
}
#faq .qa dd {
  color: var(--text-main-color) !important;
}
#faq .qa dd div {
  border-top: 1px solid var(--grad-end);
  padding: 20px 10px;
}
#faq .qa dd div::before {
  content: "A";
  font-size: 24px;
  color: var(--grad-start);
  font-family: futura-pt, sans-serif;
  font-weight: 600;
  margin-right: 10px;
}
#faq .qa p {
  padding-top: 0.25em;
}
#faq .qa-list div dl:last-of-type {
  margin-bottom: 0;
}

.btn {
  border: none !important;
  background: transparent;
  padding: 0;
}
.btn:focus, .btn:active, .btn:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  background-color: transparent !important;
}

#caution {
  color: var(--text-main-color);
  font-size: 10px;
}
@media (min-width: 992px) {
  #caution {
    position: relative;
    z-index: 100;
  }
}
#caution h2,
#caution h3 {
  font-size: 10px;
  font-weight: 600;
}/*# sourceMappingURL=lp_layout_medicaldiet.css.map */