@charset "UTF-8";

/*テンプレートcssファイルの読み込み
---------------------------------------------------------------------------*/
@import url("aos.css");
@import url("drawer.css");
@import url("../webfonts/css/all.css");
@import url("../slick/slick.css");
@import url("../slick/slick-theme.css");

/*全体の設定
---------------------------------------------------------------------------*/
html {
-moz-text-size-adjust:none;
-webkit-text-size-adjust:100%;
overflow-x: hidden;
overflow-y:scroll;
}
body {font-size:1em;
font-family: "Meiryo", "メイリオ", "ＭＳ　Ｐゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;font-style:normal;
line-height: 1.9;color: #333;-webkit-text-size-adjust: 100%;text-align: center;-webkit-font-smoothing: antialiased;}
* {
margin: 0;
padding: 0;
}

/*リセット*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
margin:0;
padding:0;
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
dd {margin: 0;}
nav,ul,li,ol {margin: 0;padding: 0;}
ul {list-style: none;}
input {font-size: 1rem;}

.clearfix:after {
content: "."; 
display: block;
clear: both;
height: 0;
visibility: hidden;
}
.clearfix {
min-height: 1px;
overflow:hidden;
}

/*reCAPTCHA*/
.grecaptcha-badge { visibility: hidden; }


/*container（サイト全般を囲むブロック）
---------------------------------------------------------------------------*/
.container,
.container_top{
padding: 0 6%;
box-sizing:border-box;
width:100%;
}
#main {
display: grid;
grid-template-rows: auto 1fr auto;
grid-template-columns: 100%;
min-height: 100vh;
}
@media screen and (min-width: 768px) {
.container {
margin: 0 auto;
}}
@media screen and (min-width: 1024px) {
.container{
width:1000px;
padding: 0;
}}
@media screen and (min-width: 1300px) {
.container_top {
padding: 0 10%;
}}

/*img*/
img{vertical-align:middle;border-style:none;border:0;-webkit-backface-visibility: hidden; backface-visibility: hidden;}
a:hover img{opacity:0.8;filter:alpha(opacity=80);-ms-filter:"alpha( opacity=80 )";}
/*img Chromeのみ*/
@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
img {image-rendering: -webkit-optimize-contrast;}
}

/*p*/
p {text-align: justify;}

/*回りこみ解除*/
.clear {
clear:both;
}
a img,
ol li img,
li img,
ul li img {/*上揃え*/
vertical-align: top;
text-align:center;
border-style:none;
}
img {
vertical-align: middle;
border: none;
max-width: 100%;
height: auto;
}

/*フロート設定*/
.tex img.centered,.tex img.aligncenter {
display:block;
margin-left:auto;
margin-right:auto;
clear:none;
}
.tex img.alignright,
.tex .alignright img{
margin-left:20px;
margin-right:0;
margin-bottom:20px;
display:inline;
clear:none;
}
.tex img.alignleft,
.tex .alignleft img {
margin-left:0;
margin-right:20px;
margin-bottom:20px;
display:inline;
clear:none;
}
.tex img.alignnone,
.tex .alignnone img {
margin-left:0;
margin-right:0;
margin-bottom:10px;
clear:none;
display:block;
}
.tex .alignright,.right {
float:right;
}
.tex .alignleft {
float:left;
}
@media only screen and (max-width:60em) {
.tex img.alignright,.tex img.alignleft,.tex img.alignnone,.tex img.aligncenter {clear:both;display:block;margin-left:auto;margin-right:auto;}
.tex .alignright {float:none;}
.tex .alignleft {float:none;}
.tex .aligncenter {clear:both;display:block;margin-left:auto;margin-right:auto;}
}


