﻿#contents{
    margin: 0 auto;
    max-width: inherit;
    width: 100%;
}

/*--------リンク・フォント--------*/
@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;
}
@font-face {
    font-family: 'NotoSans';
    font-style: normal;
    font-weight: 900;
    src: url('../Dup/img/NotoSans_black.woff') format('woff'),
        url('../Dup/img/notosans_black.eot')  format('eot');
    font-display: swap;
}
@font-face {
    font-family: 'URW_DIN';
    font-style: normal;
    font-weight: 400;
    src: url('../Dup/img/URW_DIN.woff') format('woff'),
        url('../Dup/img/URW_DIN.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_urw{font-family: 'URW_DIN',"NotoSans",sunserif;}

.linkStyle{color: #333333; text-decoration: underline;}



/*--------youtube埋込--------*/
.youtube_box{
  position: relative;
  width: 60%;
    padding-top: 43.25%;
margin-bottom: 50px;
}
.youtube_box iframe{
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;

}


/*--------全体--------*/
#main_img{width: 80%;}
#main_img #left,
#main_img #right{
    z-index: 0!important;
    height: 85vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}
.subpage #header .nav_box{    padding: 15px 20px;}
.index_header .nav_box {
    padding: 30px 100px 13% 3%;
}
header.all_header {
    padding-bottom: 70px;
}
.all_header .contact_box {
    margin-top: 80px;
}
.index_header .nav_box{position:relative;}
/*
.index_header .nav_box:before{
content: '';
    display: block;
    background: repeating-linear-gradient(-45deg ,rgba(255, 255, 255, .3) 0,rgba(255, 255, 255, .3) 5px,transparent 5px,transparent 15px);
    width: 220px;
    height: 82%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 0;
}
*/
.contact_box{font-weight:700;}
.more span.before {background-color: #ffffff;}
.contact_box .header_contact_link a {
    padding: 8px 25px 8px;
    border: 2px solid #35449a;
    color:#333;
    font-weight: 900;
}
.contact_box .header_contact_link a:hover{
    color:#fff;
}
.index_header #global-nav ul li {
    margin: 0 0 25px;
    font-family: 'URW_DIN',"NotoSans",sunserif;
    font-size: 1.2em;
    text-transform: uppercase;
}
/*
#catch {
    position: relative;
        background: url(./Dup/img/item02.png) no-repeat;
    background-size: 58%;
    background-position: 100% 68%;
}
*/
#catch:after {
position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 15px;
    content: '';
    background-image: -webkit-repeating-linear-gradient(135deg, #017abd, #13b7bb 2px, transparent 2px, transparent 7px);
    background-image: repeating-linear-gradient(-45deg, #017abd, #13b7bb 2px, transparent 2px, transparent 7px);
    background-size: 10px 10px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

#catch .catch_txt > div{
    position: relative;
    width: 100%;
    margin: 0 auto;
}
/*
#catch .catch_txt > div::before{
content: "";
    display: inline-block;
    width: 35em;
    height: 13em;
    background: url(./Dup/img/item_01.png) no-repeat;
    position: absolute;
    left: -53px;
    top: -7px;
    background-size: 24%;
    z-index: -1;
}
*/
#catch .catch_txt h2{
   font-size: 2.6vw;
    letter-spacing: 4px;
    margin: 11%;
    padding: 0;
}
#catch .grid_9 p{
    background-color: rgba(255, 255, 255, .75);
}
#contents .contents_inner h2 {
    font-size: 2.4vw;
    letter-spacing: 0.25em;
    margin-bottom: 0;
}
#contents .contents_inner h2 span {
    top: 140px;
    width: 3px;
}
/*
#contents::before{
content: "";
    display: inline-block;
    width: 70em;
    height: 60em;
    background: url(./Dup/img/back1.png) no-repeat;
    position: absolute;
    right: -190px;
    top: 0px;
    background-size: cover;
    z-index: -1;
}
*/
#contents .bg_white_opa {background-color: #35449a;}
#contents .contents_inner .contents_txt {padding: 60px;}
#contents2 .contents_txt {background-color: rgba(255,255,255,0.9);}

