@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;}


/* BIZ UDPGothic */
@font-face {
    font-family: ' BIZUDPGothic ';
    src: url('../fonts/BIZUDPGothic-Regular.woff2') format('woff2'),
             url('../fonts/BIZUDPGothic-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}
/* BIZ UDPGothic-Bold */
@font-face {
    font-family: ' BIZUDPGothic ';
    src: url('../fonts/BIZUDPGothic-Bold.woff2') format('woff2'),
             url('../fonts/BIZUDPGothic-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}

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

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

body {
color: #333;
font-size: 93%;
line-height: 1.6;
font-weight:normal;
font-family: ' BIZUDPGothic ';
letter-spacing: 0.05rem;
padding-top: 60px;
position: relative;
overflow: hidden;
background:white;}


@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: 80px;}

}
@media (min-width: 1200px) {
body {
font-size: 99%;
line-height: 1.8;
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: 25px;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;}

.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;}

}

@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;}
}
@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;
}

.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;
}


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

/* font-size color
---------------------------------------------------- */
.x-small { font-size: .8em; line-height: 1.5; }
.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-Bold ';}

.white { color: #ffffff; }
.red { color: #f00; }
.blue{color: dodgerblue;}
.green { color: forestgreen; }
.pink { color: #EB5960; }
.orange { color: #f60; }
.kiiro { color: yellow!important; }
.brown{color: #8b6f57;}

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




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

}



/* 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:white;
	border-left:15px solid #0070c0;}
	
.sc .logo{padding-left: 15px;}
.sc .logo a{}
.sc img{vertical-align: bottom;width: 100px;height: auto;}

header{display: none;}



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

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



.header {
  background: #fff;
  position: fixed;
  top: 0px;
  left:0;
  transition: color 0.4s ease-out;
  width: 100%;
  z-index: 60;
  height: 80px;
  display: flex;border-left:30px solid #0070c0;
  align-items: center;justify-content: space-between;
}
.logo {position: relative;padding-left: 50px;}
.logo.color {display: none;}

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

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

.menu-item a {
font-size: 16px;
  color:#111;
  position: relative;
  text-align: center;
  overflow: hidden;
  padding: .3em 1em;
}
.menu-item a.active {color: #fff!important;background: #008EE1;border-radius: 30px;}
.link-current {color: #fff!important;background: #008EE1;border-radius: 30px;}

}

.contents {}
/* スクロールしたらヘッダーメニューのフォントカラー変更 */
.header.headerColorScroll {
  color: #000;
  background: #fafafa;
  height: 80px;
  transition: color 2s ease-out;
}
.header.headerColorScroll .logo {display: none;}
.header.headerColorScroll .logo.color {display: block;margin-top: .3em;}
.header.headerColorScroll .logo.color a{display: flex;align-items: center;color: black;transition: .4s;}
.header.headerColorScroll .logo.color a span{margin-left: .5em;}
.header.headerColorScroll .logo.color a:hover span{color: #00810A;}

.header.headerColorScroll .menu-item a {color: black;}


@media (max-width: 1680px){


}

@media (max-width: 1366px){
.logo{padding-left: 20px;}


}

@media (max-width: 1199px){
.logo{padding-left: 20px;width: 160px;}
.menu-item a {
font-size: 15px;
  color:#111;
  position: relative;
  text-align: center;
  overflow: hidden;
  padding: .3em .7em;
}

}











/*main
------------------------------------------------------------------*/

#main{position: relative;width: 100%;}
.main-h2{position: absolute;z-index: 50;
bottom: 0;
left: 0;
border-left:30px solid #0072C6;
}
.main-h2 h2{}
.main-h2 h2 span{padding: 30px 30px 30px 50px;color: #0074CC;font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-size: 55px; background: white;display: inline-block;font-weight: 600;}



.scrolldown{
    /*描画位置※位置は適宜調整してください*/
	position:absolute;
	z-index: 30;
	right:7%;
	bottom:100px;
    /*全体の高さ*/
	height:50px;
}

/*Scrollテキストの描写*/
.scrolldown span{
    /*描画位置*/
	position: absolute;
	left:-.8em;
	top: -80px;
    /*テキストの形状*/
	color: #fff;
  writing-mode: vertical-rl;
	font-size: 1em;
	letter-spacing: 0.2rem;
	font-family: ' ReemKufi ';
font-weight: 500;
}

/* 線の描写 */
.scrolldown::after{
	content: "";
    /*描画位置*/
	position: absolute;
	top: 0;
    /*線の形状*/
	width: 1px;
	height: 200px;
	background: #fff;
    /*線の動き1.4秒かけて動く。永遠にループ*/
	animation: pathmove 1.4s ease-in-out infinite;
	opacity:0;
}

/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	30%{
		height:75px;
		opacity: 1;
	}
	100%{
		height:0;
		top:150px;
		opacity: 0;
	}
}






@media (max-width: 1680px){



}



@media (max-width: 1440px){
.main-h2 h2 span{padding: 25px 20px 25px 50px;font-size: 45px;}




}


@media (max-width: 1199px){
.main-h2 h2 span{padding: 25px 20px 25px 50px;font-size: 35px;}

}




@media only screen and (max-width: 991px) {
.main-h2{position: absolute;z-index: 50;
bottom: 0;
left: 0;
border-left:15px solid #0072C6;
}
.main-h2 h2 span{padding: 25px 25px 25px 40px;font-size: 30px; }

.scrolldown{display: none;}

}

@media only screen and (max-width: 767px) {
#main{}
.main-h2 h2 span{padding: 20px 20px 20px 30px;font-size: 26px; }


}


@media only screen and (max-width: 666px) {
#main{}
.main-h2 h2 span{padding: 12px 10px 12px 18px;font-size: 18px; }





}





/* index.html 
---------------------------------------------------- */
.home #section01{position: relative;padding: 50px 0;background: linear-gradient(90deg, #fff 0%, #fff 80%, #0070c0 80%, #0070c0 100%);}
.home #section01 .wrap{margin-bottom: 1.5em;padding: 0 0px;width: 80%;}
.home #section01 .wrap .txt{margin-bottom: 1.5em;}
.home #section01 .thumb1{position: relative;width: 70%;margin-bottom: 1em;}
.home #section01 .thumb2{position:relative;}

.home #section02{position: relative;padding: 50px 0 0;border-left: 15px solid #0072C6;}
.home #section02 .heading{text-align: center;}
.home #section02 .wrap{padding: 1.5em 15px 1.5em 20px;}
.home #section02 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section02 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 1.5em;}
.home #section02 .pic{}

.home #section03{position: relative;padding: 50px 0;border-right: 15px solid #0072C6;}
.home #section03 .wrap{padding: .5em 15px 1.5em 20px;}
.home #section03 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section03 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 1.5em;}
.home #section03 .pic{}

.stripe{background: url("../images/stripe.jpg");width: 70%;height: 50px;}

.home #section04{position: relative;padding: 50px 0;}
.home #section04 .container{position: relative;max-width: 1420px;}
.home #section04 .txt{margin-bottom: 1.5em;}
.home #section04 ul li{margin-bottom: 30px;}
.home #section04 ul li:last-child{margin-bottom:0px;}

.item-box{}
.item-box .category{font-size: .9em;color: #0072C6;margin-bottom: 5px;}
.item-box .item{display: block;}
.item-box .item .thumb{width: 100%;position: relative;margin-bottom: 10px;}
.item-box .item .thumb .photo-ofi img {
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transition: .4s;
}
.item-box .item .thumb .bt{width: 25px;display: none;
  position:absolute;
  bottom:15px;
  right:15px;
}
a .item-box .item .thumb .photo-ofi img:hover {opacity: .7;}
a .item-box .item .thumb .bt{width: 25px;display: block;
  position:absolute;
  bottom:15px;
  right:15px;
}
.item-box .item .txtbox{width: 100%;}
.item-box .item .txtbox .area{color: #333;margin-bottom: .6em;}
.item-box .item .txtbox .area::before {
  font-family: "Font Awesome 5 Free";
  content: "\f276";
font-weight: 900;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  color: #0072C6;
  margin-right: 5px;
}
.item-box .item .txtbox .tag{line-height: 1;}
.item-box .item .txtbox .tag span{padding: .3em .7em;color: white;font-size: .9em;border-radius: .2em;}

.home #section05{position: relative;background: #f7f7f7;}
.home #section05 .pic{width: 150px;margin-left: -50px;}
.home #section05 .wrap{position: relative;padding: 20px 15px 50px;}

.gmap{margin-bottom: 1.6em;}
.gmap iframe{width: 100%;height: 220px;margin-bottom: 0;vertical-align: bottom;}

.btn-posi-right{display: flex;justify-content: flex-end;}
.btn-arrow {}
.btn-arrow a {
width: 230px;
    height: 50px;   
    display: flex;
    justify-content: center;
    align-items: center;
	background:rgba(0,102,204,0);
    color: #333;
	padding: 0 .5em;
	transition: .5s;
	border:1px solid #06c;
	font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
	font-weight: 500;
	position: relative;}
.btn-arrow a::after {
  position: absolute;
  right: 15px;
  top:50%;
  transform: translateY(-50%);
  font-family: "Font Awesome 5 Free";
  content: "\f054";
font-weight: 900;
font-size: .9em;
 }
.btn-arrow a:hover {
    align-items: center;background:rgba(0,102,204,1);
    color: #fff;
    }
.btn-arrow a:hover::after {width: 50px;}


@media (min-width: 667px) {
.home #section01 .wrap{padding: 0 0px;width: 85%;}



.home #section04 .wrap{padding: 0 0px;width: 85%;margin: 0 auto; }

.home #section05 .pic{position: absolute;width: 180px;margin-left: 0;top:0;left:0;}
.home #section05 .wrap{position: relative;padding: 40px 15px 40px 190px;}

}




@media (min-width: 768px) {

.home #section01{padding: 70px 0;}
.home #section01 .wrap{width: 80%;}
.home #section01 .thumb1{position: relative;width: 45%;margin-left: 0;}
.home #section01 .thumb2{position:relative;width: 80%;}



.home #section02{padding: 70px 0 0px;}
.home #section02 .wrap{padding: 1.5em 15px 1.5em 20px;}
.home #section02 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section02 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;}
.home #section02 .pic{}
.home #section02 .btn-arrow {margin-left: 45px;}



.home #section03{padding: 70px 0;}
.home #section03 .wrap{padding: 0em 15px 1.5em 20px;}
.home #section03 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section03 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;}
.home #section03 .pic{}
.home #section03 .btn-arrow {margin-left: 45px;}
.stripe{background: url("../images/stripe.jpg");width: 65%;height: 70px;}

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

.home #section05{overflow: hidden;}
.home #section05 .pic{position: absolute;width: 250px;margin-left: 0;top:0;left:0;}
.home #section05 .wrap{position: relative;padding: 70px 55px 70px 260px;}



.link-pdf{width: 100px;}

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


}



@media (min-width: 992px) {
.home #section01{padding: 70px 0 0;}
.home #section01 .wrap{width: 60%;margin-left: 0;}
.home #section01 .wrap .txt{margin-bottom: 1.5em;line-height: 2;}
.home #section01 .thumb1{width: 95%;margin-left: 0;margin-bottom: 2em;}
.home #section01 .thumb2{margin: 0;width: 60%}

.home #section02{border-left: 30px solid #0072C6;}
.home #section02 .wrap{padding: 0 0px 50px 30px;}
.home #section02 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section02 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;padding-right: 1.5em;}
.home #section02 .pic{}
.home #section02 .btn-arrow {margin-left: 45px;}


.home #section03{border-right: 30px solid #0072C6;}
.home #section03 .tate{position: absolute;left:0;top:0;border-left: 30px solid #0072C6;height: 100px;}
.home #section03 .wrap{padding: 70px 30px 1.5em 0px;}
.home #section03 h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 1.3em;margin-bottom: 1em;text-align: right; padding-bottom: .5em;border-bottom: 1px solid #0070c0;}
.home #section03 h4 span{font-family: "Lucida Sans Unicode", "Lucida Grande", "sans-serif";font-weight:400;font-size: 1.8em;color: #0070c0;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;padding-right: 1.5em;}
.home #section03 .pic{}
.home #section03 .btn-arrow {margin-left: 45px;}

.home #section04 .txt{margin-bottom: 0;}
.item-box{display: flex;justify-content: space-between;}
.item-box .category{font-size: .9em;color: #0072C6;margin-bottom: 0px;writing-mode: vertical-rl;width: 25px;text-align: left;}
.item-box .item{display: block;width: calc(100% - 25px);}
.item-box .item .thumb{width: 100%;position: relative;margin-bottom: .8em;}
.item-box .item .thumb .photo-ofi img {
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transition: .4s;
}
.item-box .item .thumb .bt{width: 45px;display: none;
  position:absolute;
  bottom:15px;
  right:15px;
}
a .item-box .item .thumb .bt{width: 45px;display: block;
  position:absolute;
  bottom:15px;
  right:15px;
}
a:hover .item-box .item .thumb .bt img{filter:hue-rotate(135deg);}

.item-box .item .txtbox{width: 100%;}
.item-box .item .txtbox .area{color: #333;margin-bottom: .6em;}
.item-box .item .txtbox .area::before {
  font-family: "Font Awesome 5 Free";
  content: "\f276";
font-weight: 900;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  color: #0072C6;
  margin-right: 5px;
}
.item-box .item .txtbox .tag{line-height: 1;}
.item-box .item .txtbox .tag span{padding: .3em .7em;color: white;font-size: .9em;border-radius: .2em;}

.home #section05 .pic{position: absolute;width: 40%;margin-left: 0;top:0;left:0;}
.home #section05 .wrap{position: relative;padding: 70px 55px 70px 45%;}

.btn-arrow a {
width: 250px;
    height: 60px;   
	padding: 0;
	}

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

}



@media (min-width: 1200px) {

.home #section01{padding: 120px 0 0;}
.home #section01 .thumb1{width: 100%;margin-left: 0;margin-bottom: 2em;}

.home #section02{padding: 120px 0 0px;}
.home #section02 .wrap{padding: 0;width: 85%;margin-left: 15%;}
.home #section02 h4{font-size: 1.8em;margin-bottom: 1em;padding-bottom: .5em;}
.home #section02 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;padding-right: 1.5em;}
.home #section02 .pic{}
.home #section02 .btn-arrow {margin-left: 45px;}


.home #section03{padding: 100px 0 120px ;}
.home #section03 .wrap{padding: 0;width: 85%;margin-right: 15%;}
.home #section03 h4{font-size: 1.8em;margin-bottom: 1em;padding-bottom: .5em;}
.home #section03 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 1.5em;padding-left: 45px;padding-right: 1.5em;}
.home #section03 .pic{}
.home #section03 .btn-arrow {margin-left: 45px;}
.stripe{background: url("../images/stripe.jpg");width: 65%;height: 100px;}


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

.home #section05{overflow: hidden;}
.home #section05 .pic{position: absolute;width: 40%;margin-left: 0;top:0;left:0;}
.home #section05 .wrap{position: relative;padding: 100px 10% 100px 45%;}


.btn-arrow a {
width: 350px;
height: 75px;}

.btn-arrow a::after {width: 50px;}
.btn-arrow a:hover::after {width: 80px;}

.gmap {margin-bottom: 1.5em;}
.gmap iframe{height: 450px;}

}





@media (min-width: 1440px) {
.home #section01{padding: 180px 0 0;}
.home #section01 .container{max-width: 80%; }
.home #section01 .wrap{width: 70%;margin-left: 0;}
.home #section01 .wrap .txt{margin-bottom: 3em;line-height: 2.3;}
.home #section01 .thumb2{margin: 0;width: 45%}
.home #section02 .wrap{padding: 0;width: 85%;margin-left: 15%;}
.home #section02 h4{font-size: 1.8em;margin-bottom: 1.3em;padding-bottom: .5em;}
.home #section02 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 1.8em;padding-left: 45px;padding-right: 1.5em;line-height: 2;font-size: 18px;}
.home #section02 .pic{}
.home #section02 .btn-arrow {margin-left: 45px;}
.home #section03 .wrap{padding: 0;width: 85%;}
.home #section03 h4{font-size: 1.8em;margin-bottom: 1.3em;padding-bottom: .5em;}
.home #section03 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 1.8em;padding-left: 45px;padding-right: 1.5em;line-height: 2;font-size: 18px;}
.home #section03 .pic{}
.home #section03 .btn-arrow {margin-left: 45px;}
.item-box .item .thumb .bt{width: 55px;}
a .item-box .item .thumb .bt{width: 55px;}


}

@media (min-width: 1680px) {
.home #section01 .container{max-width: 76%; }
.home #section01 .wrap{width: 68%;margin-left: 0;}

.home #section02 .wrap{padding: 0;width: 65%;margin-left: 35%;}
.home #section02 h4{font-size: 2.2em;margin-bottom: 1.3em;padding-bottom: .5em;font-weight: 400;}
.home #section02 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section02 .wrap .txt{margin-bottom: 2.5em;padding-left: 80px;padding-right: 6em;line-height: 2.2;font-size: 18px;}
.home #section02 .btn-arrow {margin-left: 80px;}

.home #section03 .wrap{padding: 0;width: 65%;}
.home #section03 h4{font-size: 2.2em;margin-bottom: 1.3em;padding-bottom: .5em;font-weight: 400;}
.home #section03 h4 span{font-size: 1.6em;margin-right: 5px;}
.home #section03 .wrap .txt{margin-bottom: 2.5em;padding-left: 80px;padding-right: 6em;line-height: 2.2;font-size: 18px;}
.home #section03 .btn-arrow {margin-left: 80px;}
.stripe{background: url("../images/stripe.jpg");width: 60%;height: 120px;}

.home #section05 .wrap{position: relative;padding: 100px 25% 100px 45%;}
}




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



.btn-view {position: relative;display: flex;align-items: center;color: #333;font-size: .9em;letter-spacing: .05rem;transition: .5s;}
.btn-view::after{
content: "";
display: inline-block;
  width: 50px;
  height: 50px;
  border:1px solid #06f;
  margin-left: 3em;
  transition: .5s;
}
.btn-view::before {
content: "";
    width: 60px;
    height: 6px;
    position: absolute;
	left:9em;
    border-bottom: 1px solid #06f;
    border-right: 1px solid #06f;
    -webkit-transform: skew(45deg);
    transform: skew(45deg);
}
.btn-view:hover {color: #069;}
.btn-view:hover::after{background:rgba(247,130,9,.5);}


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) {
.cp_button {
  width: 230px;
  padding: 1em;
}

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) {


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


}


@media (min-width: 1200px) {
.cp_button {
  width: 290px;
  padding: 1em;
}

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


}



/* pagetop 
---------------------------------------------------- */
#pagetop {
    position: fixed;
    bottom: 20px;
    right:20px;
    z-index: 999;
	transition: .5s;
}
#pagetop:hover {opacity: .8;}


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



}

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

}

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

}


/* -----  footer ------- */
.common{background: url("../images/bg-common-xs.jpg");background-position: center;background-size: cover;padding: 50px 0;color: white;position: relative;}
.common #contact{position: absolute;left:0;top:-60px;}
.common .container{}
.common .heading{color: white;}
.common .heading span{color: white;}
.common .txt{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";}
.common .box{border:1px solid #ccc;padding: 1.5em;}
.common .box ul{padding: 1em;}
.common .box ul li{border-bottom: 1px solid #ccc;padding-bottom: 1.5em;margin-bottom: 1.5em; display: flex;flex-direction: column;align-items: center;justify-content: center;}
.common .box ul li h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";text-align: center;margin-bottom: 1em;line-height: 1;font-size: 1.1em;}
.common .box ul li .tel{text-align: center;display: flex;align-items: center;justify-content: center;line-height: 1; margin-bottom: 10px;}
.common .box ul li .tel img{width: 26px;height: auto;margin-right: .5em;;}
.common .box ul li .tel span.call{font-size: 25px;font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";color: white;}
.common .box ul li .time{line-height: 1.4; font-size: .9em;}
.common .box ul li:last-child{border-bottom: none;padding-bottom: 0em;margin-bottom: 0;}


footer{ padding: 40px 0px 15px;position: relative;background:#128cda; color: white;}
footer .wave-xs{position: absolute;top:-10px;left:0;}
footer .wave-md{display: none;}
footer .wave{display: none;}

footer .logoblock{position: relative;text-align: center;width: 150px; margin: 0 auto; margin-bottom: 20px;}


footer .address{font-size: .9em;letter-spacing: 0;text-align: center;margin-bottom: 1em;}
footer .address a{color: white;transition: .4s;}
footer .address a:hover{color:#BEE7A3;}
footer .tel{font-size: .9em;letter-spacing: 0;text-align: center;margin-bottom: 1.5em;}
footer .tel span.call{color: white;}



.footer-menu{width: 100%;padding: 0 30px; margin: 0 auto; margin-bottom: 2em;}
.footer-menu ul{display: block;border-top: 1px solid #ccc;}
.footer-menu li{width:100%;text-align:center;background:none;font-size: 14px;}
.footer-menu li a{color: #fff;letter-spacing: .1rem; text-decoration: none; text-align: center; padding: .8em 0;border-bottom: 1px solid #ccc;display: block;transition: .3s;}
.footer-menu li a:hover{color:#eee;background:#0070c0;}


.copy{text-align: center;color: #eee; font-size: .8em;letter-spacing: 0;}
.copy{padding-top: .5em;}

@media (min-width: 667px) {
.common{background: url("../images/bg-common-sm.jpg");background-position: center top;background-size:cover;}
.common .container{max-width: 90%;}
.common .box{padding: 1em;}
.common .box ul{padding: 1em;}
.common .box ul li{border-bottom: none;border-right: 1px solid #ccc;padding-bottom: 0;margin-bottom: 0; display: flex;flex-direction: column;align-items: center;justify-content: flex-start;}
.common .box ul li h4{font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";text-align: center;margin-bottom: 1em;line-height: 1;font-size: 1.1em;}
.common .box ul li .tel{text-align: center;display: flex;align-items: center;justify-content: center;line-height: 1; margin-bottom: 10px;}
.common .box ul li .tel img{width: 26px;height: auto;margin-right: .5em;;}
.common .box ul li .tel span.call{font-size: 30px;font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";color: white;}
.common .box ul li .time{line-height: 1.4; font-size: .9em;}
.common .box ul li:last-child{border-bottom: none;border-right: none; padding-bottom: 0em;margin-bottom: 0;}

footer{ padding: 40px 0px 20px;background: #128cda;color: white;position: relative;}
footer .container{max-width: 95%;}
footer .address{text-align: center;}
footer .address a{color: white;}

footer .tel{text-align: center;margin-bottom: 1.5em;}
footer .tel span.call{color: white;margin-right: 1em;}
footer .tel span.call:last-child{color: white;margin-right: 0;}

.footer-menu{width: 100%;border-top: none;padding: 0px;}
.footer-menu{border-top: none;margin-bottom: 2em;}
.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;font-size: .9em;}
.footer-menu li a{letter-spacing:0rem;border-right:none; padding: 0 .8em;text-align: left;border-bottom: none;line-height: 1;}
.footer-menu li a:hover{color:#ddd;background:none;}
.footer-menu li:first-child a {padding: 0 .8em 0 0;}
.footer-menu li:last-child a {padding: 0 0 0 .8em;}

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

}



@media (min-width: 768px) {
.common{padding: 70px 0;}
.common .box ul li h4{font-size: 1.1em;}
.common .box ul li .tel{text-align: center;display: flex;align-items: center;justify-content: center;line-height: 1; margin-bottom: 10px;}
.common .box ul li .tel img{width: 28px;height: auto;margin-right: 5px;}
.common .box ul li .tel span.call{font-size: 32px;}

footer{ padding: 60px 0px 30px;}
footer .wave-xs{display: none;}
footer .wave-md{display: block; position: absolute;top:-10px;left:0;}
footer .wave{display: none;}

footer .address{font-size: .9em;}

footer .txt{margin-bottom: 1.6em;text-align: center;}



.copy{font-size: 12px;}


}


@media (min-width: 992px) {
.common #contact{position: absolute;left:0;top:-80px;}

.common .txt{font-size: 1em;}

footer{ padding: 80px 0px 50px;}

footer .wave-xs{display: none;}
footer .wave-md{display: none;}
footer .wave{display: block; position: absolute;top:-15px;left:0;}

footer .logoblock{margin-bottom: 20px;text-align: left;margin-left: 0;width: auto;}
footer .address{font-size: .9em;text-align: left;}
footer .tel{text-align:left;margin-bottom: 0;}
footer .tel span.call{color: white;margin-right: 0;}
footer .tel span.call:last-child{color: white;margin-right: 0;}

.footer-menu{width: 100%;border-top: none;padding-top: 0;margin-bottom: 0px;padding: 0;border-left:none;border-right: none;}
.footer-menu ul{border-top: none;border-left:none;justify-content: flex-end;}
.footer-menu li {padding-bottom: 0px;text-align: left;font-size: 14px;}
.footer-menu li a{text-decoration: none;padding: 0em .5em;letter-spacing: .05rem;}


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

.copy{font-size: 12px;text-align: right;letter-spacing: .08rem;}

}




@media (min-width: 1200px) {
.common{padding: 100px 0;}
.common{background: url("../images/bg-common.jpg");background-position: center top;background-size:cover;}
.common .container{max-width: 1140px;}
.common .box{padding: 1.5em .5em;}
.common .box ul li h4{font-size: 1.2em;}
.common .box ul li .tel{text-align: center;display: flex;align-items: center;justify-content: center;line-height: 1; margin-bottom: 10px;}
.common .box ul li .tel img{width: 37px;height: auto;margin-right: 13px;}
.common .box ul li .tel span.call{font-size: 42px;}

footer{padding: 90px 0 30px;}
footer .container{max-width: 1140px;}

footer .logoblock{position: relative;margin-bottom: 20px;}
footer .address{font-size: .9em;}
.footer-menu li {font-size: 15px;}
.footer-menu li a{text-decoration: none;padding:0em .5em;letter-spacing: .08rem;}

.copy{font-size: 12px;}



}





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

.h2area{
background: white;
position: relative;
width:calc(100% - 30px);
margin-left: 30px;
height:360px;
display: flex;align-items:center;
}
.h2area::after {
  content: "";
  position: absolute;
  top: 0;  bottom: 0;
  left: 0;  right: 0;
  background:rgba(0,114,198,.3);
}
.h2area.h2-prefab{background: url("../images/h2-prefab.jpg");background-position: center;background-size: cover;}
.h2area.h2-ex{background: url("../images/h2-ex.jpg");background-position: center;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;}

.h2-txt{position:relative;z-index: 10;font-family:YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;font-size: 50px;letter-spacing: .1rem;color: #fff;text-align: left;margin-left: 15%;text-shadow: 1px 1px 2px rgba(0,0,0,.5);}
.h2-txt span { display: block;font-size: 32px;font-weight: 400;letter-spacing: .2rem;margin-bottom: .3em;}


@media (max-width: 1440px){
.h2area{height:320px;}
.h2-txt{font-size: 42px;}



}


@media (max-width: 1199px){
.h2area{height: 250px;}

.h2-txt{font-size: 38px;}
.h2-txt span {font-size: 22px;}



}

@media only screen and (max-width: 991px) {
.h2area{height: 220px;width:calc(100% - 15px);
margin-left: 15px;
}

.h2-txt{font-size: 32px;margin-left:50px;}
.h2-txt span {font-size: 22px;}



}


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

.h2-txt{font-size: 32px;}
.h2-txt span {font-size: 20px;}



}

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

.h2area{height: 160px;}

.h2-txt{font-size: 25px;margin-left:20px;}
.h2-txt span {font-size: 18px;}


}

/*------------------------------　　下層ページ style　　------------------------------------------*/
.heading{ font-family:YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";font-weight: 600;color: #0070c0;font-size: 16px;margin-bottom: 1.5em;}
.heading span{display: block;font-size: 25px;margin-top: 5px;color: black;}

.headline-h3 {
color: #000;
  position: relative;
  margin-bottom: 25px;
  font-size: 22px;
  letter-spacing: .1rem;
  line-height: 1.4;
font-family: ' BIZUDPGothic-Bold ';font-weight: 700;}
.headline-h3 span{display: block;color: #999;font-weight: 500;font-size: 16px;}
.headline-h3:before {
  content: '';/*何も入れない*/
  position: absolute;
  top:-15px;
  left:-10px;
  width: 12px;/*画像の幅*/
  height: 12px;/*画像の高さ*/
  border-radius: 50%;
  background: #09f;
}



.headline-h4 {
  font-family: ' BIZUDPGothic ';font-weight: 700;
  font-size: 1.3em;
 position: relative;
  margin-bottom: 1.2em;
  text-align: left;
}
.headline-h4::before {
  font-family: "Font Awesome 5 Free";
  content: "\f142";
font-weight: 900;
color: #009D00;
margin-right: .2em;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}

.headline {
 font-family: ' BIZUDPGothic ';font-weight: 700;
  font-size: 18px;
 position: relative;
  margin-bottom: 2em;
  color:#222;
}
.headline:before {
  content: '';/*何も入れない*/
  position: absolute;
  bottom:-15px;
  left:0px;
  width: 2.3em;
  height: 2px;
  background: #09f;
}
.h5-about{ font-family: ' BIZUDPGothic-Bold ';font-weight: 700;border-bottom: 1px dashed #BCA46E;padding-bottom: .5em;margin-bottom: 1em;font-size: 1.1em;}
.h6-about{ font-family: ' BIZUDPGothic-Bold ';font-weight: 700;color: forestgreen;margin-bottom: .6em;}

@media (min-width: 667px) {




}



@media (min-width: 768px) {
.heading{font-size: 18px;margin-bottom: 1.5em;}
.heading span{font-size: 30px;}


.headline-h3 {font-size: 24px;margin-bottom: 30px; }

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

.headline {font-size: 24px;}

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

}


@media (min-width: 992px) {



.headline-h3 {font-size: 26px;margin-bottom: 40px;letter-spacing: .3rem;}

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


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


}


@media (min-width: 1200px) {
.heading{font-size: 24px;margin-bottom: 1.5em;font-weight: 400;}
.heading span{font-size: 40px;margin-top:5px;}


.headline-h3 {font-size: 30px;letter-spacing: .3rem;}


.headline-h4 { font-size: 24px;letter-spacing: .1rem;}

.headline {font-size:26px;margin-bottom: 2.5em;}

}


@media (min-width: 1680px) {
.heading{font-size: 28px;margin-bottom: 2em;font-weight: 400;}
.heading span{font-size: 50px;margin-top:5px;}

.headline {font-size: 28px;}

.headline-h4 { font-size: 28px;letter-spacing: .1rem;}



}



#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: 4px;
  background:#0072C6;
  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;
}
.paging .page{text-align: center;margin-bottom: 5px;font-size: 13px;}
.paging span.current,
.paging  span.paging-text a{
	padding:5px 10px;
	color:#333;
	display:inline-block;
	margin:3px 0;
	background: #fff;
	border: 1px solid #ddd;
	text-decoration: none;
}
.paging span.current {
	background:#08ace2;
	color:#fff;
}
.paging span.paging-text a:hover {
	background:#08ace2;
	color:#fff;
}



/* 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;
}
}



/*サムネ付きスライダー 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;}








/* ----- prefab.html  -----*/
.prefab #section01{padding: 50px 0;position: relative;border-left: 15px solid #0072C6;}
.prefab #section01 .container{max-width: 100%;}
.prefab #section01 .container .wrap{margin-bottom: 1em;}
.prefab #section01 .container .pic{width: 250px;margin: 0 auto;}

.prefab #section02{padding: 50px 0;position: relative;background: #f6f6f6;border-right: 15px solid #0072C6;}
.merit-wrap{padding-top: 50px;}
.merit-wrap .box{background: white;position: relative;margin-bottom: 10px;padding: 1.5em;border-radius: .5em;}
.merit-wrap .number{background: #008FE1;border-radius: 1em;padding: .6em; color: white;line-height: 1; font-size: 1.3em;text-align: center;margin-bottom: 1em;}
.merit-wrap .box h4{font-weight: 600;color: black;text-align: center;margin-bottom: .7em;font-size: 1.3em;}


.prefab #section03{padding: 50px 0;position: relative;border-left: 15px solid #0072C6;}
.prefab #section03 ul li .box{position: relative;display: flex;padding-bottom: 1.5em;margin-bottom: 1.5em;border-bottom: 1px dashed #ccc;}
.prefab #section03 ul li .box .thumb{position: relative;width: 43%;}
.prefab #section03 ul li .box .txtbox{position: relative;width: 52%;padding-left: 5%;}
.prefab #section03 ul li .box .txtbox h4{font-weight: 600;margin-bottom: .5em;color: black;font-size: 1.1em;}
.prefab #section03 ul li .box .txtbox p{line-height: 1.4;}
.prefab #section03 .btn-arrow {display: flex;justify-content: center;}

.prefab #section04{padding: 50px 0;position: relative;background: #f6f6f6;border-right: 15px solid #0072C6;}

.prefab #section05{padding: 50px 0;position: relative;border-left: 15px solid #0072C6;}
.prefab #section05 p{margin-bottom: 1em;}
.prefab #section05 .thumb{width: 250px;margin: 0 auto;}



@media (min-width: 667px) {

.prefab #section01 .container{max-width: 90%;}
.prefab #section02 .container{max-width: 94%;}
.merit-wrap{padding-top: 50px;display: flex;flex-wrap: wrap;justify-content: center;}
.merit-wrap .box{width: 31.333%;margin-bottom: 0px;margin: 0 1% 50px; padding: 1.5em;border-radius: .5em;}
.merit-wrap .number{width: 56px;height: 56px; border-radius: 50%;padding:0; display: flex;align-items: center;justify-content: center;margin: 0 auto; color: white;line-height: 1; font-size: 1.2em;text-align: center;margin-bottom:1em;margin-top: -50px;}
.merit-wrap .box h4{font-weight: 600;color: black;text-align: center;margin-bottom: .7em;font-size: 1.3em;}

.prefab #section03 .box .thumb{position: relative;width: 45%;}
.prefab #section03 .box .txtbox{position: relative;width: 50%;}

}


@media (min-width: 768px) {
.prefab #section01{padding: 70px 0;}
.prefab #section01 .container{max-width: 94%;}
.prefab #section01 .container .wrap{margin-bottom: 0;padding-right: 1.5em;}
.prefab #section01 .container .pic{width: 100%;margin: 0 auto;}




.prefab #section02{padding: 70px 0;}


.prefab #section03{padding: 70px 0;}
.prefab #section03 .container{max-width: 90%;}
.prefab #section03 ul li{margin-bottom: 40px;}
.prefab #section03 ul li .box{position: relative;display: block;padding-bottom: 0;margin-bottom: 0;border-bottom:none;}
.prefab #section03 ul li .box .thumb{position: relative;width: 100%;margin-bottom: 1em;}
.prefab #section03 ul li .box .txtbox{position: relative;width: 100%;padding-left: 0;}
.prefab #section03 ul li .box .txtbox h4{font-weight: 600;margin-bottom: .7em;text-align: center;font-size: 1.1em;}
.prefab #section03 ul li .box .txtbox p{line-height: 1.4;}

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

.prefab #section05{padding: 70px 0;}
.prefab #section05 p{margin-bottom: 0em;padding-left: 1.5em;padding-right: 1.5em;}
.prefab #section05 .thumb{width: 100%;margin: 0 auto;}



}


@media (min-width: 992px) {
.prefab #section01{border-left:30px solid #0072C6;}
.prefab #section01 .container{max-width: 94%;}
.prefab #section01 .container .wrap{margin-bottom: 0;padding-right: 1.5em;padding-left: 1em;line-height: 2;}

.prefab #section02{border-right:30px solid #0072C6;}
.merit-wrap{padding-top: 50px;display: flex;flex-wrap: wrap;justify-content: center;}
.merit-wrap .box{width: 31.333%;margin-bottom: 0px;margin: 0 1% 60px; padding: 2em;border-radius: .5em;}
.merit-wrap .number{width: 65px;height: 65px; border-radius: 50%;padding:0; display: flex;align-items: center;justify-content: center;margin: 0 auto;  font-size: 1.4em;text-align: center;margin-bottom:1em;margin-top: -60px;}
.merit-wrap .box h4{font-weight: 600;color: black;text-align: center;margin-bottom: .7em;font-size: 1.4em;}

.prefab #section03{border-left:30px solid #0072C6;}


.prefab #section04{border-right:30px solid #0072C6;}

.prefab #section05{border-left:30px solid #0072C6;}
.prefab #section05 p{line-height: 2;padding-left: 1.5em;padding-right: 2em;}

}


@media (min-width: 1200px) {
.prefab #section01{padding: 100px 0;}
.prefab #section01 .container .wrap{margin-bottom: 0;padding-right: 1.5em;padding-left: 1.5em;}


.prefab #section02{padding: 100px 0;}

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

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

.prefab #section05{padding: 100px 0;}

}

@media (min-width: 1440px) {
.prefab #section01 .container{max-width: 1330px;}
.prefab #section01 .container .wrap{width: 450px;padding-right: 0;padding-left: 1.8em;line-height: 2.3;font-size: 1.05em;}

.prefab #section02 .container{max-width:1330px;}
.merit-wrap{padding-top: 50px;display: flex;flex-wrap: wrap;justify-content: center;}
.merit-wrap .box{width: 19%;margin-bottom: 0px;margin: 0 .5% 0px; padding: 2em;border-radius: .5em .5em 2.5em .5em;}
.merit-wrap .number{width: 65px;height: 65px; border-radius: 50%;padding:0; display: flex;align-items: center;justify-content: center;margin: 0 auto;  font-size: 1.4em;text-align: center;margin-bottom:1em;margin-top: -60px;}
.merit-wrap .box h4{font-weight: 600;color: black;text-align: center;margin-bottom: .7em;font-size: 1.4em;}
.merit-wrap.ex{padding-top: 50px;display: flex;flex-wrap: wrap;justify-content: center;}
.merit-wrap.ex .box{width: 31.333%;margin: 0 1% 0px; padding: 2.5em;margin-bottom: 50px;}

.prefab #section03 .container{max-width:1330px;}
.prefab #section03 ul li {margin-bottom: 55px;}
.prefab #section03 ul li .box .thumb{position: relative;width: 100%;margin-bottom: 1.5em;}
.prefab #section03 ul li .box .txtbox h4{margin-bottom: .7em;text-align: center;font-size: 1.2em;}
.prefab #section03 ul li .box .txtbox p{line-height: 1.6;}


}

@media (min-width: 1680px) {
.prefab #section05 p{line-height: 2.2;padding-left: 3em;padding-right: 1.5em;}


}


.flow12 {
	margin: 0;
	padding: 0;
}
.flow12 > li {
	list-style-type: none;
	position: relative;
  padding-bottom: 30px;
	display: flex;
	align-items: flex-start;
}
.flow12 > li:last-child { padding-bottom: 10px;}

.flow12 > li:nth-of-type(even)::after {
	content: "";
	position: absolute;
	left: 30px;
	top: 0;
	width: 0;
  height: 100%;
	border-left: 4px dotted #d4d4d4;
}
.flow12 > li:nth-of-type(odd)::before {
	content: "";
	position: absolute;
	left: 30px;
	top: -40px;
	width: 20%;
	height: 40px;
}
.flow12 > li:nth-of-type(odd)::after {
	content: "";
	position: absolute;
	left: 30px;
	top: 50px;
	width: 20%;
	height: calc(100% - 50px);
	border-left: 4px dotted #d4d4d4;
}
.flow12 > li:first-of-type::before, .flow12 > li:last-of-type::after {content: unset;}
.flow12 > li dl {
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 90px);
}
.flow12 > li .icon12 {
	display: inline-block;
	margin: 0;
	width: 60px;
	height: auto;
	margin-right: 20px;
	text-align: center;
	font-weight: bold;
	vertical-align: middle;
	font-size: 1.2rem;
	line-height: 60px;
	background:#0074CC;
	color: #fff;
	border-radius: 100vh;
	position: relative;
	z-index: 1;
}
.flow12 > li dt {
	display: inline-block;
	margin: 1rem 0 0.5rem;
	font-size: 1.2rem;
	font-weight: 600;
	color: #0076D3;
	line-height: 1.5;
	letter-spacing: .08em;
}
.flow12 > li dd {
	max-width: 550px;
	margin: 0;
	font-weight: normal;
	line-height: 1.5;
	letter-spacing: .08em;
}

@media screen and (min-width: 960px) {
.flow12 > li {
list-style-type: none;
position: relative;
padding-bottom: 50px;
display: flex;
align-items: flex-start;
}

.flow12 > li:nth-of-type(even) {
margin-left: 40%;
padding-top: 20px;
}
.flow12 > li:nth-of-type(even)::after {height: calc(100% - 40px);left: 40px;}
.flow12 > li:nth-of-type(odd)::after {border-bottom: 4px dotted #d4d4d4;left: 40px;width: 40%;}
.flow12 > li:nth-of-type(odd)::before {
border-top: 4px dotted #d4d4d4;
border-left: 4px dotted #d4d4d4;
left: 40px;
width: 40%;
}
.flow12 > li .icon12 {
	display: inline-block;
	margin: 0;
	width: 80px;
	height: auto;
	margin-right: 20px;
	text-align: center;
	font-weight: bold;
	vertical-align: middle;
	font-size: 1.4rem;
	line-height: 80px;
}
.flow12 > li dt {
	display: inline-block;
	margin: 1rem 0 0.5rem;
	font-size: 1.4rem;
	font-weight: 600;
	color: #0076D3;
	line-height: 1.5;
	letter-spacing: .08em;
}

}
@media screen and (min-width: 1440px) {
.flow12 > li dt {
	font-size: 1.6rem;
}


}

/* works.html
--------------------------------------------------------- */

.works #section01{padding: 50px 0px 50px;position: relative;background:rgba(0,142,225,.8);border-left: 15px solid #0072C6;}
.works #section01 .index{font-weight: 600;font-size: 1.2em;color: white;margin-bottom: 1em;  align-items: center;display: flex;}
.works #section01 .index::after {
  background-color: #eee;
  content: "";
  flex-grow: 1;
  height: 1px;
}
.works #section01 .index::after { margin-left: 15px;}
.item-nav{display: flex;align-items: center;flex-wrap: wrap;}
.item-nav a{line-height: 1.2;padding: .5em 1em;border:1px solid #ccc;border-radius: .4em;color:white;margin: 0 5px 5px 0;transition: .4s;}
.item-nav a:hover{background: white;color:#62a6d7;}
.works #section02 .item-category{font-weight: 600;color: black;font-size: 1.2em;margin-bottom: 1.2em;}

.works #section02{padding:50px 0px 50px;position: relative;border-right: 15px solid #0072C6;}
.works #section02.detailpage{border-right: none;border-left: 15px solid #0072C6;}

.works #section02 ul li{margin-bottom: 30px;}
.works #section02 ul li:last-child{margin-bottom:0px;}
.works #section02 .item-box .item{display: block;}
.works #section02 .comment{color: #333;font-size: .9em;line-height: 1.5;padding-top: .6em;}
.works #section02 .swiper{max-width: 800px;margin: 0 auto;padding: 0 0px 30px;margin-bottom: 30px;}
.swiper-slide{background: white;text-align: center;padding: 0 30px;}
.works #section02 .swiper-slide img {
  height: auto;
  width: 100%;
}
/* 前への矢印 */
.works #section02 .swiper-button-prev {left: 0;}
/* 次への矢印 */
.works #section02 .swiper-button-next {right: 0;}
/* ページネーション */
.works #section02 .swiper-pagination-bullets.swiper-pagination-horizontal {bottom: 0px;}
.swiper-pagination-bullet {
  height: 13px;
  width: 13px;
}

.detailbox{margin-bottom: 50px;}
.detail-head{}
.detail-head .area{color: #333;margin-bottom: .6em;}
.detail-head .area::before {
  font-family: "Font Awesome 5 Free";
  content: "\f276";
font-weight: 900;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  color: #0072C6;
  margin-right: 5px;
}
.detail-head .tag{line-height: 1;}
.detail-head .tag span{padding: .3em .7em;color: white;font-size: .9em;border-radius: .2em;}


#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) {

.detailbox{margin-bottom: 50px;}
.detail-head{display: flex;align-items: center;margin-bottom: 1em;}
.detail-head .area{color: #333;margin-bottom: 0em;margin-right: 1.5em;}
.detail-head .area::before {
  font-family: "Font Awesome 5 Free";
  content: "\f276";
font-weight: 900;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  color: #0072C6;
  margin-right: 5px;
}
.detail-head .tag{line-height: 1;}
.detail-head .tag span{padding: .3em .7em;color: white;font-size: .9em;border-radius: .2em;}

}



@media (min-width: 768px) {


.works #section01{padding: 70px 0px 70px;}
.works #section01 .index{font-size: 1.4em;margin-bottom: 1.5em;}
.item-nav a{line-height: 1.2;font-size: 1.1em;}


.works #section02{padding: 70px 0px 70px;}
.works #section02 .item-category{font-size: 1.4em;margin-bottom: 1.2em;}

.works #section02 .swiper{margin-bottom: 50px;}
/* 前への矢印 */
.works #section02 .swiper-button-prev {left: 0;}
/* 次への矢印 */
.works #section02 .swiper-button-next {right: 0;}


}



@media (min-width: 992px) {

.works #section01{border-left: 30px solid #0072C6;}
.item-nav a{font-size: 1.1em;padding: .8em 1.3em; margin: 0 10px 10px 0;}


.works #section02{border-right: 30px solid #0072C6;}
.works #section02.detailpage{border-right: none;border-left: 30px solid #0072C6;}

.works #section02 .item-box{display: flex;justify-content: space-between;}
.works #section02 .item-box .category{font-size: .98em;color: #0072C6;margin-bottom: 0px;writing-mode: vertical-rl;width: 25px;text-align: left;}
.works #section02 .item-box .item{display: block;width: calc(100% - 25px);}
.works #section02 .item-box .item .thumb{width: 100%;position: relative;margin-bottom: .8em;}
.item-box .item .thumb .photo-ofi img {
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transition: .4s;
}
.works #section02 .item-box .item .thumb .bt{width: 45px;display: none;
  position:absolute;
  bottom:15px;
  right:15px;
}
.works #section02 a .item-box .item .thumb .bt{width: 45px;display: block;
  position:absolute;
  bottom:15px;
  right:15px;
}
.works #section02 .item-box .item .txtbox{width: 100%;}
.works #section02 .comment{font-size: .9em;line-height: 1.5;padding-top: .8em;}

#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: 1280px) {
.works #section01{padding:100px 0px 100px;}
.works #section01 .index{font-size: 1.8em;margin-bottom: 1.5em;}
.item-nav a{line-height: 1.2;font-size: 1.2em;padding: .8em 1.6em; margin: 0 10px 10px 0;}


.works #section02{padding:100px 0px 100px;}
.works #section02 .container{max-width:1380px;}
.works #section02 .container.detail{max-width:900px;}
.works #section02 .item-category{font-size: 1.7em;margin-bottom: 1.2em;}

.works #section02 .swiper{margin-bottom: 80px;}


}

@media (min-width: 1680px) {
.works #section02 .container{max-width:90%;}


}



/* company.html
--------------------------------------------------------- */


.company #section01{padding: 50px 0px 50px;position: relative;border-left:15px solid #0072C6;background: #fafafa;}
.company #section01 .container{max-width: 93%;}
.company #section01 .pic{width: 230px;margin: 0 auto;}
.company #section01 p{margin-bottom: 1.5em;}
.company #section02{padding: 50px 0px 50px;position: relative;border-right:15px solid #0072C6;}
.company #section02 .rinen{}
.company #section02 .rinen li{margin-bottom: 20px;}
.company #section02 .rinen li .box{background: #f7f7f7;position: relative;padding: 1.2em;border-radius: 1em;}
.company #section02 .rinen li .box .number{background: #0072C6;color: white;font-weight: 600;text-align: center;border-radius: .8em;margin-bottom: 1.5em;padding: .4em;font-size: 1.2em;}
.company #section02 .rinen li .box h4{font-weight: 600;text-align: center;font-size: 1.1em;margin-bottom: 1em;}


.company #section03{padding: 50px 0px 50px;position: relative;border-left:15px solid #0072C6;background: rgba(2,57,114,.05);}

.company .table{font-size: .9em;letter-spacing: .03rem;border-bottom: 1px solid #dee2e6;margin-bottom: 0;}
.company .table th{font-weight:normal;width: 100%;display: block;background:white!important;padding: 15px .5em;}
.company .table td{width: 100%;display: block;padding-left: 2em;background: white!important;}
.company .table td span{color: #333;}



.company #section04{padding: 50px 0px 50px;position: relative;border-right:15px solid #0072C6;}
.company #section04 h4{font-weight: 600;font-size: 1.2em;margin-bottom: .5em;}



@media (min-width: 667px) {
.company #section01 .container{max-width: 85%;}

.company #section02 .rinen{}
.company #section02 .rinen li .box{background: #f7f7f7;position: relative;padding: 1.2em;border-radius: 1.5em;display: flex;justify-content: space-between;}
.company #section02 .rinen li .box .number{border-radius: 50%;margin-bottom:0;padding:0;font-size: 1.8em;width: 100px;height: 100px;display: flex;align-items: center;justify-content: center;}
.company #section02 .rinen li .box .txt{width: calc(100% - 130px);}
.company #section02 .rinen li .box h4{font-weight: 600;text-align: left;font-size: 1.1em;margin-bottom: 1em;}


.company .table th{width: 140px;display: table-cell;vertical-align: middle;}
.company .table td{width: auto;display: table-cell;padding-left: 1em;vertical-align: middle;}



}



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



.company #section02{padding: 70px 0px 70px;}
.company #section02 .rinen li .box{padding: 1.5em;}



.company .table{font-size: 1em;}
.company .table th{width: 180px;}

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

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



}




@media (min-width: 992px) {
.company #section01{border-left:30px solid #0072C6;}
.company #section01 .pic{width: 90%;margin-left: 0;}
.company #section01 p{margin-bottom: 0;}

.company #section02{border-right:30px solid #0072C6;}
.company #section02 .rinen{padding-top: 50px;}
.company #section02 .rinen li{margin-bottom: 0;}
.company #section02 .rinen li .box{padding: 70px 1.6em 1.6em;border-radius: 1.5em;display:block;}
.company #section02 .rinen li .box .number{border-radius: 50%;position: absolute;top:-50px;left:50%;transform: translateX(-50%);font-size: 1.8em;width: 100px;height: 100px;display: flex;align-items: center;justify-content: center;}
.company #section02 .rinen li .box .txt{width: 100%;}
.company #section02 .rinen li .box h4{font-weight: 600;text-align:center;font-size: 1.1em;height: 3em; line-height: 1.5; margin-bottom: 1em;}

.company #section03{border-left:30px solid #0072C6;}
.company .table th{width: 250px;}

.company #section04{border-right:30px solid #0072C6;}

}



@media (min-width: 1200px) {
.company #section01{padding: 100px 0px;}
.company #section01 .container{max-width: 1140px;}
.company #section01 .pic{width:100%;margin-left: 0;}
.company #section01 p{width: 500px;margin: 0 auto;font-size: 1.1em;line-height: 2.2;}




.company #section02{padding: 100px 0px 100px;}
.company .table th{padding: 1.5em 1.2em;width: 280px;}
.company .table td{padding: 1.5em 1em;}

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

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

}


@media (min-width: 1440px) {
.company #section01 .container{max-width: 1300px;}
.company #section01 p{width: 500px;margin: 0 auto;font-size: 1.1em;line-height: 2.4;}

.company #section02 .container{max-width: 1200px;}
.company #section02 .rinen li .box{padding: 70px 3em 2em;border-radius: 1.5em;}

}



/* recruit.html
--------------------------------------------------------- */
.recruit #section01{padding: 50px 0px;position: relative;}
.recruit #section01 .thumb{;}
.recruit #section01 .container{z-index: 5;}
.recruit #section01 .wrap{margin-bottom: 1em;}
.recruit #section01 .index{font-size: 1.3em;color:#0BA500;font-weight: 700; margin-bottom: .6em;}
.recruit #section01 .txt{}

.deco-logo{width: 160px;position: absolute;bottom:5px;right:25px;}



.recruit #section02{padding: 50px 0px;position: relative;background:rgba(0,103,0,.05);}
.recruit #section02 .wrap{position: relative;background: #1f580b;color: white;display: block; width: 100%;}
.recruit #section02 .wrap .thumb{position: relative;width: 100%;height: 200px;transition: .4s; overflow: hidden;background: url("../images/top-recruit.jpg");background-position: center;background-repeat: no-repeat;background-size: cover;}
.recruit #section02 .deco{width: 150px;position: absolute;z-index: 1; bottom:0px;right:10px;}
.recruit #section02 .wrap .box{position: relative;width: 100%;padding:20px 20px 40px;}
.recruit #section02 .wrap .box .title{font-weight: 700;text-align: center;font-size: 1.5em;margin-bottom: .4em;}
.recruit #section02 .wrap .box p{margin-bottom: 1.5em;}
.recruit #section02 .wrap .box .btn-arrow{display: flex; justify-content: center;}

.table.yoko{margin-bottom: 50px;font-size: .9em;}
.table.yoko th{background: rgba(50,50,50,.03)!important;width: 100px;font-weight: 400;}
.table.yoko td{background: white!important;width: auto;}



@media (min-width: 667px) {
.recruit #section01 .thumb{width: 55%; position: absolute;left:0;top:50px;z-index: 1;}
.recruit #section01 .container{z-index: 5;padding-top:80px;}
.recruit #section01 .wrap{width: 100%;background: white;padding:1.6em;margin-bottom: 0;}
.deco-logo{width: 160px;position: absolute;bottom:auto;right:auto;top:10px;left:25px;}

.recruit #section02 .wrap .box{position: relative;width: 100%;padding:20px 40px 40px;}

.table.yoko th{width: 120px;}

.table.entry{width: 100%!important; margin-bottom: 30px;font-size: .9em;}
.table.entry th{width: 100%;display: block;vertical-align: middle;}
.table.entry td{background: white!important;width: 100%;display: block;vertical-align: middle;}

}


@media (min-width: 768px) {
.recruit #section01{padding: 70px 0px;}
.recruit #section01 .thumb{width: 50%; position: absolute;left:0;top:70px;z-index: 1;}

.recruit #section01 .txt{margin-bottom: 0em;}
.recruit #section01 .wrap{width: 70%;margin-left:30%;padding:1.6em;}

.recruit #section02{padding: 70px 0px;}
.recruit #section02 .wrap{position: relative;background: #1f580b;color: white;display: flex;align-items: center;width: 100%;}
.recruit #section02 .wrap .thumb{position: relative;width: 50%;height:320px;}
.recruit #section02 .wrap .box{position: relative;width: 50%;padding:20px 35px;}
.recruit #section02 .deco{width: 150px;position: absolute;z-index: 1; bottom:0px;right:10px;}


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

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

.recruit #section05{padding: 50px 0px;}


.table.yoko th{width: 170px;}

.table.entry{margin-bottom: 50px;font-size: .9em;}
.table.entry th{width: 190px;display: table-cell;}
.table.entry td{width: auto;display: table-cell;}

}


@media (min-width: 992px) {
.recruit #section01 .wrap{width: 70%;margin-left:30%;padding:2em 1em 0 3em;}
.recruit #section01 .index{font-size:2em;margin-bottom: .6em;}
.recruit #section02 .wrap .box{position: relative;width: 50%;padding:20px 55px;}

.table.yoko th{width: 190px;}

.table.entry{margin-bottom: 70px;font-size: .9em;}
.table.entry th{width: 210px;display: table-cell;}
.table.entry td.subindex{width: 190px;}

}


@media (min-width: 1200px) {
.recruit #section01{padding: 100px 0px;}
.recruit #section01 .thumb{width: 50%;top:100px;z-index: 1;}
.recruit #section01 .wrap{width: 60%;margin-left:40%;padding:2em 1em 0 3em;}
.recruit #section01 .index{font-size:2.5em;margin-bottom: .6em;}
.recruit #section01 .txt{line-height: 2;}
.deco-logo{width: 220px;position: absolute;bottom:auto;right:auto;top:30px;left:45px;}

.recruit #section02{padding: 100px 0px;}
.recruit #section02 .wrap .thumb{position: relative;width: 50%;height:400px;}
.recruit #section02 .wrap .box{position: relative;width: 50%;padding:20px 55px;}
.recruit #section02 .deco{width: 200px;position: absolute;z-index: 1; bottom:10px;right:10px;}



.table.yoko{font-size: 1em;}
.table.yoko th{width: 230px;}
.table.entry{margin-bottom: 80px;font-size: 1em;}
.table.entry th{width: 260px;display: table-cell;}
.table.entry td.subindex{width: 230px;}


}


@media (min-width: 1440px) {
.recruit #section01 .wrap{width: 60%;margin-left:40%;padding:3.5em 0em 0 4em;}
.recruit #section01 .index{font-size:2.5em;margin-bottom: .6em;}
.recruit #section01 .txt{line-height: 2;font-size: 1.1em;}
.deco-logo{width: 250px;position: absolute;bottom:auto;right:auto;top:50px;left:50px;}
.recruit #section02 .wrap .box .title{font-size: 1.9em;margin-bottom: .4em;}

}


@media (min-width: 1680px) {
.recruit #section01 .wrap{width: 60%;margin-left:35%;padding:4em 0em 0 6.5em;}


}

/* contact.html
--------------------------------------------------------- */


.contact #section01{padding: 50px 0px 50px;position: relative;}


.contact #section02{padding: 50px 0px;position: relative;}

.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;}
.contact .table{font-size: .9em;margin-bottom: 50px;}
.contact span.hissu{color: white;background:red; padding: 3px 5px;border-radius: 2px;font-size: 12px;}
.contact .table th{position: relative;background: rgba(0,106,1,.03)!important;display: block;font-weight: 700;}
.contact .table th span.hissu{color: white!important;background: red; padding: 3px 5px;border-radius: 2px;position: absolute;right:15px;top:50%;transform: translateY(-50%);font-size: 12px;}
.contact .table td{position: relative;background:white;display: block;}
.auto{font-size: .9em;background: #eee;line-height: 1;padding: .5em;border-radius: .4em;margin-left: .4em;color: #999;}
.contact h5{font-weight: normal;border-bottom: 1px solid #ddd;padding-bottom: 10px; margin-bottom: 15px;font-size:1.2em;}
.tenpu{margin: 0;}
.tenpu input {
width: 90%;
 display: block;
 position: relative;
 font-size: 13px;
 letter-spacing: 0;
 padding: 5px 10px 5px 0;
 border-radius: 4px;
 transition: all 0.3s;
 color: #555;
 cursor: pointer!important;
 margin: 0px 0px 2px;
}


@media (min-width: 667px) {



}


@media (min-width: 768px) {

.contact #section01{padding: 70px 0px;}

.contact #section02{padding: 70px 0px;}
.contact .table th{width: 220px;display:table-cell;vertical-align: middle;}
.contact .table td{width: auto;display:table-cell;}

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

}


@media (min-width: 992px) {

.contact .table th{width: 240px;}

}




@media (min-width: 1200px) {

.contact #section01{padding: 100px 0px;}


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

.contact .table th{width: 280px;}

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

}




.doi-box{padding: 30px 15px;border-radius: .4em;background:rgba(162,202,171,.2);border:1px solid rgba(162,202,171,.9);}
.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;}
.captcha-area{text-align: center;margin-bottom: 1.5em;}
.captcha_code{margin-bottom: .3em;}


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

@media (min-width: 1140px) {
.doi-box{padding: 50px 15px;}

.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 red!important;}

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


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

}



/*-----------------------------------------------------------------------------
print css
-----------------------------------------------------------------------------*/
@media print {
body {padding-top:80px;}
.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: 10;
  height: 80px;
  display: flex;
  border-left:15px solid #0072C6;
  align-items: center;justify-content: space-between;
}
.logo{padding-left: 10px;}
.logo.color {display: none;}

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

/* ナビゲーションメニュー */
.nav-menu {}
.menu-list {
  display: flex;
  justify-content: flex-end; /* メニューアイテムを中央揃えに */
  margin-right:0em;
}
.menu-item {position: relative;padding: 0 .5em;}
.menu-item:last-child {padding: 0 0 0 .5em;}
.menu-item a {
font-size: 14px;
  color:#111;
  position: relative;
  text-align: center;
  overflow: hidden;
  padding: .3em .5em;
}

.menu-item a.active {color: #fff!important;background: #008EE1;border-radius: 30px;}

.drop-menu-list {display: none;}
#main{height: 600px;}
.mv02{height: 600px;padding-left: 15px;}
.mv02 .slide {height: 600px;}

.home #section01 .wrap{width: 65%;margin-left: -18%;}
.home #section02{border-left: 30px solid #0072C6;}
.home #section03{border-right: 30px solid #0072C6;}
.item-box{display: flex;justify-content: space-between;}
.item-box .category{font-size: .9em;color: #0072C6;margin-bottom: 0px;writing-mode: vertical-rl;width: 25px;text-align: left;}
.item-box .item{display: block;width: calc(100% - 25px);}
.item-box .item .thumb{width: 100%;position: relative;margin-bottom: .8em;}
.item-box .item .thumb .photo-ofi img {
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transition: .4s;
}
.item-box .item .thumb .bt{width: 45px;display: none;
  position:absolute;
  bottom:15px;
  right:15px;
}
a .item-box .item .thumb .bt{width: 45px;display: block;
  position:absolute;
  bottom:15px;
  right:15px;
}
.item-box .item .txtbox{width: 100%;}
.item-box .item .txtbox .area{color: #333;margin-bottom: .6em;}
.item-box .item .txtbox .area::before {
  font-family: "Font Awesome 5 Free";
  content: "\f276";
font-weight: 900;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  color: #0072C6;
  margin-right: 5px;
}
.item-box .item .txtbox .tag{line-height: 1;}
.item-box .item .txtbox .tag span{padding: .3em .7em;color: white;font-size: .9em;border-radius: .2em;}

.h2area{height: 220px;width:calc(100% - 15px);margin-left: 15px;}



.works #section02.detailpage{border-right: none;border-left:15px solid #0072C6;}
.works #section02 .item-box{display: flex;justify-content: space-between;}
.works #section02 .item-box .category{font-size: .98em;color: #0072C6;margin-bottom: 0px;writing-mode: vertical-rl;width: 25px;text-align: left;}
.works #section02 .item-box .item{display: block;width: calc(100% - 25px);}
.works #section02 .item-box .item .thumb{width: 100%;position: relative;margin-bottom: .8em;}
.item-box .item .thumb .photo-ofi img {
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transition: .4s;
}
.works #section02 .item-box .item .thumb .bt{width: 45px;display: none;
  position:absolute;
  bottom:15px;
  right:15px;
}
.works #section02 a .item-box .item .thumb .bt{width: 45px;display: block;
  position:absolute;
  bottom:15px;
  right:15px;
}
.works #section02 .item-box .item .txtbox{width: 100%;}
.works #section02 .comment{font-size: .9em;line-height: 1.5;padding-top: .8em;}

.company #section02 .rinen{padding-top: 50px;}
.company #section02 .rinen li{margin-bottom: 0;}
.company #section02 .rinen li .box{padding: 70px 1.6em 1.6em;border-radius: 1.5em;display:block;}
.company #section02 .rinen li .box .number{border-radius: 50%;position: absolute;top:-50px;left:50%;transform: translateX(-50%);font-size: 1.8em;width: 100px;height: 100px;display: flex;align-items: center;justify-content: center;}
.company #section02 .rinen li .box .txt{width: 100%;}
.company #section02 .rinen li .box h4{font-weight: 600;text-align:center;font-size: 1.1em;height: 3em; line-height: 1.5; margin-bottom: 1em;}
.company .table th{width:250px;display: table-cell;}
.company .table td{width: auto;display: table-cell;padding-left:0;}



.common{background: url("../images/bg-common-sm.jpg");background-position: center top;background-size:cover;}
footer {padding: 90px 0 50px;}
footer .logoblock{margin-bottom: 20px;text-align: left;margin-left: 0;}
footer .address{font-size: .9em;text-align: left;}
footer .tel{text-align:left;margin-bottom: 0em;}

.footer-menu{width: 100%;border-top: none;padding-top: 0;margin-bottom: 50px;padding: 0em;border-left:none;border-right:none;}
.footer-menu ul{border-top: none;border-left:none;justify-content: flex-end;}
.footer-menu li {padding-bottom: 0px;text-align: left;font-size: 13px;}
.footer-menu li a{text-decoration: none;padding: 0em .5em;letter-spacing: .03rem;}

.copy{font-size: 12px;text-align: right;}

.drawer_menu{display: none!important;}

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

}
