﻿/* color -----------------------------------------------------------------------------*/

:root{
    --color1:#AEE8E6;
    --color2:#bad2d5;
    --color3:#FFB480;
    --color4:#f6f5ee;
    --color5:#92d0cd;
    --white:#ffffff;
    --black:#42210b;
    --gray:#ccc;
    --fontJp: 'Kiwi Maru', serif;
    --fontEn: 'Kodchasan', sans-serif;
}

body,.txt_color_nomal,.hvr_txt_color_nomal:hover{color: var(--black);}
.txt_white,.hvr_txt_white:hover{color: var(--white);}
.txt_color1,.hvr_txt_color1:hover{color: var(--color5);} /* メインカラー */
.txt_color2,.hvr_txt_color2:hover{color: var(--color2);} /* サブカラー */
.txt_color3,.hvr_txt_color3:hover{color: var(--color3);} /* アクセントカラー1 */
.txt_color4,.hvr_txt_color4:hover{color: var(--color4);} /* アクセントカラー2 */
.txt_color5,.hvr_txt_color5:hover{color: var(--color5);} /* アクセントカラー2 */
/* background-color */
.bg_white,.hvr_bg_white:hover{background-color: var(--white)} /* 白背景 */
.bg_black,.hvr_bg_black:hover{background-color: var(--black);} /* 黒背景 */
.bg_color1,.hvr_bg_color1:hover{background-color: var(--color1);} /* メインカラー */
.bg_color2,.hvr_bg_color2:hover{background-color: var(--color2);} /* サブカラー */
.bg_color3,.hvr_bg_color3:hover{background-color: var(--color3);} /* アクセントカラー1 */
.bg_color4,.hvr_bg_color4:hover{background-color: var(--color4);} /* アクセントカラー2 */
.bg_color5,.hvr_bg_color5:hover{background-color: var(--color5);} /* アクセントカラー2 */
.bg_color_clear,.hvr_bg_color_clear:hover{background-color: transparent!important;}
/* border-color ※!important */
.border_white,.hvr_border_white:hover{border-color: var(--white);}
.hvr_border_black:hover{border-color: var(--black);}
.border_black{border-color: var(--gray);}
.border_color1,.hvr_border_color1:hover{border-color: var(--color5);}
.border_color2,.hvr_border_color2:hover{border-color: var(--color2);}
.border_color3,.hvr_border_color3:hover{border-color: var(--color3);}
.border_color4,.hvr_border_color4:hover{border-color: var(--color4);}
.border_color5,.hvr_border_color5:hover{border-color: var(--color5);}

.linkStyle{color: var(--color3);
          border-bottom:solid 1px;
}
body#body {
    background: var(--color4);
}
/* color -----------------------------------------------------------------------------*/