#top_cms .cate_box:nth-child(1) {
  -webkit-animation: fade_up 0.5s ease 0.5s 1 forwards;
  animation: fade_up 0.5s ease 0.5s 1 forwards;
}
#top_cms .cate_box:nth-child(2) {
  -webkit-animation: fade_up 0.5s ease 1s 1 forwards;
  animation: fade_up 0.5s ease 1s 1 forwards;
}
#top_cms .cate_box:nth-child(3) {
  -webkit-animation: fade_up 0.5s ease 1.5s 1 forwards;
  animation: fade_up 0.5s ease 1.5s 1 forwards;
}
#top_cms .cms_title{
    position: relative;
}
/*
#top_cms .cms_title::before{
    content: "";
     display: inline-block;
    width: 17.5em;
    height: 13.5em;
    background: url(./Dup/img/item03.png) no-repeat;
    position: absolute;
    left: 52%;
    transform: translateX(-50%);
    top: 0px;
    background-size: cover;
    z-index: -1;
}
*/
#top_cms .cms_title .cms_title_inner span {
    top: 163px;
        width: 2px;
}
#top_cms .cms_title p.opacity06 {
     opacity: 1; 
}
#top_cms .cms_title h2{
    color:#333;
   font-family: 'URW_DIN',"NotoSans",sunserif;
    font-size: 2.3em;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 0px;
}
#top_cms .cms_title h2::first-letter{color:#35449a;}
#top_cms .d_flex .top_cms_box{width:46.5%;}
#cms_5-b .cate_box .open_bt .box_title1::before,
.cms_5-b .cate_box .open_bt .box_title1::before {
    content: " ";
}
#top_cms .cms_5-b .cate_box {margin-bottom: 25px;}
#top_cms .cms_5-b .cate_box .open_bt {padding: 9px 0;}
#top_cms .cms_5-b .cate_box .box_txt1 {
    margin-top: 10px;
    margin-bottom: 15px;
}
#footer_info .inner {
    width: 30%!important;
}
#footer_info .bg_white_opa {background-color: rgba(255,255,255,0.9);}
#top_cms .more a,
#footer_info .more a{
    color: #333;
    font-family: 'URW_DIN',"NotoSans",sunserif;
    font-size: 1.6em;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    border: 2px solid #333;
}
#top_cms .more a:hover,
#footer_info .more a:hover{
    color:#fff;
}
#bottom_menu nav li a{
    font-family: 'URW_DIN',"NotoSans",sunserif;
        text-transform: uppercase;
    letter-spacing: 1.5px;
}
#bottom_menu nav span.before { background-color: #cacac3;}



.all_header #global-nav ul li a, .fat-nav.active li a {
     font-family: 'URW_DIN',"NotoSans",sunserif;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-size: 1.3em;
}
.fat-nav li:last-child a {
    border-bottom: 1px solid #fff;
    border-top: 1px solid #fff;
}
#contents .contents_inner .contents_txt p{
    margin-right: 0px;
}


/*--------下層--------*/
#global-nav ul li a .after, .fat-nav.active li a .after {
    background-color: #fff;
}
.cate_list li a:hover {
    color: #fff;
}
#page_title .page_title_inner {
    padding-bottom: 25px;
}
#page_title .page_title_inner h2{
    color:#333;
   font-family: 'URW_DIN',"NotoSans",sunserif;
    font-size: 2.7em;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 0px;
}
#page_title .page_title_inner h2::first-letter{color:#35449a;}
#page_title .page_title_inner span {
    width: 2px;
    top: 140px;
}
#page_title .page_title_inner p.opacity06 {
     opacity: 1; 
}
#page_title .page_title_inner{
    position: relative;
}
/*
#page_title .page_title_inner::before{
    content: "";
     display: inline-block;
    width: 17.5em;
    height: 13.5em;
    background: url(./Dup/img/item03.png) no-repeat;
    position: absolute;
    left: 52%;
    transform: translateX(-50%);
    top: 0px;
    background-size: cover;
    z-index: -1;
}
*/
.cate_list li { border: 2px solid;}
.cate_list li a {
    color:#333;
    font-weight: 700;
}
.pager li a {
    font-family: 'URW_DIN',"NotoSans",sunserif;
    font-weight: 700;
}
    
