@charset "utf-8";
html {
  scroll-behavior: smooth;
}

body {
  font-family:'Noto Sans JP','小塚ゴシック Pro','Kozuka Gothic Pro',sans-serif;
  font-size: 19px;
  font-weight: 450;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
  color: #231815;
  background: #000;
  padding: 10px;
}

.cont_inner{
	background: #fff;
	border-radius: 10px;
}

a {
  color: #000;
  text-decoration: none;
  transition: 0.5s;
}
a:hover, .active {
  text-decoration: none;
  opacity: 0.5;
  transition: 0.5s;
}
a:active, a:focus, input:active, input:focus {
  outline: 0;
}
a.red {
  color: #C30D23;
}
.min {
  font-family: 'Kozuka Mincho Pro', 'Kozuka Mincho Std', '小塚明朝 Pro R', '小塚明朝 Std R', 'Hiragino Mincho Pro', 'ヒラギノ明朝 Pro W3', 'ＭＳ Ｐ明朝', 'Times', 'Times New Roman', serif;
}
p {
  letter-spacing: 2px;
  line-height: 160%;
}
table {
  line-height: 160%;
}
.cen {
  text-align: center;
}
.lef {
  text-align: left;
}
.rig {
  text-align: right;
}
.top_10m {
  margin-top: 10px;
}
.top_20m {
  margin-top: 20px;
}
.top_30m {
  margin-top: 30px;
}
.top_40m {
  margin-top: 40px;
}
.top_50m {
  margin-top: 50px;
}
.top_60m {
  margin-top: 60px;
}
.top_70m {
  margin-top: 70px;
}
.top_80m {
  margin-top: 80px;
}
.top_90m {
  margin-top: 90px;
}
.top_100m {
  margin-top: 100px;
}
.bot_10m {
  margin-bottom: 10px;
}
.bot_20m {
  margin-bottom: 20px;
}
.bot_30m {
  margin-bottom: 30px;
}
.bot_40m {
  margin-bottom: 40px;
}
.bot_50m {
  margin-bottom: 50px;
}
.bot_60m {
  margin-bottom: 60px;
}
.bot_70m {
  margin-bottom: 70px;
}
.bot_80m {
  margin-bottom: 80px;
}
.bot_90m {
  margin-bottom: 90px;
}
.rig_10m {
  margin-right: 10px;
}
.rig_20m {
  margin-right: 20px;
}
.rig_30m {
  margin-right: 30px;
}
.lef_10m {
  margin-left: 10px;
}
.lef_20m {
  margin-left: 20px;
}
.lef_30m {
  margin-left: 30px;
}

.ma40 {
  margin-top: 40px;
}
.pl20 {
  padding-left: 20px;
}
.pl40 {
  padding-left: 40px;
}
.pl70 {
  padding-left: 70px;
}

.notxt {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  height: 1px;
  font-size: 1px;
}
.ind_01 {
  padding-left: 1em;
  text-indent: -1em;
}
.ind_02 {
  padding-left: 2em;
  text-indent: -2em;
}
.ind_03 {
  padding-left: 3em;
  text-indent: -3em;
}
.ind_04 {
  padding-left: 4em;
  text-indent: -4em;
}
.ind_05 {
  padding-left: 5em;
  text-indent: -5em;
}
.gray {
  height: 2px;
  background-color: #ccc;
  border: 0;
}
.line_g {
  height: 2px;
  background-color: #ccc;
  border: 0;
}
.line_o {
  height: 2px;
  background-color: #E95412;
  border: 0;
}
.pc_blc {
  display: block;
}
.sp_blc {
  display: none;
}
@media only screen and (max-width: 820px) {
  .pc_blc {
    display: none;
  }
  .sp_blc {
    display: block;
  }
}
body {
  animation: fadeIn 1s ease 0s 1 normal;
  -webkit-animation: fadeIn 1s ease 0s 1 normal;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}


.top_h1 {
  opacity: 0;
  animation-duration: 2s;/* アニメーション時間 */
  animation-delay : 0.5s;/* 変化開始の時間 */
  animation-name: fadeIn_h1;/* アニメーション名 */
  animation-iteration-count: 1;/* アニメーションの繰り返し（無限）*/
  animation-fill-mode: forwards; /*これで値を保持*/
}
@keyframes fadeIn_h1 {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }
  
  100% {
    opacity: 1;
	transform: translateY(0);
  }
}
@-webkit-keyframes fadeIn_h1 {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }

  100% {
    opacity: 1;
	transform: translateY(0);
  }
}

