﻿:root{
    --color1:#ffffff;
    --color2:#183f3b;
    --color3:#a58e20;
    --color4:#012927;
    --color5:#cdb95b;    
    --white:#012927;
    --black:#ffffff;
    --gray:#bec8c0;
}

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 */
.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,#contents,.con1_outer, .con2_outer, .con3_outer,.img5, .img6, .img7,div#left,div#right,div#intro_wrap,#contents2_wrap,#fakeloader,#main_img{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,#contents2::before,div#contents2::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,section#con_bg::before,.link_type3 .cate_box a::before,#fakeloader::before{
    content: '';
    position: absolute;
    display: block;
    background-repeat: no-repeat;
    z-index: 1;
}
/*装飾に便利な疑似クラス設定*/

/*top■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

div#wrap {
    background: var(--white);
    background-image: url(dup/img/bg_img.jpg);
    background-size: contain;
    background-attachment: fixed;
    color: var(--black);}


    
.txt_box1,.txt_box2,.txt_box3 {
    writing-mode: vertical-rl;
    margin:0 auto;
}

.con1_img_box figure,.con2_img_box figure,.con3_img_box figure {
    height: 60vh;
    width: 100%;
    object-fit: cover;
    position: relative;
    overflow: hidden;
    min-height: 500px;}

.con1_img_box figure img,.con2_img_box figure img,.con3_img_box figure img {
    position: absolute;
    bottom: 0%;
    left: 0;}
    
div#contents1, div#contents2, div#contents3 {margin-bottom: 3%;}
div#contents1 {margin-top: 3%;}

.modal-open{text-align: center;}

p.txt3 {
    font-size: 19px;
    letter-spacing: 2px;
    line-height: 3;}

.txt_box1 h2, .txt_box2 h2, .txt_box3 h2 {margin-left: 25px;}
.con1_txt_box,.con3_txt_box {margin-left: -2%;}
.con3_txt_box {margin-right: -2%;}

section#con_bg::before {
    background: var(--color2);
    width: 95%;
    height: 82%;
    z-index: 0;
    top: 50%;
    right: 0;
    transform: translate(0%, -48%);
    opacity: 0.7;
}

div#contents3 {margin-bottom: 5%;}

.aboutus {
    text-align: center;
    z-index: 0;
    position: relative;
    margin-top: 10%;
}
section#intro {margin-top: 8%;}
section#intro p {line-height: 2;}

.intro_sub {
    margin-left: 10px;
    text-orientation: sideways;
    display: block;}

div#logo {
    align-self: center;
    margin-top: -2%;}
.top_cms_box {
    margin-bottom: 15%;
    margin-top: 10%;}    

.index_header #header #header_menu li {max-height: 11.5em;}
header #header #header_menu li a .jp {
    height: 11.5em;
    font-size: 16px !important;
    letter-spacing: 1px;
}

#main_img {max-height: 77vh;}

img.catch {
    position: absolute;
    max-width: 500px;
    width: 50%;
    bottom: 6%;
    left: 2%;
}
.fadein{
	transform: translateY(20px);
	transition: transform 2s ease, opacity 2s;
	transition-property: opacity,transform;
	opacity: 0;
}
.fadein.start{transform: translateY(0);opacity: 1;}

/* モーダル-------------------------------------------------------------------- */
html.modalset{
	overflow: hidden;
}
.modal{
	display: none;
	width: 100%;
	height: 100vh;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 9999;
}
.modal-wrap {
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	text-align: center;
	padding: 20px;
	overflow: hidden;
	-webkit-overflow-scrolling: touch;
	-ms-overflow-style: none;
	overflow: -moz-scrollbars-none;
}
.modal-wrap::-webkit-scrollbar {
	display: none;
}
.modal-wrap:after {
	content: '';
	display: inline-block;
	vertical-align: middle;
	width: 1px;
	height: 100%;
}
.modal-bg{
	position: absolute;
	left: 0;
	top: 0;
	background: rgba(0,0,0,0.3);
	width: 100%;
	height: 100%;
}
.modal-box{
	width: 90%;
	box-sizing: border-box;
	display: inline-block;
	vertical-align: middle;
	position: relative;
}
.modal-box:before{
	content: "";
	display: block;
	background-color: var(--white);
	box-sizing: border-box;
	width: 100%;
	height: 10%;
	position: absolute;
	bottom: 0;
	left: 50%;
	-ms-transform: translate(-50%,0);
	-webkit-transform: translate(-50%,0);
	transform: translate(-50%,0);
	z-index: 1;
}
.modal-box .inner{
	background:  var(--white);
	max-height: 700px;
	box-sizing: border-box;
	overflow: auto;
	-ms-overflow-style: none;
	scrollbar-width: none;
}
.modal-box .inner::-webkit-scrollbar {
	display:none;
}
.modal-box .inner > :first-child {
	margin-top: 0;
}

.modal-box .modal-close{
	cursor: pointer;
	position: absolute;
    top: 0;
    right: 0;
}
.modal-box .modal-close span{
	display: block;
	width: 50px;/*枠の大きさ*/
	height: 50px;/*枠の大きさ*/
	position: relative;
}

