﻿/*--------link_font--------*/
@import url('https://fonts.googleapis.com/css2?family=Sawarabi+Gothic&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap');


:root {
    --font-jp: "Zen Kaku Gothic New", 'Noto Sans JP', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    --font-en: 'Barlow',  "Zen Kaku Gothic New", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.intro_title_en, .no.font_mo,#topCms .cmstitle p, .pagetitle .title_box p,#bottom_tel a span,.more a,.en{
    font-family: var(--font-en) !important;
}

h1, h2, h3, h4, h5, h6 ,.catch ,#topCms .cmstitle p, .pagetitle .title_box p,.pc_nav li .page_title,#sp_nav .sp_nav_inner .l-menu .l-menu_cms, .f_contact_btn a{
    font-family: var(--font-jp);

}

#top_contents1 h2,#top_contents2 h2,#top_cms h2,.title_box h2,.gyoumu_box h2{
        font-size: calc(1rem + 11px);
}

#top_contents1 h2 {
    font-size: calc(1rem + 16px);
}

.font_2dw {
    font-size: calc(1rem + 1px) !important;
    letter-spacing: 0px;
}



/* color -----------------------------------------------------------------------------*/
:root{
    --color1: #1E549F;
    --color2: #2E79BA;
    --color3: #5FC9F3;
    --color4: #BBE1FA;
    --color5: #EDEDED;
    --white:#ffffff;
    --black: #000033;
    --gray:#ccc;
}

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(--color1);
    border-bottom:solid 1px;
}

.linkStyle:hover{
	color: var(--color3);
	opacity: 0.7;
	transition: all 0.5s;
}

body#body {
    background: var(--white);
}
/* color -----------------------------------------------------------------------------*/


/* ----------　all　---------- */
.linkStyle{
	color:var(--color1);
}

.linkStyle:hover{
	color:var(--color1);
	opacity: 0.7;
	transition: all 0.5s;
}

#sp_nav .sp_nav_inner .l-menu ul li a span {
    display: none;
}

#sp_nav .sp_nav_inner .l-menu ul li a:hover {
    color: var(--color2);
}

#sp_nav .sp_nav_inner .l-menu ul li a {
    font-weight: 400;
}
#bottom_tel2 {
    right: 0;
    bottom: 94px;
    z-index: 4;
    display: none;
    max-width: 393px;
}
#bottom_tel a ,#bottom_tel2 a {
    height: 92px;
    border-right: 1px solid;
    box-sizing: border-box;
    transition: .3s;
    background: var(--color1);
    color: #fff;
    border-radius: 15px 0 0 0;
    padding: 7px 0;
}
#bottom_tel2 a {
    border-radius: 15px 0 0 15px;
    height: auto;
    padding: 10px 0;
}

#bottom_tel a:hover ,#bottom_tel2 a:hover {
    background: var(--color3);
    color: var(--color5);
}

#bottom_tel a span,#bottom_tel2 a span {
    font-size: calc(1rem + 12px) !important;
    letter-spacing: 0px;
}

#bottom_tel a span .tel_another #bottom_tel2 a span .tel_another {
    font-size: calc(1rem + 0px) !important;
    letter-spacing: 0px;
}

#bottom_tel a span i,#bottom_tel2 a span i, .f_contact_btn a span i,.contact_tel a i{
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-style: initial;
}

.f_con_bgcolor {
    background: #000;
    opacity: 0.3;
}

.pc_nav .page_title {
    font-weight: 900 !IMPORTANT;
}
/* ----------------------------------------------------------------------------------------------　top　----------------------------------------------------------------------------------------------------------------- */
#main_img .swiper-slide:before,#main_img .swiper-slide:after{
    content: "";
    background: var(--color1);
    position: absolute;
}

.slider1 {
    transform: rotate(-3deg);
}

#main_img:after {
    height: 30%;
    background: linear-gradient(0deg, #fff 14%, transparent);
    opacity: 1;
    z-index: 0;
}

#content .box_img img {
    height: auto !important;
    width: 100% !important;
    border-radius: 10px;
}

.footer .footertxt {
    color: var(--black);
}

.copy {
    background-color: var(--color1);
    color: var(--white);
}

