﻿/*--------link_font--------*/
@font-face {
    font-family: 'ZenOldMin';
    font-style: normal;
    font-weight: 400;
    src: url('./Dup/img/ZenOldMincho_r.woff') format('woff'),
        url('./Dup/img/ZenOldMincho_r.eot')  format('eot');
    font-display: swap;
}
@font-face {
    font-family: 'ZenOldMin';
    font-style: normal;
    font-weight: 700;
    src: url('./Dup/img/ZenOldMincho_b.woff') format('woff'),
        url('./Dup/img/ZenOldMincho_b.eot')  format('eot');
    font-display: swap;
}
body{font-family: "ZenOldMin","游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";}
.linkStyle{color: #333333; text-decoration: underline;}

.linkStyle{color: #333333; text-decoration: underline;}

body .font_14 {font-size: 16px;}

/*--------all_page--------*/
#wrap{
    position:relative;
    background: linear-gradient(309deg, #f9f0f3, #f6ebee);}
    
.back1.pd_t-5per {
    padding-top: 7%;
}
#main_img{
    background-image: url(./Dup/img/main_img.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
}
#pc_nav li:last-of-type{
    padding-right: 125px;
}  

.top header.scr_header #pc_nav li a.txt_white {
    font-weight: bold;
}
.add_contact{    right: -50px;}

@media screen and (min-width: 768px) and (max-width: 1280px){
    .add_contact {
    right: 120px;
    top: 38px;
    transition: 0.3s;
}
.top header.scr_header .add_contact {
    top: 15px;
    transition: 0.3s;
}
}

@media screen and (max-width: 768px){    
#header{padding: 0 1.5% 0 5%;}
header #nav_menu .add_contact {
    top: 27px;
    right: 100px;
    transition: all 0.3s;
}

header.scr_header #nav_menu .add_contact {
    top: 14px;
}
}
@media screen and (max-width: 667px){
    .button_container {
    right: 2%;
    }
    #header.pd_l-r5per {
    padding: 0 1.5%;
}
header #nav_menu .add_contact {
    top: 6px;
    right: 55px;
}
header.scr_header #nav_menu .add_contact {
    top: 9px;
}
header #nav_menu .add_contact a {
    ppadding: 8px 12px;
    font-size: 4.1vw;
    letter-spacing: 0.1em;
}
}

#top_pc_nav ul li a{
    text-shadow: 0 0 5px #141414;
    font-size: calc(1rem + 1px);
}

#main_img .menu .bg_white {
    background-color: rgba(255, 255, 255, 0);
}
header.scr_header #logo {
    max-width: 180px;
}
.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;}

.line:before {
    background-color: rgba(227, 227, 227, .8)!important;
}

#intro:after{
    content: "";
    position: absolute;
    display: inline-block;
    background: url(./Dup/img/item_01.png) no-repeat;
    background-size: contain;
    z-index: 0;
    opacity: 0.9;
    width: 12%;
    height: 10em;
    left: 51.5%;
    transform: translateX(-50%);
    top: -50px;
}
#intro_wrap {
    background-color: rgba(255, 255, 255, .5);
}
#contents1{
    background-image: url(./Dup/img/item_02.jpg);
    background-repeat: no-repeat;
    background-size: auto;
    background-position: 50% 50%;
}
#contents2{
    background-image: url(./Dup/img/item_03.jpg);
    background-repeat: no-repeat;
    background-size: 30%;
    background-position: 50% 88%;
}
#contents3_wrap:before {
    background-attachment: fixed;
    background-position: 50% 0%;
}