.modal-box .modal-close span::before, .modal-box .modal-close span::after{
	content: "";
	display: block;
	width: 100%;/*バツ線の長さ*/
	height: 2px;/*バツ線の太さ*/
	background: var(--color1);
	transform: rotate(45deg);
	transform-origin:0% 50%;
	position: absolute;
	top: calc(14% - 1px);
	left: 14%;
}

.modal-box .modal-close span::after{
	transform: rotate(-45deg);
	transform-origin:100% 50%;
	left: auto;
	right: 14%;
}
.modal-open span{cursor: pointer;}

.modal_title_wrap{
	top: 0;
	left: 0;
}
.modal_title1{padding-top: 60px;}
.modal_title1:before{
	content: "";
	display: block;
	background-color: #666; 
	width: 1px;
	height: 50px;
	position: absolute;
	top: 0;
	left: 6px;
}
.modal_title1 span{
	transform: rotate(90deg);
	display: block;
	line-height: 1;
}

span.more_item {
    background: transparent;
    border: solid 1px var(--color3);
    color: var(--color1);
    max-width: 200px;
    padding: 10px 0;
    transition: 0.5s;
}
/* モーダル-------------------------------------------------------------------- */

.link_type3{padding-bottom: 50px;}
.link_type3 .link_img1 {z-index: 1;}
.link_type3 .cate_box{position:relative;}
.link_type3 .cate_box a:hover .link_img1 img {transform: translate(-50%, -50%) scale(1.05,1.05);}
.link_type3 .link_title1 {
    left: 1px;
    bottom: 1px;
    width: calc(100% - 2px);
    box-sizing: border-box;
}
.link_type3 .cate_box a .link_title1 {transition-timing-function: cubic-bezier(.78,.09,.27,1.36);}
.link_type3 .cate_box a:hover .link_title1 {bottom: -47px;}

.link_type3 .cate_box a::before {
    width: 100%;
    height: 100%;
    background: rgb(24 63 59 / 30%);
    z-index: 2;
}

.link_type3 h3, .link_type3 p {
    color: white;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    transform: translate(-50%, -50%);
}
.link_type3 h3 {
    font-size: 30px;
    text-align: center;
}
.link_type3 h3 span {
    font-size: 16px;
    /*color:var(--color3);*/
}

.link_type3 .link_img1, .link_type3 .link_img1 img {
    height: 40vh !important;
    object-fit: cover !important;
    width: 100% !important;
    min-height: 200px;
}
/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){	
.link_type3{padding-bottom: 0;}
}



/*top■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/*all■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

.is-show,.all_header {background-color: rgb(1 41 39 / 90%);}
.drawer-nav {background-color: rgb(1 41 39 / 90%);}

.fa-envelope:before{content: "\f075" !important;}
p.contact i, .tel i {border-color: var(--color1);}

#fakeloader::before{
    width:100%;
    height:100%;
    background-color:var(--color4);
    z-index: 0;
}
div#logo2 {width: 70% !important;}
/*all■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*sub■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#page_title .back_color2 {background-color: rgb(24 63 59 / 50%);}
ul.cate_list a:hover {
    color: var(--color1);
    opacity: 0.8;}
    
 /* 【背景色のみ】*/
 section#cms_2-b .cate_title,section#cms_3-b .cate_title {
    background-color: var(--color2) !important;
    color: var(--color1);
    border:solid 0px;
    padding-left:15px;}
    
section#cms_2-b .cate_box,section#cms_3-b .cate_box  {
    background:  var(--color2);
    border: solid 0;}
    
.cms_3-b .cate_box,#cms_3-b .cate_box,.cms_2-b .cate_box,#cms_2-b .cate_box {padding: 20px;}
.cms_3-b .cate_box .box_txt1,#cms_3-b .cate_box .box_txt1, .cms_2-b .cate_box .box_txt1,#cms_2-b .cate_box .box_txt1{margin-bottom: 0;}
    
#page_title h2 {max-height: 231px;}
#page_title {height: 300px;}

.all_header .header_info,.clone-nav .header_info {margin-left: 11.66667%;}
.all_header #logo,.clone-nav #logo {
    width: 25%!important;
    margin-top: 0%;}

.cate_list li a {border-bottom: solid 1px;}

