﻿@import url('https://fonts.googleapis.com/css2?family=Fuzzy+Bubbles:wght@400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&family=Otomanopee+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Yomogi&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400&display=swap');
html {
    font-size: 115%;
}
body {
    font-family: 'Zen Kaku Gothic New', sans-serif;
    font-weight: bold;
}
.hannari, .cate_title {
    font-family: 'Yomogi', cursive;
    font-weight: bold;
}
.catch {
    color: #4a4a4a;
    letter-spacing: 6px;
    font-size: 23px;
    font-family: 'Yomogi', cursive;
}
#intro .num, #contents1 .num, #contents2 .num, .cms_title .pop400, .pop400 {
    font-family: 'Fuzzy Bubbles', cursive;
}
#intro .num, #contents1 .num, #contents2 .num {
    font-size: 28px;
}
.cms_title .pop400 {
    font-size: 22px;
}

.letter_3 {
    letter-spacing: 2px;
}
#contents3, footer, .page main {
    position: relative;
}
figure.shadow {
    box-shadow: none;
}
#contents1 .con_img, #contents2 .con_img, figure {
    border-radius: 17px;
}
#intro_wrap, #contents3 .con_box, .more_btn {
    border-radius: 30px;
}
.font_14 {
    font-size: 16px;
}
.nav_menu_more:first-of-type a .icon:before {
    content: "\f086";
}
#page6 .cate_title {
    position: relative;
    border-bottom: 0;
    text-align: center;
    padding-bottom: 10px;
}
#page6 .cate_title:before {
    position: absolute;
    content: "";
    bottom: 2px;
    left: 0;
    right: 0;
    margin: auto;
    background: #f8dad2;
    height: 3px;
    width: 50px;
}
/*お問合わせバナー*/
#fix_bnr{bottom: 7px;right: 65px;z-index: 5;width: 331px;}
@media screen and (max-width: 1280px){
	#fix_bnr{width: 277px;}
}
@media screen and (max-width: 768px){
#fix_bnr {
    bottom: 31px;
    width: 253px;
}
}
@media screen and (max-width: 667px){
#fix_bnr {
    bottom: 11px;
    right: 30px;
    max-width: 216px;
    width: 61%;
}
}
/* ---------------------------------------------------------------------------- */
main {position: relative}
main:before {
content: "";
    display: block;
    position: absolute;
    top: -59px;
    left: 0px;
    width: 100%;
    height: 60px;
    background-image: url(Dup/img/wave.png);
    background-position: 0 0;
    background-repeat: repeat-x;
    background-size: 100% 60px;
    z-index: 1;
}
#intro:before {
content: "";
    display: block;
    position: absolute;
    bottom: -59px;
    left: 0px;
    width: 100%;
    height: 60px;
    background-image: url(Dup/img/wave.png);
    background-position: 0 0;
    background-repeat: repeat-x;
    background-size: 100% 60px;
    z-index: 0;
    transform: rotate(180deg);
}
#intro_wrap {
    background: #fff3f0;
}
#contents3 {
    margin-bottom: 0;
}
#contents3_wrap:before, #contents3_wrap:after {
    top: 0;
}
#contents3_wrap {
    margin-top: 200px;
}
#contents3_wrap .con_box {
    transform: translateY(-200px);
}
#contents3:after {
    content: "";
    display: block;
    left: 0;
    width: 100%;
    height: 50px;
    background-image: url(Dup/img/wave2.png);
    background-size: 100% 100%;
    background-position: 50% 100%;
    top: -1px;
    position: absolute;
    transform: rotate(180deg);
}
#top_cms:after {
    content: "";
    display: block;
    left: 0;
    width: 100%;
    height: 50px;
    background-image: url(Dup/img/wave2.png);
    background-size: 100% 100%;
    background-position: 50% 0%;
    top: -49px;
    position: absolute;
}
#contents1:before {
    content: "";
    display: block;
    position: absolute;
    top: -100px;
    right: 20px;
    width: 2400px;
    height: 2000px;
    background-image: url(Dup/img/huwahuwa3.png);
    background-position: 0 0;
    /* background-repeat: no-repeat; */
    background-size: 1400px;
    z-index: -1;
}
.page main:before {
    content: "";
    display: block;
    left: 0;
    width: 100%;
    height: 50px;
    background-image: url(Dup/img/wave2.png);
    background-size: 100% 100%;
    background-position: 50% 0%;
    top: -49px;
    position: absolute;
    z-index: 1;
}
#footer_con {
    padding-top: 50px;
}
footer:after {
    content: "";
    display: block;
    left: 0;
    width: 100%;
    height: 50px;
    background-image: url(Dup/img/wave2.png);
    background-size: 100% 100%;
    background-position: 50% 100%;
    top: -1px;
    position: absolute;
    transform: rotate(180deg);
}
#top_pc_nav li a::after {
    display: none;
}
#top_pc_nav ul li {
    background: #fff;
    margin-right: 0;
}
#top_pc_nav ul li:first-child {
    border-radius: 17px 0 0 17px;
}
#top_pc_nav ul li:last-child {
    border-radius: 0 17px 17px 0;
}
#top_pc_nav ul li a {
    color: #212121;
    padding: 6px 8px;
    margin: 0 6px;
    transition: all 0.3s;
}
#top_pc_nav ul li a:hover {
    color: #ff9292;
}

