﻿@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Unna:ital@1&display=swap');
  
:root{--font_unna:'Unna', 'Zen Kaku Gothic New', "Yu Gothic Medium", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, "MS PGothic", sans-serif ;}
:root{--font_zenkaku:  'Zen Kaku Gothic New', "Yu Gothic Medium", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, "MS PGothic", sans-serif ;}
    　
.con1_title,.intro_title, #contents .con_title,h3,h2,h4,h5,h6,#cms_3-g .box_txt1, .cms_3-g .box_txt1, .font_sans-serif,.cms_title p, p.con_no,#main_menu ul li a,.font_en, .date, a[href^="tel:"], a[href^="mailto:"]{font-family:var(--font_unna)!important;}
body{font-family:var(--font_zenkaku);}
html, body,.font_14{font-size:16px;}
.fat-nav li{font-size: 14px;}


:root{
    --color1:#664023;
    --color2:#e0d9c9;
    --color3:#845229;
    --color4:#f2efe7;
    --color5:#d78039;    
    --white:#fefef2;
    --black:#934C16;
    --pink:#664023;
}

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(--color1);} /* メインカラー */
.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 */
body{background-color: var(--color4);}
.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(--color1);}
.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;
}

/*装飾に便利なposi_rel*/
#contents_box,#contents1,#contents2,#contents3,#contents4,#contents,.con1_outer, .con2_outer, .con3_outer,.img5, .img6, .img7,div#left,div#right,div#intro_wrap,#contents2_wrap,.con2_box1,div#contents3 p,div#contents3 h3,.con1_txt_box{position: relative;}
/*装飾に便利なposi_rel*/
/*装飾に便利な疑似クラス設定*/
#main_img::before, #main_img::after, #contents_box::before, .con1_outer::after, #attach::before, .con2_outer::before,.con2_outer::after,.con3_outer::before,.con3_outer::after,#page_title .title_img::after,article .width_1280-max::before,div#contents1::before,div#contents1::after,div#contents3::before,#contents3::after,#contents2::before,div#contents2::after,#contents4::before,div#contents4::after,#page_title .title_img::after,#contents::before,.img5::before, .img6::before, .img7::before,div#left::before,div#right::before,div#intro_wrap::before,div#intro_wrap::after,#contents2_wrap::before,.con2_box1::before,.con2_box1:after,div#contents3 .con3_box::before,div#contents3 .con3_box::after{
    content: '';
    position: absolute;
    display: block;
    background-repeat: no-repeat;
    z-index: 1;
}
/*装飾に便利な疑似クラス設定*/
/*top■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
header.bg_color4 {background:var(--white);}
.button:hover::after {box-shadow: inset 0 0 0 15em var(--color5);}
.catch img {
    top: 8%;
    left: 3%;
    z-index: 3;
    width: 50%;
    max-width: 600px;
}

div#contents1,div#contents2,div#contents4 {padding: 100px 0;}

span.item01 img {
    width: 50%;
    max-width: 400px;
    top: -140px;
    left: 50%;
    height: 125px;
    object-fit: contain;
    transform: translateX(-50%);
}

.con1_txt_box {
    padding-left: 100px;
    padding-right: 100px;
    margin-top: 130px;
}

p.txt3 {
    line-height: 2;
    border-top: solid 1px var(--color5);
    border-bottom: solid 1px var(--color5);
    padding: 25px 20px;
}

/*--------------------------------------*/
/*con2*/

span.item02 img {
    width: 50%;
    max-width: 270px;
    top: 35%;
    right: 100px;
    object-fit: contain;
    transform: translateY(-50%);
}

.con2_txt_box::before {
    border: solid 1px var(--color5);
    padding: 50px;
    position: absolute;
    content: '';
    width: 50%;
    height: 26%;
    right: 2%;
    top: 40%;
    transform: translateY(-50%);
    z-index: -1;
}