/* ----------------　all　---------- */
.linkStyle:hover{
	color:　var(--color1);
	opacity: 0.7;
	transition: all 0.5s;
}
body {
    font-family: 'Kodchasan','Kiwi Maru', serif;
}
footer {
    background-color: var(--color4);
}
figure, .img-container_img {
    border-radius: 24px;
}
#footer p {
    color: var(--black);
}
#link_fixd {
    bottom: 10px;
    right: 80px;
    z-index: 10;
}
#loading_line .line {
    background: linear-gradient(90deg, rgba(255,211,128,1) 0%, rgba(174,232,219,1) 100%);
}
#loading_logo {
    max-width: 250px;
}
/*.menu {*/
/*    position: relative;*/
/*}*/
.menu:before {
    content: "";
    background-image: url(./dup/img/menu1.png);
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: -19px;
    right: 0;
    width: 100%;
    height: 20px;
    z-index: 1;
}
#luxy {
    position: relative;
}
#luxy:before {
    content: "";
    background-image: url(./dup/img/menu2.png);
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    bottom: -13px;
    right: 0;
    width: 100%;
    height: 20px;
    z-index: 4;
}
.sns_box .sns_links img {
    height: 98%!important;
}
/* ------------------------------　TOP　---------- */
.menu .logo {
    width: 12%!important;
}
.menu .nav1 {
    font-weight: 500;
}
.menu .nav2 {
    font-family: var(--fontEn);
    opacity: 0.8;
}
#wrap.top_page {
    width: 100%;
    margin-top: 0;
}
.main_wrap {
    margin-top: 102vh;
}
.main_img_wrap {
    width: 100%;
}
.main_img_wrap:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    background-image: url(./Dup/img/catch.png),url(./Dup/img/fv1.png),url(./Dup/img/fv2.png);
    background-repeat: no-repeat;
    background-position: 20% 95%,50% 101%,50% -1%;
    background-size: max(400px,26%),max(1400px,100%),max(1500px,100%);
    z-index: 1;
}
#contents {
    position: relative;
}
#contents:before,#contents:after {
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    background-image: url(./dup/img/leaf1.png);
    width: 400px;
    height: 600px;
}
#contents:before {
    top: 0;
    left: 0;
}
#contents:after {
    bottom: 0;
    right: 0;
    transform: scale(-1,-1);
}
#contents .box h3 {
    font-size: 24px;
    letter-spacing: 5px;
    font-weight: normal;
    text-shadow: 2px 2px 10px rgba(255,211,128,1);
}
#contents .box h3.t_cms_txt6 {
    text-shadow: 2px 2px 10px #70e0dc;
    text-shadow: 2px 2px 9px #a7fffc;
}
#contents .box h3:before {
    content: "";
    background-image: url(./dup/img/1.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
    transform: translate(-50%, -50%);
    width: 120px;
    height: 120px;
    opacity: 0.5;
    z-index: -1;
}
#contents .box h3.t_cms_txt6:before {
    background-image: url(./dup/img/2.png);
    transform: translate(-10%, -50%);
    width: 110px;
    height: 110px;
}
.img-container:before,.t_cms_img2 .img-container:before {
    background: linear-gradient(90deg, rgba(255,211,128,1) 0%, rgba(174,232,219,1) 100%);
}

#top_cms {
    background: linear-gradient(356deg, rgba(255,211,128,1) 0%, rgba(174,232,219,1) 100%);
    position: relative;
}
#top_cms .top_cms_bg:before, #top_cms .top_cms_bg:after {
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    background-image: url(./dup/img/leaf2.png);
    width: 400px;
    height: 600px;
    opacity: 0.5;
}
#top_cms .top_cms_bg:before {
    top: 0;
    left: 0;
}
#top_cms .top_cms_bg:after {
    bottom: 0;
    right: 0;
    transform: scale(-1,-1);
}
#top_cms .cms_title .font_2up {
    font-size: 30px;
    font-weight: normal;
    opacity: 0.5;
}
#top_cms .cms_title .font_12up {
    font-weight: normal;
    font-size: 40px;
}
.other .box figure {
    opacity: 0.6;
    border-radius: 0;
}
.other .box_title2 {
    color: var(--black);
}
.other .box {
    border: 2px solid var(--color3);
}
.cms_6-c .cate_box {
    border-radius: 10px;
    background: var(--white);
    border: 1px solid var(--color3);
    box-shadow: none;
}
.top_cms_box .more_box .more {
    border-radius: 50px;
}
#top_cms .line {
    width: 250px;
}
.line.txt_color_nomal:before {
    content: "";
    background-image: url(./dup/img/wave.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 80%;
    left: 0;
    width: 100%;
    height: 60%;
}
.cms_4-a .cate_box {
    padding: 5px;
}
.cms_4-a figure {
    border-radius: 5px;
}
.sns_box li a {
    font-weight: 500;
    font-size: 16px;
}
/* ------------------------------　下層ページ　---------- */
#title_img .img-container_img {
    background: url(./dup/img/p_title.png)!important;
    background-position: center;
    background-size: cover!important;
    border-radius: 0;
}
#page_title {
    position: relative;
}
#page_title:before {
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    background-image: url(./dup/img/leaf1.png);
    width: 400px;
    height: 600px;
    top: 0;
    left: 0;
}
#page_title .font_45 {
    font-weight: 500;
}
#page_title p {
    text-shadow: 0 0 10px #fff, 0 0 10px #fff;
}
.pager .border_color1 {
    border-color: var(--black);
}
.pager a {
    color: var(--black);
}

