@charset "UTF-8";
/*-----------------------------------------------------------------------------
basic
-----------------------------------------------------------------------------*/
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, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	list-style: none;
}

html {
	overflow-y: scroll;
	overflow-x: hidden;
	background-color: #fff;
	scroll-behavior: smooth;
}
nav ul {list-style:none;}

blockquote, q {quotes:none;}

blockquote:before, blockquote:after,
q:before, q:after {
	content:'';
	content:none;
}

a {
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
	text-decoration: none;
}

ins {
	background-color:#ff9;
	color:#000;
	text-decoration:none;
}

mark {
	background-color:#ff9;
	color:#000;
	font-style:italic;
	font-weight:bold;
}

del {text-decoration: line-through;}

abbr[title], dfn[title] {
	border-bottom:1px dotted #000;
	cursor:help;
}

table {border-collapse:collapse;}

hr {
    display:block;
    height:4px;
    border:0;
    border-top:4px solid #e1edf6;
    margin: 0;
    padding:0;
}

input, select {vertical-align:middle;}


/* ZenOldMincho */
@font-face {
    font-family: ' ZenOldMincho ';
    src: url('../fonts/ZenOldMincho-SemiBold.woff2') format('woff2'),
             url('../fonts/ZenOldMincho-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}
/* ZenOldMincho */
@font-face {
    font-family: ' ZenOldMincho ';
    src: url('../fonts/ZenOldMincho-Regular.woff2') format('woff2'),
             url('../fonts/ZenOldMincho-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}


@font-face {
    font-family: ' CrimsonText ';
    src: url('../fonts/CrimsonText-Regular.woff2') format('woff2'),
             url('../fonts/CrimsonText-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}


body {
color: #102153;
font-size: 93%;
line-height: 1.6;
font-weight:600;
font-family: ' ZenOldMincho ';
letter-spacing: 0.05rem;
padding-top:60px;
position: relative;
overflow: hidden;
background:#f5f6f7;}


@media (min-width: 768px) {
body {
letter-spacing: 0.05rem;

}
}

@media (min-width: 992px) {

body {
font-size: 94%;
line-height: 1.7;
letter-spacing: 0.05rem;
padding-top: 0px;}

}
@media (min-width: 1200px) {
body {
font-size: 99%;
letter-spacing: 0.08rem;
}


}


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

/* 共通
---------------------------------------------------- */

.fluid {position: relative;
	max-width: 1140px;
	margin: 0 auto;
}
.clearfix:after {
  content: "";
  clear: both;
	display: table;
}
.clear {clear: both;}

.f-right {float: right;}
.f-left {float: left;}
.pointer {cursor: pointer;}
ul.decimal li{list-style: decimal;margin-left: 2em;line-height: 1.7;}
ul.dot li{list-style:disc;margin-left: 25px;line-height: 1.7;text-align: left;}
ul.square {margin-left: 30px;}
ul.square li{list-style:disc;line-height: 1.7;}
ol.dot li{list-style:disc;margin-left: 25px;line-height: 1.5;text-align: left;font-size: .9em;}

.mb0  { margin-bottom: 0 !important; }
.mb5  { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb60 { margin-bottom: 60px !important; }
.mt10 { margin-top: 10px !important; }
.mt20 { margin-top: 20px !important; }
.pad10 { padding: 10px; }
.pad20 { padding: 20px; }
.pr05 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pl10 { padding-left: 10px !important; }
.pt5 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt20 { padding-top: 20px !important; }
.pt30 { padding-top: 30px !important; }
.pt40 { padding-top: 40px !important; }
.pt50 { padding-top: 50px !important; }
.pb5 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb50 { padding-bottom: 50px !important; }
.w20 { width: 20%; }
.w25 { width: 25%; }
.w33 { width: 33.33333333%; }
.w50 { width: 50%; }
.w60 { width: 60%; }
.w70 { width: 70%; }
.w80 { width: 80%; }
.mb150mb100{margin-bottom: 150px;}
.mb120mb80{margin-bottom: 120px;}
.mb80mb50{margin-bottom: 80px;}
.mb50mb30{margin-bottom: 50px;}
.mb30mb10{margin-bottom: 30px;}

@media (max-width: 1140px) {
.mb120mb80{margin-bottom: 80px;}
.mb150mb100{margin-bottom: 100px;}
.mb50mb30{margin-bottom: 40px;}

}


@media (max-width: 991px) {
.mb120mb80{margin-bottom: 60px;}
.mb150mb100{margin-bottom: 90px;}
.mb30-md{margin-bottom: 30px;}
.mb50mb30{margin-bottom: 30px;}
.mb10-md{margin-bottom: 10px;}

}

@media (max-width: 767px) {
.space15{margin-bottom: 15px;}
.mb150mb100{margin-bottom: 80px;}
.mb120mb80{margin-bottom: 50px;}
.mb80mb50{margin-bottom: 50px;}
.mb50mb30{margin-bottom: 30px;}
.mb20-xs{margin-bottom: 20px;}
.mb30-xs{margin-bottom: 30px;}
.mb10-xs2{margin-bottom: 10px;}

}
@media (max-width: 666px) {
.mb30-xs2{margin-bottom: 30px;}
.mb10-xs{margin-bottom: 10px;}
.mb30mb10{margin-bottom: 10px;}
.mb20-xs2{margin-bottom: 20px;}

}


@media (min-width: 1200px) {

.mb30-xl { margin-bottom: 30px !important; }
}

.indent {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.5;
}

.indent2 {
  padding-left: 1.8em;
  text-indent: -1.8em;
}

.flexbox{display: flex;align-items: center;}

.flexbox-between{display: flex;align-items: center;justify-content: space-between;}
.flexbox2{display: flex;align-items: stretch;}

.flexbox3{display: flex;align-items: flex-end;}
.flexbox4{display: flex;justify-content: flex-end;}


@media (max-width: 767px) {
.flexbox4{display:block;}


}


.bg-gray{background:rgba(152,133,95,.06);}
.bg-blue{background:rgba(0,156,255,0.05);}
.bg-border-top{border-top: 1px solid #ddd;}




/*btn
------------------------------ */
html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

img{vertical-align: bottom;}




/* アニメーション
---------------------------------------------------- */
.delayed-image {
	/* じわっと画像が表示される */
 	animation: fadeIn 3s ease 0s 1 normal;
    -webkit-animation: fadeIn 3s ease 0s 1 normal;
}

/* じわっと画像が表示される ---------　一度追加していたら不要*/
@keyframes fadeIn { /*上のbody内で呼び出しているアニメーションと名前をそろえる*/
    0% {opacity: 0} /* 始め */
    100% {opacity: 1} /* 終わり */
}

/*古いブラウザ用　---------　一度追加していたら不要*/
@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

.vertical {
  animation: vertical_6392 2.44s ease infinite;
  transform-origin: 50% 50%;
}

@keyframes vertical_6392 {
  0% { transform:translate(0,-3px) }
  3.27869% { transform:translate(0,3px) }
  6.55738% { transform:translate(0,-3px) }
  9.83606% { transform:translate(0,3px) }
  13.11475% { transform:translate(0,-3px) }
  16.39344% { transform:translate(0,3px) }
  18.03279% { transform:translate(0,0) }
  100% { transform:translate(0,0) }
}



.horizontal {
  animation: horizontal_5801 5s ease infinite;
  transform-origin: 50% 50%;
}

@keyframes horizontal_5801 {
  0% { transform:translate(0,0) }
  4.41177% { transform:translate(5px,0) }
  8.82353% { transform:translate(0,0) }
  13.23529% { transform:translate(5px,0) }
  17.64706% { transform:translate(0,0) }
  22.05882% { transform:translate(5px,0) }
  26.47059% { transform:translate(0,0) }
  100% { transform:translate(0,0) }
}

.passing-reverse {
  animation: passing-reverse_1059 4s linear infinite;
  transform-origin: 50% 50%;
}

@keyframes passing-reverse_1059 {
  0% { transform:translateX(50%); opacity:0 }
  50% { transform:translateX(35%); opacity:.5 }
  100% { transform:translateX(0%); opacity:1 }
}

.float {
  animation: float_1 4s linear infinite;
  transform-origin: 50% 50%;
}
@keyframes float_1 {
  0% { transform: translateY(0) }
  50% { transform: translateY(-10px) }
  100% { transform: translateY(0) }
}

.float2 {
  animation: float_2 2s linear infinite;
  transform-origin: 50% 50%;
}
@keyframes float_2 {
  0% { transform: translateY(0) }
  60% { transform: translateY(-5px) }
  100% { transform: translateY(0) }
}

.fuwafuwa {
-webkit-animation:fuwafuwa 3s infinite linear alternate;
animation:fuwafuwa 3s infinite linear alternate;
}

@-webkit-keyframes fuwafuwa {
0% {-webkit-transform:translate(0, 0) rotate(-5deg);}
50% {-webkit-transform:translate(0, -5px) rotate(0deg);}
100% {-webkit-transform:translate(0, 0)rotate(5deg);}
}

@keyframes fuwafuwa {
0% {transform:translate(0, 0) rotate(-5deg);}
50% {transform:translate(0, -5px) rotate(0deg);}
100% {transform:translate(0, 0)rotate(5deg);}
}

@keyframes floating-y {
  0% {
    transform: translateY(-10%);
  }
  100% {
    transform: translateY(10%);
  }
}

@keyframes rotate-z {
  from { transform: rotateZ(0deg); }
  to { transform: rotateZ(360deg); }
}

.animation{
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-duration: 1.5s;
}

.swing {
animation: swing 2s ease-in-out infinite;
}
/* swing */
@keyframes swing {
    20% {
        transform: rotate(15deg)
    }
    40% {
        transform: rotate(-10deg)
    }
    60% {
        transform: rotate(5deg)
    }
    80% {
        transform: rotate(-5deg)
    }
    100% {
        transform: rotate(0deg)
    }
}

/* link
---------------------------------------------------- */
a:link,a:visited{text-decoration:none;}
a:hover,a:active{text-decoration:none;}
a.opacity {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a.opacity:hover {
	-webkit-opacity: 0.6;
	-moz-opacity: 0.6;
	opacity: 0.6;
}








@media (min-width: 667px) {



}

@media (min-width: 1199px) {




}

@media (min-width: 1200px) {

}

@media (min-width: 1440px) {


}


.txt-justify{text-align:justify;}

[data-action="call"]  {text-decoration: none;}

/* font-size color
---------------------------------------------------- */
.x-small { font-size: 12px; }
.small { font-size: .9em; line-height: 1.5; letter-spacing: 0;}
.middle { font-size: 14px; letter-spacing: 0;}
.large { font-size: 1.2em; }
.x-large { font-size: 1.4em; }
.x2-large { font-size: 20px; }
.x3-large { font-size: 22px; }
.x4-large { font-size: 24px; }
.max-large { font-size: 32px; }
.italic {font-style: italic;}
.bold{font-weight: 700;font-family: ' BIZUDPGothic ';}

.white { color: #ffffff; }
.red { color:#FF0328; }
.blue{color:#008EEF;}
.green { color: forestgreen; }
.navy { color:#0034A0; }
.orange { color: #f60; }
.kiiro { color: yellow!important; }
.brown{color: #8b6f57;}

/* スクロールでナビ表示
---------------------------------------------------- */
.cb-header {
    position: fixed;
    top: 0;
    left: 0;
	right:0;
    display: none;
    background: #fff;
}
.cb-header .inner {width: 96%;margin: 0px auto; margin-top: 20px;}




@media (max-width: 767px) {
.cb-header {display: none!important;}

}



/* 背景ライン
---------------------------------------------------- */

.grid {
  display: flex;
  height: 100%;
  position: absolute;
  width: 95%;left:2.5%;z-index: 1;border-left: 1px solid #d3d5d6;
}
.grid span {
  border-right: 1px solid #d3d5d6;
  height: 100%;
  width: 20%;
}
.grid span:last-child {
  border-right: 1px solid #d3d5d6;
  height: 100%;
  width: 80%;
}

@media (min-width: 1024px) {
.grid {
  display: flex;
  height: 100%;
  position: absolute;
  width: 960px;left:50%;transform: translateX(-50%);margin-right: -50%;
}

.grid span {width: 34%;}
.grid span:last-child {width: 66%;}

}

@media (min-width: 1280px) {
.grid {
  display: flex;
  height: 100%;
  position: absolute;
  width: 1140px;left:50%;transform: translateX(-50%);margin-right: -50%;
}
.grid span {width: 25%;}
.grid span:last-child {width: 75%;}


}

@media (min-width: 1440px) {
.grid {
  display: flex;
  height: 100%;
  position: absolute;
  width: 1250px;left:50%;transform: translateX(-50%);margin-right: -50%;
}
.grid span {width: 22%;}
.grid span:last-child {width: 78%;}


}


@media (min-width: 1680px) {
.grid {
  display: flex;
  height: 100%;
  position: absolute;
  width: 1560px;left:50%;transform: translateX(-50%);margin-right: -50%; 
}
.grid span {width: 19%;}
.grid span:last-child {width: 81%;}


}


/* header mobile pad
---------------------------------------------------- */
#header{display: none;}
.cb-header2 {
    position: fixed;
    /* 固定 */
    top: 0;
    /* 上から0の位置に固定 */
    left: 0;
    /* 左から0の位置に固定 */
    display: block;
    /* 表示 */
	z-index: 200;
	width: 100%;
	box-sizing: border-box;
}

.sc {
display: flex;
align-items: center;
    width: 100%;
    margin: 0 auto;
	height: 60px;
	background:none;
	background:#083160;}
.sc .logo{padding-left: 15px;width: 150px;}



header{display: none;}



/*header pc
------------------------------------------------------------------*/
@media (min-width: 992px) {

header{display: block;}
.cb-header2 {display: none;}


.header {
  position: fixed;
  top: 0px;
  left:0;
  transition: color 0.4s ease-out;
  width: 100%;
  z-index: 500;
  height: 100px;
  display: flex;
  align-items: center;justify-content:space-between;
}

.header .logo {position: relative;margin-left: 15px;width:200px;}
.header .logo a img{transition: .4s;}
.header .logo a:hover img{opacity: .7;}

.header .logo.color {display: none;}


.header .navi{padding-right: 10px;display: flex;align-items: center;justify-content: flex-end;}


/* ナビゲーションメニュー */
.nav-menu {margin-right: 1.5em;}
.menu-list {
  display: flex;
  justify-content: center; /* メニューアイテムを中央揃えに */
}
.menu-item {position: relative;padding: 0 .8em;line-height: 1;}
.menu-item:first-child {padding: 0 .8em 0 0;}
.menu-item:last-child {padding: 0 0 0 .8em;}

/* メニューアイテムのホバースタイル */
.menu-item a {
font-size: 16px;
letter-spacing: 0;
padding: 0;
  text-align: center;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: .3s;line-height: 1;
}
.menu-item a:hover {color:#FF6900;}

.menu-item a.active {color:#fff;position: relative;}
.menu-item a.active::after {
  content: '';
  width: 100%;
  height: 2px;
  display: inline-block;
  background-color: #fff;
  position: absolute;
  bottom: -10px;
  left: 0;
}

}


/* スクロールしたらヘッダーメニューのフォントカラー変更 */

/* スクロールでヘッダー背景色表示 */
.hide {transition: .8s;background-color: rgba(255, 255, 255, 1);height: 80px;}
.hide .logo {display: none;}
.hide .logo.color{display: block;}

.hide .menu-item a {color: #102153;}
.hide .menu-item a:hover {color: #FF6900;}

.hide .menu-item a.active::after {
  background-color: #102153;
  bottom: -10px;
}


@media (min-width: 1200px){
.header .logo {position: relative;margin-left: 20px;width: 250px;}

.menu-item {position: relative;padding: 0 1.2em;}
.menu-item:first-child {padding: 0 1.2em 0 0;}
.menu-item:last-child {padding: 0 0 0 1.2em;}

.header .navi{padding-right:20px;}
.nav-menu {margin-right: 2em;}

.hide .logo {position: relative;margin-left: 20px;width:250px;}

}


@media (min-width: 1680px){
.header .logo {position: relative;margin-left: 50px;width: auto;}
.hide .logo {position: relative;margin-left: 50px;}

.header .navi{margin-right: 20px;}
.menu-item {position: relative;padding: 0 1.5em;}
.menu-item:first-child {padding: 0 1.5em 0 0;}
.menu-item:last-child {padding: 0 0 0 1.5em;}
.menu-item a {font-size: 18px;}

}

@media (min-width: 1920px){

.nav-menu {margin-right: 4em;}
.menu-item {position: relative;padding: 0 1.7em;}
.menu-item:first-child {padding: 0 1.7em 0 0;}
.menu-item:last-child {padding: 0 0 0 1.7em;}

}










/*　swiper
------------------------------------------------------------------*/

.sp-box {
    width: 100%;
    position: absolute;
    z-index: 2;
}
.slider__filter {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(rgba(111, 120, 127, .5), rgba(16, 33, 83, 1));
    opacity: .4;
	z-index: 3;
}

.mv {position: relative;height: 105vh;}

.swiper-container-back {
    position: relative;
    width: 100%;
	overflow: hidden;
}

.swiper-container-back .swiper-slide img {object-fit: cover;width: 100%;height:1480px;}

.main-h2{position: absolute;z-index: 50;bottom: 15%;right: 5%;}
.main-h2 h2.mv-h2{color: white;font-size: 64px;font-weight: 600;line-height: 1.2;letter-spacing: .05rem;}
.mv .scrolldown{position: absolute;z-index: 30;left:50px;bottom:50px;}
.mv .block {
  width: 75px;
  height: 75px;
  margin: auto;
}

.mv .circleText {
  overflow: visible;
  animation: rotation 24s linear infinite;
 } /*数値が大きいとスピードが遅くなる */

.mv .circleText__circle {
  fill: none;
}
.mv .circleText__text {
  fill: #fff;
  font-size: 14px;
  letter-spacing: 0.05em;
}

@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.mv .scroll-line {
    position  : absolute;
    top : 30px;
    left : 50%;
    transform: translateX(-50%) ;
}
.mv .scroll-line::after {
    content : '';
    display : inline-block;
    position : absolute;
    background-color: #fff;
    right : 50%;
    bottom : -120px;
    transform : translateX(-50%);
    width : 1px;
    height : 120px;
    animation: scroll 1.5s infinite;
}

@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}


@media (max-width: 1679px){
.swiper-container-back .swiper-slide img {height:1300px;}

.main-h2 h2.mv-h2{color: white;font-size: 58px;line-height: 1.2;}



}



@media (max-width: 1440px){
.swiper-container-back .swiper-slide img {height:1280px;}
.mv {position: relative;height: 100vh;}

.main-h2 h2.mv-h2{color: white;font-size: 50px;line-height: 1.2;}





}


@media (max-width: 1280px){
.swiper-container-back .swiper-slide img {height:1210px;}

.mv {position: relative;height: 95vh;}

.main-h2 h2.mv-h2{font-size: 46px;line-height: 1.2;}


}


@media (max-width: 1199px){
.swiper-container-back .swiper-slide img {height:1150px;}
.mv {position: relative;height: 100vh;}

.main-h2 h2.mv-h2{font-size: 40px;line-height: 1.3;}

}




@media only screen and (max-width: 991px) {
.sp-box {
    width: 100%;
    position: absolute;
    z-index: 2;
	height: 750px;
}

.mv {position: relative;height: 320px;}
.swiper-container-back .swiper-slide img {display: none;}
.swiper-container-back .swiper-slide.bg1{background: url("../images/back_slide_1.jpg");background-position: center;background-size: cover;width: 100%;height: 750px;}
.swiper-container-back .swiper-slide.bg2{background: url("../images/back_slide_2.jpg");background-position: center;background-size: cover;width: 100%;height: 750px;}

.main-h2 h2.mv-h2{font-size:36px;line-height: 1.3;}

.mv .scrolldown{display: none; }


}

@media only screen and (max-width: 767px) {
.sp-box {
    width: 100%;
    position: absolute;
    z-index: 2;
	height: 660px;
}

.mv {position: relative;height: 260px;}
.swiper-container-back .swiper-slide img {display: none;}
.swiper-container-back .swiper-slide.bg1{background: url("../images/back_slide_1.jpg");background-position: center;background-size: cover;width: 100%;height: 660px;}
.swiper-container-back .swiper-slide.bg2{background: url("../images/back_slide_2.jpg");background-position: center;background-size: cover;width: 100%;height: 660px;}

.main-h2 h2.mv-h2{font-size: 32px;line-height: 1.3;}

}


@media only screen and (max-width: 666px) {
.sp-box {height: 580px;}
.swiper-container-back .swiper-slide.bg1{background: url("../images/back_slide_1.jpg");background-position: center;background-size: cover;width: 100%;height: 580px;}
.swiper-container-back .swiper-slide.bg2{background: url("../images/back_slide_2.jpg");background-position: center;background-size: cover;width: 100%;height: 580px;}




}

@media only screen and (max-width: 430px) {

.mv {position: relative;height: 200px;}

.main-h2 h2.mv-h2{font-size: 25px;line-height: 1.3;}

}


/* IMAGE BLUR EFFECT */
.thumb img {
  max-width: 100%;
  -webkit-filter: blur(15px);
  filter: blur(15px);
}
.img-blur {
  animation: imageBlur 2s both;
}
@keyframes imageBlur {
  100% {
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}




/* index.html 
---------------------------------------------------- */

.btn-posi-right{display: flex;justify-content: flex-end;}
.btn-posi-center{display: flex;justify-content:center;}


.home #section01{position: relative;padding: 30px 0 50px;z-index: 10;color: white;}
.home #section01 .sub{font-weight: 600;font-size: 1.3em;margin-bottom: .7em;}
.home #section01 .txt{line-height: 1.4;margin-bottom: 1.5em;}
.home #section01 .pic{display: none; width: 50%;margin-left: 50%;}

.home #section02{position: relative;padding: 0px;z-index: 10;border-top: 1px solid #d3d5d6;border-bottom: 1px solid #d3d5d6;margin-bottom: 50px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}
.home #section02 .sub{font-weight: 600;font-size: 1.35em;line-height: 1.5;margin-bottom: .8em;}
.home #section02 .txt{line-height: 1.4;margin-bottom: 1.5em;}
.home #section02 a.box{position: relative;display: block;overflow: hidden;}
.home #section02 a.box img{position: relative;z-index: 10;transition: transform .6s ease;transform: scale(1.1);}
.home #section02 a.box .num{position: absolute;left:20px;top:20px;line-height: 1;color: white;z-index: 20;font-family: ' CrimsonText ';font-weight: 400;font-size: 20px;}
.home #section02 a.box .title{position: absolute;color: white;bottom:20px;right:40px;z-index: 20;font-weight: 600;font-size: 20px;}
.home #section02 a.box .title::after{
    content:"■";
	position: absolute;
	top:50%;
	transform: translateY(-50%);
    font-size: .5em;
    margin-left: 10px;
	color: #f7731b;
}
.home #section02 a.box:hover img{transform: scale(1);}


.home #section03{position: relative;z-index: 10;border-top: 1px solid #d3d5d6;border-bottom: 1px solid #d3d5d6;margin-bottom: 50px;}
.home #section03 .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}
.home #section03 .btn-box{padding-top: 30px;display: flex;justify-content: center;}
.p-top-lineup {overflow: hidden;}
.p-top-lineup__slide {
  position: relative;overflow: hidden;
  padding: 0 15px;
}
.p-top-lineup__slide-controller {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.js-swiper-lineup .swiper-slide:hover{cursor: default;}
.js-swiper-lineup a.swiper-slide:hover{cursor: pointer;}

.js-swiper-lineup a img{transition: .4s;}
.js-swiper-lineup a:hover img{opacity: .7;}
.js-swiper-lineup a .txt{padding: 15px 0 0;text-align: left;}
.js-swiper-lineup .swiper-slide .txt{padding: 15px 0 0;text-align: left;}
.js-swiper-lineup a .txt .title{color:#333;line-height: 1.4;font-weight: 400;
overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: 45px;}
.js-swiper-lineup a .txt .date{font-size: 12px;color: #555;margin-bottom: .5em!important;line-height: 1;display: flex;flex-direction: column;}
.js-swiper-lineup a .txt .date .cate{background: #89c3eb;display: inline-block;text-align: center; color: white;font-size: 12px;margin-top: .5em;padding: .3em;}
.js-swiper-lineup .swiper-slide:hover{cursor: default;}

.js-swiper-lineup .swiper-slide .txt .title{color:#333;line-height: 1.4;font-weight: 400;
overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: 45px;}
.js-swiper-lineup .swiper-slide .txt .date{font-size: 12px;color: #555;margin-bottom: .5em!important;line-height: 1;display: flex;flex-direction: column;}
.js-swiper-lineup .swiper-slide .txt .date .cate{background: #89c3eb;display: inline-block;text-align: center; color: white;font-size: 12px;margin-top: .5em;padding: .3em;}

.c-container{position: absolute;top:3em;left:60%;}
.p-top-lineup__slide-btns {display: flex;}
.p-top-lineup__slide-btns .swiper-button-next,.p-top-lineup__slide-btns .swiper-button-prev{position:relative;}
.p-top-lineup__slide-btns .swiper-button-next::after,
.p-top-lineup__slide-btns .swiper-button-prev::after {
  color: #fff;
  font-size: 14px;
}
.p-top-lineup__slide-btns .swiper-button-next,
.p-top-lineup__slide-btns .swiper-button-prev {
  width: 35px;
  height: 35px;
  background: #102153;
  border-radius: 50%;
  margin-left: 35px;
  transition: .5s;
}
.p-top-lineup__slide-btns .swiper-button-next:hover,
.p-top-lineup__slide-btns .swiper-button-prev:hover {
  width: 35px;
  height: 35px;
  background: #2a50be;
  border-radius: 50%;
  margin-left: 35px;
}


.p-top-lineup__pic img {
  width: auto;
  height: auto;
  max-width: 100%;
}
.p-top-lineup .swiper {overflow: visible;}
.p-top-lineup .swiper-slide {
  width: -webkit-max-content;
  width:max-content;
}
.p-top-lineup .slide {
  width: 100%;
  transition: var(--transition);
}
.p-top-lineup .slide img {
  width: 100%;
  transition: var(--transition);

  -o-object-fit: cover;
     object-fit: cover;
}

.js-swiper-lineup .photo-ofi img {
  max-width: inherit;
  max-height: inherit;
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  position: absolute;
  left: 0;
  top: 0;
}

.gmap{margin-bottom: 30px;}
.gmap:last-child{margin-bottom: 0px;}

.gmap iframe{width: 100%;height: 220px;border-radius:0;vertical-align: bottom;}




@media (min-width: 667px) {
.home #section01 .container{max-width: 630px;}
.home #section01 .pic{display: block; width: 46%;margin-left:auto;position: absolute;right:15px;top:auto;bottom:-50px;}

.home #section02{padding: 0px 0;margin-top: 50px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:65px;border-bottom: 1px solid #d3d5d6;}

.home #section02 .container{max-width: 90%;}

.home #section03 .yokosen{position: absolute;left:0;right: 0;top:65px;border-bottom: 1px solid #d3d5d6;}

.p-top-lineup .slide img {height: 22vw !important;  }
.c-container{position: absolute;top:3em;left:20%;}
.home #section03 .btn-box{padding-top: 0px;position: absolute;top:10px;right:15px;}


}




@media (min-width: 768px) {

.home #section01{padding: 40px 0 70px;}
.home #section01 .container{max-width: 730px;}

.home #section01 .pic{display: block; width: 52%;margin-left:auto;position: absolute;right:0px;bottom:-70px;}

.home #section02{padding: 0px 0 ;margin-top: 70px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}



.home #section03 {padding: 0px;margin-bottom: 70px;}
.home #section03 .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}

.js-swiper-lineup a .txt .date{font-size: 12px;color: #555;margin-bottom: .7em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup a .txt .date .cate{display: inline-block;text-align: center; font-size: 12px;margin-top: auto;margin-left: .4em; padding: .3em;}

.js-swiper-lineup .swiper-slide .txt .date{font-size: 12px;color: #555;margin-bottom: .7em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup .swiper-slide .txt .date .cate{display: inline-block;text-align: center; font-size: 12px;margin-top: auto;margin-left: .4em; padding: .3em;}
.home #section03 .btn-box{padding-top: 0px;position: absolute;top:10px;right:18px;}


.gmap{margin-bottom: 30px;}

.roop-wrapper.info {width:88%;margin: 0 auto; margin-bottom: 70px;}





.gmap{}
.gmap iframe{height: 250px;}


}



@media (min-width: 992px) {
.home #section01{padding: 20px 0 70px;}

.home #section01 .container{max-width: 960px;padding: 0;}
.home #section01 .wrap{padding-left: 5px;}
.home #section01 .sub{font-size: 1.3em;margin-bottom: .7em;}
.home #section01 .txt{line-height: 1.4;margin-bottom: 1.5em;}
.home #section01 .pic{display: block; width: 52%;margin-left:auto;position: absolute;right:0px;bottom:auto;top:80px;}

.home #section02{padding: 0px;margin-top: 70px;margin-bottom: 70px;}

.home #section02 .container{max-width: 960px;padding: 0;}
.home #section02 .wrap{padding-left: 5px;}
.home #section02 .headline{margin-top: -.5em;}
.home #section02 .sub{font-size: 1.5em;line-height: 1.5;margin-bottom: .8em;}
.home #section02 .txt{line-height: 1.4;margin-bottom: 1.5em;letter-spacing: 0;}

.home #section03 .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}
.home #section03 .wrap{position: relative;}
.home #section03 .wrap{padding: 0 0 0 3%;} 
.home #section03 .headline{margin-top: -.5em;}

.c-container{position: absolute;top:3em;left:20%;}

.p-top-lineup .slide img {height: 15vw !important;}
.js-swiper-lineup a .txt .date{font-size: 12px;color: #555;margin-bottom: .9em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup a .txt .date .cate{display: inline-block;text-align: center; font-size: 12px;margin-top: auto;margin-left: .4em; padding: .3em;}

.js-swiper-lineup .swiper-slide .txt .date{font-size: 12px;color: #555;margin-bottom: .9em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup .swiper-slide .txt .date .cate{display: inline-block;text-align: center; font-size: 12px;margin-top: auto;margin-left: .4em; padding: .3em;}

.d-btwn{display: flex;flex-direction: column;justify-content: space-between;}
.gmap iframe{width: 100%;height: 350px;}

}




@media (min-width: 1200px) {

.home #section01{padding: 60px 0 100px;margin-bottom: 150px;}
.home #section01 .container{max-width:1140px;padding: 0;}
.home #section01 .wrap{padding-left: 5px;}

.home #section01 .pic{display: block; width: 50%;margin-left:auto;position: absolute;right:0;bottom:auto;top:70px;}


.home #section02{padding: 0px;margin-top: 100px;margin-bottom: 150px;}
.home #section02 .container{max-width:1140px;padding: 0;}
.home #section02 .headline{margin-bottom: .9em;}

.home #section02 .wrap{padding-left: 5px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:65px;border-bottom: 1px solid #d3d5d6;}

.home #section02 .txt{font-size: .95em;letter-spacing: 0;line-height: 1.6;margin-bottom: 2em;}


.home #section03 {padding: 0px 0;margin-bottom: 150px;}
.home #section03 .yokosen{position: absolute;left:0;right: 0;top:65px;border-bottom: 1px solid #d3d5d6;}
.home #section03 .wrap{padding: 0 0 0 5%;} 
.home #section03 .btn-box{padding-top: 0px;position: absolute;top:10px;right:7%;}

.c-container{position: absolute;top:1.8em;left:20%;}

.p-top-lineup__slide-btns .swiper-button-next,
.p-top-lineup__slide-btns .swiper-button-prev {
  width: 48px;
  height: 48px;
  background: #102153;
  border-radius: 50%;
  margin-left: 35px;
  transition: .5s;
}
.p-top-lineup__slide-btns .swiper-button-next:hover,
.p-top-lineup__slide-btns .swiper-button-prev:hover {
  width: 48px;
  height: 48px;
  background: #2a50be;
  border-radius: 50%;
  margin-left: 35px;
}

.home #section04{padding: 100px 0px 100px;}


.roop-wrapper.info {width: 85%;margin: 0 auto; margin-bottom: 100px;}




}





@media (min-width: 1440px) {
.home #section01{margin-bottom: 150px;}

.home #section01 .container{max-width: 1250px;padding: 0;}
.home #section01 .wrap{padding-left: 15px;}
.home #section01 .sub{font-size: 28px;margin-bottom: .7em;}
.home #section01 .txt{line-height: 1.4;margin-bottom: 1.5em;}
.home #section01 .pic{display: block; width: 52%;margin-left:auto;position: absolute;right:0px;bottom:auto;top:70px;}

.home #section02{padding: 0px 0;margin-top: 150px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:70px;border-bottom: 1px solid #d3d5d6;}

.home #section02 .container{max-width: 1250px;padding: 0;}
.home #section02 .wrap{padding-left: 15px;}
.home #section02 .headline{margin-top: -.65em;margin-bottom: 1.2em;}
.home #section02 .txt{font-size: .95em;letter-spacing: 0;line-height: 1.7;margin-bottom: 2em;}

.home #section03{padding: 0px 0;margin-top: 180px;}
.home #section03 .headline{margin-top: -.65em;}
.home #section03 .yokosen{position: absolute;left:0;right: 0;top:70px;border-bottom: 1px solid #d3d5d6;}
.home #section03 .wrap{padding: 0 0 0 6%;} 
.js-swiper-lineup a .txt .date{font-size: 14px;color: #555;margin-bottom:1em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup a .txt .date .cate{display: inline-block;text-align: center; font-size: 13px;margin-top: auto;margin-left: .4em; padding: .3em;}
.js-swiper-lineup .swiper-slide .txt .date{font-size: 14px;color: #555;margin-bottom:1em!important;line-height: 1;display: flex;flex-direction: row;align-items: center;}
.js-swiper-lineup .swiper-slide .txt .date .cate{display: inline-block;text-align: center; font-size: 13px;margin-top: auto;margin-left: .4em; padding: .3em;}

.c-container{position: absolute;top:2em;left:20%;}

}

@media (min-width: 1500px) {

.home #section03 .wrap{padding: 0 0 0 9.7%;} 
.home #section03 .btn-box{padding-top: 0px;position: absolute;top:10px;right:11.5%;}

}

@media (min-width: 1680px) {
.home #section01{padding: 120px 0 100px;margin-bottom: 280px;}
.home #section01 .container{max-width: 1560px;}

.home #section01 h3{font-size: 48px;margin-bottom:1em;}
.home #section01 h3 span{background: #f7731b;font-size: 14px;line-height: 1;padding: 0 .5em .2em;}
.home #section01 .sub{font-size: 28px;margin-bottom: 1em;}
.home #section01 .txt{line-height: 1.8;margin-bottom: 2.5em;}
.home #section01 .pic{display: block; width: 55%;margin-left:auto;position: absolute;right:0px;top:30px;}

.home #section02{padding: 0px 0;margin-bottom: 250px;}
.home #section02 .yokosen{position: absolute;left:0;right: 0;top:75px;border-bottom: 1px solid #d3d5d6;}

.home #section02 .container{max-width: 1560px;}
.home #section02 .headline{margin-top: -.65em;margin-bottom: 2em;}
.home #section02 .sub{font-size: 1.7em;line-height: 1.5;margin-bottom: .8em;}
.home #section02 .txt{line-height: 1.9;margin-bottom: 2.5em;}

.home #section03{padding: 0px 0;margin-bottom: 200px;}
.home #section03 .wrap{padding: 0 0 0 6%;} 
.home #section03 .yokosen{position: absolute;left:0;right: 0;top:75px;border-bottom: 1px solid #d3d5d6;}
.home #section03 .container{max-width: 1560px;}
.c-container{position: absolute;top:2.3em;left:15%;}


.gmap iframe{width: 100%;height: 450px;}

}

@media (min-width: 1920px) {
.home #section01 .pic{width: 57%;margin-left:auto;position: absolute;right:15px;top:50px;}
.home #section03 .wrap{padding: 0 0 0 9.5%;} 
.c-container{position: absolute;top:2.3em;left:17%;}
.home #section03 .btn-box{padding-top: 0px;position: absolute;top:15px;right:10.4%;}

}

@media screen and (min-width: 2000px) { 
.p-top-lineup .slide img { height: 300px !important;}
.p-top-lineup .slide:hover {}
.p-top-lineup .slide:hover img { opacity: 1;}
}

/* TOP LINEUP
--------------------------------------------------------- */







.maker{
  background: linear-gradient(
    transparent 60%,
    #fbeb64 60%
  );}


.btn-center{display: flex;justify-content: center;position: relative;z-index: 50;}
.btn-right{display: flex;justify-content:flex-end;position: relative;z-index: 50;}


.linkbtn{
    font-size: 1em;
    color: #fff;
    position: relative;
    text-decoration:none;
    display: flex;
    overflow: hidden;
	width: 200px;
    padding:0px 1em 0 1.6em;
	height: 50px;
    border-radius: 25px;
    transition: opacity .45s ease, background .35s ease;
    background: #f7731b;
    align-items: center;
}

.linkbtn__circle{
    position: absolute;
    top: 50%;
    right: 1.5rem;
    width: .5rem;
    height: .5rem;
    transform: translateY(-50%);
	background: white;
}

.linkbtn__circle::before{
    position: absolute;
    z-index: 1;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    content: '';
    transition: width .45s cubic-bezier(.87, .24, .36, 1), height .45s cubic-bezier(.87, .24, .36, 1);
    transform: translate3d(-50%, -50%, 0);
    border-radius: 0%;
    background: #fff;
}

.linkbtn__text{
    line-height: 1;
    position: relative;
    z-index: 2;
    transition: color .45s cubic-bezier(.87, .24, .36, 1);
}

.linkbtn:hover .linkbtn__circle::before{
    width: 50rem;
    height: 50rem;
	background: #102153;
}

.linkbtn:hover .linkbtn__text{color: #fff;}

.linkbtn.kon{background: #102153;}
.linkbtn.kon .linkbtn__circle::before{background: #f7731b;}
.linkbtn.kon .linkbtn:hover .linkbtn__circle::before{background: #f7731b;}



a.btn-large{width: 100%;line-height: 55px; font-size: 17px; background: black;color: white;text-align: center;margin-top: 10px;display: block;
  padding: 0px;
  border:none;
  transition: .3s;
  padding-right: 0px!important;
  margin-right: 0!important;
}
a.btn-large:hover{background: #07a3d7;}

@media (min-width:667px) {


}



@media (min-width:768px) {


a.btn-large{width: 100%;line-height: 68px;font-size: 20px; background: black;color: white;text-align: center;margin-top: 40px;}


}

@media (min-width: 992px) {

.linkbtn
{
    font-size: 16px;
    color: #fff;
    position: relative;
    text-decoration:none;
    display: flex;
    overflow: hidden;
	width: 200px;
    padding:0px 1em 0 1.5em;
	height: 50px;
    border-radius: 25px;
    transition: opacity .45s ease, background .35s ease;
    background: #f7731b;
    align-items: center;
}

a.btn-large{width: 100%;font-size: 20px; background: black;color: white;text-align: center;margin-top: 40px;}


}


@media (min-width: 1200px) {

a.btn-large{width: 100%;line-height: 80px;font-size: 24px;}


}

@media (min-width: 1680px) {
.linkbtn
{
    font-size: 18px;
	width: 200px;
}


}

/* pagetop 
---------------------------------------------------- */
#pagetop {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 500;
	transition: .5s;
}
#pagetop .block {
  width: 65px;
  height: 65px;
  margin: auto;
}

#pagetop .circleText {
  overflow: visible;
  animation: rotation 24s linear infinite;
 } /*数値が大きいとスピードが遅くなる */

#pagetop .circleText__circle {fill: none;}
#pagetop .circleText__text {
  fill: #89c3eb;
  font-size: 14px;
  letter-spacing: 0.05em;
}

@keyframes rotation2 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

#pagetop .scroll-line {
    position  : absolute;
    bottom : 30px;
    left : 50%;
    transform: translateX(-50%) ;
}
#pagetop .scroll-line::after {
    content : '';
    display : inline-block;
    position : absolute;
    background-color: #89c3eb;
    right : 50%;
    top : -120px;
    transform : translateX(-50%);
    width : 1px;
    height : 120px;
    animation: scroll2 1.5s infinite;
	animation-direction: reverse;
}
@keyframes scroll2 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}





@media (max-width: 1280px) {
#pagetop {
    bottom: 25px;
    right: 25px;
}



}

@media (max-width: 992px) {
#pagetop {
bottom: 15px;
right: 15px;
}

}

@media (max-width: 568px) {
#pagetop {
bottom: 15px;
right: 10px;
}

}



/* -----  common / footer ------- */
.common{padding: 40px 0;position: relative;background:#102153;color: white;z-index: 10;}
.common .title{margin-bottom: 40px;}
.common .txt{}
.common .wrap{}
.common .wrap .box{padding-bottom: 1em;border-bottom:1px solid #fff;}
.common .wrap .box .tel{font-family: ' CrimsonText ';font-weight: 400;display: flex;align-items: center;justify-content: center;}
.common .wrap .box .tel img{width: 25px;height: auto;margin-right: 6px;}
.common .wrap .box .tel .call{color: #fff;font-size: 34px;}
.common .wrap .box .time{font-size: 13px;letter-spacing: 0;display: flex;justify-content: center;}
.common .wrap a.mailbox{display: flex;align-items: center;justify-content: center;color: white;transition: .4s;font-size: 18px;padding-top: 1em;}
.common .wrap a.mailbox img{width: 25px;height: auto;margin-right: .5em;transition: .4s;}
.common .wrap a.mailbox:hover{color: #ccc;}
.common .wrap a.mailbox:hover img{opacity: .7;}

footer{ padding: 40px 0px 15px;position: relative;z-index: 10; color:#222;border-bottom: 1px solid #d3d5d6;margin-bottom: 40px;}
footer .yokosen{position: absolute;left:0;right: 0;top:40px;border-bottom: 1px solid #d3d5d6;}

footer .container{}
footer .logoblock{position: relative; width: 180px;margin: 0 auto; margin-bottom: 25px;}
footer .address{text-align: center;margin: 13px;line-height: 1;}
footer .address a{transition: .4s;color: #1b2a34;margin-left: .2em;}
footer .address a:hover{color: #0d5282;}
footer .tel{margin-bottom: 8px;line-height: 1;display: flex;align-items: center;justify-content: center;font-family: ' CrimsonText ';font-weight: 400;}
footer .tel .call{color: #222;font-size: 20px;}
footer .tel .index{background: #f7731b;color: white;margin-right: .5em;line-height: 1;font-size: .9em;padding: .2em;width: 42px;text-align: center;}
.page-top{position: absolute;right:10px;bottom:15px;width: 15px;}
.footer-menu{width: 100%;margin: 0 auto; margin-top: 1em;}
.footer-menu ul{display: flex;flex-wrap: wrap; justify-content: space-between;}
.footer-menu li{width:48.6%;text-align: left;background:none;margin-bottom: 10px;}
.footer-menu li.home{width:100%;text-align: left;background:none;}

.footer-menu li a{color: #222;text-decoration: none; text-align: center; padding: .7em 0;display: block;transition: .3s;margin-bottom: 0;border:1px solid #ddd;background: white;}



.copy{text-align: center;color: #555;letter-spacing: 0;background: #f5f6f7;border-bottom: 1px solid #d3d5d6;margin-bottom: 50px;}

@media (min-width: 667px) {
.common .container{max-width: 100%;}
.common .txt{margin-bottom: 0px;}
.common .wrap{display: flex;}
.common .wrap .box{padding-bottom: 0;border-bottom:none;border-right:1px solid #fff;width: 32%;}
.common .wrap .box .tel{font-family: ' CrimsonText ';font-weight: 400;display: flex;align-items: center;justify-content: center;}
.common .wrap .box .tel img{width: 22px;height: auto;margin-right: 6px;}
.common .wrap .box .tel .call{color: #fff;font-size: 25px;}
.common .wrap .box .time{font-size: 13px;letter-spacing: 0;display: flex;justify-content: center;}
.common .wrap a.mailbox{display: flex;align-items: center;justify-content: center;color: white;width: 36%; transition: .4s;font-size: 16px;text-align: center;padding-top: 0;}
.common .wrap a.mailbox img{width: 22px;height: auto;margin-right: .2em;}


footer{ padding: 40px 0px 20px;}

.footer-menu{width: 100%;border-top: none;padding: 0px;}
.footer-menu{border-top: none;margin: 0 auto;margin-top: 1em;}
.footer-menu ul{border-top: none;border-left:none;margin-left: 0;display: flex;justify-content: center;}

.footer-menu li {width: auto;padding-bottom: 0px;position: relative;background: none;text-align: left;margin-bottom: 0px;}
.footer-menu li.home{width:auto;}

.footer-menu li a{letter-spacing:0.05rem;border-right:none; padding: 0 1em;text-align:center;border-bottom: none;line-height: 1.4;background: none;border:none;margin-bottom: 10px;}
.copy{text-align: center;color: #555;letter-spacing: 0;}

.down{border-bottom: none;padding: 0;}

}



@media (min-width: 768px) {

.common .txt{}
.common .wrap .box .tel img{width: 25px;height: auto;margin-right: 6px;}
.common .wrap .box .tel .call{color: #fff;font-size: 28px;}
.common .wrap a.mailbox{display: flex;align-items: center;justify-content: center;color: white;width: 36%; transition: .4s;font-size: 16px;text-align: center;padding-top: 0;}
.common .wrap a.mailbox img{width: 25px;height: auto;margin-right: .2em;}

footer{ padding: 60px 0px 0px;margin-bottom: 60px;}
footer .yokosen{position: absolute;left:0;right: 0;top:60px;border-bottom: 1px solid #d3d5d6;}

footer .logoblock{position: relative; margin-left: 0;}
footer .address{text-align:left;margin: 0;margin-bottom: 15px;}
footer .tel{margin-bottom: 8px;line-height: 1;display: flex;align-items: center;justify-content: flex-start;}

.page-top{position: absolute;right:15px;bottom:25px;width: 20px;}
.footer-menu{margin-top: 0;display: flex;justify-content: flex-end;}
.footer-menu ul{display: block;}
.footer-menu li{margin-bottom: .5em;}
.footer-menu li a{letter-spacing:0.05rem;border-right:none; padding: 0;text-align:left;border-bottom: none;line-height: 1.4;background: none;border:none;margin-bottom: 0;}


.copy{font-size: 14px;margin-bottom: 70px;}


}


@media (min-width: 992px) {
.common .headline{margin-top: -.4em;margin-bottom: 0;}
.common .title{margin-bottom:60px;}

.common .wrap .box .tel img{width: 30px;height: auto;margin-right: 6px;}
.common .wrap .box .tel .call{color: #fff;font-size: 34px;}
.common .wrap .box .time{font-size: 14px;letter-spacing: 0;display: flex;justify-content: center;}
.common .wrap a.mailbox{font-size: 20px;}
.common .wrap a.mailbox img{width: 30px;height: auto;margin-right: .2em;}


footer{ padding: 60px 0px 0px;}
footer .container{max-width: 960px;}

footer .logoblock{position: relative; width:auto;margin-left: 0; margin-bottom: 15px;}
footer .title{text-align: left;margin: 0;margin-bottom: 10px;}
footer .address{text-align: left;margin: 0;margin-bottom:10px;line-height: 1.3;}

footer .tel{text-align:left;}


.footer-menu{width: auto;border-top: none;padding-top: 0;margin-right: 0;}
.footer-menu ul{border-top: none;border-left:none;margin-left: 0;display: block;}
.footer-menu li {padding-bottom: 5px;text-align: left;}
.footer-menu li a{text-decoration: none;letter-spacing: .05rem;margin-bottom: 0em!important;display: block;}


.btwn{display: flex;flex-direction: column;justify-content: space-between;}
.btwn2{display: flex;flex-direction: column;justify-content: center;}

.copy{font-size: 14px;}

}




@media (min-width: 1200px) {
.common{padding: 100px 0;}
.common .container{max-width: 1140px;padding: 0;}
.common .headline{margin-top: -.5em;margin-bottom: 0;}

.common .txt{}
.common .wrap .box .tel img{width: 33px;height: auto;margin-right: 6px;}
.common .wrap .box .tel .call{color: #fff;font-size: 38px;}
.common .wrap a.mailbox{font-size: 22px;}
.common .wrap a.mailbox img{width: 33px;height: auto;margin-right: .2em;}




footer{padding: 100px 0 0px;margin-bottom: 100px;}
footer .container{max-width: 1140px;}
footer .yokosen{position: absolute;left:0;right: 0;top:100px;border-bottom: 1px solid #d3d5d6;}

footer .logoblock{position: relative;}

.footer-menu li a{text-decoration: none;letter-spacing: .08rem;}
.copy{font-size: 14px;margin-bottom: 100px;}

}


@media (min-width: 1440px) {
.common .container{max-width: 1250px;padding: 0;}

footer .container{max-width: 1250px;}

.copy{font-size: 14px;}

}




@media (min-width: 1680px) {
.common .container{max-width: 1560px;}
.common .wrap .box .tel .call{color: #fff;font-size: 40px;}
.common .wrap a.mailbox{font-size: 26px;}

footer .container{max-width: 1560px;}
footer .logoblock{position: relative; width:auto;margin-bottom: 25px;}
.footer-menu li a{letter-spacing: .08rem;}
.page-top{position: absolute;right:35px;bottom:100px;width: 21px;}

}


/*------------------------------　　h2area 背景　　------------------------------------------*/

.h2area{
margin-top: 0px;
position: relative;
width:100%;
height: 480px;
z-index: 20;
display: flex;align-items:center;
}
.h2area::after {
  content: "";
  position: absolute;
  top: 0;  bottom: 0;
  left: 0;  right: 0;
  background-image: linear-gradient(180deg, rgba(0, 0, 0, .85) 10%, rgba(57, 124, 248, .5) 90%);
}
.original-gradient {
  height: 200px;
  width: 90%;
  
}
.h2area.h2-service{background: url("../images/h2-service.jpg");background-position: center top;background-size: cover;}
.h2area.h2-works{background: url("../images/h2-works.jpg");background-position: center;background-size: cover;}
.h2area.h2-company{background: url("../images/h2-company.jpg");background-position: center;background-size: cover;}
.h2area.h2-contact{background: url("../images/h2-contact.jpg");background-position: center bottom;background-size: cover;}

.h2-txt{position:relative;font-family: ' CrimsonText ';font-weight: 400;font-size: 100px;letter-spacing: .5rem;color: #fff;z-index: 10;padding-left: 15%;padding-top: 100px; line-height: 1;}
.h2-txt span {position: relative;display: flex;align-items: center;font-size: 32px;letter-spacing: .1rem;font-weight: 400;font-family: ' ZenOldMincho ';}
.h2-txt span::before {
  background-color: #fff; 
  content: "";
  height: 1px; 
  width: 60px; 
}
.h2-txt span::before {margin-right: 15px;}

@media (max-width: 1440px){
.h2area{height: 380px;}
.h2-txt{padding-left: 10%;font-size: 85px;letter-spacing: .5rem;}
.h2-txt span {font-size: 32px;letter-spacing: .1rem;}

}


@media (max-width: 1199px){
.h2area{height: 380px;}
.h2-txt{padding-left: 7%;font-size: 72px;letter-spacing: .5rem;}
.h2-txt span {font-size: 28px;letter-spacing: .1rem;}

.h2-txt span::before {
  background-color: #fff; 
  content: "";
  height: 1px; 
  width: 50px; 
}




}

@media only screen and (max-width: 991px) {
.h2area{height: 200px;margin-top: 0;}

.h2-txt{padding-left: 50px;font-size: 62px;letter-spacing: .3rem;padding-top: 0;}
.h2-txt span {font-size: 28px;letter-spacing: .1rem;}
.h2-txt span::before{
  background-color: #fff; 
  content: "";
  height: 1px; 
  width: 2em; 
}
.h2-txt span::before {margin-right: 7px;}



}


@media only screen and (max-width: 767px) {
.h2area{height: 180px;}
.h2-txt{font-size:45px;}
.h2-txt span {font-size: 24px;}
.h2-txt span::before{
  background-color: #fff; 
  content: "";
  height: 1px; 
  width:1.5em; 
}



}

 @media only screen and (max-width: 666px) {
 .h2area{height: 150px;}

.h2-txt{font-size:38px;padding-left: 15px;letter-spacing: .1rem;}
.h2-txt span {font-size: 22px;}


}

/*------------------------------　　下層ページ style　　------------------------------------------*/

.headline-h3 {
color: #222;
  position: relative;
  padding-top: 20px;
  margin-bottom: 2em;
  font-size: 20px;
  letter-spacing: .1rem;
  line-height: 1.4;
font-weight: 500;text-align:left;}


.headline-h4 {
  font-weight: 600;
  font-size: 24px;
 position: relative;
  margin-bottom: 1.5em;
  text-align: left;
  color: #001d40;
  border-left:6px solid #318de8;padding-left: .4em;
}

.headline {
 position: relative;
 font-weight: 600;
 font-size: 27px;
 padding-top: 0;
  margin-bottom: 1em;
  line-height: 1;
  display: block;
  padding: 0;
}
.headline span{display: inline-block;background: #f7731b;font-size: 13px;line-height: 1;padding: 0 .5em .2em;margin-bottom: .5em;}
.headline.kon{color: #1b2a34;}
.headline.kon span{color: #fff;}



@media (min-width: 667px) {

}







@media (min-width: 768px) {

.headline-h3 {
  position: relative;
  padding-top: 30px;
  margin-bottom: 2em;
  font-size: 18px;
  letter-spacing: .1rem;
  line-height: 1.4;
}
.headline-h3 span{display: block;position: relative;font-size: 40px; letter-spacing: .2rem;}
.headline-h3::after {
 content: '';/*何も入れない*/
  position: absolute;
  left:0;
  top:0px;
  width: 87px;/*画像の幅*/
  height: 30px;/*画像の高さ*/
  background-image: url(../images/hasami.png);
  background-size: contain;
  vertical-align: middle;}



.headline-h4 {font-size: 26px;margin-bottom: 35px;}



.h5-about{ padding-bottom: .5em;margin-bottom: 1em;font-size: 20px;}
.h6-about{margin-bottom: .6em;font-size: 17px;}

}


@media (min-width: 992px) {
.headline{font-size: 35px;margin-bottom: .8em; line-height: 1;padding-top: 0;margin-top: -.5em;}
.headline span{font-size: 13px;padding: 0 .5em .2em;}




 .headline-h4{font-size: 26px; }


}


@media (min-width: 1200px) {

.headline-h3 {
  position: relative;
  margin-bottom: 2em;
  padding-top: 40px;
  font-size: 20px;
  letter-spacing: .1rem;
  line-height: 1.4;}
.headline-h3 span{display: block;position: relative;font-size: 52px; }
.headline-h3::after {
 content: '';/*何も入れない*/
  position: absolute;
  left:0;
  top:0px;
  width: 115px;/*画像の幅*/
  height: 40px;/*画像の高さ*/
  background-image: url(../images/hasami.png);
  background-size: contain;
  vertical-align: middle;}


.headline{font-size: 38px;margin-bottom: 1.4em; line-height: 1;}

.headline-h4 { font-size: 30px;letter-spacing: .1rem;margin-bottom:40px;}



}


@media (min-width: 1440px) {

.headline{font-size: 42px;margin-bottom: .8em;line-height: 1;}
.headline span{background: #f7731b;font-size: 14px;padding: 0 .5em .2em;}


.headline-h3 span{font-size: 58px; }


}

@media (min-width: 1920px) {
.headline{font-size: 48px;margin-bottom: 1em;}
.headline span{background: #f7731b;font-size: 14px;line-height: 1;padding: 0 .5em .2em;}


}


#pankuzu{}





.marker {background: linear-gradient(transparent 60%, #ccff66 60%);padding-bottom: 3px;}
.marker2 {background: linear-gradient(transparent 80%, rgba(255,102,0,.5) 0%);}
.marker-ao {padding-bottom: 0.4em;background: linear-gradient(transparent 40%, #b5fbfb 60%);}
.marker-pink {padding-bottom: 0.4em; background: linear-gradient(transparent 40%, #fcaacb 60%);}
.marker-green {padding-bottom: 0.4em;background: linear-gradient(transparent 40%, #a8f099 60%);}



.btn-back {
  display: inline-block;
  padding:10px 5px;
  text-align: center;
  width:200px;
  text-decoration: none;
  border-radius: 6px;
  background:rgba(0,142,239,1.00);
  color: #fff;/*文字色*/
  font-size: 15px;
  letter-spacing: 0;
  transition: .3s;
}
.btn-back:hover{
  color: #fff;/*文字色*/
  background:#555;

}

.btn-pdf {
  text-align:center;
  text-decoration: none;
}
.btn-pdf a{display: flex;align-items: center;justify-content: space-between;padding: 10px 10px;background: #99CC66;color: #111;transition: .5s;border-radius: 4px;width: 260px;margin: 0 auto;}
.btn-pdf a .fas{}
.btn-pdf a:hover{
  color: #222;
  background:#f90;
}


@media (min-width: 768px) {
.btn-read{width: 325px;}
.btn-pdf a{width: 320px;padding: 20px 40px;font-size: 1.2em;}


.btn-back {
  padding:18px 5px;
  width:300px;
  font-size: 16px;
}

}


@media (min-width:1200px) {
.btn-pdf {margin-bottom: 0px;}

.btn-read{line-height: 70px;padding: 0;}

}



.photo-ofi {
  height: 0;
  display: block;
  background: none;
  overflow: hidden;
  position: relative;
  padding-bottom: 65%;
  /* 高さを指定（ボックスの横幅を基準） */
}
.photo-ofi img {
  max-width: inherit;
  max-height: inherit;
  width: 100%;
  height: 100%;
  object-fit: scale-down;
  font-family: 'object-fit: scale-down;';
  position: absolute;
  left: 0;
  top: 0;
}



/* paging */
.paging {
	padding:0em 10px 0;
	line-height: 1.4;
	font-size: 15px;
	font-family: Century Gothic,CenturyGothic,AppleGothic,sans-serif;
	display: flex;
	justify-content: center;
}
.paging span.current,
.paging  span.paging-text a{
	width: 40px;
	height: 40px;
	color:#333;
	display:flex;
	align-items: center;justify-content: center;
	margin:0 .25em;
	background: #fff;
	border: 1px solid #ddd;
	text-decoration: none;
	border-radius: 50%;
}
.paging span.current {
	background:#001E46!important;
	color:#fff!important;
}
.paging span.paging-text a:hover {
	background:#001E46!important;
	color:#fff!important;
}



/* shadow */
.box-shadow {box-shadow: 4px 4px #cdeaf8;}
.box-shadow2 {box-shadow: 2px 2px 10px rgba(0,0,0,.5)}
.drop-shadow { -webkit-filter: drop-shadow(0px 2px 1px rgba(0,0,0,.2));
        filter: drop-shadow(0px 2px 1px rgba(0,0,0,.2)); }
.drop-shadow2 { -webkit-filter: drop-shadow(0px 0px 10px rgba(0,0,0,.08));
        filter: drop-shadow(0px 0px 10px rgba(0,0,0,.08));}


.table-responsive {position: relative;z-index: 10;
border:none;
}


@media screen and (max-width: 666px) {
.table-responsive {
border:none;margin-bottom: 30px;
}
.table-responsive::-webkit-scrollbar {
height: 8px;
}

.table-responsive::-webkit-scrollbar-track {
border-radius: 2px;
background: #eee;
}

.table-responsive::-webkit-scrollbar-thumb {
border-radius: 2px;
background:#999;
}
.paging span.current,
.paging  span.paging-text a{
	width: 35px;
	height: 35px;
	color:#333;
	display:flex;
	align-items: center;justify-content: center;
	margin:0 .15em;
	background: #fff;
	border: 1px solid #ddd;
	text-decoration: none;
	border-radius: 50%;
}

}



/*サムネ付きスライダー start*/
.slickwrap {
max-width: auto;
width: 93%;
margin: 0px auto;
margin-left: 0;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.slider {
border:1px solid #eee;
  width: 100%;
  margin: 0 0 10px 0;
  overflow:hidden;
  background: white;
  padding: 0;
}
.slide-item img {width: 100%;}


.thumbnail-list {
  width: 100%;
  margin: 0;
  padding:0 0px;
}
.thumbnail-list .slick-track {
  transform: unset !important;
  width: 100% !important;
  display: flex!important;
  flex-flow:wrap;
}
.thumbnail-item {
  transition: .3s;
  padding: 1px;
  width:33.3%!important;
  box-sizing: border-box;
  position: relative;
  list-style:none;
  cursor: pointer;
}
.thumbnail-item .photo-ofi img {
  max-width: inherit;
  max-height: inherit;
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  position: absolute;
  left: 0;
  top: 0;
}
.thumbnail-item img{opacity: .5;}
.thumbnail-item.slick-current img{
border: 2px solid darkorange;
opacity: 1;
}
.thumbnail-item:hover img{opacity: 1;}
.thumbnail-item img {
  width: 100%;
  margin: 0 auto;
}

@media screen and (max-width:991px) {
.slickwrap{width: 400px;margin: 0 auto;}
}

@media only screen and (max-width:767px){
.slider {margin: 0 0 10px 0;}

}

@media only screen and (max-width:500px){
.slickwrap{width:100%;margin: 0 auto;}

}
/*サムネ付きスライダー end*/










.gmap2{}
.gmap2 iframe{width: 100%;height: 200px;}









/* service.html
--------------------------------------------------------- */

.service #section01{padding: 50px 0px 50px;position: relative;background:white;}
.service #section01 .txt{text-align: justify;font-weight: 400;margin-bottom: 35px;}
.service #section01 .wrap{margin-bottom: 1.3em;}
.service #section01 .wrap h4{font-weight: 600; margin-bottom: 20px;font-size: 20px;display: flex;align-items: center;}
.service #section01 .wrap h4 .num{background: #4f81bd;width: 50px;height: 50px;border-radius: 50%;font-weight: 400;color: white;font-size: 26px; display: flex;align-items: center;justify-content: center;margin-right: 8px;}
.service #section01 .wrap p{}
.service-pic{width: 280px;margin: 0 auto;}

.service #section02{padding:50px 0px 50px;position: relative;background: rgba(45,75,106,.07);}
.service #section02 .servicebox{position: relative;margin-bottom: 50px;}
.service #section02 .servicebox:last-child{position: relative;margin-bottom:0px;}

.service #section02 ul{}
.service #section02 .wrap{margin-bottom: 1.3em;}
.service #section02 .wrap h4{font-weight: 600; margin-bottom:26px;line-height: 1.3;}
.service #section02 .wrap h4 span{font-size: 20px;padding-bottom: .2em;border-bottom:2px solid #264665;}
.service #section02 .wrap p{margin-bottom: 1.5em;}

.service #section03{padding: 50px 0px 50px;position: relative;}
.service #section03 p{text-align: justify;margin-bottom: 25px;font-weight: 600;font-size: 19px;line-height: 1.4;}
.areamap{width: 200px;margin: 0 auto;}



#target1{position: absolute;left:0;top:-60px;}
#target2{position: absolute;left:0;top:-60px;}
#target3{position: absolute;left:0;top:-60px;}
#target4{position: absolute;left:0;top:-60px;}
#target5{position: absolute;left:0;top:-60px;}

@media (min-width: 667px) {

.service-pic{width: 350px;margin: 0 auto;}
.service #section03 p{text-align: justify;margin-bottom: 0;font-weight: 600;font-size: 19px;line-height: 1.7;}
.areamap{width: 95%;margin-left: 0;}

}



@media (min-width: 768px) {
.service #section01{padding: 70px 0px 70px;}
.service-pic{width: 100%;margin: 0 auto;}
.service #section01 .wrap{margin-bottom: 0;}




.service #section02{padding: 70px 0px 70px;}
.service #section02 .wrap{margin-bottom:0;}
.service #section02 .wrap h4{margin-bottom:26px;line-height: 1.3;}
.service #section02 .wrap h4 span{font-size: 20px;}
.service #section02 .servicebox{margin-bottom: 70px;}


.service #section03{padding: 70px 0px 70px;}
.service #section03 p{padding-left: 15px; font-size: 19px;line-height: 1.7;}

}



@media (min-width: 992px) {
.service #section01 .wrap{padding: 0 1.5em;}
.service #section01 .wrap h4{margin-bottom: 20px;font-size: 25px;}
.service #section01 .wrap h4 .num{width: 60px;height: 60px;font-size: 30px}

.service #section02 .wrap{padding: 0 1.5em;}
.service #section02 .wrap h4{margin-bottom:30px;line-height: 1.3;}
.service #section02 .wrap h4 span{font-size: 25px;}

.service #section03 p{padding-left: 15px; font-size: 22px;line-height: 1.7;}
.areamap{width: 92%;margin-left: 0;}


#target1{position: absolute;left:0;top:-80px;}
#target2{position: absolute;left:0;top:-80px;}
#target3{position: absolute;left:0;top:-80px;}
#target4{position: absolute;left:0;top:-80px;}
#target5{position: absolute;left:0;top:-80px;}

}



@media (min-width: 1200px) {
.service #section01{padding:100px 0px 100px;}
.service #section01 .txt{line-height: 2.1;font-size: 1.1em;margin-bottom: 50px;}
.service #section01 .wrap{padding: 0 2.5em;}
.service #section01 .wrap h4{margin-bottom: 20px;font-size: 25px;}
.service #section01 .wrap h4 .num{width: 60px;height: 60px;font-size: 30px}
.service #section01 .wrap p{line-height: 2;}



.service #section02{padding:100px 0px 100px;}
.service #section02 .wrap{padding: 0 2.5em;}
.service #section02 .wrap h4{margin-bottom:30px;line-height: 1.3;}
.service #section02 .wrap h4 span{font-size: 28px;}
.service #section02 .wrap p{line-height: 1.9;}
.service #section02 .servicebox{margin-bottom: 100px;}


.service #section03{padding:100px 0px 100px;}
.service #section03 p{padding-left: 15px; font-size: 24px;line-height: 2;}
.areamap{width: 90%;margin-left: 0;}



}

@media (min-width: 1440px) {
.service #section01 .wrap{padding: 0 2.5em;}
.service #section01 .wrap h4{margin-bottom: 30px;font-size: 30px;}
.service #section01 .wrap h4 .num{width: 70px;height: 70px;font-size: 36px;margin-right: 10px;}
.service #section01 .wrap p{line-height: 2;font-size: 1.1em;}

.service #section02 .wrap{padding: 0 2.5em;}
.service #section02 .wrap h4{margin-bottom:37px;line-height: 1.3;}
.service #section02 .wrap h4 span{font-size: 30px;}
.service #section02 .wrap p{font-size: 1.05em;}

}

@media (min-width: 1680px) {
.service #section01{padding:120px 0px;}
.service #section01 .txt{line-height: 2.1;font-size: 1.15em;margin-bottom: 70px;}

.service #section02{padding:120px 0px;}

.service #section03{padding:120px 0px;}

}



/* works.html
--------------------------------------------------------- */
.works #section01{padding: 50px 0 40px;position: relative;}
.works #section01 ul li{margin-bottom: 10px;}
.works #section01 ul li:last-child{margin-bottom: 0px;}
.works #section01 ul li a{display: flex;align-items: center;justify-content: center;height: 48px;line-height: 1.2;padding: 0 .4em; background:rgba(10,34,85,.6);color: white;transition: .4s;}
.works #section01 ul li a:hover{background:rgba(10,34,85,1);color: white;transition: .4s;}
.works #section01 ul li a.active{background:rgba(10,34,85,1);color: white;}

.works #section02{padding: 50px 0;position: relative;background: white;}


.works #section02 .container{max-width: 100%;}
.item-wrap{position: relative;margin-bottom: 50px;padding-bottom: 50px;border-bottom: 1px solid #999;}
.item-wrap .date{font-size: 14px;color: #555;margin-bottom: .8em;line-height: 1;display: flex;align-items: center;}
.item-wrap .date .cate{background: #89c3eb;display: inline-block;text-align: center; color: white;font-size: 12px;padding: .3em;letter-spacing: 0;margin-left: 5px;}
.item-wrap .item-title{font-weight: 600;font-size: 17px;margin-bottom: 25px;}
.before{background: rgba(61,151,222,1.00);padding: .3em .5em;text-align: center;font-size: 1.3em;color: white;margin-bottom: 10px;}
.after{background:rgba(228,100,0,1.00);padding: .3em .5em;text-align: center;font-size: 1.3em;color: white;margin-bottom: 10px;}

.item-wrap .swiper{margin-bottom: 25px;position: relative;padding: 0 5px; }
.item-wrap .swiper-wrapper,
.item-wrap .swiper-slide{height: auto;padding-bottom: 15px;}
.item-wrap .photo-ofi {
  height: 0;
  display: block;
  background: none;
  overflow: hidden;
  position: relative;
  padding-bottom: 65%;
  /* 高さを指定（ボックスの横幅を基準） */
}
.item-wrap .swiper-button-next,
.item-wrap .swiper-button-prev {color: #3399ff;}
.item-wrap .swiper .swiper-pagination-bullets{bottom: 0px;}
.item-wrap .swiper .swiper-pagination-bullet{background-color: #3399ff;}
.item-wrap .swiper .swiper-pagination-bullet{
    width: 12px;
    height: 12px;
    margin: 0 5px!important;
}
.item-wrap .swiper-pagination{left:50%;transform: translateX(-50%);}
.item-wrap .txtarea{padding-top: 20px;}
.item-wrap .swiper-button-prev {left: 0px;}
.item-wrap .swiper-button-next {right: 0px;}

@media (min-width: 667px) {

}


@media (min-width: 768px) {

.works #section02{padding: 70px 0;}
.item-wrap .date{font-size: 14px;color: #555;margin-bottom: .8em;line-height: 1;display: flex;align-items: center;}
.item-wrap .date .cate{background: #89c3eb;display: inline-block;text-align: center; color: white;font-size: 12px;padding: .3em;letter-spacing: 0;margin-left: 5px;}
.item-wrap .item-title{font-size: 17px;margin-bottom: 30px;}

.works #section03{padding: 70px 0;}

.works #section04{padding: 70px 0;}

.works #section05{padding: 70px 0;}

.works #section06{padding: 70px 0;}

}

@media (min-width: 992px) {
.works #section01 ul li a{height: 52px;}


}


@media (min-width: 1200px) {
.works #section01{padding: 80px 0 70px;}

.works #section02{padding: 100px 0;}
.works #section02 .container{max-width: 1110px;}
.item-wrap{position: relative;margin-bottom: 80px;padding-bottom: 80px;}

.item-wrap .date{font-size: 16px;color: #555;margin-bottom: .8em;}
.item-wrap .date .cate{background: #89c3eb;display: inline-block;text-align: center; color: white;font-size: 13px;padding: .3em;letter-spacing: 0;margin-left: 10px;}
.item-wrap .item-title{font-size: 20px;margin-bottom:40px;}

.works #section03{padding: 100px 0;}

}

@media (min-width: 1440px) {

}

@media (min-width: 1680px) {
.works #section01 ul li a{height: 60px;font-size: 1.1em;}

}


/* about.html
--------------------------------------------------------- */
.company #section01{padding: 50px 0;position: relative;background: white;}
.company #section01 .wrap{margin-bottom: 1.5em;}

.company #section01 .name{text-align: right;font-weight: 600;font-size: 1.2em;}

.company #section02{padding: 50px 0;position: relative;background: rgba(43,73,103,.06);}
.company #section02 .table{margin-bottom: 0;}
.company #section02 .table th{background: rgba(39,71,102,1.00)!important;color: white;width: 100%;display: block;}
.company #section02 .table td{background:white!important;width: 100%;display: block;}
.company #section02 .table td .call{color:#102153;}

.company #section03{padding: 50px 0;position: relative;background: white;}
.company #section03 .wrap{margin-bottom: 1.5em;}
.company #section03 .pic{}
.welfare{margin-bottom: 34px;}
.welfare li{margin-bottom: 18px;}

.company #section03 .box{border:1px solid #ccc;padding: 1.3em;background: white;box-shadow: 3px 4px 5px rgba(62,80,133,.2);border-radius:.3em;}
.company #section03 h5{margin-bottom: .8em;font-weight: 600;line-height: 1.1;font-size: 22px;color:#095195; }
.company #section03 h5 span{display: block;margin-bottom: .1em;font-size:40px;font-family: ' CrimsonText ';font-weight: 400;font-style: oblique;}
.company #section03 .txt{text-align: justify;}
.company #section03 .linkbtn{width: 330px;}

.recruit-table{margin-bottom: 30px;}
.recruit-table th{width: 95px;padding: 15px 10px;font-weight: 400;line-height: 1.4;border-top: none;background: rgba(0,51,102,.7)!important;color: white; border-bottom: 3px solid white;}
.recruit-table td{padding: 15px 10px;font-weight: 400;text-align: justify;line-height: 1.4;border-top: none;background: #fafafa!important; border-bottom: 3px solid white;}
.recruit-table td a{border-bottom: 1px solid #ccc;color: #0A2256;transition: .4s;}
.recruit-table td a:hover{border-bottom: 1px solid #3366ff;color: #3366ff;transition: .4s;}

@media (min-width: 667px) {
.company #section03 .pic{}
.recruit-table th{width: 130px;padding: 15px 15px;vertical-align: middle;}
.recruit-table td{padding: 15px 15px;}
.company #section03 .linkbtn{width: 370px;}

}


@media (min-width: 768px) {
.company #section01{padding: 70px 0;}
.company #section01 .wrap{margin-bottom: 0;}

.company #section01 .name{text-align: right;font-weight: 600;font-size: 1.2em;}


.company #section02{padding: 70px 0;}
.company #section02 .table th{width: 240px;display: table-cell;letter-spacing: 0;}
.company #section02 .table td{width: auto;display: table-cell;}

.company #section03{padding: 70px 0;}
.company #section03 .wrap{margin-bottom: 0;}

.welfare{margin-bottom: 40px;}
.welfare li{margin-bottom: 34px;}
.company #section03 h5{margin-bottom: .8em;font-size: 25px; }
.company #section03 h5 span{display: block;margin-bottom: .06em;font-size:50px;}

}


@media (min-width: 992px) {
.company #section01 .wrap{padding-right: 2em;}
.company #section02 .table th{width: 250px;letter-spacing: 0.05rem;}

.company #section03 .wrap{padding-left: 2em;line-height: 2;}
.company #section03 h5{margin-bottom: .8em;font-size: 24px; }
.recruit-table th{width: 180px;padding: 15px 20px;}
.recruit-table td{padding: 15px 20px;}
.company #section03 .linkbtn{width: 330px;height: 60px;border-radius: 30px;}

}



@media (min-width: 1200px) {
.company #section01{padding: 100px 0;}
.company #section01 p{font-size: 1.1em;line-height: 2;}


.company #section02{padding: 100px 0;}
.company #section02 .table th{width: 270px;letter-spacing: 0.05rem;}

.company #section03{padding: 100px 0;}
.company #section03 .wrap{padding-left: 3em;font-size: 1.1em; line-height: 2.1;}
.welfare{margin-bottom: 70px;}

.company #section03 h5{margin-bottom: 1em;font-size: 27px; }
.company #section03 h5 span{margin-bottom: .06em;font-size:60px;}
.recruit-table th{width: 200px;padding: 20px 20px;}
.recruit-table td{padding: 20px 20px;}
.company #section03 .linkbtn{width: 420px;height: 70px;border-radius: 35px;}

}




/* privacy.html
--------------------------------------------------------- */


.contact #section01{padding: 50px 0px 50px;position: relative;background: white;}
.contact #section01 .txt{text-align: justify;margin-bottom: 40px;}
.contact #section01 .wrap{}
.contact #section01 .wrap ul li{margin-bottom: 10px;}
.contact #section01 .wrap ul li:last-child{margin-bottom:0px;}
.contact #section01 .box{background: rgba(0,50,99,1.00);color: white;padding: 1em;}
.contact #section01 .box .tel{text-align: center;margin-bottom: .5em;line-height: 1;font-family: ' CrimsonText ';font-weight: 400;display: flex;align-items: center;justify-content: center;}
.contact #section01 .box .tel span{margin-left: 4px;color:#fff;font-size:35px;letter-spacing: .1rem;}
.contact #section01 .box .tel img{width: 26px;height: auto;margin-right: 5px;}
.contact #section01 .box .time{font-size: .9em;color: #eee;line-height: 1;font-weight: 600;text-align: center;}


.contact #section02{padding: 50px 0px;position: relative;background:rgba(199,189,146,.08);}
.contact #section02 p{font-weight: 400;color: #001d40;}
.contact #section02 .pre-scrollable{max-height: 300px;padding: 15px;background: white; word-break: break-all;border:1px solid rgba(0,0,0,.09);box-shadow: inset 0 0 20px rgba(0, 0, 0, .02);border-radius: 5px;}
.privacybox{position: relative;color: #333;}
.privacybox #privacy{position: absolute;left:0;top:-100px;}

span.hissu{color: white;background:#FF6800; padding: 3px 5px;border-radius: 4px;font-size: 12px;line-height: 1.5;}
.contact .table {margin-bottom: 50px;}
.contact .table th{background: rgba(225,234,241,.9)!important;vertical-align: middle;font-weight: 400;position: relative;display: block;}
.contact .table td{background: white!important;vertical-align: middle;display: block;font-weight: 400;}
.table th span.hissu{color: white;background: #FF6800; padding: 3px 5px;border-radius: 4px;position: absolute;right:15px;top:50%;transform: translateY(-50%);font-size: 12px;line-height: 1.5;}

.auto{font-size: .9em;background: #eee;line-height: 1;padding: .5em;border-radius: .4em;margin-left: .4em;color: #999;}
.tenpu{ margin: 0;font-size: 13px;}
 input.tenpu {
width: 90%!important;
 display: block;
 position: relative;
 letter-spacing: 0;
 padding: .3em 0!important;
 border-radius: 4px;
 color: #999;
 cursor: pointer!important;
 margin: 0px 0px 10px;
 font-size: 13px;
}
.tenpu input:last-child{margin: 0;}
.tenpufile{display: flex;align-items: center;padding-top: .5em;line-height: 1;}
.tenpufile .pdf{color: #b30b00;margin-right: .4em;}
.tenpufile .exl{color: #128046;}

.contact h5{font-weight: 700;border-bottom: 1px solid #ddd;padding-bottom: 10px; margin-bottom: 15px;font-size:1.2em;}


@media (min-width: 667px) {
.contact #section01 .wrap ul li{margin-bottom: 0px;}

.contact #section01 .box .tel span{margin-left: 4px;color:#fff;font-size:28px;letter-spacing: .05rem;}


}


@media (min-width: 768px) {

.contact #section01{padding: 70px 0px;}
.contact #section01 .headline{margin-bottom: 50px;}
.contact #section01 .txt{margin-bottom: 50px;text-align: center;}
.contact #section01 .box{padding: 1.5em 1em;}
.contact #section01 .box .tel span{margin-left: 4px;color:#fff;font-size:35px;letter-spacing: .05rem;}

.contact #section02{padding: 70px 0px;}
.contact .table {margin-bottom: 70px;}

.contact .table th{display: table-cell;width: 200px;}
.contact .table td{display: table-cell;width: auto;}

.contact #section02 .pre-scrollable{max-height: 400px;padding: 15px;}

}


@media (min-width: 992px) {
.contact #section01 .box{}
.contact #section01 .box .tel{text-align: center;margin-bottom: .7em;line-height: 1;}
.contact #section01 .box .tel span{margin-left: 4px;font-size:45px;letter-spacing: .2rem;}
.contact #section01 .box .tel img{width: 30px;height: auto;margin-right: 5px;}
.contact #section01 .box .time{font-size: 1em;line-height: 1;letter-spacing: .1rem;}

.contact .table th{display: table-cell;width: 240px;}


}




@media (min-width: 1200px) {

.contact #section01{padding: 100px 0px;}
.contact #section01 .headline{margin-bottom: 70px;}

.contact #section01 .txt{margin-bottom: 70px;text-align: center;font-size: 1.1em;}
.contact #section01 .box{padding: 1.8em 1em;}

.contact #section01 .box .tel span{margin-left: 6px;font-size:50px;letter-spacing: .2rem;}
.contact #section01 .box .tel img{width:33px;height: auto;margin-right: 5px;}


.contact #section02{padding: 100px 0px 100px;}
.contact .table {margin-bottom: 80px;}

.contact .table th{display: table-cell;width: 250px;}

.contact #section02 .pre-scrollable{max-height: 500px;padding: 50px;}

}




.doi-box{padding: 30px 15px;background: white;border:1px solid #ddd;border-radius: .4em;}
.doi-box p{line-height: 1.6;}
.doi-box span.hissu{color: white;background:#FF6800; padding: 2px 5px;border-radius: 2px;font-size: 12px;line-height: 1;}
.doi-box div.posi{width: 100%;margin: 0 auto;display: flex;justify-content: center;}
.doi-box label{font-size: 13px;margin-bottom: 15px;width: auto;display:inline-block;}
.doi-box p a{color: #F46A02;font-size: 15px;transition: .3s;font-weight: bold;}
.doi-box p a:hover{color: #333;}
.doi-box .btn-lg{font-size: 13px;padding: 10px 10px;}
.doi-box .linkbtn{
    font-size: 14px;
    color: #fff;
    position: relative;
    text-decoration:none;
    display: flex;
	justify-content: center;
    overflow: hidden;
	width: 149px;
    padding:0px .5em;
	height: 45px;
    border-radius: 25px;
    transition: opacity .45s ease, background .35s ease;
    background: #f7731b;
    align-items: center;
	border:none;
	margin-right: 1em;
}
.doi-box .linkbtn:last-child{margin-right: 0;}

.doi-box .linkbtn.kon{background: #102153;}
.doi-box .linkbtn.kon .linkbtn__circle{right: .8rem;}
.doi-box .linkbtn.kon .linkbtn__circle::before{background: #f7731b;}
.doi-box .linkbtn.kon .linkbtn:hover .linkbtn__circle::before{background: #f7731b;}


@media (min-width: 768px) {
.doi-box label{font-size: 14px;margin-bottom: 20px;}
.doi-box .btn-lg{font-size: 14px;padding: 10px 10px;}

.doi-box .linkbtn{
	width: 180px;
    padding:0px .5em;
	height: 50px;
    border-radius: 25px;
}


}

@media (min-width: 1140px) {
.doi-box{padding: 50px 15px;}
.doi-box .linkbtn{
font-size: 16px;
	width: 230px;
    padding:0px .5em;
	height: 60px;
    border-radius: 30px;
}
.doi-box .linkbtn.kon .linkbtn__circle{right: 1rem;}

.doi-box .btn-lg{font-size: 16px;padding: 20px 50px;}
}








.form-s{width:70px}
.form-m{width:150px}
.form-name{width:99%;}
.form100{width:90%}
.form-h{ height:15em;}
input ,select {
    position:relative;
	color: #111;
}
input[type="checkbox"], input[type="radio"] {vertical-align:middle;position: relative;top:-2px;display: inline-block;}
input{font-size:100%;vertical-align:middle; padding:12px;width: auto;}
input[type="text"], select{border:1px solid #ddd;}
input,textarea,select { outline:0; padding:12px;border-radius: 7px; }
textarea{border:1px solid #ccc;color: #111;width: 90%;}
.needinput{background-color:rgba(255,255,255,1)!important;border:1px solid #FF6800!important;}
.selectbox {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.selectbox::after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #535353;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}

.selectbox select {
    appearance: none;
    min-width: 180px;
    height: 2.8em;
    padding: .4em calc(.8em + 30px) .4em .8em;
    border: 1px solid #d0d0d0;
    border-radius: 7px;
    background-color: #fff;
	background: white;
    color: #333333;
    font-size: 1em;
    cursor: pointer;
}

input::placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
input::-webkit-input-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
input:-ms-input-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
input::-moz-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
textarea::placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
textarea::-webkit-input-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
textarea:-ms-input-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}
textarea::-moz-placeholder {
	color: #999;font-size: 14px;letter-spacing: 0.03rem;
}


@media (min-width: 768px) {
.form-name{width:350px;}

}



/*-----------------------------------------------------------------------------
print css
-----------------------------------------------------------------------------*/
@media print {
body {padding-top:0px;}
.aos-init { opacity: 1 !important; transform: none !important; }
.cb-header2 {display: none!important;}
header{display: block;}
.cb-header2 {display: none;}

.header {
  position: absolute;
  top: 0px;
  left:0;
  transition: color 0.4s ease-out;
  width: 100%;
  z-index: 500;
  height: 100px;
  display: flex;
  align-items: center;justify-content:space-between;
}
.header .logo {position: relative;margin-left: 15px;width:200px;}
.header .logo.color {display: none;}
.header .navi{padding-right: 10px;display: flex;align-items: center;justify-content: flex-end;}
.nav-menu {margin-right: 1.5em;}
.menu-list {
  display: flex;
  justify-content: center;
}
.menu-item {position: relative;padding: 0 .8em;line-height: 1;}
.menu-item:first-child {padding: 0 .8em 0 0;}
.menu-item:last-child {padding: 0 0 0 .8em;}
.menu-item a {
font-size: 16px;
letter-spacing: 0;
padding: 0;
  text-align: center;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: .3;line-height: 1;
}
.menu-item a.active {color:#102153;position: relative;}
.menu-item a.active::after {
  content: '';
  width: 100%;
  height: 2px;
  display: inline-block;
  background-color: #102153;
  position: absolute;
  bottom: -10px;
  left: 0;
}

.sp-box {
    width: 100%;
    position: absolute;
    z-index: 2;
	height: 750px;
}

.mv {position: relative;height: 320px;}
.swiper-container-back .swiper-slide img {display: none;}
.swiper-container-back .swiper-slide.bg1{background: url("../images/back_slide_1.jpg");background-position: center;background-size: cover;width: 100%;height: 730px;}
.swiper-container-back .swiper-slide.bg2{background: url("../images/back_slide_2.jpg");background-position: center;background-size: cover;width: 100%;height: 730px;}
.main-h2 h2.mv-h2{font-size:36px;line-height: 1.3;}
.home #section01{padding: 50px 0 20px;margin-bottom: 150px;}
.home #section01 .pic{display: block; width: 52%;margin-left:auto;position: absolute;right:0px;bottom:auto;top:80px;}




footer .logoblock{position: relative; width: 200px;margin-left: 0; margin-bottom: 15px;}
footer .title{text-align: left;margin: 0;margin-bottom: 10px;}
footer .address{text-align: left;margin: 0;margin-bottom:10px;line-height: 1;}
footer .address a{transition: .4s;color: #222;margin-left: .2em;}
footer .tel{margin-bottom: 0px;text-align:left;line-height: 1;}

.footer-menu{width: 100%; display: flex!important;justify-content: flex-end!important;}
.footer-menu ul{border-top: none;border-left:none;margin-left: 0;display:block;}
.footer-menu li {padding-bottom: 0px;text-align: left;}
.footer-menu li a{text-decoration: none;padding: 0;display: block;font-size: 14px!important;}

.copy{font-size: 12px;}
.page-top{display: none;}


.drawer_menu{display: none!important;}
.linkbtn{
    font-size: 1em;
    color: #fff;
    position: relative;
    text-decoration:none;
    display: flex;
    overflow: hidden;
	width: 200px;
    padding:0px 1em 0 1.6em;
	height: 50px;
    border-radius: 25px;
    transition: opacity .45s ease, background .35s ease;
    background: #f7731b;
    align-items: center;
}

.linkbtn__circle{
    position: absolute;
    top: 50%;
    right: 1.5rem;
    width: .5rem;
    height: .5rem;
    transform: translateY(-50%);
	background: white;
}

.linkbtn__circle::before{
    position: absolute;
    z-index: 1;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    content: '';
    transition: width .45s cubic-bezier(.87, .24, .36, 1), height .45s cubic-bezier(.87, .24, .36, 1);
    transform: translate3d(-50%, -50%, 0);
    border-radius: 0%;
    background: #fff;
}

.linkbtn__text{
    line-height: 1;
    position: relative;
    z-index: 2;
    transition: color .45s cubic-bezier(.87, .24, .36, 1);
}

.linkbtn:hover .linkbtn__circle::before{
    width: 50rem;
    height: 50rem;
	background: #102153;
}

.linkbtn:hover .linkbtn__text{color: #fff;}

.linkbtn.kon{background: #102153;}
.linkbtn.kon .linkbtn__circle::before{background: #f7731b;}
.linkbtn.kon .linkbtn:hover .linkbtn__circle::before{background: #f7731b;}


.no-print{display: none!important;}
.gmap iframe{width: 100%;height: 360px;}
#pagetop {display: none!important;}

}