/*sub■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

@media screen and (max-width: 1280px){
div#header {padding: 20px;}
}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){	
div#logo {margin-top: 0%;}
.header_info {margin-left: 2% !important;}

.all_header #logo, .clone-nav #logo {
    width: 33%!important;
    margin-top: 0%;}
#intro {
    height: 340px;
    max-height: 340px;}
img.catch {
    bottom: 6%;
    left: 3%;}
section#intro {margin-top: 12%;}
.aboutus {margin-top: 15%;}
div#contents1, div#contents2, div#contents3 {margin-bottom: 10%;}
div#contents1 {margin-top: 5%;}
.con1_img_box figure, .con2_img_box figure, .con3_img_box figure {
    height: 30vh;
    width: 100%;
    margin-top: 0;
    min-height: 200px;}
.modal-open {margin-top: 20px !important;}
div#contents1, div#contents2, div#contents3 {align-content: flex-end;}
span.more_item {
    max-width: 140px;
    padding: 5px 0;}
section#con_bg::before {
    width: 96%;
    height: 81%;
    transform: translate(0%, -45%);}
.top_cms_box {
    margin-bottom: 25%;
    margin-top: 15%;}
.cms_title {margin-bottom: 50px;} 
.link_type3 .link_img1, .link_type3 .link_img1 img {
    height: 23vh !important;
    object-fit: cover !important;
    width: 100% !important;
    min-height: 200px;}
.link_type3 h3 {
    font-size: 27px;
    text-align: center;
    width: 100%;}
.all main {padding-top: 90px;}
#page_title {height: 230px;}
#page_title h2 {
    max-height: 230px;
    letter-spacing: 1px;
    font-size: 18px;}
div#cms_2-g h3 {font-size: 0.9em;}
div#logo2 {width: 100% !important;}
}



@media screen and (max-width: 667px){
    video{
        max-height: 77vh;
        height: 50vh;
        object-fit: cover;
        width: 100% !important;}
    img.catch {
        bottom: 6%;
        left: 5%;
        position: absolute;
        max-width: 300px;
        width: 70%;}
    .contact,.tel,.header_info{display:none;}
    div#logo {
        margin-top: -1%;
        width: 67% !important;}
    div#logo img {width: 100% !important;}
    .all_header #logo, .clone-nav #logo {
        width: 66%!important;
        margin-top: -1%;}
    .intro_sub {
        margin-left: 0px;
        text-align: center;
        margin-bottom: 10px;}
    #intro {
        max-height: inherit;
        height: 100%;}   
    #intro_txt h2 {
        display: block;
        font-size: 25px;}        
    .aboutus {
        margin-top: 15%;
        font-size: 25px;
        line-height: 1.4;}        
    .con1_img_box figure, .con2_img_box figure, .con3_img_box figure {
        height: 37vh;
        width: 100%;
        margin-top: 0;
        min-height: 200px;}
    .con1_txt_box, .con2_txt_box, .con3_txt_box {
        margin: 0%;
        margin-top: 8%;}    
    .con2_txt_box {order: 2;}   
    div#contents1 {margin-top: 8%;}    
    div#contents1, div#contents2, div#contents3 { margin-bottom: 16%;}    
    p.txt3 {
        font-size: 17px;
        letter-spacing: 2px;
        line-height: 2.5;}
    .txt_box1 h2, .txt_box2 h2, .txt_box3 h2 {margin-left: 20px;}
    div#header {padding: 10px 10px;}
    .modal-box .inner {max-height: 500px;}
    .modal-box {width: 95%;}
    .modal-box .modal-close span {
        width: 30px;
        height: 30px;}
    section#con_bg::before {
        width: 96%;
        height: 93%;
        transform: translate(0%, -45%);}
.top_cms_box {
    width: 90% !important;
    margin: 30% auto 50%;}
.cms_1-a .cate_box {margin: 0 0 20px;}
.cms_title {margin-bottom: 30px;}
.link_type3 .cate_box {
    margin-bottom: 0;
    width: 100% !important;}

.link_type3 .link_img1, .link_type3 .link_img1 img {
    height: 20vh !important;
    object-fit: cover !important;
    width: 100% !important;
    min-height: 100px;}

.link_type3 h3 {
    font-size: 23px;
    text-align: center;
    width: 100%;
    line-height: 1.1;
}

#page_title h2 {
    max-height: 230px;
    letter-spacing: 1px;
    font-size: 18px;
    padding: 10px 0px;
}

div#cms_2-g h3 {
    font-size: 0.8em;
    line-height: 1.5;}

#info{text-align:center;}
div#cms_2-g h3 {
    font-size: 18px;
    line-height: 1.5;
    letter-spacing: 1px;}
    
.all main {padding-top: 75px;}

.modal-box:before {
    content: "";
    display: block;
    background-color: var(--white);
    box-sizing: border-box;
    width: 100%;
    height: 5% !important;}

/*バナー----------------------------------------------------*/
div#h1txt {padding-bottom: 30px;}
#fix_bnr {
    bottom: 0px;
    right: auto;
    left: 0;
    width: calc(100% - 50px);
    text-align: center;
    z-index: 3;
}
#fix_bnr span {
    padding: 9px 0;
    color:var(--color1);
    background: var(--color2);
    border-top: solid 1px var(--color2);
    display: block;
}

p#copyright {padding-bottom: 50px;}
}
/*バナー----------------------------------------------------*/
/*縦書き中央寄せ--------------------------------------*/
.con1_txt_box, .con2_txt_box, .con3_txt_box {text-align: center !important;}
.txt_box1, .txt_box2, .txt_box3 {
    writing-mode: vertical-rl;
    margin: 0 auto;
    display: inline-block;
}
/*縦書き中央寄せ--------------------------------------*/