.top_h1_txt {
  opacity: 0;
  animation-duration: 2s;/* アニメーション時間 */
  animation-delay : 1.0s;/* 変化開始の時間 */
  animation-name: fadeIn_h1_txt;/* アニメーション名 */
  animation-iteration-count: 1;/* アニメーションの繰り返し（無限）*/
  animation-fill-mode: forwards; /*これで値を保持*/
}
@keyframes fadeIn_h1_txt {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }
  
  100% {
    opacity: 1;
	transform: translateY(0);
  }
}
@-webkit-keyframes fadeIn_h1_txt {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }

  100% {
    opacity: 1;
	transform: translateY(0);
  }
}

.top_h2_txt {
  opacity: 0;
  animation-duration: 2s;/* アニメーション時間 */
  animation-delay : 1.5s;/* 変化開始の時間 */
  animation-name: fadeIn_h2;/* アニメーション名 */
  animation-iteration-count: 1;/* アニメーションの繰り返し（無限）*/
  animation-fill-mode: forwards; /*これで値を保持*/
}
@keyframes fadeIn_h2 {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }
  
  100% {
    opacity: 1;
	transform: translateY(0);
  }
}
@-webkit-keyframes fadeIn_h2 {
  0% {
    opacity: 0;
	transform: translateY(30px);
  }

  100% {
    opacity: 1;
	transform: translateY(0);
  }
}

/* footer
------------------------------------------------------------*/
#foot {

  clear: both;
  max-width: 100%;
  margin: 250px auto 0 auto;
  padding: 0px 0 20px 0;
  text-align: center;
  font-size: 12px;
}

#foot .inner {
  width: 1280px;
  margin: 0 auto;
  position: relative;
}

#foot .foot_logo{
	position: absolute;
	bottom: 0px;
	left: 0;
}


@media only screen and (max-width: 820px) {
#foot .inner {
  width: 1280px;
  margin: 0 auto;
  position: relative;
}

#foot .foot_logo{
	position: static;
        margin: 0 auto 30px auto;
        width: 40%;
}


}

/* パンくずリスト
------------------------------------------------------------*/
.breadcrumb{
display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 30px 0 20px 0;
  margin: 0 0 50px 0;
  border-bottom: 1px #960A00 solid;
}

.breadcrumb li{
	font-size: 19px;
}

.breadcrumb li a{
text-decoration: underline;
}

.breadcrumb li:not(:last-of-type)::after {
  content: "＞";
  margin: 0 .6em; /* 記号の左右の余白 */
  color: #777; /* 記号の色 */
}

@media only screen and (max-width: 820px) {
.breadcrumb{
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 15px 0 15px 0;
  margin: 0 auto 50px auto;
  width: 90%;
  line-height: 140%;
}

.breadcrumb li{
	font-size: 13px;
}

}

