﻿:root{
    --red: #ca301e;
}

.bg_color1{background-color: var(--red);} 
.bg_black{background-color: #e3e3e3;}

#pc_nav li a{
    color: black;
}

.loading_logo{
    width: min(30%, 200px);
}

@keyframes zoomUp {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(1);
	}
}

#main_img span{
    display: block;
    position: absolute;
    background-position: center;
    background-repeat: no-repeat;
    

}

span.main{
    width: 80%;
    height: 80vh;
    background-image: url(./Dup/img/main.jpg);
    z-index: 3;
    top: 50%;
    left: 50%;
        transform: translate(-50%, -50%);
}

#main_img:before{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    background-image: url(./Dup/img/left.png), url(./Dup/img/right.png);
    background-position: center left, center right;
    background-repeat: no-repeat;
    -webkit-transform: translate(-50% , -50%);
    transform: translate(-50% , -50%);
    background-size: 40%, 40%;
    pointer-events: none;
    z-index: 4;
}

#main_img:after{
        content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    background-image: url(./Dup/img/copy.svg);
    background-position: center left;
    background-repeat: no-repeat;
    -webkit-transform: translate(-50% , -50%);
    transform: translate(-50% , -50%);
    background-size: 18vw;
    pointer-events: none;
    z-index: 5;
    background-position: 75.5% 40%;
}


.tl{
    width: 17%;
    height: 27vh;
    background-color: #3a5974;
    top: 15%;
    left: 0%;
    z-index: 2;
    transform: none;
    background-image: url(./Dup/img/tl.jpg);
    z-index: 3;
}

.tr{
    height: 40vh;
    background-color: #3a5974;
    top: 0%;
    right: 0%;
    z-index: 2;
    transform: none;
    background-image: url(./Dup/img/tr.jpg);
    background-size: cover;
    width: max(20%, 400px);
}

.br{
    height: 30vh;
    background-color: transparent;
    bottom: 0%;
    right: 0%;
    z-index: 4;
    transform: none;
    background-image: url(./Dup/img/br.png);
    background-size: cover;
    width: max(40%, 400px);
}

.bl{
        width: 12%;
    height: 27vh;
    background-color: #3a5974;
    bottom: 0;
    left: 7%;
    z-index: 2;
    transform: none;
    background-image: url(./Dup/img/bl.jpg);
    z-index: 2;
}

#pc_nav {
    background-color: white;
}

#main_img h1#logo{
        top: 20px;
    z-index: 4;
}


.flow_type4 .box_description2{
	border-left: dotted 4px #1e2b38;
	background-color: rgba(204, 204, 204, .35);
}
.flow_type4 .box_txt1,
.flow_type4 .box_txt2{
	padding-left:20px;
}
.flow_type4 .box_wrap{
    position: relative;
    padding-left: 30px;
}
.flow_type4 .box_wrap:before{
    content: "";
    display: inline-block;
    height: calc(100% - 30px);
    border-left: 4px dotted #1e2b38;
    position: absolute;
    top: 30px;
    left: 26px;
}
.flow_type4 .cate_box:last-of-type{
	padding-bottom: 0;
}
.flow_type4 .box_description2{
    position: relative;
    border-left: none;
    background-color: rgba(255, 255, 255, 0);
}
.flow_type4 .box_description2 span{
	position: absolute;
    display: inline-block;
    width: 68px;
    top: 5px;
    left: -38px;
}

.top_info_left .txt_white{
    color: black;
}

.page_title_bg{
    display: none;
}

.linkStyle{
color: #29a9e0;
font-weight: bold;
}

.form_wrap{
    display: none;
}

#page_top a.txt_white{
    color: white;
}

#copyright{
    color: black;
}

.border_white {
    border-color: #484848;
}

#cms_6-b div.cate_title{
    color: black;
}

#cms_5-f .cate_box .open_bt .box_title1:before, .cms_5-f .cate_box .open_bt .box_title1:before {
    display: none;
}

.nav_wrap ul.sns_links{
        mix-blend-mode: difference;
}

#menu_nav #nav_logo {
    width: 100px;
}

#head_contact a {
    backdrop-filter: blur(5px);
    color: #979797;
}

#head_contact a {
    backdrop-filter: blur(5px);
    color: #c5c5c5;
}

#top_info .contact_bt a {
    background-color: rgba(255,255,255,0.5);
}


#top_info span.top_info_left_bg{
    opacity: 0;
}

.top_info_left > div{
        filter: invert(1) !important;
}

/*--------カスタム--------*/
@media screen and (max-width: 1080px){
    #pc_nav{
        display: none;
    }
}

/*--------タブレット--------*/
@media screen and (max-width: 768px){
.flow_type4 .cate_box{
	flex-direction: column-reverse;
}
.flow_type4 .box_description2 span {
	width: 61px;
	left: -34px;
}

#main_img {
    height: 100vh;
}

span.main {
    background-position: 15% 50% !important;
}

.modal_bt > h4, .modal_bt > h3{
    padding-left: 0;
}

#main_img:after {
    background-size: 330px;
    background-position: 5px 45%;
}

}


/*--------スマートフォン--------*/
@media screen and (max-width: 667px){
.flow_type4 .box_wrap{
    padding-left: 23px;
}
.flow_type4 .box_wrap:before {
    left: 19px;
}

span.main {
    background-size: cover;
    background-position: 20% 50% !important;
}

.tr {
    height: 30vh;
    background-size: cover;
    width: max(20%, 180px);
}

.br {
    height: 30vh;
    width: max(40%, 270px);
}

#main_img:before {
    background-size: 50%, 50%;
}

.modal_bt > h4, .modal_bt > h3{
    padding-left: 0;
}

.nav_wrap{
    padding-top: 130px;
}

#menu_nav #nav_logo {
    width: 62px;
}

#main_img:after {
    background-size: 215px;
    background-position: 5px 54.5%;
}

}