#contents2 .modal_bt,#contents3 .modal_bt,#contents4 .modal_bt{
    cursor: pointer;
}
#contents2 .modal_bg,#contents3 .modal_bg,#contents4 .modal_bg{
    top: 0;
    left: 0;
    background-color: rgb(242 239 231 / 90%);
    z-index: 9998;
    backdrop-filter: blur(5px);
}
#contents2 .modal_box,#contents3 .modal_box,#contents4 .modal_box{
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
    overflow-y: auto;
    z-index: 9999;
    height:100%;/*test*/
    
}
#contents2 .close_bt,#contents3 .close_bt,#contents4 .close_bt{
    top: 20px;
	right: 20px;
    cursor: pointer;
}
#contents2 .cate_box,#contents4 .cate_box {
    position: relative;
    overflow: hidden;
}



/*con2*/
/*--------------------------------------*/


/*--------------------------------------*/
/*con3*/

.item03 {
    width: 100%;
    text-align: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    position: absolute;
    z-index: 2;
    height: 100%;
}

.con3_txt_box {
    padding: 100px 7%;
    height: calc(35vh + 100px);
}

div#contents3::before {
    background: rgb(224 217 201 / 50%);
    width: 70%;
    height: 85%;
    top: 51%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    border-right: solid 10px var(--color4);
    border-bottom: solid 10px var(--color4);
    box-shadow: 1px 1px 0px 0px var(--color5);
}
div#contents3::after {
    background-image: url(Dup/img/con3_img01.png),url(Dup/img/con3_img02.jpg);
    width: 90%;
    height: 100%;
    background-repeat: no-repeat;
    background-size: 22%, 20%;
    background-position: top left, bottom right;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


    
figure.item03 img {
    max-width: 270px;
    width: 50%;
    height: 100%;
    object-fit: contain;
    transform: translate(0%,-1%);}
/*con3*/
/*--------------------------------------*/
/*con4*/

span.item04 img {
    width: 50%;
    max-width: 400px;
    top: 50%;
    left: 90px;
    object-fit: contain;
    transform: translateY(-50%);
    filter: drop-shadow(1px 1px 0px var(--color4));    
}

.con4_txt_box::before {
    border: solid 1px var(--color5);
    padding: 50px;
    position: absolute;
    content: '';
    width: 50%;
    height: 24%;
    left: 2%;
    top: 54%;
    transform: translateY(-50%);
    z-index: -1;
}

.cate_box.con4_img_box {order: 2;}

/*modal------------------------------------------------*/
.modal_wrap{
	top: 0;
	left: 0;
	opacity: 0.95;
	z-index: 9999;
}

.modal_wrap .modal_scroll{
	overflow-y: auto;
}

.modal_wrap .close_bt{
	top: 20px;
	right: 20px;
	cursor: pointer
}

.more_box{
    cursor:pointer;
}

.modal_box h3 {
    font-weight: 400 !important;
    color: var(--color5);
    letter-spacing: 3px;
    font-size: 22px;
    margin-bottom: 10px;
}

.modal_box p {line-height: 2;}
/*modal------------------------------------------------*/


div#contents1 {padding: 150px 0 200px;}
div#contents2 {padding: 50px 0 250px;}
div#contents4 {padding: 250px 0 100px;}

/* ---------- cursor ---------------------- */
.cursor{
    width: 8px;
	height: 8px;
	position: fixed;
	top: 0;
	left: 0;
	pointer-events: none;
	z-index: 10;
	transition: 0.5s;
	transition-property: opacity,background,width,height,transform
}
.cursor::before {
    content: " ";
    display: block;
    width: 65px;
    height: 65px;
    position: relative;
    top: -33px;
    left: -22px;
    opacity: 1;
    transition: 0.3s;
    background-size: contain;
    background-repeat: no-repeat;
	background-image: url("../dup/img/cursor01.png");    
}
.cursor.is-active{
	opacity: 1;
	background-color: transparent;
	transform: scale(1.5);
}
.cursor.is-active::before{
	background-image: url("../dup/img/cursor.png");
}