/* 共通パーツ
------------------------------------------------------------*/
h3 {
  font-size: 40px;
  font-weight: bold;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
.next {
  float: none;
  page-break-before: always;
}
section {
  clear: both;
  float: none;
}

section .cont_bg{
	/*background: -webkit-linear-gradient(#fffefe, #feefec);
    background: -o-linear-gradient(#fffefe, #feefec);
    background: linear-gradient(#fffefe, #feefec);*/	
	background: #fff3f1;
}

section .inner {
  /*width: 100%;*/
  width: 1280px;
  margin: 0 auto;
  padding: 0 0 10px 0;
}

section .bg_o {
  background: #EA5415;
}
section .line_o {
  border-bottom: 1px #EA5415 solid;
}
section .bg_w {
  background: #fff;
}
section .bg_y {
  background: #FFFBEF;
}
section .cont {
  width: 90%;
  margin: 0 auto;
  padding: 0 0 50px 0;
}
/*見出し*/
h2.single {
  padding: 50px 0 50px 0;
}
h2.twin {
  padding: 0px 30px 0px 0;
}
h2.busi {
  width: 400px;
}
h2.busi_300 {
  width: 300px;
}

.line_tit{
	display: flex;
	align-items: center;
	color:#0075C4;
	font-size: 32px;
	margin: 50px 0 50px 0;
}

.line_tit:before,
.line_tit:after {
    content: "";
    height: 8px;
    flex-grow: 1;
    background-color: #009FE9;
}

.line_tit:before {
    margin-right: 2rem;
}

.line_tit:after {
    margin-left: 2rem;
}

@media only screen and (max-width: 820px) {
  .line_tit{
	font-size: 26px;
}

}


.logo_under{
	width: 22%;
    margin: 0px auto 30px auto;
    padding: 50px 0 0 0;
}

.top_photo h1.logo_under_news{
	width: 22%;
    margin: 0px auto 30px auto;
    padding: 50px 0 0 0;
}

/*flex*/
section .flex {
  display: -webkit-flex;
  display: flex;
}
section .jc_spar {
  justify-content: space-around;
}
section .jc_spbet {
  justify-content: space-between;
}

section .js_rig {
  justify-content: flex-end;
}

section .ai_cen {
  align-items: center;
}



/*-----------------------------------------------------*/
/*header*/
header{
	width: 100%;
	min-height: 100px;
	z-index: 50;
}

header.other{
	position: relative;
	background: #8f0d0e;
	width: 100%;
	min-height: 100px;
	z-index: 50;
}

.pc_head{
	display: flex;
	justify-content:right;
	
	padding: 10px 30px 20px 0;
}

.pc_head nav{
	
}


.logo_area{
	/*background: #fff;
	width: 270px;
	height: 75px;*/
	padding: 10px 0 0 0;
}

.logo_area img{
	height: 65px;
}


.pc_head ul{
	list-style: none;
	display: flex;
	margin: 15px 0 0 0;
}

.pc_head ul li{
  text-align: left;
  height: 100%;
  font-size: 17px;
  line-height: 160%;
  margin-right: 10px;
  margin: 0 30px;
}

.pc_head ul li a{
	padding:0px;
 /* background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 1) 100%);*/
  background-position: 0 0;
  background-size: 200% auto;
  transition: .3s;
}

.pc_head ul li a:hover{
	 background-position: -100% 0;
  color: #000;
  opacity: 0.5;
}

.pc_head ul li img{
	height: 100%;
	max-height: 50px;
	width: 100%;
	margin: 10px 0 0 0;
}

.pc_head ul li.tel img{
	height: 100%;
	max-height: 65px;
	width: 100%;
	margin: 0 0 0 20px;
}


.nav_sub{
	background: #fff;
	height: 50px;  
	text-align: center;
	display:flex;
	justify-content: center;
 align-items: center;
 border-bottom: 1px solid #e5e5e5;
}

.nav_sub ul{
display: flex;
    justify-content: center;
    align-items: start;
    flex-wrap: wrap;
}

.nav_sub ul li{
	    margin: 0 50px;
		font-size: 14px;
}
/*menu*/
.menu_box {
  background: #fff;
  position: relative;
  width: 1280px;
  margin: 0 auto;
}
.menu {
  position: absolute;
  right: 0px;
  top: 0px;
  width: 120px;
  height: 112px;
  z-index: 99;
  background: url("../images/top/menu_open.png") top center;
}
.menu.active {
  background: url("../images/top/menu_close.png") top center;
  opacity: 1.0;
}
/*gnav*/
.gnav {
  background: rgba(0, 117, 196, 0.9);
  display: none;
  height: 100%;
  position: fixed;
  width: 100%;
  z-index: 98;
  top: 0;
}
.gnav__wrap {
  align-items: center;
  display: flex;
  height: 100%;
  position: absolute;
  width: 100%;
}
/*gnav panel_menu*/
.panel_menu {
  width: 760px;
  margin: 0 auto;
}
.panel_menu .panel_in {
 /* display: flex;*/
}
.panel_menu .panel_in .left {
  width: 150px;
}
.panel_menu .panel_in .right {
  width: 600px;
}
.panel_menu .panel_in .right .panel_sub {
  display: flex;
  margin: 10px 0 20px 15px;
  color: #fff;
}
.panel_menu .panel_in .right .panel_sub a {
  margin: 0 10px 0 0;
  font-size: 19px;
  color: #fff;
}
/*page-top*/

#page-top {
  width: 80px;
  height: 80px;
  display: none;
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 99;
  border-radius: 50px;
}

.page-top-in{
	display:flex;
	justify-content: center;
 align-items: center;width: 80px;
    height: 80px;
}


#page-top p {
  margin: 0;
  padding: 0;
  text-align: center;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 0px;
  background: none;
  behavior: url(PIE.htc);
  text-decoration: none;
  color: #250246;
}

#page-top p a {
  color: #fff;
}
#page-top p a:hover {
  color: #fff;
}
#page-top p:hover {
  color: #fff;
}
#page-top p.bnr:hover {
  background: none;
}
#move-page-top {
  font-size: 15px;
  line-height: 20px;
  text-decoration: none;
  display: block;
  cursor: pointer;
}

@media only screen and (max-device-width: 480px) {
header{
	width: 100%;
	min-height: 70px;
	z-index: 50;
}
#page-top {
  width: 60px;
  height: 60px;
 right: 10px;
    bottom: 20px;
}

.page-top-in{
	width: 60px;
    height: 60px;
}

#move-page-top {
  font-size: 11px;
  line-height: 15px;
}