/*リンク（全般）設定
---------------------------------------------------------------------------*/
a {
color:#333;
text-decoration:none;
}
a:hover {
color:#848484;
text-decoration:none;
}
/* a TEL */
a[href^="tel:"] {text-decoration:none;color:#333;}
@media screen and (min-width: 1024px) {
a[href^="tel:"] {pointer-events: none;}
}

/*PC･スマホ 表示・非表示
---------------------------------------------------------------------------*/
@media screen and (min-width: 1024px) {.sp{display: none !important;}}
@media screen and (max-width: 1023px) {.pc{display: none !important;}}


/*pagetop
---------------------------------------------------------------------------*/
.pagetop {
display: none;
position: fixed;
bottom: 0;
left: 0;
}
.pagetop a {
display: block;
background-color: #3f3a83;
text-align: center;
color: #FFF;
font-size: 12px;
padding: 8px 13px 8px 13px;
}
.pagetop a:hover {
display: block;
opacity: 0.5;
transition: 0.5s;
text-align: center;
color: #fff;
}


/*header（ロゴが入ったサイト上部のブロック）
---------------------------------------------------------------------------*/
/*ロゴ画像*/

h1 a {
background: url(../img/logo.svg) no-repeat;
background-size: 120px 18px;
display: block;
width: 120px;
height: 18px;
float: left;
}
h1 a span {
display: none;
}
h1 a.logo{
margin: 18px 0;
}

@media screen and (min-width: 768px) {
h1 a {
background-size: 130px 20px;
width: 130px;
height: 20px;
}
}
@media screen and (min-width: 1024px) {
h1 a {
background-size: 139px 21px;
width: 139px;
height: 21px;
}
h1 a.logo{
margin: 30px 0 15px 0;
}
}


/*フッター
---------------------------------------------------------------------------*/
#footer {
width: 100%;
color: #fff;
padding: 60px 0;
background: #100964;
}
.flexbox:afterr{content: "";
display: block;
clear: both}

/*address*/
.f_box {
text-align: left;
}
.f_box h5 {
margin: 0 0 20px 0;
font-style: normal;
}
.f_box h5 img {
width: 140px;
height: auto;
}
.f_box h5 span {
display: block;
font-size: 15px;
color: #fff;
}
.f_box address {
font-style: normal;
display:block;
}
.f_box address a{
color: #fff;
}
.f_box address p{
margin: 20px 0 0 0;
}
.copy {
font-family: Verdana, “Droid Sans”;
font-size: 70%;
padding: 30px 0 0 0;
text-align: left;
font-weight:normal;
clear: both
}

/*footer　menu　 */
.flex_foot-box {
display: flex;
text-align: left;
}
.flex_foot-item ul {
list-style: none;
}
.flex_foot-item li{
font-weight:600;
text-align: left;
line-height: 1.6;
}
.flex_foot-item ul li a{
font-size:80%;
color: #fff;
height: 100%;
width: 100%;
text-transform:uppercase;/* 大文字 */
}
.flex_foot-item ul li a:hover {
opacity: 0.6;
transition: 0.5s;
}
/*リストの点 */
.flex_foot-item li.list-h {
position: relative;
list-style-type: none;
list-style-position: inside;
margin-left:18px;
font-weight: normal;
}
.flex_foot-item li.list-h :before{
content: '';
width: 5px;
height: 1px;
background-color: white;
position: absolute;
top: 14px;
left: -10px;
}


@media screen and (min-width: 768px) {
#footer {
display: flex;
justify-content: space-between;
padding: 100px 0;
}
.copy{
padding: 5% 0 0 0;
}
.f_box {
width: auto;
margin: 0 50px 0 0;
text-align: left;
float: left;
}
.flex_foot-item {
padding-left: 20px;
}
}

@media screen and (min-width: 1024px) {
.flex_foot-item ul li {
line-height: 2;
}
.flex_foot-item ul li a{
font-size: 90%;
}
.flex_foot-item {
padding-left: 50px;
}
}

@media screen and (max-width: 767px){
.f_box{
width: 100%;
}

.flex_foot-box {
margin-top: 30px;
display: block;
column-count: 2;
}
.flex_foot-item ul li {
font-weight:normal;
line-height: 2;
}
.flex_foot-item li.list-h {
display: none
}
}

/*footerbutton Contact
---------------------------------------------------------------------------*/
.button_contact{
margin-bottom: 30px;
display: flex;
justify-content: flex-end;
}
.button_contact a{
width: 200px;
margin: 0;
padding: .9em 2em;
color: #fff;
font-weight: normal;
font-size: 1em;
border: 1px solid #fff;
display: block;
background-color: none;
text-align: left;
position: relative;
flex: flex-end
}
.button_contact a::after {
content: '\f0e0';
font-family: 'fontawesome';
font-weight: 900;
position: absolute;
top: 50%;
right:2em;
margin-top: -15px;
}
.button_contact a:hover {
background-color: #3f3a83;
color: #fff;
border: 1px solid #3f3a83;
opacity: 0.8;
transition: 0.8s;
}
@media screen and (max-width: 767px){
.button_contact a{
width: 100%;
}
}