/* ---------- cursor ---------------------- */

section#top_cms {
    background: rgb(224 217 201 / 30%);
    margin-top: 50px;}
    
.top_cms_box {padding-bottom: 100px !important;}

.fadein03{
	transform: translateY(20px);
	transition: transform 1.5s ease, opacity 2s;
	transition-property: opacity,transform;
	opacity: 0;
}
.fadein03.start{transform: translateY(0);opacity: 1;}
/*top■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*all■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

#main_menu a:hover .en{opacity: 0}
#main_menu a:hover .jp{opacity: 1}
.jp{opacity: 0}
.tel_bt a:hover .en{opacity: 0}
.tel_bt a:hover .jp{opacity: 1}
.tel_bt a {display: block;}
.tel_bt a span {
    display: inline-block;
}
.head_banner{position:relative;}
.head_banner a:hover .en{opacity: 0}
.head_banner a:hover .jp{opacity: 1}
.head_banner a {display: block;}
.head_banner a span {
    display: inline-block;
}
.tel_bt a, .head_banner a {
    height: 42px;
    padding: 15px 0px 0px 0px;
}
.tel_bt a span, .head_banner a span{width:100%;}

/*all■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*sub■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#cms_5-d .box_title1:before, .cms_5-d .box_title1:before {border-color: var(--white) transparent;}
#cms_5-c .box_txt1::before,#cms_5-c .box_title1::before,.cms_5-c .box_txt1::before,.cms_5-c .box_title1::before{font-family:var(--font_unna)!important;}
#cms_5-c .box_txt1::before,.cms_5-c .box_txt1::before{color:var(--color5);}
#cms_2-a .cate_box {
    border-bottom: solid 1px;
    border-color: var(--color2);}
    
div#cms_2-a h3 {
    border-top: solid 2px var(--color5);
    border-bottom: solid 2px var(--color5);}
    
div#cms_2-a .cate_txt1 {padding-left: 4%;}
/*sub■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/*1280*/
@media screen and (max-width: 1280px){
    .catch img {max-width: 450px;}
    div#contents1 {padding: 100px 0 100px;}
    .con1_txt_box {
        padding-left: 50px;
        padding-right: 30px;
        margin-top: 130px;}
    p.txt3 {
        line-height: 1.5;
        border-top: solid 1px var(--color5);
        border-bottom: solid 1px var(--color5);
        padding: 20px 0px;}
    span.item02 img {
        width: 50%;
        max-width: 200px;
        top: 35%;
        right: 50px;}
    div#contents2 {padding: 50px 0 150px;}
    div#contents4 {padding: 150px 0 100px;}
    span.item04 img {
    width: 50%;
    max-width: 280px;
    left: 50px;}
}

/*1100*/
@media screen and (max-width: 1100px){
.catch img {max-width: 330px;}
div#contents1 {padding: 80px 0 100px;}
span.item01 img {
    width: 50%;
    max-width: 400px;
    top: -88px;
    left: 50%;
    height: 80px;}
figure.item03 img {max-width: 230px;}
div#contents3 {padding: 80px 7%;}

span.item04 img {
    width: 50%;
    max-width: 280px;
    left: 50px;}
span.item02 img {max-width: 180px;}
}