.nav_sub ul li{
	    margin: 0 10px;
		font-size: 14px;
}
}

/* ヘッダ周り
------------------------------------------------------------*/

.main_intro{
	background: url("../images/head_bg.png");
	background-size: cover;
    background-attachment: fixed;
    background-position: center center;
	padding: 250px 0 100px 0;
}

.main_intro h2{
	text-align: center;
    margin: 0px auto;
    width:70%;
}

.main_intro h2 img{
    width: 100%;
}

@media only screen and (max-width: 820px) {
.main_intro{
	background: url("../images/head_bg.png");
	background-size: contain;
    background-attachment: fixed;
    background-position: center center;
	padding: 150px 0 50px 0;
}

.main_intro h2{
	text-align: center;
    margin: 0px auto;
    width:90%;
}

}


/* ハルトナル トップ
------------------------------------------------------------*/
.box_about{
	width: 80%;
	margin:0 auto 300px auto;
	padding: 0px 0 0 0;
	display: flex;	
justify-content:space-between;
align-items:center;
}

.box_about_left{
		text-align: center;
	display:flex;
	justify-content: center;
 align-items: center;
}

.box_about_left .txt{
text-align: left;
line-height: 440%;

}

.box_about_left .txt p{
	display: inline;
	font-size: 24px;
}


.box_about_left .txt h1{
	display: inline;
	font-size: 35px;
}

.box_about_right{
	max-width: 700px;
}


@media only screen and (max-width: 820px) {
.box_about{
	width: 100%;
	margin: 0 auto 100px auto;
	padding: 0px 0 0 0;
	display: block;	
}

.box_about_left{
		text-align: center;
	display:flex;
	justify-content: center;
 align-items: center;
}

.box_about_left .txt{
text-align: center;
line-height: 280%;

}

.box_about_left .txt p{
	display: inline;
	font-size: 14px;
}


.box_about_left .txt h1{
	display: inline;
	font-size: 22px;
}

.box_about_right{
	max-width: 846px;
}

}


/* 会社概要
------------------------------------------------------------*/
#company{
	margin: -100px auto 0 auto;
    padding: 100px 0 0 0;
    width: 80%;
    position: relative;
}
#company::before {
    content: "";
    position: absolute;
    top: 100px; /* ボーダーを下に50px移動 */
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000; /* ボーダーの色を設定 */
}
#company h2{
	margin:-110px 0 40px 0;
	z-index: 1;
    position: relative;
}

#company h3{
	font-size: 32px;
	text-align: center;
    line-height: 160%;
}
#company hr{
	width: 40px;
    height: 0px;
    margin: 70px auto 70px auto;
    text-align: center;
    color: #000;
    border: 5px solid #000;
}

#company p{
	text-align: center;
    line-height: 400%;
    font-size: 22px;
}

#company .company_data{
	border-bottom: 6px solid #000;
	border-top: 6px solid #000;
	max-width: 540px;
	margin: 100px auto 100px auto;
	padding: 30px 40px 10px 40px;
}

#company .company_data div {
  display: flex;
  /*flex-wrap: wrap;*/
}

#company .company_data div p{
	line-height: 100%;
	font-size: 20px;
}

#company .company_data div .lef {
 width: 20%;
 margin: 0 0 30px 0;
 text-align: left;
 border-right: 1px solid;
}

#company .company_data div .rig  {
  width: 80%;
  text-align: right;
}

#company .company_news{
	box-sizing: border-box;
	width: 60%;
	margin: 0 auto 150px auto;
	border: 1px solid;
    border-radius: 10px;
    padding: 50px 20px 50px 20px;
	box-shadow: 3px 3px 2px 1px rgba(0, 0, 0, 0.8);
	
} 

#company .company_news h3{
	font-size: 24px;
}
#company .company_news p{
	font-size: 14px;
	    line-height: 200%;
}

#company .company_news .add_photo_only{
	box-sizing: border-box;
	width: 50%;
    margin: 0 auto;
	border-radius: 5px;
}

#company .company_news .add{
	box-sizing: border-box;
	width: 80%;
    margin: 0 auto;
    background: #ebebeb;
	padding: 10px 30px;
	border-radius: 5px;
}

#company .company_news .add p{
	text-align: left;
}

#company .company_news .add .add_in{
	    display: flex
;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    width: 100%;
    margin: 10px auto 10px auto;
}

#company .company_news .add .add_in .photo{
	width: 40%;
}

#company .company_news .add .add_in .txt{
	width: 50%;
}

#company .company_news .add .add_in .txt p.txt_add{
	font-size: 12px;
}



@media only screen and (max-width: 820px) {
#company{
	

margin: -50px auto 0 auto;
padding: 50px 0 0 0;
	width: 90%;
	position: relative;
}

