﻿/*--------リンク・フォント--------*/
@font-face {
    font-family: 'NotoSans';
    font-style: normal;
    font-weight: 400;
    src: url('./Dup/img/NotoSans_r.woff') format('woff'),
        url('./Dup/img/Notosans_r.eot')  format('eot');
    font-display: swap;
}
@font-face {
    font-family: 'NotoSans';
    font-style: normal;
    font-weight: 700;
    src: url('./Dup/img/Notosans_bold.woff') format('woff'),
        url('../Dup/img/Notosans_bold.eot')  format('eot');
    font-display: swap;
}
body{font-family: "NotoSans","游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
    font-size: 16px;
}

.linkStyle{color: #333333; text-decoration: underline;}

/*--------全体--------*/
.back1:before {
    background-image: url(./Dup/img/back1.jpg);
    background-repeat: no-repeat;
    background-size: auto;
}
.back2:before {
    background-image: url(./Dup/img/back2.jpg);
    background-repeat: no-repeat;
    background-size: auto;
    background-position: 76% 50%;
}
.back1, .back2,#contents3 {
    background-color: #fff;
}
#main_img::after{
    content: "";
    position: absolute;
    display: inline-block;
    background: url(./Dup/img/main_catch.png) no-repeat;
    background-size: contain;
    z-index: 1;
    opacity: 1;
    width: 32%;
    height: 22%;
    left: 50%;
    top: 3%;
    transform: translate(-50%, 0);
}
#contents3 .con_box{
    box-shadow: rgba(0, 0, 0, 0.1) -4px 9px 25px -6px;
    background-color: rgba(255, 255, 255, .85);
}
#contents3_wrap:after {
    background-color: rgba(201, 202, 193, .4)!important;
}
#contents3_wrap:before {
    background-attachment: fixed;
}


.top .more_btn {    
    display: block;
    position: relative;
    box-sizing: border-box;        
    overflow: hidden;
    border: #fc5f42 solid 1px;
    max-width: 300px;
    height: 50px;
    margin: 50px auto;
    padding: 10px 0;
}
.top .more_btn a{
  display: block;
}
.top .more_btn div {
    position: absolute;
    text-align: center;
    width: 100%;
    height: auto;
}
.top .more_btn div:nth-of-type(1) {
    color: #fc5f42;
}
.top .more_btn div:nth-of-type(2) {
    background-color: #fc5f42;
    transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    transform: translate(-400px, -10px) skewX(-30deg);
    height: 50px;
    width: 120%;
}
.top .more_btn div:nth-of-type(3) {
    color: #ffffff;
    left: -350px;
    transition: left 0.2s ease;
    -webkit-transition: left 0.2s ease;
    -moz-transition: left 0.2s ease;
}
.top .more_btn:hover div:nth-of-type(2) {
    transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    transform: translate(-35px, -10px) skewX(-30deg);
    -webkit-transform: translate(-35px, -10px) skewX(-30deg);
    -moz-transform: translate(-35px, -10px) skewX(-30deg);
}
.top .more_btn:hover div:nth-of-type(3) {
    left: 0px;
    transition: left 0.30000000000000004s ease;
    -webkit-transition: left 0.30000000000000004s ease;
    -moz-transition: left 0.30000000000000004s ease;
}



#page10 .more_btn{		
	position: relative;	
	text-transform: uppercase;
	transition: all 500ms cubic-bezier(0.77, 0, 0.175, 1);	
	cursor: pointer;
	user-select: none;
	padding-bottom: 8px!important;
}
#page10 .more_btn:before, #page10 .more_btn:after {
	content: '';
	position: absolute;	
	transition: inherit;
	z-index: 0;
}
#page10 .more_btn:hover{
	transition-delay: .5s;
}
#page10 .more_btn:hover:before{
	transition-delay: 0s;
}
#page10 .more_btn:hover:after{
	transition-delay: .35s;
}
#page10 .more_btn:before, 
#page10 .more_btn:after {
	top: 0;
	width: 0;
	height: 100%;
}
#page10 .more_btn:before {
	left: 0;
	border: 1px solid;
	border-left: 0;
	border-right: 0;	
}
#page10 .more_btn:after{
	top: 1px;
	right: 0;
}
#page10 .more_btn:hover:before,
#page10 .more_btn:hover:after {
	width: 100%;
}
#top_cms{position:relative;}
#top_cms:before{
    content: " ";
    position: fixed;
    display: inline-block;
    width: 100%;
    height: 100%;
    background: url(./Dup/img/back1.jpg) no-repeat;
    background-size: cover;
    left: 0px;
    top: 0px;
    z-index: -10;
    opacity: 0.45;
}
#info_contact .con_box a{
    box-shadow: rgba(17, 17, 26, 0.05) 0px 4px 16px, rgba(17, 17, 26, 0.05) 0px 8px 32px;
}