.button_container span {
    background: #2d2d2d;
}
.button_container span:nth-of-type(1) {
    background-color: transparent;
    color: #212121;
}
.overlay {
    background: linear-gradient(135deg, rgba(255,169,201,0.9) , rgb(255 158 143 / 90%) )!important;
}
#intro {
    background: #fff;
    background-image: url(Dup/img/huwahuwa1.png), url(Dup/img/huwahuwa2.png);
    background-repeat: no-repeat;
    background-position: 111% 0, -10% 100%;
    background-size: 600px, 400px;
}
.illust1 {
    z-index: 1;
    width: 200px;
    left: 13%;
    top: -12px;
}
.illust3 {
    z-index: 1;
    width: 200px;
    right: 4%;
    bottom: 44px;
}
@keyframes ushi-ugoki {
  0%   {transform: rotate(2deg);}
  50%  {transform: rotate(2deg);}
  51%  {transform: rotate(-2deg);}
  100% {transform: rotate(-2deg);}
}
#contents1 {
    background-image: url(Dup/img/illust2.png);
    background-repeat: no-repeat;
    background-position: 91% 92%;
    background-size: 123px;
}
#contents2 {
    background-image: url(Dup/img/illust6.png);
    background-repeat: no-repeat;
    background-position: 42% 25%;
    background-size: 130px;
}
.illust8 {
    width: 300px;
    right: 11%;
    bottom: -30px;
}
.cms_title {
    text-align: center;
}
.car {
    position: absolute;
    right: 5%;
    width: 90px;
    top: 0;
	animation-name: sample1;
	transform-origin: center center;
	animation-duration: 5s;
	animation-fill-mode: both;
	animation-iteration-count: infinite;
}
@keyframes sample1 {
	from {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} to {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1.0;
	} 3% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 6% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 9% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 12% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 15% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} 
}
#contents3 .num {
    top: -66px;
    width: 200px;
    animation: ushi-ugoki 1.5s infinite;
    left: 0;
    right: 0;
    margin: auto;
}
/* -----------------------------------CMS------------------------------------------*/
.cate_list li a:before {
    color: #a3a3a3;
}
.cate_list li a {
    background-color: #ffedf4!important;
    border-radius: 28px;
}
.cate_list li a:hover {
    background-color: #ffe9dc!important;
}
.cate_title.bg_color3 {
    background-color: #ffbba9;
}
#cms_3-e .cate_box, .cms_3-e .cate_box {
    background: #fffafc;
    margin-top: 17px;
    border-radius: 22px;
}
#cms_3-e .box_item:nth-of-type(2), .cms_3-e .box_item:nth-of-type(2) {
    background-color: #fff;
    margin: 0 13px 3px;
}
#cms_3-e .box_title1, #cms_3-e .box_title2, .cms_3-e .box_title1, .cms_3-e .box_title2 {
    border-bottom: 0;
}
.qa_type3 .con_no {
	left: 20px;
	top: 15px;
	color: #333333;
	line-height: 1;
}
.qa_type3 .box_title1 .con_no {
    color: #fff;
}
.qa_type3 .cate_box .box_title1, .qa_type3 .cate_box .box_txt1{
	min-height: 1.5em
}
.qa_type3 .box_q{
	background-image: url(./Dup/img/icon_q.png);
	background-repeat: no-repeat;
	background-position: top 0px left;
	background-size: 60px
}
.qa_type3 .box_a{
	background-image: url(./Dup/img/icon_a.png);
	background-repeat: no-repeat;
	background-position: top 0px right;
	background-size: 60px
}
.qa_type3 .box_q, .qa_type3 .box_a{
	padding: 0 90px
}
.qa_type3 .box_q .box_title1::before, .qa_type3 .box_a .box_txt1::before{
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    border-color: rgba(0, 0, 0, 0);
}
.qa_type3 .box_q .box_title1::before{
    border-top-width: 7px;
    border-bottom-width: 7px;
    border-left-width: 10px;
    border-right-width: 15px;
    margin-top: -10px;
    border-right-color: #ffb0cd;
    right: 100%;
    top: 34px;
}
.qa_type3 .box_a .box_txt1::before{
    border-top-width: 7px;
    border-bottom-width: 7px;
    border-left-width: 15px;
    border-right-width: 10px;
    margin-top: -10px;
    border-left-color: #f8dad2;
    left: 100%;
    top: 35px;
}