#content {
    background-color: linear-gradient(180deg, var(--color4), transparent);
    background-image: url(/Files/img/content_bg.png);
    background-size: cover;
    background-position: bottom;
    background-repeat: no-repeat;
}

/* ---------------------------------------　topCms　▼--------------------------- */

#topCms .cmstitle p, .pagetitle .title_box p {
    font-weight: 200;
}

/* ---------------------------------------　topCms　▲--------------------------- */


/* -----------------------------------------------------------------------------------------------　下層ページ　--------------------------------------------------------------------------------------------------------- */
.pagetitle {
    background-color: linear-gradient(180deg, var(--color4), transparent);
    background-image: url(/Files/img/page_bg.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#cms_2-g .cate_title {
    line-height: 1.5;
    font-size: 2.2em;
}

#page2 .footer_contact:before,#page3 .footer_contact:before,#page4 .footer_contact:before,#page5 .footer_contact:before,#page6 .footer_contact:before,#page7 .footer_contact:before,#page8 .footer_contact:before,#page9 .footer_contact:before,#page10 .footer_contact:before {
    content: "";
    position: absolute;
    width: 100px;
    height: 20px;
    top: -2px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    background-color: var(--color5);
    z-index: 1;
}

/* サイトマップ */
#page10 .sitemap li .sub {
    font-weight: 300;
}

/*-----------------------------------------------------------------------------------------------------------1000----------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 1000px){
}

/*---------------------------------------------------------------------------------------------------------タブレット------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 768px){

/* ----------　all　---------- */
#bottom_tel {
    max-width: 343px;
}
#bottom_tel2 {
    bottom: 54px;
}
#bottom_tel a {
    height: 50px;
}
/* ----------　TOP　---------- */
#main_img {
    padding-bottom: 14vh;
}

.catch.slide_ver {
    padding-right: 20px;
    max-width: 100%;
}

#main_img::before {
    top: 12px;
    background-size: auto 35%;
    animation: loop 50s linear infinite;
}

#content .box_img {
    max-height: 350px;
    overflow: hidden;
  }

#content .cate_item {
    padding: 30px 15px 40px 35px;
}
}

/*---------------------------------------------------------------------------------------------------------スマホ----------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 667px){
.header .logo1{padding-right: 0px;max-width: 120px;padding: 10px 0;}

/* ----------　all　---------- */
#fakeloader .fl {
    width: 40% !important;
}
.copy {
    padding-top: 10px;
    padding-bottom: 60px;
}
#bottom_tel a, #bottom_tel2 a {
    border-radius: 0;
    padding: 5px 0;
}
#bottom_tel a span, #bottom_tel2 a span {
    font-size: calc(1rem + 8px) !important;
}
/* ----------　TOP　---------- */
#main_img {
    padding-bottom: 12vh;
    padding-top: 70px;
}

#main_img::before {
    top: 32px;
}

#main_img:after {
    height: 40%;
    background: linear-gradient(0deg, #fff 34%, transparent);
    opacity: 1;
    z-index: 1;
}

.catch:after {
    display: none;
}

.catch.slide_ver {
    right: -5px;
    max-width: 100%;
    padding-top: 0px;
    padding-right: 10px;
    bottom: 20px;
    padding-bottom: 20px;
}

.intro_title_en {
    top: 50px;
    left: 5px;
    font-size: calc(1rem + 9px);
}

.intro_inner {
    width: 85%!important;
}

.intro_inner h2 {
    line-height: 1.4;
    font-size: -webkit-calc(1rem + 11px);
    font-size: calc(1rem + 9px);
}

.pagetitle .title_box p {
    bottom: -20px;
}

#cms_2-g .cate_title {
    font-size: 1.8em;
}

#content {
    position: relative;
    top: -2px;
}

#content .box_img {
    max-height: 280px;
}

#content .box_img img {
    height: 100% !important;
    width: auto !important;
}

.modal_title1 {
    font-size: -webkit-calc(1rem + 10px);
    font-size: calc(1rem + 10px);
    letter-spacing: 0;
}

#content .box_title{
    font-size: -webkit-calc(1rem + 2px);
    font-size: calc(1rem + 2px);
    letter-spacing: 0;
}

.modal_title1 {
    padding-top: 0px;
    font-size: -webkit-calc(1rem + 2px);
    font-size: calc(1rem + 1px);
    letter-spacing: 0;
}

}