#cms_5-b .cate_box, .cms_5-b .cate_box {border: 1px solid #2a2922;}
#cms_5-b .cate_box .open_bt, .cms_5-b .cate_box .open_bt { border: none;}
#cms_5-b .cate_box .box_item, .cms_5-b .cate_box .box_item { border: none;    padding: 0px 30px 0px;}
#cms_5-b .cate_box .box_txt1,.cms_5-b .cate_box .box_txt1{
	padding: 1em;
    background-color: #f5f5f5;
}
#cms_5-b .cate_box .open_bt .box_title1, .cms_5-b .cate_box .open_bt .box_title1 {  margin-left: 50px;}
#cms_5-b .cate_box .open_bt .arrow img, .cms_5-b .cate_box .open_bt .arrow img{display: none;}
#cms_5-b .cate_box .arrow, .cms_5-b .cate_box .arrow {
	left: 2px;
    top: 50%;
    margin-top: 0px;
}
#cms_5-b .cate_box .open_bt .arrow::before,
#cms_5-b .cate_box .open_bt .arrow::after,
.cms_5-b .cate_box .open_bt .arrow::before,
.cms_5-b .cate_box .open_bt .arrow::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #909090;
    
}
#cms_5-b .cate_box .open_bt .arrow::before,
.cms_5-b .cate_box .open_bt .arrow::before{
    top:48%;
    left: 15px;
    transform: rotate(0deg);    
transition: all 0.5s;
}
#cms_5-b .cate_box .open_bt .arrow::after,
.cms_5-b .cate_box .open_bt .arrow::after{    
    top:48%;
    left: 15px;
    transform: rotate(90deg);
transition: all 0.5s;
}
#cms_5-b .cate_box .open_bt .arrow.arrow_be::before,
.cms_5-b .cate_box .open_bt .arrow.arrow_be::before{
	transform: rotate(45deg);
transition: all 0.5s;
}
#cms_5-b .cate_box .open_bt .arrow.arrow_be::after,
.cms_5-b .cate_box .open_bt .arrow.arrow_be::after{
	transform: rotate(-45deg);
transition: all 0.5s;
}

#page8 .tel_box{
position: relative;
    overflow: hidden;
}
#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%;
}
#page10 .more { border: 2px solid;}
#page10 .more a {
    color:#333;
    font-weight: 700;
    font-size: 1.5em;
    text-transform: uppercase;
}
#page10 .more a:hover {
    color:#fff;
}

/*--------タブレット--------*/
@media screen and (max-width: 768px){
    
    #global-nav{display:none;}
    #logo {
    max-width: 250px;
    width: 30%!important;
}
    .all_header #global-nav ul li {width: auto;}
    .index_header .nav_box:before { display: none;}
    .index_header .nav_box {padding: 20px 0px 0px 20px;}
    .hamburger {
    top: 24px;
    opacity: 1;
    transform: translateY(0px);
    }
    #main_img .inner {
    margin-right: 0px;
    padding-bottom: 0;
}
    #main_img #left, #main_img #right {
      height: 45vh; 
}
#left .vegas-slide .vegas-slide-inner{background-position:100% 50%!important;}
#right .vegas-slide .vegas-slide-inner{background-position:0% 50%!important;}
.index_header #logo {
       width: 50%!important;
    max-width: 220px;
    margin-bottom: 20px;
    
}
#main_img {
    
    width: 100%;
    top: 100px;
    left: 0px;
}
.main_copy p {
    font-size: 5.5vw;
    top: 50%;
    left: 50%;
}
.main_copy p:nth-child(4) {
    font-size: 4vw;
}

header {padding-bottom: 55%;}
#slider {
    height: 100vh;
}
#catch {
    background-size: 85%;
    background-position: 96% 13%;
}
#contents::before{
        width: 39em;
        right: 0px;
    
}
#catch .catch_txt h2 {
    font-size: 4vw;
    letter-spacing: 4px;
    line-height: 2;
    margin: 3% 13%;
}
#contents .contents_inner h2 span { top: 120px;}
#contents .contents_inner h2 {font-size: 5vw;}
#contents .contents_inner .contents_txt p {
    padding: 10px 30px 30px;
}
#top_cms .d_flex .top_cms_box {
    width: 95%;
    margin: 0px auto 80px;
}
#top_cms .cms_title h2{font-size: 2.3em;}
#page_title .page_title_inner::before { left: 60%;}
#page10 .more {
    width: 44%!important;
}
#page10 .more a {font-size: 1.4em;}
    
.youtube_box {
    width: 83%;
    padding-top: 56.25%;
    margin: 50px auto;
}   
#footer_info .inner {
    width: 65%!important;
}
}