.flow_type1 .cate_box{border-left:none;background-color: rgba(0,0,0,0);}
.flow_type1 .box_txt1,
.flow_type1 .box_txt2{padding-left:100px;}

.flow_type1 .box_wrap{
    position: relative;
    padding-left: 30px;
}
.flow_type1 .box_wrap:before{
    content: "";
    display: inline-block;
    height: calc(100% - 0px);
    border-left: 14px solid rgba(243, 237, 225, .78);
    position: absolute;
    top: -5px;
    left: 63px
}
.flow_type1 .box_txt1{position:relative;}
.flow_type1 .box_txt1::before,
.flow_type1 .box_txt1::after {
	content: "";
	display: block;
	position: absolute;
	top: 18px;
}
.flow_type1 .box_txt1::before {
	width: 7px;
	height: 7px;
	margin-top: -3px;
	background: #ff8dcc;
	border-radius: 50%;
	left: 17.5px;
}
.flow_type1 .box_txt1::after {
	width: 50px;
	border-bottom: 1px dashed #999;
	position: absolute;
	left: 30px;
}
.flow_type1 .box_description2{
    position: relative;
    border-left: none;
    background-color: rgba(255, 255, 255, 0);
}
.flow_type1 .box_description2 span{
position: absolute;
    display: inline-block;
    width: 90px;
    top: -23px;
    left: -50px;
}
/*--------タブレット--------*/
@media screen and (max-width: 768px){
.flow_type1 .flex_order2_tb{
    width: 78%!important;
    margin-left: auto;
}
}
/*--------スマートフォン--------*/
@media screen and (max-width: 667px){

}
/* ---------------------------------------------------------------------------- */
body {
    background-color: #fff0f0;
    background-image: url(Dup/img/groovepaper.png);
}
#pc_nav .line_banner {
    max-width: 226px;
}
#pc_nav .line_banner a:hover:after {
    display: none;
}
#intro .num, #contents1 .num, #contents2 .num, #contents3 .num {/*数字*/
opacity: 1;z-index: 2;
color: #f9bcbc;
}

header.scr_header {
    background-color: rgba(255, 255, 255, 0.93)!important;
    border-bottom: 1px solid #fff;
}
#pc_nav li a, #footer_nav li a {
    color: #545454;
    font-weight: bold;
    font-size: 17px;
}
#main_img .menu p.bg_white.square_box {
    border-radius: 50%;
}
#logo2 a {
    max-width: 230px;
}
.back1:before, .back2:before {
    z-index: -1;
    background-image: url("Dup/img/groovepaper.png");
}
#intro .num {
    top: 41px;
}
#contents1 .num {
    left: 66px;
    top: -58px;
    transform: none;
}
#contents2 .num {
    transform: inherit;
    top: -54px;
    left: 0;
}
#contents1 .con_box, #contents2 .con_box {
    position: relative;
    background-color: rgba(255,255, 255, 0);
    background-image: radial-gradient(#ffffff 57%, rgba(255, 255, 255, 0.2) 68%,  rgba(255, 255, 255, 0) 89%, rgba(255, 255, 255, 0) 85%);
}
.more_btn {
    background-color: #ffcbdf;
    color: #fff;
}
.more_btn:hover {
    background-color: #fdd8ca;
    transition-delay: 0s!important;
}
.more_btn:hover:before, .more_btn:hover:after {
    display: none;
}
#info_contact .con_img {
    border: 1px solid #ededed;
}
footer.bg_color2 {
    background-color: #fff3f6;
}
.tel_bt a {
    color: #212121;
}
#info_contact .con_img:before {
    background-color: rgb(76 76 76 / 28%);
}