/* 会社情報 */
#page7 .font_18 {
    color: var(--black);
    font-weight: normal;
}
#page7 h3 {
    font-family: var(--fontJp);
}
#page7 .box_item.grid_3 h3 {
    letter-spacing: 3px;
}
#page7 .box_item.grid_3 {
    padding: 0 3%;
}
/* お問い合わせ */
#contact_tel a {
    border-radius: 10px;
    padding: 15px;
}
/* プライバシーポリシー */
/* サイトマップ */



/*---------------------------------------------------------------------------
			          タブレット
---------------------------------------------------------------------------*/
@media screen and (max-width: 768px){
/* --------------------　all　---------- */
#footer {
    padding-bottom: 60px;
}
.sns_box {
    padding-left: 30px;
}
/* --------------------　TOP　---------- */
header .logo {
    width: 30%;
    filter: drop-shadow(0px 0px 15px #fff);
}
.main_img_wrap:before {
    background-image: url(./Dup/img/catch.png),url(./Dup/img/fv1_tb.png),url(./Dup/img/fv2_tb.png);
    background-position: 90% 97%,80% 103%,90% -4%;
    background-size: 58%,102%,104%;
}
.button_container {
    top: -70px;
}
.main_wrap {
    padding-top: 0;
}

#contents .box {
    margin-bottom: 20px;
}
#contents .box .txt_wrap {
    width: 90%;
    padding-right: 0px;
}
#contents .box figure {
    width: 90%;
}
#contents .box .txt_wrap {
    padding-left: 0;
}
#contents .box:nth-child(even) {
    margin-top: 100px;
    display: flex;
    flex-direction: column-reverse;
}
#contents .box:nth-child(3) .txt_wrap {
    margin-top: 60px;
    z-index: 1;
}
#contents .box figure {
    width: 90%;
    margin-top: 30px;
}
/* --------------------　下層ページ　---------- */
#title_img span {
    height: 250px;
}
#page_title:before {
    width: 300px;
    height: 400px;
}
/* 会社情報 */
#page7 .box_item.grid_3 {
    padding: 0 2%;
}
/* お問い合わせ */
/* プライバシーポリシー */
/* サイトマップ */

}



/*---------------------------------------------------------------------------
		            	スマホ
---------------------------------------------------------------------------*/
@media screen and (max-width: 667px){
/* --------------------　all　---------- */
#footer {
    padding-bottom: 30px;
}
header .logo {
    width: 35%;
}
#loading_logo {
    width: 50%;
}
#link_fixd {
    width: 70%!important;
}

/* --------------------　TOP　---------- */
.button_container {
    top: -50px;
}
.main_img_wrap {
    height: 70vh;
}
.main_wrap {
    margin-top: 70vh;
}
.main_img_wrap:before {
    background-position: 90% 97%,80% 103%,40% -1%;
    background-size: 58%,102%,104%;
}
#contents:before, #contents:after {
    opacity: 0.7;
}
#contents {
    padding-top: 100px;
}
#contents .box:nth-child(even) {
    margin-top: 100px;
}
#contents .box:nth-child(3) figure {
    margin-top: 30px;
}
#contents .box:nth-child(3) .txt_wrap {
    margin-top: 50px;
    z-index: 1;
}
#contents .box .txt_wrap {
    padding-left: 0;
}
#contents .box h3:before {
    transform: translate(-30%, -40%);
    width: 100px;
    height: 100px;
}
#contents .box h3.t_cms_txt6:before {
    transform: translate(-20%, -40%);
    width: 100px;
    height: 100px;
}
#top_cms .top_cms_bg:before {
    display: none;
}
.other .box:last-child {
    border-left: 2px solid var(--color3);
}
.other .box_item .posi_center {
    width: 100%;
}
/* --------------------　下層ページ　---------- */