#company::before {
    content: "";
    position: absolute;
    top: 45px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
}
#company h2{
	margin:-40px 0 40px 0;
	width: 50%;
	        z-index: 1;
        position: relative;
}

#company h3{
	font-size: 18px;
	text-align: center;
    line-height: 160%;
}
#company hr{
	width: 40px;
    height: 0px;
    margin: 40px auto 30px auto;
    text-align: center;
    color: #000;
    border: 5px solid #000;
}

#company p{
	text-align: center;
    line-height: 370%;
    font-size: 14px;
}

#company .company_data{
	border-bottom: 6px solid #000;
	border-top: 6px solid #000;
	max-width: 540px;
	margin: 100px auto 100px auto;
	padding: 30px 20px 10px 20px;
}

#company .company_data div {
  display: flex;
  /*flex-wrap: wrap;*/
}

#company .company_data div p{
	line-height: 100%;
	font-size: 20px;
}

#company .company_data div .lef {
 width: 20%;
 margin: 0 0 30px 0;
 text-align: left;
 border-right: 1px solid;
 font-size: 14px;
}

#company .company_data div .rig  {
  width: 80%;
  text-align: right;
  font-size: 14px;
}


#company .company_news{
box-sizing: border-box;
	width: 100%;
	margin: 0 auto 100px auto;
	border: 1px solid;
    border-radius: 10px;
    padding: 30px 20px 30px 20px;
	box-shadow: 3px 3px 2px 1px rgba(0, 0, 0, 0.8);
	
} 

#company .company_news h3{
	font-size: 16px;
}
#company .company_news p{
	font-size: 12px;
	    line-height: 160%;
		text-align: left;
}

#company .company_news .add_photo_only{
	box-sizing: border-box;
	width: 90%;
    margin: 0 auto;
	border-radius: 5px;
}

#company .company_news .add{
box-sizing: border-box;
	width: 90%;
    margin: 0 auto;
    background: #ebebeb;
	padding: 10px;
	border-radius: 5px;
}

#company .company_news .add p{
	text-align: left;
}

#company .company_news .add .add_in{
	    display: block;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    width: 100%;
    margin: 10px auto 10px auto;
}

#company .company_news .add .add_in .photo{
	width: 90%;
	width: 90%;
        margin: 0 auto 20px auto;
        text-align: center;
}

#company .company_news .add .add_in .txt{
	width: 90%;
	margin: 0 auto;
}

#company .company_news .add .add_in .txt p.txt_add{
	font-size: 12px;
}


}

/* サービス内容
------------------------------------------------------------*/
#services{
	margin: -100px auto 0 auto;
    padding: 100px 0 0 0;
	width: 80%;
	position: relative;
}

#services::before {
    content: "";
    position: absolute;
    top: 100px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
}

#services h2{
	margin:-110px 0 40px 0;
	z-index: 1;
    position: relative;
}

#services .services_menu{
	display: flex;
    justify-content: space-between;
    align-items: center;
	width: 95%;
    margin: 0 auto 300px auto;
}

#services .services_menu .item{
	width: 30%;
}


@media only screen and (max-width: 820px) {
#services{
	margin: -50px auto 0 auto;
	padding: 50px 0 0 0;
	width: 90%;
}

#services::before {
        content: "";
        position: absolute;
        top: 45px;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #000;
    }

#services h2{
	margin:-40px 0 40px 0;
	width: 50%;
}

#services .services_menu{
	display: block;
    justify-content: space-between;
    align-items: center;
	width: 95%;
    margin: 0 auto 100px auto;
}

#services .services_menu .item{
	width: 80%;
    margin: 0 auto 30px auto;
}


}

/* 実績
------------------------------------------------------------*/
#works{
	margin: -100px auto 0 auto;
    padding: 100px 0 0 0;
	width: 80%;
	position: relative;
}

#works::before {
    content: "";
    position: absolute;
    top: 100px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
}

#works h2{
	margin:-110px 0 40px 0;
	z-index: 1;
    position: relative;
}


#works .works_menu{
	display: flex;
    justify-content: space-between;
    align-items: center;
	width: 95%;
    margin: 0 auto;
}

#works .works_menu .item{
	width: 30%;
}


@media only screen and (max-width: 820px) {
#works{
	margin: -50px auto 0 auto;
	padding: 50px 0 0 0;
	width: 90%;
}

#works::before {
        content: "";
        position: absolute;
        top: 45px;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #000;
    }

#works h2{
	margin:-40px 0 40px 0;
	width: 50%;
}
#works .works_menu{
	display: block;
    justify-content: space-between;
    align-items: center;
	width: 95%;
    margin: 0 auto;
}