.add_btn {
    position: fixed;
    right: 80px;
    z-index: 2;
}
.add_btn a span {
  position: relative;
}
.add_btn a {
  position: relative;
  display: inline-block;  
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  text-align: center;
  color: #fff;
  font-size: 1.5em;
  border-radius: 10px;
padding: 15px 80px;
   background-image: -webkit-linear-gradient(
    335deg,
    #fc5f42 0%,
    #e3492c 25%,
    #ebd74a 90%,
    #f5e7ca 100%
  );
  background-image: linear-gradient(
    115deg,
    #fc5f42 0%,
    #e3492c 25%,
    #ebd74a 90%,
    #f5e7ca 100%
  );
  -webkit-box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2);
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2);
}
.add_btn a:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  background-image: -webkit-linear-gradient(
    335deg,
    #fc5f42 0%,
    #e3492c 15%,
    #ebd74a 70%,
    #f5e7ca 100%
  );
  background-image: linear-gradient(
    115deg,
    #fc5f42 0%,
    #e3492c 15%,
    #ebd74a 70%,
    #f5e7ca 100%
  );
  border-radius: 10px;
}
.add_btn span a:after {
  font-family: "Font Awesome 5 Free";
  font-size: 1.6rem;
  line-height: 1;
  position: absolute;
  top: calc(50% - 0.8rem);
  right: 1rem;
  margin: 0;
  padding: 0;
  content: "\f30b";
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.add_btn a:hover {
  color: #fff;
}
.add_btn a span i{
 transition: all 0.5s;
}
.add_btn a:hover span i{
 transform: translateX(10px);
 transition: all 0.5s;
}

.add_btn a:hover:before {
  opacity: 0;
}
.add_btn a:hover:after {
  right: 0.5rem;
}



.overlay {background: linear-gradient(135deg, rgba(231, 124, 105,.9) , rgba(221, 137, 104, .85) )!important;}
.overlay .opacity07 {opacity: 1;}
.nav_menu_more:first-of-type a .icon:before{content: "\f879";}
#nav_menu .mg_b-50px h2,#nav_menu .mg_b-50px .nav_menu_more:last-of-type{display:none;}
#overlay .left li { max-width: inherit!important;}

/*--------下層--------*/


#page8 .tel_box{
    position: relative;
    overflow: hidden;
    padding: 20px 20px 15px 20px;
}
#page8 .tel_box > a:before{
    content:"";
    position: absolute;
    width:100vw;
    height:100vh;
    -moz-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
    left:50%;
    top:50%;
}
@media screen and (max-width: 1200px){
    #page8 .tel_box p{
        display: block;
        padding-right: 0px;
        margin-right: 0px;
        border-right: none;
        
    }
}

@media screen and (max-width: 667px){  
#page8 .tel_box a{
    font-size: 4.8vw;
    letter-spacing: 2px;    
}
}

/*--------タブレット--------*/
@media screen and (max-width: 768px){
#logo {
    opacity: 0;
}
header.scr_header #logo {
    opacity: 1;
}
#main_img::after {
        width: 45%;
    top: auto;
    bottom: 1.5%;
    }
    #intro_wrap::before {
    width: 14em;
    height: 4em;
    }

    #contents1 .con_box,
    #contents2 .con_box{
background-color: #fff;
    margin-top: 10%;
}
#footer .con_box h2{display:none;}

.add_btn {
    right: 65px;
}
.top .more_btn div:nth-of-type(2),.top .more_btn div:nth-of-type(3){display:none;}


.page_title h2{font-size:3.5vw;}
    #h1txt{display:none;}
    #footer{    padding-bottom: 70px;}
    #foot_fix_ban {
    right: 52px;
    width: 37%;
    }
}

/*--------スマートフォン--------*/
@media screen and (max-width: 667px){
#intro_wrap {
    padding-bottom: 24%;
}
#main_img::after {
    width: 80%;
    height: 13%;
    top: auto;
    bottom: 4%;
}
    #contents1 .con_box,
    #contents2 .con_box{
        padding:20px;
        margin-top: 0%;
}
    
    #foot_fix_ban {
    right: 30px;
    width: 53%;
}
#footer {
    padding-bottom: 90px;
}
.add_btn {
    right: auto;
    left: 50%;
    transform: translate(-50%, 0);
    width: 80%;
    text-align: center;
}
.add_btn a {
    padding: 2% 27%;
    font-size: 5.3vw;
}
.page_title_box{
    width: 80%;
    background-color: transparent;
}
.pager li a {
    padding: 10px 10px 3px 10px;
}
    
}


/*--------------------------------------------
IE
--------------------------------------------*/
@media all and (-ms-high-contrast:none){
}