/*--------スマートフォン--------*/
@media screen and (max-width: 667px){
    .hamburger {top: 8px;}
    .hamburger__icon {margin-top: 11px;}
.index_header #logo {
    width: 71%!important;
    max-width: 220px;
    margin-bottom: 0px;
    padding-top: 0px;
}
    header {padding-bottom: 0%;}
    header.all_header {
    padding-bottom: 30px;
}
    .index_header .nav_box, .nav_box { padding: 10px 10px 15px 10px;}
    #main_img{width: 100%;}
    #main_img .inner { margin-right: 0px;}
    .main_copy p {
        width: 95%;
    font-size: 9vw;
    top: 40%;
    padding: 0px;
    }
    .main_copy p:nth-child(4) {
    font-size: 7vw;
}
main{    margin-top: -40%;}
    #slider {height: 90vh;}
    #catch .catch_txt h2 { font-size: 6vw;}
    #catch .catch_txt > div::before {
    width: 19em;
    left: -30px;
    top: -7px;
    }
    .all_header #global-nav ul li a, .fat-nav.active li a {
    font-size: 1.05em;
}
#catch .catch_txt > div {
    width: 87.5%;
}
    #contents .contents_inner .contents_txt p {
    padding: 10px 0px 30px;
}
#contents .contents_inner h2 span.border_anime.start{
    width: 2px;
    height: 40px;
    top: 97px;
}
#contents .contents_inner .contents_txt {
    margin-top: 0px;
    padding: 40px 30px 30px;
}
#top_cms .cms_title .cms_title_inner span.border_anime.start {
    width: 2px;
    height: 60px;
    top: 120px;
}
#top_cms .cms_title .cms_title_inner {
    padding-bottom: 15px;
}
#top_cms .cms_title h2 {
    font-size: 6.5vw;
}
#footer_info #logo2{    width: 75%!important;}
#top_cms .d_flex .top_cms_box {
    width: 100%;
}
#contents .contents_inner h2 {
    font-size: 7vw;
}
#contents .contents_inner h2 span {
    bottom: -100px;
}

#top_cms .more a, #footer_info .more a {
    font-size: 1.4em;
}
#footer .footer_cms p{
    padding-bottom: 30px;
}
footer{padding-bottom: 70px;}
#copyright{
    background-color: rgba(255,255,255,0);
    color: #333;
    padding: 0;
    font-size: 3.2vw;
    text-align: left;
    padding-left: 20px;
}
#copyright a{
    color: #333;
}
p.gotop {
    right: 15px!important;
    bottom: 60px!important;
}
.subpage #header .nav_box {
    padding: 10px 20px;
}
.subpage #logo {
    width: 44%!important;
    padding-top: 2px;
}

#page_title{padding-top: 200px!important;}
#page_title .page_title_inner {
    padding-bottom: 15px;
}
#page_title .page_title_inner h2 {
    font-size: 1.8em;
}
#page_title .page_title_inner span {
    top: 120px;
    height: 70px!important;
    width: 2px;
}
#cms_5-b .cate_box .box_item, .cms_5-b .cate_box .box_item {
    border: none;
    padding: 0px 10px 0px;
}
#page10 .more {
    width: 90%!important;
}

