@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600&display=swap');

/* ---------------------------------------
  ttl common
-----------------------------------------*/
.sec_ttl{
  text-align: center;
  margin: 0 auto 40px;
}
.sub_ttl{
  text-align: center;
  margin: 0 auto 14px;
}
@media screen and (max-width: 767px) {
  .sec_ttl{
    text-align: center;
    margin: 0 auto 9.333vw;
  }
  .sub_ttl{
    text-align: center;
    margin: 0 auto 2.133vw;
  }
}
.acc{
  position: absolute;
}

/* ---------------------------------------
  FV
-----------------------------------------*/
.fv {
  background: url("/brand/catdoctor/img/bg_fv_pc.png") repeat;
}
.fv .wrap{
  max-width: inherit;
  width: calc(100% - 40px);
}
.fv .fv_inner{
  position: relative;
  width: 100%;
  max-width: 1600px;
  margin: auto;
}
.fv .fv_main{
  position: relative;
  height: 50vw;
}
.fv .fv_girl{
  position: absolute;
  width: 40.75%;
  left: 0;
  bottom: 0;
}
.fv .fv_maincat{
  position: absolute;
  width: 33.2%;
  left: 38.6%;
  top: 15.2%;
}
.fv .headline{
  position: absolute;
  width: 53.15%;
  text-align: center;
  line-height: 0;
  right: 5%;
  bottom: 3%;
}
.fv .img_cat{
  position: absolute;
  right: 0;
  top: 3%;
  background: url("/brand/catdoctor/img/fv_bg_cat_pc.png") no-repeat center center /cover;
  width: 27.688vw;
  height: 30.813vw;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 1.75vw;
}
.fv .img_cat img{
  width: 20.5vw;
}
@media screen and (min-width: 1600px) {
  .fv .fv_main{
    height: 800px;
  }
  .fv .img_cat{
    width: 443px;
    height: 493px;
    padding-top: 48px;
  }
  .fv .img_cat img{
    width: 328px;
  }
}
@media screen and (max-width: 1000px) {
  .fv .fv_main{
    height: 501px;
  }
  .fv .img_cat{
    width: 259px;
    height: 290px;
  }
  .fv .img_cat img{
    width: 186px;
  }
}

@media screen and (max-width: 767px) {
  .fv {
    background: url("/brand/catdoctor/img/bg_fv_sp.png") repeat;
    background-size: 100% auto;
  }
  .fv .wrap{
    width: 100%;
  }
  .fv .fv_main{
    height: 105.333vw;
  }
  .fv .fv_girl{
    width: 56vw;
    bottom: inherit;
    top: 5.6vw;
  }
  .fv .fv_maincat{
    width: 44.267vw;
    left: inherit;
    right: 0;
    top: 41.333vw;
    z-index: 3;
  }
  .fv .headline{
    width: 97.067vw;
    left: 1.867vw;
    right: 0;
    bottom: 5.067vw;
  }
  .fv .img_cat{
    right: 5.333vw;
    top: 4.8vw;
    width: 36.267vw;
    height: 40.533vw;
    padding-top: 4.267vw;
  }
  .fv .img_cat img{
    width: 25.067vw;
  }
}

@keyframes rumble {
  0% {	transform: translate(0, 0);}
	3% {	transform: translate(1px) rotate(3deg);}
	6% {	transform: translate(-1px) rotate(-3deg);}
	9% {	transform: translate(1px) rotate(3deg);}
	12% {	transform: translate(-1px) rotate(-3deg);}
	15% {	transform: translate(1px) rotate(3deg);}
	18% {	transform: translate(-1px) rotate(-3deg);}
	21% {	transform: translate(1px) rotate(3deg);}
	24% {	transform: translate(-1px) rotate(-3deg);}
	27% {	transform: translate(1px) rotate(3deg);}
	30% {	transform: translate(0, 0);}
	100% {	transform: translate(0, 0);}
}
.buruburu {
  animation:rumble 1.0s linear infinite;
}



/* slider wrapper */
.fv .slider{
  margin-top: -1px;
}
.fv .slider{
  width: 100%;
  border-top: 5px solid #5DC4DC;
  border-bottom: 5px solid #5DC4DC;
  box-sizing: border-box;
}
/*
.fv .slider .slider_img {
  max-width: 216px;
  width: 100%;
  aspect-ratio: 216/150;
}
*/
@media screen and (max-width: 767px) {
  .fv .slider{
    margin-top: 0;
    border: none;
    max-height: 86px;
  }
  .fv .slider .slider_img {
    max-width: 125px;
    width: 100%;
    aspect-ratio: 125/94;
    object-fit: cover;
  }
}