/*table
---------------------------------------------------------------------------*/
table {
width: 100%;
border-collapse: collapse;
margin: 10px 0;
border-style: solid;
border-width: 0;
text-align: left;
}
table td {
font-weight:normal;
padding: 15px 0;
border-bottom: 1px solid #ccc;
vertical-align: middle;
}
table.normal td:first-child{
width: 15%;
color: #3f3a83;
font-weight: bold
}
.red {
color: red;
}
.contactform-width {
max-width: 100%;
}
/* 確認赤枠 */
.red_line {
margin: 2em 0;
padding:2em;
border: solid 1px red;
text-align: center;
font-weight:normal
}
.red_line p {
margin: 0; 
padding: 0;
}
@media only screen and (max-width: 787px) {
table.normal td {
width: 100%;
display: block;
padding: 10px 0;
}
table.normal td:first-child{
width: 100%;
border-bottom: none;
padding: 20px 0 0 0;
}
}



/*お問い合わせ　バナー
---------------------------------------------------------------------------*/
.two-inquiry-pc{
width: 80%;
margin: 0 auto;
}
.two-inquiry-pc:after{content: "";
display: block;
clear: both}
.two-inquiry-l{
margin-bottom: 10px}
.two-inquiry-limg{
width: 185px;
height: auto}
.two-inquiry-r i{
padding-right: 10px
}
.back_inquiry .size{
font-size:1.3em;
}
.btn_01 a {
display: flex;
justify-content: center;
align-items: center;
position: relative;
width: 100%;
height: 75px;
line-height:75px;
margin: 0 auto;
padding: 0;
background-color: #fff;
font-size: 1em;
color: #333;
text-decoration: none;
}
.btn_01 a:hover {
color:#848484;
text-decoration:none;
}

@media screen and (min-width: 768px) {
.two-inquiry-pc{
width: 100%;
}
.two-inquiry-l{float: left;
width: 48%;
margin-bottom: 0}
.two-inquiry-r{float: right;
width: 48%;
}
}
@media screen and (min-width: 1024px) {
.back_inquiry {
padding:60px 0;
}
.two-inquiry-pc{
width: 700px;
}
.section-inquiry-h3 {
font-size: 23px;
margin: 0 0 30px 0;
}}


/* instagram
/* ------------------------------------- */
/*footer*/
.fa-size {
font-size: 2em;
color: #fff;
}
/*header pc*/
.fa-header-insta {
font-size: 2em;
color: #555;
margin-top: 5px;
margin-left: 20px
}
a .fa-size:hover,
a .fa-header-insta:hover{
opacity: 0.6;
transition: 0.5s;
text-decoration: none;
}
@media screen and (min-width: 1024px) {
.fa-header-insta {
padding-top: 5px;
padding-left: 10px
}
}

/*sns footer
---------------------------------------------------------------------------*/
.sns {
display: flex;
flex-wrap: wrap;
padding: 0;
margin: 0;
list-style: none;
}
.sns a {
 color: #fff;
 font-size: 23px;
}
.sns a:hover {
color: #fff;
	opacity: 0.6;
transition: 0.5s;
}

.sns a.icon-instagram::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.sns a.icon-instagram {
background: #fff;
}



/*youtube
---------------------------------------------------------------------------*/
.wp-block-embed-youtube {
position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  overflow: hidden;
}

