/*----------------------------------------
reset
----------------------------------------*/

html, body, div, p, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6,
blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

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

table {
	border-collapse: collapse;
	border-spacing: 0;
}

.flex {
	display: -webkit-flexbox;
	display: -moz-flexbox;
	display: -ms-flexbox;
	display: -o-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-o-flex-wrap: wrap;
	flex-wrap: wrap;
	-js-display: flex;
  }

@import url('https://fonts.cdnfonts.com/css/neue-haas-grotesk-text');

/*----------------------------------------
全体
----------------------------------------*/

body {
	font-family: "ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
	font-weight: 400;
	font-size: 18px;
	line-height: 28px;
	word-break: break-word;
	text-size-adjust: none;
}

.wrapper {
	box-sizing: border-box;
	height: 100%;
	margin: 0 auto;
}

.sp-wrapper {
	overflow: hidden;
}

.center {
	display: block;
	margin: 0 auto;
}

.left {
	float: left;
}

.right {
	float: right;
}

.pc-left {
	float: left;
}

.pc-right {
	float: right;
}

.aligncenter {
	display: block;
	margin: 0 auto;
}

.alignleft {
	float: left;
}

.alignright {
	float: right;
}

.t-center {
	text-align: center !important;
}

.t-left {
	text-align: left !important;
}

.t-right {
	text-align: right !important;
}

.pc-t-center {
	text-align: center !important;
}

.clear {
	clear: both;
}

.inline {
	display: inline !important;
}

.inline-b {
	display: inline-block !important;
}

.block {
	display: block !important;
}

.of {
	overflow: hidden;
}

.pc-of {
	overflow: hidden;
}

img,
iframe {
	display: block;
}

a:hover img {
	opacity: 0.6;
}

.img-banner {
	background-size: 100% !important;
	box-sizing: border-box;
	display: block;
	height: 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	width: 100%;
}

a:hover .img-banner {
	opacity: 0.6;
}

a.bo {
	text-decoration: underline;
}

a.bo:hover {
	text-decoration: none;
}

a.no-bo {
	text-decoration: none;
}

a.no-bo:hover {
	text-decoration: underline;
}

.full {
	height: auto;
	width: 100%;
}

.list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.list li {
	box-sizing: border-box;
	list-style: disc !important;
	margin-left: 19px !important;
}

_::-webkit-full-page-media, _:future, :root .list li {
	margin-left: 23px !important;
}

.num-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list li {
	box-sizing: border-box;
	list-style: decimal !important;
	margin-left: 20px !important;
}

.num-list li:nth-child(n+10) {
	margin-left: 28px !important;
}

.num-list-2 {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list-2 li {
	box-sizing: border-box;
	padding-left: 33px;
}

.num-in {
	left: 0;
	position: absolute;
}

.check-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.check-list li {
	box-sizing: border-box;
	margin-bottom: 10px;
	min-height: 25px;
	padding-left: 37.5px;
	position: relative;
}

.check-list li:last-child {
	margin-bottom: 0;
}

.check-list li::before {
	background: #fff;
	box-sizing: border-box;
	border: 3px solid #000;
	content: "";
	left: 0;
	height: 25px;
	position: absolute;
	top: 3px;
	width: 25px;
}

.check-list li::after {
	box-sizing: border-box;
	border-right: 4px solid #ff0000;
	border-bottom: 4px solid #ff0000;
	content: "";
	left: 12px;
	height: 22px;
	position: absolute;
	top: -1px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	width: 14px;
}

.douga {
	margin: 0 auto;
}

.douga iframe {
	margin: 0 auto;
}

.text-base {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 18px;
	position: relative;
}

.text-base-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 36px;
	position: relative;
}

.text-base-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 54px;
	position: relative;
}

.text-base-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 72px;
	position: relative;
}

.text-base-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 90px;
	position: relative;
}

.text-in {
	left: 0;
	position: absolute;
	top: 0;
}