/* ---------------------------------------
  #sec01
-----------------------------------------*/
#sec01 {
  position: relative;
  padding: 116px 0 145px;
  background: #fff url("/brand/catdoctor/img/bg_sec01_pc.png") repeat;
}
#sec01 .wrap{
  position: relative;
}
#sec01 .sec01_inner{
  position: relative;
  max-width: 1000px;
  width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
  margin: 173px auto 52px;
  z-index: 3;
}
#sec01 .txt_wrap{
  padding-left: 40px;
  padding-top: 26px;
}
#sec01 .ttl{
  margin: 0 auto 23px;
}
#sec01 .ttl + p{
  font-size: 2rem;
  line-height: calc(34/20);
  letter-spacing: .025em;
  font-weight: 600;
  color: #000;
  text-align: center;
}
#sec01 .movie{
  width: 700px;
  margin: auto;
}
#sec01 .movie iframe{
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
#sec01 .acc01{
  top: -107px;
  /* left: 74px; */
  left: calc(50% - 545px);
}
#sec01 .acc02{
  top: 200px;
  /* right: 43px; */
  right: calc(50% - 520px);
}
#sec01 .acc03{
  bottom: -28px;
  /* left: 113px; */
  left: calc(50% - 500px);
}
#sec01 .acc04{
  bottom: -192px;
  /* right: 120px; */
  right: calc(50% - 500px);
  z-index: 2;
}

/* 複数動画 */
#sec01 .video {
  position: relative;
  z-index: 3;
}

#sec01 .movie_box {
	max-width: 700px;
	margin: 0 auto;
}

#sec01 .movie_box .movie-main-thumb {
	margin-bottom: 20px;
}

#sec01 .movie_box .movie-main {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	overflow: hidden;
}

#sec01 .movie_box .movie-main-iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

#sec01 .movie_box .movie-sub-list .slick-slide {
	margin-right: 15px;
}

#sec01 .movie_box .movie-sub-list .slick-list {
	margin-right: -15px;
}

#sec01 .movie_box .movie-sub-item {
	background: #000;
}

#sec01 .movie_box .movie-sub-item a {
	cursor: pointer;
}

#sec01 .movie_box .movie-sub-item a:hover {
	opacity: 1;
}

#sec01 .movie_box .movie-sub-item img {
	opacity: .5;
}

#sec01 .movie_box .movie-sub-item.slick-current img {
	opacity: 1;
}


@media screen and (max-width: 1280px) {
  #sec01 .acc02{
    right: calc(50% - 500px);
  }
}


@media screen and (max-width: 767px) {
	#sec01 {
    padding: 6.4vw 0 0;
    background-size: 100%;
    overflow: hidden;
	}
  /* 0524追加 */
  #sec01 .headline{
    width: 94vw;
    margin: 0 auto 15vw;
  }
  #sec01 .sec01_inner{
    display: block;
    width: 93%;
    margin: 0 auto 8vw;
  }
  #sec01 .txt_wrap{
    padding: 0;
  }
  #sec01 .img_sec01{
    width: 67.2vw;
    margin: auto;
  }
  #sec01 .ttl{
    margin: 0 auto 7.467vw;
    width: 58.133vw;
  }
  #sec01 .ttl + p{
    font-size: 3.5vw;
    line-height: calc(51/26);
    letter-spacing: .05em;
  }
  #sec01 .movie{
    position: relative;
    z-index: 3;
    width: 93%;
    margin: auto;
  }
  #sec01 .movie iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 700/393;
  }
  #sec01 .acc01{
    width: 27.733vw;
    top: 24vw; /* 0524変更 */
    left: 5.333vw;
  }
  #sec01 .acc02{
    width: 32vw;
    top: 20.8vw; /* 0524変更 */
    right: -1.333vw;
  }
  #sec01 .acc03{
    width: 14.667vw;
    bottom: inherit;
    top: 75.2vw; /* 0524変更 */
    left: inherit;
    right: 10.133vw;
  }
  #sec01 .acc04{
    width: 27.733vw;
    bottom: inherit;
    top: 75.2vw; /* 0524変更 */
    right: inherit;
    left: 2.133vw;
  }
  /* 複数動画 */
  #sec01 .movie_box {
    max-width: none;
    width: 100%;
    padding: 0 3vw;
  }

  #sec01 .movie_box .movie-main-thumb {
    margin-bottom: 8px;
  }

  #sec01 .movie_box .movie-sub-list .slick-slide {
    margin-right: 1rem;
  }

  #sec01 .movie_box .movie-sub-list .slick-list {
    margin-right: -1rem;
  }
}