header .menu_btn_sp{
    display: block;
    position: fixed;
       top: 18px;
    right: 59px;
    z-index: 995;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
header .menu_btn_sp a{
font-size: 3.5vw;
    padding: 13px 13px;
}
#footer_info .inner {
    width: auto!important;
}
#sp_contact{
z-index:995;
position: fixed;
    bottom: 0px;
    right: 0;
    left: 0;
}
#sp_contact li{padding:15px 10px;text-align:center;background-color: #35449a;}
#sp_contact li a {display: block;font-size:4vw;color:#fff;}
#sp_contact .sp_con_line i{font-size: 1.1rem;}
}
.subpage header .menu_btn_sp {
    top: 17px;
}
.youtube_box {
    width: 100%;
    padding-top: 68.25%;
    margin: 36px auto;
}
.youtube_box {
    width: 100%;
    padding-top: 68.25%;
    margin: 36px auto;
}
@media screen and (max-width: 320px){
header .menu_btn_sp {
    right: 58px;
}
header .menu_btn_sp a {
    padding: 13px 6px;
}
}
/*--------------------------------------------
IE
--------------------------------------------*/
@media all and (-ms-high-contrast:none){
    .hamburger.head_fix {background-color: #0dd1d6;}


}





/* CSS Document */
/* color */
body,.txt_color_nomal{color: #333333;}
.txt_color_normal{color: #333333;}
.txt_white{color: white;}
.txt_red{color: red;}
.txt_color1{color: #35449a} /* メインカラー */
.txt_color2{color: #697A84} /* サブカラー */
.txt_color3{color: #302D2A} /* アクセントカラー1 */
.txt_color4{color: #E6EAED} /* アクセントカラー2 */

/* background-color */
.bg_white{background-color: white} /* 白背景 */
.bg_black{background-color: black} /* 黒背景 */
.bg_color1{background-color: #35449a} /* メインカラー */
.bg_color2{background-color: #697A84} /* サブカラー */
.bg_color3{background-color: #302D2A} /* アクセントカラー1 */
.bg_color4{background-color: #E6EAED} /* アクセントカラー2 */
.bg_color_clear{background-color: transparent!important}


/* border-color ※!important */
.border_color1{border-color: #35449a}
.border_color2{border-color: #697A84}
.border_color3{border-color: #302D2A}
.border_color4{border-color: #E6EAED}


/* hover ---------------------------------------------------------------------------------------------*/
/* color */
.hvr_txt_color_nomal:hover{color: #333333;}
.hvr_txt_white:hover{color: white;}
.hvr_txt_red:hover{color: red;}
.hvr_txt_color1:hover{color: #35449a} /* メインカラー */
.hvr_txt_color2:hover{color: #697A84} /* サブカラー */
.hvr_txt_color3:hover{color: #302D2A} /* アクセントカラー1 */
.hvr_txt_color4:hover{color: #E6EAED} /* アクセントカラー2 */

/* background-color */
.hvr_bg_white:hover{background-color: white} /* 白背景 */
.hvr_bg_black:hover{background-color: black} /* 黒背景 */
.hvr_bg_color1:hover{background-color: #35449a} /* メインカラー */
.hvr_bg_color2:hover{background-color: #697A84} /* サブカラー */
.hvr_bg_color3:hover{background-color: #302D2A} /* アクセントカラー1 */
.hvr_bg_color4:hover{background-color: #E6EAED} /* アクセントカラー2 */
.hvr_bg_color_clear:hover{background-color: transparent!important}

/* border-color ※!important */
.hvr_border_color1:hover{border-color: #35449a}
.hvr_border_color2:hover{border-color: #697A84}
.hvr_border_color3:hover{border-color: #302D2A}
.hvr_border_color4:hover{border-color: #E6EAED}

/*
.main_copy p {
    display: block;
    font-size: 4vw;
    text-align: center;
    color: #fff;
    padding: 20px;;
    opacity: 0;
    position: absolute;
    top: 45%;
    left: 56%;
    transform: translate(-50%,-50%);
    -webkit-animation-name: copy;
    -webkit-animation-duration: 20s;
    -webkit-animation-iteration-count: infinite;
    animation-name: copy;
    animation-duration: 21s;
    animation-iteration-count: infinite;
    animation-fill-mode : forwards;
}
.main_copy p:nth-child(1) {
    text-shadow: 0 0 15px rgba(255, 255, 255, .5),
               0 0 30px rgba(255, 255, 255, .5),
               0 0 40px rgba(103, 150, 224, 0.9),
               0 0 50px rgba(103, 150, 224, 0.9),
               0 0 60px rgba(103, 150, 224, 0.9),
               0 0 70px rgba(103, 150, 224, 0.9);
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}
.main_copy p:nth-child(2) {
    text-shadow: 0 0 15px rgba(255, 255, 255, .5),
               0 0 30px rgba(255, 255, 255, .5),
               0 0 40px rgba(254, 233, 105, 1),
               0 0 50px rgba(254, 233, 105, 1),
               0 0 60px rgba(254, 233, 105, 1),
               0 0 70px rgba(254, 233, 105, 1);
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}
.main_copy p:nth-child(3) {
    text-shadow: 0 0 15px rgba(255, 255, 255, .5),
               0 0 30px rgba(255, 255, 255, .5),
               0 0 40px rgba(185, 232, 143, 1),
               0 0 50px rgba(185, 232, 143, 1),
               0 0 60px rgba(185, 232, 143, 1),
               0 0 70px rgba(185, 232, 143, 1);
  -webkit-animation-delay: 10s;
  animation-delay: 10s;
}
.main_copy p:nth-child(4) {
    text-shadow: 0 0 15px rgba(255, 255, 255, .5),
               0 0 30px rgba(255, 255, 255, .5),
               0 0 40px rgba(247, 195, 232, 1),
               0 0 50px rgba(247, 195, 232, 1),
               0 0 60px rgba(247, 195, 232, 1),
               0 0 70px rgba(247, 195, 232, 1);
    font-size: 3.3vw;
  -webkit-animation-delay: 15s;
  animation-delay: 15s;
}

@-webkit-keyframes copy {
  0% {
     opacity: 0;
      transform: translateX(-100%);
  }
  15% {
    opacity: 1;
    transform: translateX(-50%);
  }
  35% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes copy {
  0% {
    opacity: 0;
    transform: translateX(-100%);
  }
  15% {
     opacity: 1;
     transform: translateX(-50%);
  }
  35% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}*/