#works .works_menu .item{
	width: 80%;
    margin: 0 auto 30px auto;
}


}


/* お問い合わせフォーム
------------------------------------------------------------*/
.contact_h3 {
  margin: 0 0 30px 0;
  padding: 10px 0 10px 30px;
  color: #fff;
  font-size: 26px;
  text-align: center;
  background: #EA5413;
}
.contact_tel {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin: 0 0 50px 0;
}

.contact_h1{
	margin: 0 auto;
    padding: 50px 0 50px 0;
    text-align: center;
    font-size: 45px;
}

.form {
  width: 70%;
      max-width: 1000px;
  margin: 0px auto 0 auto;
}
.form .txt_req {
  color: #E60012;
  font-weight: bold;
}
.form table {
  width: 100%;
  margin: 0 auto;
  border-spacing: 10px;
  border-collapse: separate;
}
.form table .sp {}
.form table th {
  width: 30%;
  padding: 20px 10px 20px 10px;
  text-align: left;
  vertical-align: middle;
  background: #F7F8F8;
  /*border: #9FA0A0 1px solid;*/
  margin: 10px 10px 10px 10px;
  display: none;
}
.form table th.confirm {
  
  display: block;
      width: 80%;
}


.form table td {
  width: 80%;
  padding: 10px 10px 10px 20px;
  /*border: #9FA0A0 1px solid;*/
}
.form table input {
  min-width: 180px;
  padding: 15px 20px;
  font-size: 14px;
  vertical-align: middle;
  box-sizing:border-box;
}
.form table input.num {}
.form table input.area {
  width: 100%;
  min-height: 85px;
  background: #eee;
    border: none;
	font-size: 25px;
    border-radius: 5px;
}

.form table .box_sele{
  width: 100%;
    height: 85px;
    background: #eee;
    border: none;
    border-radius: 5px;
	font-size: 25px;
	padding: 0 20px 0 20px;
}

.form table textarea {
  width: 100%;
  padding: 15px 10px;
  min-height: 200px;
  box-sizing:border-box;
  background: #eee;
    border: none;
    border-radius: 5px;
	font-size: 25px;
}

.form table p.err{
	font-size: 12px;
	text-align: left;
	color: #EF1316;
}

.box_btn{
	margin: 50px auto 50px auto;
}

.box_btn_confirm{
	margin: 50px auto 50px auto;
	display: flex;
}

.box_btn .btn_input,
.box_btn_confirm .btn_input{
	width: 490px;
	height: 80px;
	margin: 0 auto;
	font-size: 19px;
	text-align: center;
	display:flex;
	justify-content: center;
	align-items: center;
	border-radius: 0px;
	border: #000 1px solid;
	background: #fff;
	color: #000;
	font-weight: bold;
	box-shadow:0px 0px 6px 3px rgba(0,0,0,0.00);
	cursor: pointer;
	cursor: hand;
}

.box_btn_confirm .btn_back{
	background: #fff;
}

.box_btn .btn_input span,
.box_btn_confirm .btn_input span{
    position: relative;
    top: 0px;
    left: 0px;
    padding-right: 18px;
}
.box_btn .btn_input span::before,
.box_btn_confirm .btn_input span::before {
    content: "";
    position: absolute;
    top: -5px;
    right: -130px;
    border-top: 14px solid transparent;
    border-bottom: 14px solid transparent;
    border-left: 20px solid rgb(255, 255, 255);
}

.finish{
	width: 90%;
	height: 100svh;
	margin: 0px auto;
	font-size: 14px;
	text-align: center;
	display:flex;
	justify-content: center;
 align-items: center;
}

.policy{
	width:50%; height: 300px;
    overflow: auto;
	margin:20px auto 30px auto;
    padding: 20px;	
    border: 1px solid #eee;
    background: #fff;
}