/* ---------------------------------------
  #sec02
-----------------------------------------*/
#sec02{
  position: relative;
  padding: 43px 0 110px;
  background: url("/brand/catdoctor/img/bg_sec02.png") repeat;
}
#sec02 p{
  font-size: 1.8rem;
  line-height: calc(31/18);
  font-weight: 600;
  color: #000;
  text-align: center;
}
#sec02 .inner{
  position: relative;
  margin: auto;
  border: 10px solid #fff;
  border-radius: 20px;
  padding: 32px 0;
}
#sec02 .flex{
  position: relative;
  margin: auto;
  display: flex;
  justify-content: space-between;
  padding: 0 30px;
}
#sec02 .inner.step01{
  background: #D5BDD9;
  z-index: 11;
}
#sec02 .inner.step02{
  background: #9fd6e4;
  z-index: 10;
}
#sec02 .inner.step03{
  background: #cfe298;
}
#sec02 .inner + .inner{
  margin-top: 112px;
}
#sec02 .inner::before{
  position: absolute;
  content: "";
  height: 88px;
  width: 100%;
  top: 0;
  left: 0;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
#sec02 .inner.step01::before{
  background: #B980B4;
}
#sec02 .inner.step02::before{
  background: #27b7cc;
}
#sec02 .inner.step03::before{
  background: #8ec45f;
}

#sec02 .inner .icn_step{
  position: absolute;
  top: -107px;
  left: -30px;
  z-index: 3;
}
#sec02 .inner.step01::after{
  background-image: url("/brand/catdoctor/img/icn_sec02_step01.png");
}
#sec02 .inner.step02::after{
  background-image: url("/brand/catdoctor/img/icn_sec02_step02.png");
}
#sec02 .inner.step03::after{
  background-image: url("/brand/catdoctor/img/icn_sec02_step03.png");
}

#sec02 .img_main,
#sec02 .sub_ttl,
#sec02 .sub_ttl2{
  position: relative;
  z-index: 2;
}
#sec02 .sub_ttl + p{
  padding: 20px 0 0 14px;
  text-align: left;
  font-feature-settings: "palt";
}
#sec02 .sub_ttl + p.nowrap{
  white-space: nowrap;
}
#sec02 .txt_wrap{
  flex: 1;
}
/* acc */
#sec02 .acc01{
  top: 138px;
  right: 28px;
}
#sec02 .acc02{
  top: 250px;
  right: 280px;
}
#sec02 .acc03{
  bottom: -145px;
  right: 158px;
  background: url("/brand/catdoctor/img/img_sec02_acc03_pc.png") no-repeat center center /cover;
  width: 259px;
  height: 259px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: 18px;
  padding-bottom: 10px;
  z-index: 11;
}
#sec02 .acc04{
  top: 150px;
  right: 48px;
}
#sec02 .acc05{
  bottom: -122px;
  right: 34px;
}
#sec02 .acc06{
  bottom: -67px;
  right: 224px;
}
#sec02 .acc07{
  top: 180px;
  right: 165px;
}

