﻿@import url('https://fonts.googleapis.com/css2?family=Fuzzy+Bubbles:wght@400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Sawarabi+Gothic&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500&display=swap');
html {
    font-size: 110%;
}
body {
    font-family: 'Zen Kaku Gothic New', sans-serif;
font-family: 'Noto Sans JP', sans-serif;
background-image: url("Dup/img/bg.png");background-size: 200px;
}
.cate_list li a {
    background-color: rgb(255 246 246)!important;
}
.cate_list li a:hover {
    background-color: rgb(255 237 218)!important;
}
.hannari, .cate_title {
   font-family: 'Sawarabi Gothic', sans-serif;
    font-weight: normal
}
.line:before {
    background-color: #f6c4a2!important;
}
#contents1 h3:after, #contents2 h3:after {
    width: 108px;
    height: 34px;
    top: -44px;
    left: 0;
    content: "";
    display: block;
    position: absolute;
    background-size: contain;
    background-repeat: no-repeat;
}
#contents1 h3:after {
    background-image: url(./Dup/img/txt2.png);
}
#contents2 h3:after {
    background-image: url(./Dup/img/txt3.png);
}
#intro h3:after {
    background-image: url(./Dup/img/txt1.png);
}
#contents3 h3:after {
    background-image: url(./Dup/img/txt4.png);
}
#intro h3:after {
    content: "";
    display: block;
    position: absolute;
    width: 175px;
    height: 35px;
    top: -37px;
    left: 50%;
    transform: translate(-50%,0);
    background-size: contain;
    background-repeat: no-repeat;
}
#contents3 h3:after {
    content: "";
    display: block;
    position: absolute;
    width: 108px;
    height: 42px;
    top: -41px;
    left: 50%;
    transform: translate(-50%,0);
    background-size: contain;
    background-repeat: no-repeat;
}
.border1 {
    background: linear-gradient(transparent 0%, rgb(255 242 154) 0%) 0px 0px repeat scroll rgba(0, 0, 0, 0);
    color: #4a4a4a;
    padding: 3px 6px;
    padding: 2px 3px;
    margin: 0 3px;
}
.deco1 {
    color: #ff8736;
    font-size: 44px;
    font-family: 'Noto Sans JP', sans-serif;
}
.deco2 {
    color: #ff8198;
    font-size: 44px;
   font-family: 'Noto Sans JP', sans-serif;
}
#main_img:after {
    content: '';
    position: absolute;
    display: block;
    width: 98%;
    height: 96%;
    border: 1px solid white;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    pointer-events: none;
    z-index: 1;
}
.catch {
    display: inline-block;
    /* border-top: 1px solid; */
    /* border-bottom: 1px solid; */
    padding: 10px;
    text-shadow: 0 2px 4px rgb(0 0 0 / 33%);
    background: rgb(255 168 128 / 64%);
    font-size: 27px;
    /*font-family: "Hannari","游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";*/
     font-family: 'Zen Kaku Gothic New', sans-serif;
}
.check {
    justify-content: space-between;
    max-width: 800px;
    margin: 40px auto 0;
    background: #fffae7;
    padding: 10px;
    border-radius: 10px;
}
.check li {
    background: url(Dup/img/check.png);
    background-repeat: no-repeat;
    background-position: 0 5px;
    background-size: 28px;
    padding: 5px 5px 5px 38px;
    font-size: 16px;
    text-align: left;
}
#intro .num, #contents1 .num, #contents2 .num, .cms_title .pop400, .pop400 {
    font-family: 'Fuzzy Bubbles', cursive;
}
#intro .num, #contents1 .num, #contents2 .num {
    font-size: 28px;
}
#copyright.txt_white , #copyright .txt_white {
    color: #212121;
}
#copyright {
    background-color: transparent;
}
.cms_title .pop400 {
    font-size: 22px;
}

.letter_3 {
    letter-spacing: 2px;
}
#contents3, footer, .page main {
    position: relative;
}
#footer h2 {
color: #8b8b8b;
}
#contents3_wrap:after {
    background-color: rgb(253 209 129 / 42%)!important;
}
figure.shadow {
    box-shadow: none;
}
/*#contents1 .con_img, #contents2 .con_img {*/
/*    border: 2px solid #f5c29f;*/
/*}*/

.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: #ffffff;
    box-shadow: 3px 3px 18px rgb(0 0 0 / 8%);
    border: 2px solid #f5d6e6;
}
.con_box.bg_white {
    box-shadow: 3px 3px 18px rgb(0 0 0 / 8%);
}
#contents3 {
    margin-bottom: 0;
}
#contents3_wrap:before, #contents3_wrap:after {
    top: 0;
}
#contents3_wrap {
    margin-top: 200px;
}
#contents3_wrap .con_box {
    transform: translateY(-200px);
    box-shadow: 3px 3px 18px rgb(0 0 0 / 8%);
    border: 2px solid #f5d6e6;
}
#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;
}

#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 {
    margin-right: 0;
}
#top_pc_nav ul li:first-child {
    border-radius: 9px 0 0 9px;
}
#top_pc_nav ul li:last-child {
    border-radius: 0 9px 9px 0;
}
#top_pc_nav ul li a {
    color: #fff;
    padding: 6px 8px;
    margin: 0 6px;
    transition: all 0.3s;
}
#top_pc_nav ul li a:hover {
    color: #ffa76c;
}

.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 {
}