#contents3 .con_box {
    box-shadow: rgba(185, 185, 185, .15) 0px 48px 100px 0px;
}
#contents3 .con_box.bg_white {
    background-color: rgba(255, 255, 255, .8);
}
#contents3 .con_box::before {
  top: -1px;
  bottom: -1px;
  left: 80px;
  right: 80px;
}
#contents3_wrap:after {
    background-color: rgba(247, 247, 247, .55)!important;
}
#info_contact .con_box:before{
    content: "";
    position: absolute;
    display: inline-block;
    opacity: 0.6;
    bottom: -23px;
    z-index: +2;
    pointer-events: none;
}
#info_contact .con_box:nth-of-type(1):before{
    background: url(./Dup/img/item_04.png) no-repeat;
    background-size: contain;
    width: 22%;
    height: 60%;
    left: -55px;
}
#info_contact .con_box:nth-of-type(2):before{
    background: url(./Dup/img/item_05.png) no-repeat;
    background-size: contain;
    width: 14%;
    height: 50%;
    right: -30px;
}
#h1txt p {
    font-size: 0.75em;
    letter-spacing: 0.2em;
    line-height: 1.2;
}


/*--------sub_page--------*/
.page #logo { max-width: 230px;}
.page #page_title{
    background-image: url(./Dup/img/sub.jpg);
    background-repeat: no-repeat;
    background-position: 50% 40%;
}
#page_title:before {
    background-color: rgba(202, 177, 217, .2);
}

.page header #pc_nav li a.txt_white {
    color: #26104e;
    font-weight: bold;
}
.page header.scr_header #pc_nav li a.txt_white {
    color: #fff;
}
.page .con_box.bg_white {
    background-color: rgba(255, 255, 255, .3);
}

#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;
        letter-spacing: 1px;
        font-size: 0.92em;
    }
}
@media screen and (max-width: 667px){
#page8 .tel_box a{
    font-size: 5vw;
    letter-spacing: 2px;    
}
}

#page10 .more_btn {
    text-transform: none;
}
#overlay .right p.opacity07 {
     opacity: 1; 
}

.overlay {
    background: linear-gradient(135deg, rgba(188, 151, 211, .9) , rgba(187, 163, 178, .9) )!important;
}

/*--------mobile_tb--------*/
@media screen and (max-width: 768px){
header.scr_header #logo {
    max-width: 170px;
}

.back1.pd_t-5per {
    padding-top: 11%;
}
#contents1 {
    background-size: 65%;
}

#contents2 .con_box {
    margin-top: 3%;
}
#contents2 {
    background-size: 45%;
}

#h1txt{text-align:left;}

#info_contact{
    margin-bottom: 0;
    padding-bottom: 30px;
}
.page #page_title {
    background-position: 13% 50%;
}
.page .button_container span:not(:first-of-type){
    background: rgba(33, 14, 72, 1)!important;
}
.page .button_container span.txt_white {
    color: rgba(33, 14, 72, 1);
}
}



/*--------mobile_sp--------*/
@media screen and (max-width: 667px){
#wrap.font_14 {
    font-size: 3.7vw;
    line-height: 1.7;
    letter-spacing: 0.15em;
}
header.scr_header #logo {
    max-width: 130px;
}
#main_img{
    background-image: url(./Dup/img/main_img_sp.jpg);
}
.back1.pd_t-5per {
    padding-top: 20%;
}
#intro_wrap {
    padding: 15% 3%;
}
#intro:after {
    width: 36%;
}
#contents1 {
    background-size: cover;
}

#contents2 {
    padding: 0 0 50px 0;
    margin: 50px 0;
    background-size: 90%;
    background-position: 73% 108%;
}

#contents3_wrap {
    padding: 100px 0;
}
#contents3_wrap:before, #contents3_wrap:after {
    top: 0px;
}
#info_contact .con_box:nth-of-type(1):before {
    left: -30px;
    bottom: -3px;
}
#info_contact .con_box:nth-of-type(1):before {
    right: -19px;
    bottom: -3px;
}
footer h2.font_26{    font-size: 5vw;}
.page_title_box .font_24_sp {
    font-size: 5vw;
    letter-spacing: 0px;
}
.page #page_title {
    background-position: 100% 50%;
    background-size: cover;
}

.page #logo {max-width: 110px;}

.cate_list li a { text-align: left;padding-left:45px;}

}

/*--------SEO--------*/
@media screen and (max-width: 667px){
#wrap.font_14 {
    font-size: 16px;
}
#info_contact .con_box {
    margin-bottom: 32px;
}
}