#sec02 .step02_sub{
  margin: -45px auto 16px;
}
#sec02 .step02_sub .sub_img{
  text-align: center;
}
#sec02 .step02_sub .sub_ttl2{
  position: relative;
  margin: 0 auto;
  text-align: center;
}
#sec02 .step02_sub .sub_ttl2 + .sub_img{
  margin: -16px auto 28px;
}
#sec02 .sub_img_wrap {
  width: 100%;
  max-width: 798px;
  margin: 5px auto 0;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  #sec02{
    position: relative;
    padding: 34.667vw 0 16vw;
    background-size: 12vw auto;
    margin-top: -26.667vw;
  }
  #sec02::before{
    position: absolute;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10.667vw 0 5.333vw 100vw;
    border-color: transparent transparent transparent #ff8099;
    top: -10.667vw;
    left: 0;
    z-index: 2;
  }
  #sec02 p{
    font-size: 3.3vw;
    line-height: calc(41/25);
  }
  #sec02 .sec_ttl{
    width: 78.4vw;
  }
  #sec02 .inner{
    border: 7px solid #fff;
    border-radius: 3.733vw;
    padding: 7.467vw 0 8vw;
    width: 81%;
  }
  #sec02 .inner.step02{
    padding-bottom: 3.2vw;
  }
  #sec02 .inner.step03{
    padding-top: 1.6vw;
    padding-bottom: 10.667vw;
  }
  #sec02 .flex{
    display: block;
    padding: 0;
  }
  #sec02 .inner + .inner{
    margin-top: 20.267vw;
  }
  #sec02 .inner::before{
    position: absolute;
    content: "";
    height: 13.333vw;
    width: 100%;
    top: 79.2vw;
    left: 0;
    border-radius: 0;
  }
  #sec02 .inner .icn_step{
    width: 27.2vw;
    top: -15.467vw;
    left: -5.867vw;
  }
  #sec02 .img_main,
  #sec02 .sub_ttl,
  #sec02 .sub_ttl2{
    margin: 0 auto;
    text-align: center;
    width: 100%;
  }
  #sec02 .img_main{
    text-align: center;
    margin-bottom: 6.4vw;
  }
  #sec02 .sub_ttl{
    width: 57.067vw;
    padding: 0;
  }
  #sec02 .sub_ttl2{
    width: 72.267vw;
    padding-top: 16.533vw;
  }

  #sec02 .sub_ttl + p{
    padding: 4.8vw 0 0;
  }
  #sec02 .sub_ttl + p.nowrap{
    white-space: nowrap;
  }
  #sec02 .sub_ttl + p.nowrap{
    white-space: nowrap;
  }
  #sec02 .txt_wrap{
    padding: 3vw 4.8vw 0;
  }
  #sec02 .inner.step02 .txt_wrap{
    padding-left: 4vw;
    padding-right: 4vw;
  }
  /* acc */
  #sec02 .acc01{
    width: 26.667vw;
    top: 51.733vw;
    right: inherit;
    left: -1.333vw;
    z-index: 3;
  }
  #sec02 .acc02{
    width: 18.933vw;
    top: 111.467vw;
    right: inherit;
    left: 16.533vw;
  }
  #sec02 .acc03{
    bottom: -37.333vw;
    right: -2.667vw;
    background: url("/brand/catdoctor/img/img_sec02_acc03_sp.png") no-repeat center center /cover;
    width: 41.067vw;
    height: 41.067vw;
    padding-right: 4.8vw;
    padding-bottom: 2.667vw;
  }
  #sec02 .acc04{
    width: 28vw;
    top: 60.267vw;
    left: 1.867vw;
    right: inherit;
    z-index: 3;
  }
  #sec02 .acc05{
    width: 35.733vw;
    bottom: -22.133vw;
    right: 2.667vw;
  }
  #sec02 .acc06{
    width: 23.467vw;
    bottom: -7.2vw;
    right: 32.267vw;
  }
  #sec02 .acc07{
    width: 38.4vw;
    top: 68.267vw;
    right: inherit;
    left: 2.667vw;
    z-index: 3;
  }
  #sec02 .acc08{
    width: 16.533vw;
    bottom: -13.867vw;
    right: -4.8vw;
    z-index: 3;
  }
  #sec02 .step02_sub{
    margin: -12vw auto 0;
  }
  #sec02 .step02_sub .sub_img{
    text-align: center;
  }
  #sec02 .step02_sub .sub_ttl2{
    position: relative;
    margin: 0 auto;
    text-align: center;
  }
  #sec02 .step02_sub .sub_ttl2 + .sub_img{
    margin: -1.6vw 0 1.6vw -4.8vw;
  }
  #sec02 .step02_sub .sub_ttl2 + .sub_img + .sub_img{
    margin: 0 -4.267vw 0 2.133vw;
  }
  #sec02 .sub_img_wrap {
    max-width: inherit;
    margin: 0 auto;
    display: block;
  }
  #sec02 .sub_img_wrap .img_main {
    margin-bottom: 1.867vw;
  }
  #sec02 .sub_img_wrap .img_main:last-of-type {
    margin-bottom: 0;
  }
}
@media screen and (orientation: landscape) and (max-width: 767px){
  #sec02 .txt_wrap{
    padding: 1.6vw 4.8vw 0;
  }
  #sec02 .sub_ttl + p{
    padding: 5.2vw 0 0;
  }
}