/*タブレット*/
@media screen and (max-width: 768px){
    h1#logo {max-width: 100px;}
    .main_box {padding-top: 90px;}
    .hamburger {top: 22px;}
    #main_img { max-height: 70vh;}
    #main_img img.object_fit_img {
        max-height: 70vh;
        min-height: 70vh;}
        
    span.item01 img {
        top: -130px;
        height: 130px;}
        
    div#contents1 {padding: 107px 0 150px;}
    
    p.txt3 {
        padding: 20px 10px;
        margin-top: 50px;}
    .con1_txt_box {
        padding-left: 30px;
        padding-right: 30px;}
        
    span.item02 img {
        width: 50%;
        max-width: 250px;
        top: -5%;
        right: 3%;
        transform: translateY(0%);}
    .con2_txt_box::before{display:none;}
    div#contents3 {padding: 0px 0%;}
    figure.item03 img {max-width: 300px;}
    div#contents4 {
        padding: 120px 0 200px;}
        
    span.item04 img {
        width: 50%;
        max-width: 400px;
        left: auto;
        right: 3%;
        top: auto;
        bottom: -1%;}
    
    #top_cms > .box:first-of-type {padding-top: 100px !important;}
    .top_cms_box {padding-bottom: 100px !important;}
    
    .cms_title h2 {font-size: 35px !important;}
    .con4_txt_box::before{display:none;}
    
    #contents3 .grid_6 {margin-top: 0px;}
.head_banner {
    position: fixed !important;
}    
header .head_banner {
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    width: 200px;}    

.cursor{display:none;}
}

/*スマホ*/
@media screen and (max-width: 667px){
    /*ロゴ中央・テキスト左寄せ----------------------------------------------*/
    footer .logo{
            text-align: center;
            display: block;}
    footer .grid_5 {text-align: center;}
    p.footer_cms {
        text-align: left;
        display: inline-block;}
    /*ロゴ中央・テキスト左寄せ----------------------------------------------*/ 
    h1#logo {max-width: 75px;}
    .main_box {padding-top: 69px;}
    .hamburger {top: 14px;}
    html, body, .font_14 {font-size: 14px;}    
    p.txt3 {
        max-width: 900px;
        margin: 0 auto;
        text-align: left;
        line-height: 1.5;
        padding-top: 20px;}
    h2.txt2 {
        width: 100%;
        margin: -25px auto 20px;}
        
    #main_img img.object_fit_img {
        max-height: 55vh;
        min-height: 55vh;}
        
    #main_img {max-height: 55vh;}
    .catch img {
        max-width: 190px;
        filter: drop-shadow(1px 0px 0px var(--color4));}
        
    span.item01 img {
        top: -150px;
        height: 150px;
        width: 75%;}
        
    p.txt3 {
        max-width: 900px;
        margin: 20px auto 0;
        text-align: left;
        line-height: 1.5;
        padding: 20px 10px;}
        
    .con1_txt_box {
        padding-left: 15px;
        padding-right: 15px;}
        
    div#contents1 {padding: 107px 0 130px;}
    .item02 img {
        top: 0%;
        right: 3%;}  
        
    div#contents3::before {
        background: rgb(224 217 201 / 50%);
        width: 80%;
        height: 80%;
        border-right: solid 5px var(--color4);
        border-bottom: solid 5px var(--color4);
        box-shadow: 1px 1px 0px 0px var(--color5);}  
        
    div#contents3::after {
        background-image: url(Dup/img/con3_img01.png),url(Dup/img/con3_img02.jpg);
        width: 100%;
        height: 126%;
        background-repeat: no-repeat;
        background-size: 23%, 30%;
        background-position: top 6% left, bottom -4% right;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);}    
        
    figure.item03 img { width: 60%;}
    span.item04 img {
        width: 85%;
        max-width: 400px;
        left: auto;
        right: 3%;
        top: auto;
        bottom: 4%;}
    .cms_title h2 {font-size: 30px !important;}
    .tel_bt a, .head_banner a {
        height: 30px;
        padding: 7px 0px 0px 0px;}    
}

/*20230124*/
body {
    background-color: var(--color4);
    background-image: url(dup/img/bg_color4.jpg);
    background-size:1000px;
}


.bg_white,.hvr_bg_white:hover,header.bg_color4{
    background-color: var(--white);
    background-image: url(dup/img/bg_white.jpg);
    background-size:1000px;
}