@media only screen and (max-width: 820px) {
.contact_h3 {
    margin: 0 0 30px 0;
    padding: 10px 0 10px 30px;
    color: #fff;
    font-size: 19px;
    text-align: center;
    background: #EA5413;
  }
  section .inner p.contact_tel {
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    margin: 20px 0 50px 0;
  }
  .contact_h1{
	margin: 0 auto;
    padding: 30px 0 0px 0;
    text-align: center;
    font-size: 25px;
}

  .form {
    width: 90%;
    margin: 30px auto 0 auto;
  }
  .form .txt_req {
    color: #E60012;
    font-weight: bold;
  }
  .form table {
    width: 100%;
    margin: 0 auto;
  }
  .form table.sp {
    margin: 0px 0 0 0;
  }
  .sp th, .sp td {
    display: block;
  }
  .form table th {
    width: 100%;
    padding: 10px 0 10px 0;
    text-align: center;
    vertical-align: middle;
    background: #F7F8F8;
    border: none;
    margin: 0;
    font-size: 14px;
  }
  .form table td {
    width: 100%;
    padding: 10px 0 0px 0;
    margin: 0 0 20px 0;
    border: none;
    display: flex;
    justify-content: flex-start;
  }
  .form table input {
    min-width: 80px;
    padding: 15px 10px;
    font-size: 14px;
    vertical-align: middle;
  }
  .form table input.num {
    width: 60px;
  }
  .form table input.area {
    width: 100%;
  }
  
  .form table .box_sele{
  width:100%;
  height: 50px;
}
  
  .form table textarea {
    width: 100%;
    padding: 15px 10px;
    min-height: 200px;
  }
  .box_btn{
	margin: 0px auto 50px auto;
}

.box_btn_confirm{
	margin: 0px auto 50px auto;
	display: flex;
}

.box_btn .btn_input,
.box_btn_confirm .btn_input{
	width: 80%;
	height: 80px;
	margin: 0 auto;
	font-size: 14px;
	text-align: center;
	display:flex;
	justify-content: center;
	align-items: center;
	border-radius:0px;
	border: #000 1px solid;
	background: #fff;
	color: #000;
	font-weight: bold;
	box-shadow:0px 0px 6px 3px rgba(0,0,0,0.00);
}

.box_btn_confirm .btn_back{
	background:#fff;
}

.box_btn .btn_input span,
.box_btn_confirm .btn_input span{
    position: relative;
    top: 0px;
    left: 0px;
    padding-right: 18px;
}
.box_btn .btn_input span::before,
.box_btn_confirm .btn_input span::before{
    content: "";
    position: absolute;
    top: -5px;
    right: -60px;
    border-top: 14px solid transparent;
    border-bottom: 14px solid transparent;
    border-left: 20px solid rgb(255, 255, 255);
}

.policy{
	width:80%;
	margin:0 auto 30px auto;
}

}



/*ipad 
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 1024px) {
  .menu_box {
    width: 100%;
  }
}
@media only screen and (min-width:801px) and (max-width:1024px) {
  .top_menu {
    display: none;
  }
  #foot .inner {
    width: 100%;
  }
  section .inner {
    width: 100%;
    margin: 0 auto;
  }
}

#price{
	min-height: 800px;
}

@media only screen and (max-width: 768px) {
  body {
    font-size: 22px;
  }
  .ipad_none {
    display: none;
  }
  .menu_box {
    width: 100%;
  }
  
  #price{
	min-height: 600px;
}

}

/*SP  SP対応
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 820px) {
  section {
    padding-top: 0px;
    position: relative;
  }
  section .inner {
    width: 100%;
    margin: 0 auto;
  }
  section .inner p {
    font-size: 14px;
  }
  section .cont {
    width: 90%;
    margin: 0 auto;
    padding: 0 0 20px 0;
  }
  




  /*footer
------------------------------------------------------------*/
  #foot {
  	height: 100%;
    padding: 0px 0px 10px 0;
    font-size: 12px;
	margin: 100px auto 0 auto;
  }
  #foot .inner {
    width: 95%;
  }
#foot .sitemap{
	
}

#foot .sitemap{
	min-height: 200px;
	text-align: left;
    font-size: 16px;
	padding: 40px 10px 0px 10px;
	display: flex;
	flex-wrap:wrap;
	justify-content:space-between;
	
}

#foot .sitemap .foot_lef{
	display: flex;
	flex-wrap:wrap;
	justify-content:space-between;
	margin: 0 0 30px 0;
}

#foot .sitemap .foot_rig .foot_smile{
	display: none;
}

#foot .sitemap .foot_rig .foot_smile_sp{
	display: block;
	margin: 0 0px 20px 0;
}

#foot .sitemap .foot_rig .card_txt{
    margin: 0 20px 0 0;
}

#foot .sitemap .foot_rig .card_txt p.txt_01{
	font-size: 17px;
	font-weight: bold;
	color: #fff;
	margin: 0 ;
}

#foot .sitemap .foot_rig .card_txt p.txt_02{
	font-size: 12px;
	color: #fff;
	margin:0 0 10px 0 ;
}

#foot .sitemap .foot_rig .card_img{
	
}

#foot .sitemap h3{
	font-size: 18px;
	color: #fff;
	margin: 0 0 5px 0;
}
#foot .sitemap a{
	color: #fff;
	font-size: 16px;
}

#foot .sitemap a.arrow{
	padding: 0 0 0 20px;
	background: url("../images/foot/ico_arrow.jpg") top left no-repeat;
}