/* ---------------------------------------
  #sec03
-----------------------------------------*/
#sec03 {
  position: relative;
  padding: 24px 0 0;
  background: url("/brand/catdoctor/img/bg_sec03.png") repeat;
}
#sec03 .inner {
  position: relative;
}
#sec03 .img_main{
  padding-left: 120px;
}
#sec03 .fuki{
  top: 0;
  right: 124px;
}
#sec03 .acc01{
  top: 26px;
  left: -26px;
}
#sec03 .acc02{
  top: 15px;
  right: -34px;
}
#sec03 .acc03{
  bottom: 34px;
  left: 14px;
}
#sec03 .acc04{
  bottom: 34px;
  right: 10px;
}
@media screen and (max-width: 767px) {
  #sec03 {
    padding: 4.8vw 0 0;
    background-size: 180vw;
  }
  #sec03 .img_main{
    padding: 0;
    width: 76.267vw;
  }
  #sec03 .fuki{
    width: 46.667vw;
    top: 0;
    right: 2.667vw;
  }
}


/* ---------------------------------------
  #sec04
-----------------------------------------*/
#sec04 {
  position: relative;
  padding: 46px 0 0;
  background: url("/brand/catdoctor/img/bg_sec04.png") repeat;
}
#sec04 .buylink{
  width: 100%;
  margin: 0;
}
#sec04 .inner{
  max-width: 820px
}
#sec04 .sec_ttl{
  margin-bottom: 50px;
}
#sec04 .sub_ttl{
  margin-bottom: 10px;
}
#sec04 .box01{
  background: #fff;
  border: 12px solid #FFF8A6;
  border-radius: 30px;
  padding: 65px 80px 86px;
}
@media screen and (max-width: 767px) {
  #sec04 {
    padding: 8vw 0 9.6vw;
    background-size: 8vw;
  }
  #sec04 .sec_ttl{
    width: 80.267vw;
    margin: 0 auto 2.667vw;
  }
  #sec04 .sub_ttl{
    width: 69.867vw;
    margin-bottom: 5.333vw;
  }
  #sec04 .img_main{
    width: 72.8vw;
    margin-bottom: 8vw;
  }
  #sec04 .box01{
    width: 84%;
    margin: auto;
    border: 6px solid #FFF8A6;
    border-radius: 2.667vw;
    padding: 30px 2.133vw 45px;
  }
}


/* ---------------------------------------
  .floating_btn
-----------------------------------------*/
.floating_btn {
  position: fixed;
  display: none;
  bottom: 3rem;
  right: 3rem;
  z-index: 999;
}
@media screen and (max-width: 767px) {
  .floating_btn {
    width: 21.333vw;
    bottom: 2rem;
    right: 0;
  }
}

/* ---------------------------------------
.buylink__list #sec04
-----------------------------------------*/
#sec04 .buylink__list {
  display: flex;
  flex-wrap: wrap;
  gap: 25px 34px;
  margin: 22px auto 0;
  width: 647px;
  border: none;
  border-radius: 0;
  background-color: transparent;
}
#sec04 .buylink__ttl {
  display: none;
}
#sec04 .buylink__list .buylink__list-item {
  width: calc((100% - 34px) / 2);
}

#sec04 .buylink__list .buylink__link {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 54px;
  padding: 0;
  border: none;
  border-radius: 9999px;
  background: #ff8099;
  box-shadow: 0 6px 0 rgba(255,176,176,1);
}
#sec04 .buylink__list .buylink__link-txt {
  font-size: 2rem;
  line-height: calc(20.73/20);
  color: #fff;
  font-weight: bold;
  text-align: center;
}
#sec04 .buylink__list .buylink__link-txt::after {
  display: none;
}
#sec04 .buylink__list-item:not(:last-of-type) .buylink__link{
  border-bottom: none;
}
#sec04 .buylink__list-item--toysrus .buylink__link-txt{
  line-height: calc(21/20);
}

@media screen and (max-width: 767px) {
  #sec04 .buylink__list {
    display: block;
    width: 100%;
    margin-top: 2.933vw;
  }
  #sec04 .buylink__list .buylink__list-item {
    width: 69.867vw;
    margin: 0 auto;
  }
  #sec04 .buylink__list .buylink__list-item + .buylink__list-item {
    margin-top: 3.2vw;
  }
  #sec04 .buylink__list .buylink__link {
    height: 10.933vw;
    box-shadow: 0 4px 0 rgba(255,176,176,1);
  }
  #sec04 .buylink__list .buylink__link-txt {
    font-size: 3.7vw;
  }
}