.cms_title {
    text-align: center;
}

@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;
	} 
}

/* -----------------------------------CMS------------------------------------------*/

.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;
}
}

/* ---------------------------------------------------------------------------- */

#intro .num, #contents1 .num, #contents2 .num, #contents3 .num {/*数字*/
opacity: 1;z-index: 2;
color:#f5c29f;
font-size: 71px;
display: none;
}

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: #212121;
    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;
}
.back1:before {
/*background: linear-gradient(0deg, rgba(255,246,246,1) 0%, rgba(255,225,213,1) 100%);*/
background-color: #ffd5d5!important;
}
.back2:before {
    /*background: linear-gradient(338deg, rgb(237 237 237 / 58%) 0%, rgba(249,249,249,1) 100%);*/
    background-color: #ffd5d5!important;
}
#intro .num {

}
#contents1 .num {

}
#contents2 .num {
   
}
#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: #ffffff;
    color: #ff9fc4;
    border: 2px solid #ff9fc4;
    border-radius: 10px;
    box-shadow: 3px 5px 0px #ff9fc4;
    transition: all 200ms cubic-bezier(0.77, 0, 0.175, 1);
    font-weight: bold;
    padding: 14px;
    font-size: 18px;
}

.more_btn:hover {
    box-shadow: none;
    transform: translate3d(0,8px,0);
    color: #f2879b;
    transition-delay: 0s;
}
.more_btn:hover:before, .more_btn:hover:after {
    display: none;
}
#info_contact .con_img {
    border: 1px solid #ededed;
}
footer.bg_color2 {
    background-color: #efefef;
}
.tel_bt a {
    color: #212121;
}
#info_contact .con_img:before {
    background-color: rgb(108 67 67 / 38%);
}
.qa_type2 .cate_box {
    overflow: hidden;
    background-color: #ffffff;
    border: 2px solid;
}
.qa_type2 .cate_box, .qa_type2 .box_txt1, .qa_type2 .box_txt2{
	border-color: #ffa243;
}
.qa_type2 .box_txt1, .box2 .box_txt1{
	border-color: rgba(0,0,0,0.05)
}
.qa_type2 .box_txt1{
	color: #212121;
}
.qa_type2 .box_txt1, .qa_type2 .box_txt2,
.box2 .box_txt1, .box2 .box_txt2{
	position:relative;
	z-index: +1;
}
.qa_type2 .box_txt1::before, .box2 .box_txt1::before{
	content: "Q.";
	position: absolute;
	top: 19px;
	transform: translateY(-50%);
	left: -26px;
	font-size: 7em;
	color: #ffe5e5;
	z-index: -1;
}
.qa_type2 .box_txt2::before, .box2 .box_txt2::before{
	content: "A.";
	position: absolute;
	top: 19px;
	transform: translateY(-50%);
	left: 5px;
	font-size: 7em;
	color: #ffe4c1;
	z-index: -1;
}
/*お問合わせバナー*/
#fix_bnr {
    bottom: 20px;
    right: 77px;
    z-index: 11;
    width: 331px;
}
.events_none {
    pointer-events: none;
}
@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: 10px;
    right: auto;
    max-width: 205px;
    width: 60%;
}
}
/* ------------------------------------------------------------------------------- */
@media screen and (max-width: 1350px){
.check li {
    width: 100%!important;
}
}
@media screen and (max-width: 768px){
html {
    font-size: 100%;
}
.font_14 {
    font-size: 14px;
}

#contents2 {
    background-position: 55% 11%;
    background-size: 119px;
}
#contents2 .num {
    top: -49px;
    left: 34px;
}
#contents3 .num {
    top: -66px;
    width: 129px;
}
#contents3 .con_box {
    padding-top: 8%;
}
.page5 .page_title_box {
    width: 76%;
}
.qa_type2 .cate_box{
	width: 95%!important;
}

}
/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
    #main_img:after {
    width: 97%;
    height: 98%;
    top: 0;
    bottom: 0;
    left: -1px;
    right: 0;
}
.catch {
    letter-spacing: 5px;
    font-size: 4.5vw;margin-top: 10px;
}
#contents3 .con_box {
    padding-top: 13%;
}
.deco1, .deco2 {
    font-size: 28px;
}
#intro h3:after {
    width: 147px;
    height: 26px;
    top: -26px;
    left: 50%;
}
    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;
}
#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_type2 .box_txt1::before, .box2 .box_txt1::before {
	top: 3px;
	left: -26px;
	font-size: 18vw;
}
.qa_type2 .box_txt2::before, .box2 .box_txt2::before {
	top: 16px;
	left: 5px;
	font-size: 18vw;
}
#logo2 a {
    max-width: 136px;
}
#footer h2 {
    font-size: 19px;
}
}


.topcms_news_type4 .cate_box{
	width: 30.33333%!important;
	margin-right: 1.5%;
	margin-left: 1.5%;
}
.topcms_news_type4 .cate_box{
	background-color: #fff;
	padding: 0;
	box-shadow: 0px 5px 19px rgb(0 0 0 / 8%);
	border-top: 2px solid #ffa242;
}
.topcms_news_type4 .txt_height{
	height: 3em
}
.topcms_news_type4 .box_title1:empty{
	display: block!important;
}
/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
.topcms_news_type4 .cate_box {width: 46.33333%!important;}
}
/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.topcms_news_type4 .cate_box {width: 100%!important;}
}