.indent-1 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 1em;
	text-indent: -1em;
}

.indent-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 2em;
	text-indent: -2em;
}

.indent-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 3em;
	text-indent: -3em;
}

.indent-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 4em;
	text-indent: -4em;
}

.indent-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 5em;
	text-indent: -5em;
}

.pc {
	display: block;
}

.pc.tab {
	display: block;
}

.pc.tab.mobi {
	display: block;
}

.tab {
	display: none;
}

.tab.mobi {
	display: none;
}

.pc.mobi {
	display: block;
}

.mobi {
	display: none;
}

.first {
	margin-top: 0 !important;
}

.last {
	margin-bottom: 0 !important;
}

.m20 {
	margin: 20px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.no-mt20 {
	margin-top: -20px !important;
}

.mt-20 {
	margin-top: 20px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.m40 {
	margin: 40px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.ml40 {
	margin-left: 40px !important;
}

.mr40 {
	margin-right: 40px !important;
}

.m60 {
	margin: 60px !important;
}

.mt60 {
	margin-top: 60px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb-60 {
	margin-bottom: 60px !important;
}

.ml60 {
	margin-left: 60px !important;
}

.mr60 {
	margin-right: 60px !important;
}

.m80 {
	margin: 80px !important;
}

.mt80 {
	margin-top: 80px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.ml80 {
	margin-left: 80px !important;
}

.mr80 {
	margin-right: 80px !important;
}

.m100 {
	margin: 100px !important;
}

.mt100 {
	margin-top: 100px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.ml100 {
	margin-left: 100px !important;
}

.mr100 {
	margin-right: 100px !important;
}

.p20 {
	padding: 20px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pl20 {
	padding-left: 20px !important;
}

.pr20 {
	padding-right: 20px !important;
}

.p40 {
	padding: 40px !important;
}

.pt40 {
	padding-top: 40px !important;
}

.pb40 {
	padding-bottom: 40px !important;
}

.pl40 {
	padding-left: 40px !important;
}

.pr40 {
	padding-right: 40px !important;
}

.p60 {
	padding: 60px !important;
}

.pt60 {
	padding-top: 60px !important;
}

.pb60 {
	padding-bottom: 60px !important;
}

.pl60 {
	padding-left: 60px !important;
}

.pr60 {
	padding-right: 60px !important;
}

.p80 {
	padding: 80px !important;
}

.pt80 {
	padding-top: 80px !important;
}

.pb80 {
	padding-bottom: 80px !important;
}

.pl80 {
	padding-left: 80px !important;
}

.pr80 {
	padding-right: 80px !important;
}

.p100 {
	padding: 100px !important;
}

.pt100 {
	padding-top: 100px !important;
}

.pb100 {
	padding-bottom: 100px !important;
}

.pl100 {
	padding-left: 100px !important;
}

.pr100 {
	padding-right: 100px !important;
}

/*----------------------------------------
文字スタイル
----------------------------------------*/

.gothic {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.minchou {
	font-family: "游明朝", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.hirago {
	font-family: "ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
}

.hiramin {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif;
}

.nueue{
	font-family: 'Neue Haas Grotesk Text', sans-serif;
}
.sans {
	font-family: 'Noto Sans JP', sans-serif;
}

.serif {
	font-family: 'Noto Serif JP', serif;
}

.bahn {
	font-family: 'Bahnschrift', sans-serif;
}

strong,b,.strong {
	font-weight: 700;
}

.red {
	color: #ff3d3d;
}

.blue {
	color: #004bb3;
}

.yellow {
	color: #ffff00;
}

.green {
	color: #008800;
}

.orange {
	color: #ff8800;
}

.magenta {
	color: #F37C92;
}

.cyan {
	color: #5DBFF2;
}

.y-b {
	background: linear-gradient(transparent 50%, #ffff00 50%);
}

.fs15 {
	font-size: 15px !important;
	line-height: 25px !important;
}

.fs23 {
	font-size: 23px !important;
	line-height: 33px !important;
}

.fs30 {
	font-size: 30px !important;
	line-height: 40px !important;
}

.fs40 {
	font-size: 40px !important;
	line-height: 50px !important;
}

.fs50 {
	font-size: 50px !important;
	line-height: 60px !important;
}

.l-space-s{
	letter-spacing:-.05em;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h2.hd-underbar{
	font-size:38px;
	font-weight:900;
}

h2.hd-underbar{
  position: relative;
  margin-bottom: 1em;
}

h2.hd-underbar:before {
	content: '';
	position: absolute;
	bottom: -18px;
	width: 150px;
	height: 3px;
	left: 0;
	right:0;
	margin:auto;
	background:#004ab0;
}

.hd-style-1{
    background: #fff;
    box-sizing: border-box;
    border-color: #004bb3 !important;
    border-left: 8px solid;
    color: #004bb3;
    font-weight: 700;
    font-size: 24px;
    line-height: 34px;
    padding: 8px 20px;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.8);
}


/*----------------------------------------
画像関連
----------------------------------------*/

/*----------------------------------------
header
----------------------------------------*/

#headwrap #headmain .headbox {
    width: 1020px;
    margin: 0 auto;
    padding: 5px 0;
    overflow: hidden;
	align-items:center;
	flex-wrap:nowrap;
	justify-content:space-between;
}

.headbox #logo {
    margin: 3px 0 0 0;
	font-size:30px;
	font-weight:900;
}

.headbox #logo a{
	text-decoration:none;
	color:#000;
}

.headbox #logo span.logo-info2 {
    font-size: 14px;
	position:absolute;
	top:5px;
	font-weight:400;
}

.head-in-info {
    box-sizing: border-box;
    margin: 1px 0;
	align-items:center;
	justify-content:space-between;
	flex-wrap:nowrap;
}

.head-in-info-tel {
    box-sizing: border-box;
    margin: 5px 0;
	font-weight: 900;
	line-height:1.2;
}

.head-in-info-tel-num{
	font-size:30px;
	position:relative;
    letter-spacing: -.05em;
}

.head-in-info-tel-num::before {
    background: url(../../images/change/tel-btn.png) no-repeat;
    background-size: 100%;
    box-sizing: border-box;
    content: "";
    left: -23px;
    height: 35px;
    position: absolute;
    top: 7px;
    width: 25px;
}

.head-in-info-mail-btn {
    box-sizing: border-box;
    display: inline-block;
    margin-left: 40px;
}

.head-in-info-tel-tx{
	font-size:15px;
}

.head-in-info-tel-time{
	font-size:12px;
}

nav {
    height: 60px;
    background-color: #0050be;
}

nav ul {
    width: 1020px;
    margin: 0 auto;
}

nav ul li {
    float: left;
    text-align: center;
    line-height: 60px;
    position: relative;
}

nav ul li a {
    box-sizing: border-box;
    display: inline-block;
    text-decoration: none;
    width: 159.5px;
    height: 60px;
    font-size: 14px;
    color: #fff;
    border-right: 1px solid #bfbfbf;
    vertical-align: middle;
    font-weight: bold;
}

nav ul li:first-child a {
    border-left: 1px solid #bfbfbf;
    height: 60px !important;
    padding: 4px 0;
    width: 58px;
}

nav ul li:first-child img {
    margin: 16px auto;
}

/*----------------------------------------
枠　共通
----------------------------------------*/
.main-wrap {
    width: 1020px;
    margin: 0 auto;
}

.main-wrap .leftbox {
    width: 750px;
    float: left;
    color: #313131;
}



/*------------------------------
TOP KV
------------------------------*/

.top-kv {
	background: url(../../images/change/mv-bg.jpg);
	background-position: top center;
	box-sizing: border-box;
	background-repeat:no-repeat;
	background-size:cover;
	height:530px;
	width:100%;
}

.top-kv .inner {
	position: relative;
	width:100%;
	max-width:1020px;
	margin:0 auto;
	height:100%;
}

.top-kv-tt{
	position:absolute;
	top:9%;
}

.top-kv-ceo-tx{
	position:absolute;
	right:20%;
	bottom:3%;
	z-index:10;
	font-size:20px;
	font-weight:700;
 	text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
	line-height:1.5;
}

.top-kv-ceo-tx .big{
	font-size:28px;
}

.top-kv-ceo-pic{
	position:absolute;
	right:0;
	bottom:0;
}

/*----------------------------------------
お問い合わせバナー
----------------------------------------*/
.contact-bn{
	background: url(../../images/change/contact-bg.jpg);
	background-position: top center;
	box-sizing: border-box;	
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.8);
    height: 250px;
    background-repeat: no-repeat;
	position:relativel;
}

.contact-bn-inner{
	position:relative;
	left:0;
	right:0;
	margin:auto;
	top:50%;
	width:84%;
	justify-content:space-between;
}

.contact-bn-in-tel{
    font-size: 30px;
    position: relative;
}

.contact-bn-in-tel .num{
	position:relative;
	letter-spacing: -.05em;
    font-weight: 900;
    font-size: 37px;
	padding-left:30px;
}

.contact-bn-in-tel .num::before {
    background: url(../../images/change/tel-btn.png) no-repeat;
    background-size: 100%;
    box-sizing: border-box;
    content: "";
    left: 0;
    height: 35px;
    position: absolute;
    top: 7px;
    width: 25px;
}

.contact-bn-in-tel .time{
	font-size:16px;
	display:block;
	text-align:center;
	padding-top:5px;
}

/*----------------------------------------
トップ：メリット
----------------------------------------*/
.top-merit{
	padding-top:30px;
}

.top-merit-box{
	border:solid 5px #dce0e8;
	padding:20px;
}




/*----------------------------------------
トップ：特徴
----------------------------------------*/
.top-features{
	background:#f0f9fc;
	padding:50px 15px;
}

.top-features-list{
    box-sizing: border-box;
    position: relative;
    z-index: 2;
}

.top-features-list li {
    box-sizing: border-box;
    font-size: 17px;
    line-height: 27px;
    margin-bottom: 20px;
    padding-left: 20px;
    position: relative;
}

.top-features-list li::before {
    background: #004bb3;
    box-sizing: border-box;
    border-radius: 50%;
    content: "";
    left: 0;
    height: 15px;
    position: absolute;
    top: 5px;
    width: 15px;
}

.top-features dl{
	margin-top:50px;
	clear:both;
}

.top-features dd{
	margin-top:30px;
}

.features-pic{
	padding:0 0 20px 20px;
}

/*----------------------------------------
トップ：対応エリア
----------------------------------------*/
.top-area{
	background: url(../../images/change/area-bg.jpg);
	background-position: top center;
	box-sizing: border-box;	
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.8);
	clear:both;
	background-repeat:no-repeat;
	height:330px;
	margin:50px auto;
}

.top-area .inner{
	position:relative;
	width:100%;
	height:250px;
}

.top-area-tx1{
	position:absolute;
    left: 5%;
    top: 44%;
}

.top-area-tx2{
	font-size:20px;
	line-height:30px;
	position:absolute;
    left: 5%;
    top: 75%;
}

/*----------------------------------------
トップ：流れ
----------------------------------------*/

.top-flow{
	margin:50px 0;
	background:#f0f9fc;
	padding:50px 15px;
}
.top-flow-list li{
	
}

/*----------------------------------------
404ページ
----------------------------------------*/

/*----------------------------------------
sidebar
----------------------------------------*/

/*----------------------------------------
footer
----------------------------------------*/

footer {
	box-sizing: border-box;
}

.foot-in {
	background: #f6f4ef;
	box-sizing: border-box;
}

.foot-in .wrapper {
	padding: 60px 0;
}

.foot-in-main {
	box-sizing: border-box;
	float: left;
}

.foot-in-main-logo {
	box-sizing: border-box;
}

.foot-in-main-logo-in {
	box-sizing: border-box;
	font-weight: 700;
	font-size: 35px;
	line-height: 45px;
}

.foot-in-main-logo-in .orange {
	color: #ff6d00;
}

.foot-in-main-logo-text {
	box-sizing: border-box;
	font-weight: 700;
	font-size: 18px;
	line-height: 28px;
}

.foot-in-main-address {
	box-sizing: border-box;
	font-weight: 700;
	font-size: 16px;
	line-height: 24px;
	margin-top: 40px;
}

.foot-in-info {
	box-sizing: border-box;
	float: right;
}

.foot-in-info-tel {
    box-sizing: border-box;
    float: left;
    margin: 5px 0;
}

.foot-in-info-tel-num {
    box-sizing: border-box;
    font-weight: 700;
    font-size: 36px;
    line-height: 46px;
    padding-left: 31px;
    position: relative;
}

.foot-in-info-tel-num::before {
    background: url(images/icon-tel-1.png) no-repeat;
    background-size: 100%;
    box-sizing: border-box;
    content: "";
    left: 0;
    height: 26px;
    position: absolute;
    top: 7px;
    width: 26px;
}

.foot-in-info-tel-text {
    box-sizing: border-box;
    display: block;
    font-weight: 700;
    font-size: 14px;
    line-height: 24px;
    margin-top: -10px;
    text-align: center;
}

.foot-in-info-mail-btn {
    box-sizing: border-box;
    display: inline-block;
    float: right;
    margin-left: 40px;
    padding-bottom: 5px;
    text-decoration: none;
    width: 250px;
}

.foot-in-info-mail-btn-in {
    background: #f25459;
    box-sizing: border-box;
    border-radius: 100px;
    box-shadow: 0 5px #d03035;
    color: #fff;
    display: block;
    font-weight: 700;
    font-size: 16px;
    line-height: 26px;
    padding: 20px;
    text-align: center;
}

.foot-in-info-mail-btn:hover .foot-in-info-mail-btn-in {
    box-shadow: none !important;
    transform: translate3d(0,5px,0);
    -webkit-transform: translate3d(0,5px,0);
}

.foot-in-info-mail-btn-in-text {
    box-sizing: border-box;
    display: inline-block;
    padding-left: 41px;
    position: relative;
}

.foot-in-info-mail-btn-in-text::before {
    background: url(images/icon-mail-1.png) no-repeat;
    background-size: 100%;
    box-sizing: border-box;
    content: "";
    left: 0;
    height: 18px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    width: 31px;
}

/*----------------------------------------
ページトップ
----------------------------------------*/

.pagetop {
	background: #666;
	box-sizing: border-box;
	border-radius: 50%;
	bottom: 20px;
	cursor: pointer;
	height: 75px;
	position: fixed;
	right: 20px;
	width: 75px;
	z-index: 100;
}

.pagetop::before {
  box-sizing: border-box;
  color: #fff;
  content: "\e001";
  font-family: 'icomoon';
  font-size: 75px;
  line-height: 75px;
  position: absolute;
  text-align: center;
  width: 75px;
}

.pagetop:hover {
	opacity: 0.6;
}

/*----------------------------------------
Edge CSSハック
----------------------------------------*/

@supports (-ms-ime-align: auto) {



}

/*----------------------------------------
IE11以下 CSSハック
----------------------------------------*/

@media screen\0 {



}

/*----------------------------------------
Firefox CSSハック
----------------------------------------*/

@-moz-document url-prefix() {



}

/*----------------------------------------
Safari CSSハック
----------------------------------------*/

_::-webkit-full-page-media, _:future, :root .num-list li {
	margin-left: 30px !important;
}

_::-webkit-full-page-media, _:future, :root .num-list li:nth-child(n+10) {
	margin-left: 40px !important;
}