#foot .sitemap p{
	margin: 0 0 15px 0;
	font-size: 12px;
	text-align: left;
}

#foot .sitemap ul{

}

#foot .sitemap ul li{
	line-height: 270%;
	    margin: 0 30px 0 0;
}

#foot .copy {
  clear: both;
  float: none;
  color: #fff;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
  text-align: center;
}
  
  #foot .copy {
    clear: both;
    float: none;
    margin: 20px 0 0 0;
    padding: 15px 0 20px 0;
    text-align: center;
  }
  
  #foot .foot_kasou{
margin: 0 0 0 0;
}

#foot .foot_kasou ul{
	display: block;
}

  /* 共通パーツ SP
------------------------------------------------------------*/

}
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {
  /*iPad 縦横 */
  .panel_menu .panel_in {
    display: block;
    width: 80%;
    margin: 0 auto;
  }
  
   .panel_menu .panel_in li{
  	list-style: none;
    border-left: 5px #fff solid;
    border-bottom: 1px #fff solid;
    color: #fff;
    padding: 5px 0 10px 10px;
	margin: 0 0 15px 0;
  }
  
  .panel_menu .panel_in li a{
  	color: #fff;
  }
  
  .panel_menu .panel_in .left {
    width: 100%;
  }
  .panel_menu .panel_in .right {
    width: 100%;
  }
  .top_photo {
    min-height: 430px;
    height: 100%;
	 background: url("../images/top/top_back.png") top left no-repeat;
    background-size: cover;
  }
  .top_photo h3 {
    width: 75%;
    margin: 0 auto;
    padding: 80px 0 0 0;
  }
  .head_about {
    padding: 320px 0 50px 0;
    background-size: contain;
  }
 
}
@media only screen and (max-device-width: 480px) {
  /* スマホ用のCSS */
  /*-----------------------------------------------------*/
   
  /*header SP*/
  .pc_head{
	display: flex;
	justify-content:left;
		width: 50%;
		margin: 0 auto;
		padding: 0 0 0 0;
}

.logo_area{
	/*background: #fff;
	height: 65px;*/
    padding: 0 0 0 0;
	margin: 0 0 0 0;
}

  
  /*menu SP*/
  .menu_box {
   /* position: inherit;
    width: 100%;*/
	
}
  }


.menu {
    /*position: absolute;
    right: 10px;
    top: 10px;*/
    width: 60px;
    height: 60px;
    z-index: 99;
    background: url("../images/menu_open_sp.png") top center;
	margin: 10px 10px 0 0;
	position: fixed;
    top: 0;
    right: 0;
  }
  .menu.active {
    background: url("../images/menu_close_sp.png") top center;
    opacity: 1.0;
  }
  /*gnav SP*/
  .gnav {
    background: rgba(0, 0, 0, 0.8);
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 98;
    top: 0;
	left: 0;
  }
  .gnav__wrap {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    position: absolute;
    width: 100%;
  }
  /*gnav panel_menu*/
  .panel_menu {
    width: 90%;
    margin: 0 auto;
  }
  .panel_menu .panel_in {
    display: block;
  }
  
  .panel_menu .panel_in li{
  text-align: center;
  	list-style: none;
    color: #fff;
    padding: 5px 0 10px 10px;
	margin: 0 0 15px 0;
  }
  
  .panel_menu .panel_in li a{
  	color: #fff;
  }
  
  .panel_menu .panel_in .left {
    width: 100%;
    margin-bottom: 20px;
  }
  .panel_menu .panel_in .right {
    width: 100%;
  }
  .panel_menu .panel_in .right .panel_sub {
    display: flex;
    margin: 5px 0 5px 10px;
    color: #fff;
  }
  .panel_menu .panel_in .right .panel_sub p {
    max-height: 24px;
  }
  .panel_menu .panel_in .right .panel_sub a {
    margin: 0 0 0 0;
    font-size: 12px;
    color: #fff;
  }
  .panel_menu .panel_in .right .panel_sub a img {
    vertical-align: top;
    max-width: 108px;
  }
  
  .logo_under {
    width: 65%;
    margin: 0px auto 30px auto;
    padding: 20px 0 0 0;
}
  
  .top_photo h1.logo_under_news{
    width: 65%;
    margin: 0px auto 30px auto;
    padding: 20px 0 0 0;
}
  
  
}
@media print {
    body{
		 zoom: 0.68;
        -webkit-print-color-adjust: exact;
        top:0 !IMPORTANT;
        left:0 !IMPORTANT;
        width:172mm !IMPORTANT;
        height:251mm !IMPORTANT;
    }
}
