@charset "utf-8";

/* stylelint-disable selector-class-pattern */

/* common */
:root {
  --main-width: 570px;
  --blank-half-width: calc((100% - var(--main-width)) / 2);
}

body {
  font-family:
    'Noto Sans JP',
    -apple-system,
    BlinkMacSystemFont,
    'Helvetica Neue',
    'Segoe UI',
    'Hiragino Sans',
    Meiryo,
    sans-serif;
  line-height: 1.6;
  color: #333;
  background: linear-gradient(180deg, #eef1f5 43.64%, #e0e3ea 114.86%);
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
  margin: 0;
}

button {
  background-color: transparent;
  border: none;
  outline: none;
}

ol,
ul,
li {
  padding: 0;
  margin: 0;
  list-style: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

h1,
h2,
h3 {
  max-width: 100%;
}

h2 {
  font-size: 28px;
}

h3 {
  font-size: 24px;
}

h4 {
  font-size: 20px;
}

a {
  color: #333;
  text-decoration: underline;
  text-underline-offset: 3px;
}

a:hover {
  color: #333;
  text-decoration: none;
  opacity: 0.7;
}

a:link,
a:visited {
  text-decoration: underline;
}

.u-sp {
  display: block;
}

.u-pc {
  display: none;
}

.u-gradient {
  height: 30px;
  margin: 0 -20px;
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, #fff 100%);
}

.u-gradient--reverse {
  background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
}

header,
main,
footer {
  position: relative;
  width: 100%;
  max-width: var(--main-width);
  margin: 0 auto;
}

.u-plan-btn {
  display: block;
  max-width: 92%;
  margin: 0 auto 25px;
}

.about-product .u-plan-btn {
  margin-bottom: 0;
}

.u-plan-btn__img {
  width: 100%;
  height: auto;
}

@media (width >= 992px) {
  h2 {
    font-size: 34px;
  }

  h3 {
    font-size: 28px;
  }

  .u-sp {
    display: none;
  }

  .u-pc {
    display: block;
  }

  .u-section {
    padding: 50px 0 130px;
    margin: auto;
    border-top-right-radius: 80px;
  }

  .u-section--white {
    border-top-left-radius: 80px;
    border-top-right-radius: 0;
  }

  .u-ttl {
    font-size: 34px;
  }
}

/* .header */

.header {
  z-index: 1; /* root: body */
  display: flex;
  align-items: center;
  width: 100%;
  height: 60px;
  padding-left: 15px;
  background-color: #fff;
  border-bottom-right-radius: 8px;
  border-bottom-left-radius: 8px;
  box-shadow: 0 0 8px rgba(119, 119, 119, 0.3);
}

.header__logo {
  max-width: 205px;
}

/* END: .header */

/* .hero */

.hero {
  padding-bottom: 15px;
  margin-top: -56px;
  background-color: #fff;
}

.hero-note {
  padding: 0 15px 25px;
  font-size: 12px;
}

.hero-note__item::before {
  margin-right: 5px;
  content: '※';
}

/* END: .hero */

/* .cost */

.cost-great {
  position: relative;
  padding: 40px 20px 0;
  margin-top: -10px;
  background-color: #eef1f5;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.cost__ttl {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}

.cost__ttl--big {
  font-size: 26px;
}

.cost__ttl--highlight {
  color: #f5ab00;
}

.cost__note {
  font-size: 12px;
}

.cost__course {
  margin: 20px 0 15px;
}

.cost-sample {
  font-size: 16px;
  line-height: 28px;
  text-align: center;
}

.cost-sample__ttl {
  margin-bottom: 0;
}

.cost-sample__ttl--highlight {
  font-size: 20px;
  font-weight: bold;
}

.cost-sample__detail {
  line-height: 24px;
}

@media (width >= 360px) {
  .cost__ttl--big {
    font-size: 28px;
  }
}

/* END: .cost */

/* .point */

.point {
  padding: 0 20px;
  background-color: #fff;
}

.point__ttl {
  margin-bottom: 30px;
}

.point__txt {
  font-size: 16px;
  line-height: 26px;
}

.point__note {
  margin-bottom: 0;
  font-size: 12px;
}

/* END: .point */

/* .course */

.course {
  padding: 0 20px 20px;
  background-color: #f5f5f5;
}

.course__ttl {
  padding: 0 20px;
  margin-bottom: 20px;
  text-align: center;
}

.course__same {
  padding: 0 20px;
  margin-bottom: 30px;
}

.course__item {
  margin-bottom: 25px;
}

/* END: .course */

/* .feature */

.feature {
  padding: 30px 20px 20px;
  background-color: #fff8be;
}

.feature__ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 18px;
}

.feature__ttl--petname {
  margin-top: -7px;
  font-size: 28px;
}

.feature__ttl--highlight {
  margin-top: -35px;
  font-size: 52px;
  color: #f5ab00;
  text-decoration: underline;
  text-decoration-thickness: 15px;
  text-decoration-color: #ffee56;
  text-underline-offset: -6px;
  text-decoration-skip-ink: none;
}

.feature__ttl--no {
  font-size: 100px;
}

.feature-list {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.feature-item {
  position: relative;
  padding: 35px 20px 20px;
  margin-bottom: 40px;
  background-color: #fff;
  border: 3px solid #f5ab00;
  border-radius: 10px;
  box-shadow: 0 4px 0 0 #f5ab00;
}

.feature-item__ttl {
  position: absolute;
  top: -22px;
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 30px;
  font-size: 16px;
  color: #fff;
  background-color: #f5ab00;
  border-radius: 20px;
  transform: translateX(-50%);
}

.feature-item__ttl--highlight {
  margin-left: 3px;
  font-size: 28px;
}

.feature-item-body__course {
  display: flex;
  gap: 5px;
  justify-content: center;
  margin-bottom: 20px;
}

.feature-item-body__course img {
  width: auto;
  height: 20px;
}

.feature-item-detail__header {
  position: relative;
  font-size: 15px;
  font-weight: bold;
  cursor: pointer;
}

.feature-item-detail__header p {
  margin-bottom: 0;
}

.feature-item-detail__header--highlight {
  font-size: 18px;
  color: #f5ab00;
}

.feature-item-detail__trigger {
  position: absolute;
  top: 50%;
  right: -15px;
  width: 42px;
  height: 24px;
  cursor: pointer;
  background: rgba(245, 171, 0, 0.1);
  border-radius: 16px;
  transform: translateY(-50%);
}

.feature-item-detail__trigger::before,
.feature-item-detail__trigger::after {
  position: absolute;
  content: '';
  background-color: #f5ab00;
}

.feature-item-detail__trigger::before {
  top: 50%;
  left: 50%;
  width: 12px;
  height: 3px;
  transform: translate(-50%, -50%);
}

.feature-item-detail__trigger::after {
  top: 50%;
  left: 50%;
  width: 3px;
  height: 12px;
  transition: 0.4s transform ease;
  transform: translate(-50%, -50%);
}

.feature-item--show .feature-item-detail__trigger::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.feature-item-detail-content {
  max-height: 0;
  overflow: hidden;
  transition: 0.4s max-height ease;
}

.feature-item--show .feature-item-detail-content {
  max-height: 9999px;
}

.feature-item-detail-content-inner {
  padding: 30px 0 0;
  margin-top: 10px;
  border-top: 4px solid rgba(245, 171, 0, 0.2);
}

.feature-item-detail-content img {
  display: block;
  margin: 0 auto 20px;
}

.feature-item-detail-content__txt {
  font-size: 16px;
  text-align: justify;
}

.feature-item-detail-content__note {
  margin-top: 20px;
  font-size: 12px;
}

.feature-item-detail-content__oneday {
  width: 80%;
}

.feature__note {
  font-size: 12px;
  line-height: 20px;
  text-align: center;
}

@media (width >= 360px) {
  .feature-item-detail__header {
    font-size: 16px;
  }

  .feature-item-detail__header--highlight {
    font-size: 20px;
  }

  .feature-item-detail__trigger {
    right: 0;
  }
}

/* END: .feature */

/* .estimate */

.estimate-detail {
  position: relative;
  padding: 20px 10px 10px;
  margin-top: -13px;
  text-align: center;
  background-color: #fff;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.estimate-detail__caption {
  width: 85%;
  margin: 0 auto 20px;
}

/* END: .estimate */

/* .about */

.about {
  padding: 0 20px;
  background-color: #f7f4ef;
}

.about img {
  margin-bottom: 20px;
}

.about-product {
  margin: 0 -20px;
  background-color: #fff;
}

.about-product__img {
  padding: 15px 25px;
}

/* END: .about */

/* .basic */

.basic {
  padding: 45px 0 25px;
  text-align: center;
  background-color: #fff;
}

.basic-inner {
  padding: 60px 0 0;
  background-image: url(/ad/027/medical_cm/img/basic_img_bg.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.basic-list {
  display: flex;
  justify-content: space-around;
  margin: 40px auto 30px;
}

.basic-item {
  height: 720px;
  padding: 70px 10px 10px;
}

.basic-item-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20px 15px;
  background-color: #f6f9ef;
  border-radius: 10px;
  box-shadow: 0 4px 0 0 rgba(136, 136, 136, 0.2);
}

.basic-item-header {
  position: relative;
  display: flex;
  flex: 0 0 108px;
  align-items: center;
  justify-content: center;
  line-height: 32px;
}

.basic-item-header__ttl--need {
  position: absolute;
  top: -80px;
  left: 50%;
  transform: translateX(-50%);
}

.basic-item-header__ttl {
  margin-bottom: 0;
  font-size: 20px;
  font-weight: bold;
}

.basic-item-header__ttl--highlight {
  color: #8fb130;
}

.basic-item-img {
  display: flex;
  flex: 0 0 155px;
  align-items: center;
  justify-content: center;
}

.basic-item-img figcaption {
  font-size: 10px;
  text-align: right;
}

.basic-item-detail {
  height: 100%;
}

.basic-item-detail__txt {
  font-size: 14px;
  line-height: 26px;
  text-align: justify;
}

.basic-item-detail__note {
  font-size: 12px;
  text-align: left;
}

.basic__arrow {
  position: absolute;
  top: 50%;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  cursor: pointer;
  background: rgba(51, 51, 51, 0.2);
  border-radius: 50%;
  transform: translate(0, -50%);
}

.basic__arrow--prev {
  left: 13px;
}

.basic__arrow--next {
  right: 13px;
}

.basic__estimate {
  font-size: 20px;
  font-weight: bold;
  line-height: 32px;
  text-align: center;
}

@media (width >= 360px) {
  .basic-item {
    height: 640px;
  }
}

@media (width >= 960px) {
  .basic-item {
    height: 580px;
  }
}

/* END: .basic */

/* .note */

.note {
  padding: 0 10px 25px;
  background-color: #fff;
}

.note__hr {
  width: 90%;
  margin: 0 auto 35px;
  border: 1px solid #ccc;
}

.note__ttl {
  margin-bottom: 15px;
  font-size: 28px;
  text-align: center;
}

.note-list {
  padding: 0 10px;
}

.note-list li {
  position: relative;
  padding-left: 15px;
  margin-bottom: 3px;
  line-height: 26px;
  text-align: justify;
}

.note-list li::before {
  position: absolute;
  left: 0;
  content: '・';
}

/* .note */

/* .footer */

.footer {
  padding-bottom: 90px;
  background-color: #fff;
}

.footer__rt {
  width: 100%;
  padding-right: 15px;
  margin-bottom: 30px;
  font-size: 12px;
  color: #888;
  text-align: right;
}

.footer__copyright {
  padding: 20px 10px;
  font-size: 12px;
  line-height: 20px;
  color: #888;
  text-align: center;
  border-top: 1px solid #ccc;
}

/* END: .footer */

/* .float */

.float {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: -1;
  display: block;
  width: 100%;
  padding: 10px 20px;
  opacity: 0;
  transition: 0.3s opacity ease;
}

.float .u-plan-btn {
  margin-bottom: 0;
}

.float--show {
  z-index: 2; /* body */
  opacity: 1;
}

@media (width >= 768px) {
  .float {
    display: none;
  }
}

/* END: .float */

/* .fixed */

.fixed-logo {
  display: none;
}

.fixed-plan {
  display: none;
}

.fixed-index {
  display: none;
}

.fixed-img {
  display: none;
}

@media (width >= 960px) {
  .fixed-logo {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
  }

  .fixed-plan {
    /* top: 300px; */
    position: fixed;
    right: calc(var(--blank-half-width) + var(--main-width));
    display: block;
    width: 100%;
    max-width: min(528px, var(--blank-half-width));
    padding: 0 20px;
    text-align: right;
    text-align: center;
  }

  .fixed-plan__img {
    width: 100%;
    max-width: 528px;
    margin-bottom: 25px;
  }

  .fixed-plan__btn {
    width: 100%;
    max-width: 398px;
  }

  .fixed-index {
    position: fixed;
    top: 100px;
    left: calc(var(--blank-half-width) + var(--main-width) + 20px);
    display: block;
    width: 100%;
    min-width: 156px;
    max-width: min(346px, var(--blank-half-width));
    padding: 25px 30px 25px 0;
  }

  .fixed-index-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    padding: 20px;
    font-size: 17px;
    font-weight: bold;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 4px 0 0 #f9b534;
  }

  .fixed-index-item {
    position: relative;
    width: 100%;
  }

  .fixed-index-item__lnk {
    display: flex;
  }

  .fixed-index-item__arrow {
    position: relative;
    display: inline-block;
    flex: 0 0 24px;
    width: 24px;
    height: 24px;
    margin: 3px 0 0 5px;
    background-color: rgba(245, 171, 0, 0.1);
    border-radius: 50%;
  }

  .fixed-index-item__arrow::after {
    position: absolute;
    top: 6px;
    right: 7px;
    width: 9px;
    height: 9px;
    content: '';
    border-right: 3px solid #f5ab00;
    border-bottom: 3px solid #f5ab00;
    transform: rotate(45deg);
  }

  .fixed-index-item a {
    text-decoration: none;
  }

  .fixed-index-item a:hover {
    text-decoration: underline;
  }

  .fixed-img {
    position: fixed;
    bottom: 0;
    left: calc(var(--blank-half-width) + var(--main-width) + 20px);
    display: block;
    max-width: 450px;
  }
}

@media (width >= 1200px) {
  .fixed-index-item {
    width: fit-content;
  }
}

@media (width >= 1400px) {
  .fixed-index-list {
    gap: 20px;
    font-size: 20px;
  }
}

@media (width >= 960px) and (height <= 490px) {
  .fixed-plan {
    top: unset;
    bottom: 0;
  }
}

@media (width >= 960px) and (height >= 491px) {
  .fixed-plan {
    top: 300px;
    bottom: unset;
  }
}

@media (width >= 960px) and (height <= 540px) {
  .fixed-img {
    top: 300px;
    bottom: unset;
  }
}

@media (width >= 960px) and (height >= 541px) {
  .fixed-img {
    top: unset;
    bottom: 0;
  }
}

/* END: .fixed */