.wp-block-embed-youtube iframe {
position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


/*badge Contact
---------------------------------------------------------------------------*/
.badge a{
width: 110px;
height: 110px;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 50%;
background-color: #100964;
color: #ffffff;
text-align: center;
box-shadow: 0 0 4px #aaaaaa;
display: inline-flex;
position: fixed;
bottom: 10px;
right: 10px;
z-index: 100;
 flex-flow: column wrap; 
vertical-align: middle;
justify-content: center;
align-items: center;
}
.badge a:hover {
opacity: 0.8;
transition: 0.8s;
color: #fff;
background-color: #3f3a83;
}
.badge_text {
font-size: 1.1em;
line-height:1.5em;
font-weight: bold;
}
.badge_text_small {
font-size: 0.5em;
line-height: 1.4em;
text-align: center;
}
@media screen and (min-width: 1024px) {
.badge a{
width: 160px;
height: 160px;
bottom: 30px;
right: 30px;
}
.badge_text {
font-size: 1.5em;
line-height:2em;
}
.badge_text_small {
font-size: 0.7em;
line-height: 1.6em;
text-align: center;
}
}


/* ---------------------------------------------------------------------------------------------

　 お知らせ

--------------------------------------------------------------------------------------------- */
.info_box_list {
overflow: hidden;
}
.info_box_list ul {
list-style: none;
line-height: 0;
}
.info_box_list ul:after {
content: "";
clear: both;
display: block;
}
ul.list4,
ul.list3{
flex-wrap: wrap;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
white-space: wrap;
list-style:none;
max-width: 100%;
margin-bottom: 50px;
}
.info_box_list li div img {
position: absolute;
top: 50%;
left: 50%;
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
/* トリミングしたい枠の幅 */
-webkit-filter: opacity(100%);
filter: opacity(100%);
-webkit-transition: .3s ease-in-out;
transition: .3s ease-in-out;
}
.info_box_list ul li {
display: inline-block;
vertical-align: top;
text-align: center;
letter-spacing: normal;
}
.c_img {
width: 100%;
max-width: 100%;
margin: 0;
position: relative;
padding-bottom: 100%;
height: 0;
}
.c_img::before {
content: "";
display: block;
padding-top: 100%;
}
.c_img img {
width: 100%;
height: 100%;
position: absolute;
top: 0;
object-fit: cover;
}
.info_box_list a {
text-decoration: none;
}
.info_box_list li img a {
border: 0;
}
.info_box_list a:hover, a:hover .c_img, a:hover .cate_box {
opacity: 0.6;
transition: 0.5s;
text-decoration: none;
}
.info_box_tex {
margin-top: 18px;
text-align: left
}
.info_box_tex h5 {
text-decoration: none;
font-weight: normal;
line-height: 1.6;
clear: both;
margin-top: 10px;
}
.info_box_tex p {
margin: 0;
float: none;
line-height: 1.5;
font-weight: normal;
font-size: 90%
}
@media screen and (max-width: 1023px) {
.info_box_list ul.list4 li{
width: 48%;
margin-right: 3.5%;
}
.info_box_list ul.list4 li:nth-child(2n){
margin-right: 0;
}
.info_box_list ul.list4 li:nth-child(n+3){
margin-top: 40px;
}
.info_box_list ul.list4 li:nth-last-child(-n+3) {
margin-bottom: 0;
}
.info_box_list li h5 {
line-height: 1.5;
}
}
@media screen and (min-width: 1024px) {
.info_box_list ul.list4 li {
width: 23.2%;
margin-right: 2.2%;
}
.info_box_list ul.list4 li:nth-child(4n) {
margin-right: 0;
}
.info_box_list ul.list4 li:nth-child(n+5){
margin-top: 40px;
}
.info_box_list ul.list4 li:nth-last-child(-n+4) {
margin-bottom: 0;
}
}


/*read-more　ボタン
---------------------------------------------------------------------------*/
.btn{
margin-top: 30px;
}
.more_b,
.more_f{
margin: 0;
display: flex;
justify-content: center;
}
.more_f_recruit{
margin-top: 20px;
display: flex;
justify-content: center;
}
.more_b a,
.more_f a,
.more_f_recruit{
width: 200px;
padding: .9em 2em;
font-weight: normal;
font-size: 1em;
display: block;
background-color: none;
text-align: left;
position: relative;
flex: flex-end;
text-decoration: none
}
.more_b a{
color: #333;
border: 1px solid #333;
}
.more_f a,
.more_f_recruit{
color: #fff;
border: 1px solid #fff;
}
.more_b a::after,
.more_f a::after,
.more_f_recruit::after{
content: '\f061';
font-family: 'fontawesome';
font-weight: 900;
position: absolute;
top: 50%;
right:2em;
margin-top: -15px;
}
.more_b a:hover {
background-color: #333;
color: #fff;
border: 1px solid #333;
opacity: 0.8;
transition: 0.8s;
text-decoration: none
}
.more_f a:hover,
.more_f_recruit:hover{
background-color: #fff;
color: #333;
border: 1px solid #fff;
opacity: 0.8;
transition: 0.8s;
}
@media screen and (max-width: 1023px) {
.more_b a,
.more_f a,
.more_f_recruit{
width: 180px;
padding: .7em 2em;
font-size: .8em;
}
.more_b a::after,
.more_f a::after,
.more_f_recruit::after{
margin-top: -12px;
}
}

/*　PCで改行
---------------------------------------------------- */
.br-sp {
display: none;
}
.br-pc {
display: block
}

@media screen and (max-width: 767px) {
.br-pc {
display: none;
}

.br-sp {
display: block
}
}