/* ------------------------------------------------------------------------------- */
.eachTextAnime {
    position: relative;
}
.eachTextAnime span {
    transition: transform 0.2s ease-in, opacity 0.1s ease-in;
    margin: 0 0.1em 0 0;
    /*transform: skewX(-10deg) translate3d(0, 1em, 0);*/
    transform: translate3d(0, 1em, 0);
    opacity: 0;
}
.eachTextAnime.appeartext span {
    animation: text_anime_on 1s ease-out forwards;
    /*transform: skewX(-10deg) translate3d(0, 0, 0);*/
     transform: translate3d(0, 0, 0);
    opacity: 1;
    display: inline-block;
}
.eachTextAnime:after {
    position: absolute;
    bottom: -4px;
    left: 0;
    margin: auto;
    width: 0%;
    height: 2px;
    content: '';
    background-color: #ffb8b8;
    transition: all 1.2s;
}
.eachTextAnime.appeartext:after {
width: 100%;
}
.line:before {
    display: none;
}


@media screen and (max-width: 768px){
html {
    font-size: 100%;
}
.font_14 {
    font-size: 14px;
}

.illust1 {
    width: 138px;
    left: 17px;
    top: -47px;
}
.illust3 {
    width: 143px;
    right: 0%;
    bottom: -62px;
}
#intro .num {
    top: -10px;
}
#contents1 {
    background-position: 92% 100%;
    background-size: 80px;
    padding-bottom: 127px;
}
#contents1 .num {
    left: 33px;
    top: -44px;
}
#contents2 {
    background-position: 55% 11%;
    background-size: 119px;
}
#contents2 .num {
    top: -49px;
    left: 34px;
}
#contents3 .num {
    top: -66px;
    width: 129px;
}
.illust8 {
    width: 207px;
    right: 8%;
    bottom: -30px;
}
.page5 .page_title_box {
    width: 76%;
}
}
/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.catch {
    letter-spacing: 5px;
    font-size: 4.5vw;
}
    main:before {
    top: -27px;
    height: 28px;
    background-position: 50% 0;
    background-size: 116% 100%;
}
#intro:before {
    bottom: -48px;
    height: 49px;
    background-size: 136% 100%;
}
#intro .num, #contents1 .num, #contents2 .num {
    font-size: 23px;
}
#intro .num {
    top: -1px;
}
.illust1 {
    width: 108px;
    top: -70px;
    left: 0;
}
.car {
    right: -1%;
    width: 75px;
    top: -3px;
}
.illust8 {
    width: 193px;
    right: 3%;
    bottom: -55px;
}
#page_title h2 {
    font-size: 5.4vw;
}
.page9 .page_title_box {
    width: 64%;
}
#top_cms:after {
    background-size: 163% 100%;
}
footer:after {
    background-size: 130% 100%;
}
.qa_type3 .box_q{
	padding-right: 0
}
.qa_type3 .box_a{
	padding-left: 0
}
.qa_type3 .con_no{
    top: 15px;
}
.qa_type3 .box_q {
    padding: 0 0 0 70px;
}
.qa_type3 .box_a {
    padding: 0 70px 0 0;
}
.qa_type3 .cate_box .box_title1, .qa_type3 .cate_box .box_txt1 {
    padding: 19px 10px 15px 47px;
}
.qa_type3 .box_a, .qa_type3 .box_q {
    background-size: 52px;
}
.flow_type1 .box_description2 span {
    width: 70px;
}
.flow_type1 .box_wrap{
    padding-left: 23px;
}
.flow_type1 .box_wrap:before {
    left: 22px;
}
.flow_type1 .box_txt1::before, .flow_type1 .box_txt1::after {
    top: 58px;
}
.flow_type1 .box_txt1::before {
    margin-top: -3px;
    left: -18px;
}
.flow_type1 .box_txt1::after {
    width: 30px;
    left: -8px;
}
.flow_type1 .box_txt1, .flow_type1 .box_txt2 {
    padding-left: 30px;
}
.flow_type1 .box_txt1{
    padding-top: 46px;

}
.flow_type1 .flex_order2_tb {
    width: 87%!important;
}
.illust1 {
    width: 115px;
    bottom: 22px;
}
.illust3 {
    width: 120px;
    right: 0%;
    bottom: -70px;
}
#logo2 a {
    max-width: 136px;
}
}