.all_header #header {
    background: #fff;
}
.all_header {
    height: 60px;
    position: relative!important;
    background-color: #fff;
}
.all_header .logo {
    width: 35%;
    position: absolute;
    z-index: 2;
    left: 10px;
    top: 10px;
}
.all_header .button_container {
    top: 40px;
}
#page_title .img-container::after {
    background-color: rgb(159 131 79 / 22%);
}
#page_title .font_45 {
    letter-spacing: 3px;
}
/* 会社情報 */
/* お問い合わせ */
/* プライバシーポリシー */
/* サイトマップ */
.page10 .more span {
    width: 10%;
}
.page10 .more_box {
    margin-left: 10px;
    margin-right: 10px;
    width: 100%!important;
}
}

/*---------------------------------------------------------------------------
		            	cms4
---------------------------------------------------------------------------*/
.v_type1 .triangle {
    display: block;
    border: #FFB480 solid 2px;
    box-shadow: 5px 5px 0 0 #e2e2e2;
}
.v_type1 .triangle:before {
    content: '';
    position: absolute;
    display: block;
    z-index: 1;
    border-style: solid;
    border-color: #FFF transparent;
    border-width: 13px 13px 0 0;
    bottom: -13px;
    left: 50%;
    margin-left: -9px;
}
.v_type1 .triangle:after {
    content: '';
    position: absolute;
    display: block;
    z-index: 0;
    border-style: solid;
    border-color: #FFB480 transparent;
    border-width: 15px 15px 0 0;
    bottom: -17px;
    left: 50%;
    margin-left: -11px;
}


/*ウィジェット*/

.widget_wrap {
    position: relative;
    z-index: 10;
    margin-top: 60px;
}
.widget_wrap .footer {
    height: 0px;
}


/* 閉じるボタン付き追従バナー */
.fix_banner .close_bt{
	position: absolute;
	top: -20px;
    right: -20px;
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	transition: 0.5s;
	background-color: #fff;
	border: solid 2px var(--color3);
	z-index: 11;
	cursor: pointer;
}
.fix_banner .close_bt:hover{opacity: 0.7;}
.fix_banner .close_bt span{
	position: relative;
	display: block;
	width: 30px;
	height: 30px;
}
.fix_banner .close_bt span:before,.fix_banner .close_bt span:after{
	content: "";
	display: block;
	background-color: var(--color3);
	height: 4px;
	width: 20px;
	position: absolute;
	top:50%;
	left: 50%;
}
.fix_banner .close_bt span:before{
	-ms-transform: translate(-50%,-50%) rotate(-45deg);
	-webkit-transform: translate(-50%,-50%) rotate(-45deg);
	transform: translate(-50%,-50%) rotate(-45deg);
}
.fix_banner .close_bt span:after{
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
}
.fix_banner.close {opacity: 0;z-index: -1;
}
.fix_banner.close2{opacity: 0;z-index: -1;}

@media  screen and (max-width: 768px){
/*.fix_banner{max-width: 200px;}*/
/*.fix_banner .close_bt{bottom: 90px;right: 170px;}*/
}

@media  screen and (max-width: 667px){
/*.fix_banner{max-width: 150px;}*/
.fix_banner .close_bt{
	width: 25px;
	height: 25px;
	/*bottom: 65px;*/
	/*right: 120px;*/
}
.fix_banner .close_bt span{
	width: 25px;
	height: 25px;
}
}
/* 閉じるボタン付き追従バナー end */