@charset "UTF-8";
/* CSS Document */

/* リセット用 */
body, h1, h2, h3, h4, h5, h6, p, div, ul, li, dl, dt, dd, table, th, td{
  font-family: inherit !important;
	color: inherit;
}
a:hover img {
	opacity: inherit;
	filter: inherit;
}
#footer_sitemap .open {
width: auto;
height: auto;
background: none;
}

/* 基本-モバイルファースト ======================================================================================================== */
/* 印刷時の余白幅指定 */
@page {
margin: 12.7mm 9.7mm;
}
html {
-webkit-font-smoothing: antialiased;
}
body{
text-align: center;
width: 100%;
font-family: sans-serif !important;
line-height: 1.8;
color: #111;
/* padding-top: 70px; */
}
body,
table,
input,
textarea{
font-size: 14px;
}

/* テキスト選択時のハイライト */
::selection {
    background: #f7e8eb;
}
::-moz-selection {
    background: #f7e8eb;
}

a,
a:link,
a:visited {
color: #111;
text-decoration: none;
}

img{
max-width: 100%;
height: auto;
width /***/: auto;
vertical-align: top;
}
input[type="text"],
input[type="email"],
input[type="tel"],
textarea{
	background-color: #FFF;
	padding: 5px;
	margin: 0px;
	box-sizing: border-box;
	border: 1px solid #AAA;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}
input[type="text"]:hover,
input[type="email"]:hover,
input[type="tel"]:hover,
textarea:hover{
	border: 1px solid #666;
}
input[type="text"]:focus,
input[type="text"]:focus,
input[type="text"]:focus,
textarea:focus{
	background-color: #F3F3F3;
}

/* googleリマーケティングタグの隙間回避 */
iframe[name="google_conversion_frame"] { position:absolute; top: 0; left: 0; }

.mt05{ margin-top: 5px; }
.mt10{ margin-top: 10px; }
.mt15{ margin-top: 15px; }
.mt20{ margin-top: 20px; }
.mt30{ margin-top: 30px; }
.mt40{ margin-top: 40px; }
.mr05{ margin-right: 5px; }
.mr10{ margin-right: 10px; }
.mr15{ margin-right: 15px; }
.mr20{ margin-right: 20px; }
.mr30{ margin-right: 30px; }
.mr40{ margin-right: 40px; }
.mb05{ margin-bottom: 5px; }
.mb10{ margin-bottom: 10px; }
.mb15{ margin-bottom: 15px; }
.mb20{ margin-bottom: 20px; }
.mb30{ margin-bottom: 30px; }
.mb40{ margin-bottom: 40px; }
.ml05{ margin-left: 5px; }
.ml10{ margin-left: 10px; }
.ml15{ margin-left: 15px; }
.ml20{ margin-left: 20px; }
.ml30{ margin-left: 30px; }
.ml40{ margin-left: 40px; }
.pt05{ padding-top: 5px; }
.pt10{ padding-top: 10px; }
.pt15{ padding-top: 15px; }
.pt20{ padding-top: 20px; }
.pt30{ padding-top: 30px; }
.pt40{ padding-top: 40px; }
.pr05{ padding-right: 5px; }
.pr10{ padding-right: 10px; }
.pr15{ padding-right: 15px; }
.pr20{ padding-right: 20px; }
.pr30{ padding-right: 30px; }
.pr40{ padding-right: 40px; }
.pb05{ padding-bottom: 5px; }
.pb10{ padding-bottom: 10px; }
.pb15{ padding-bottom: 15px; }
.pb20{ padding-bottom: 20px; }
.pb30{ padding-bottom: 30px; }
.pb40{ padding-bottom: 40px; }
.pl05{ padding-left: 5px; }
.pl10{ padding-left: 10px; }
.pl15{ padding-left: 15px; }
.pl20{ padding-left: 20px; }
.pl30{ padding-left: 30px; }
.pl40{ padding-left: 40px; }

.f_right{ float: right; }
.f_left{ float: left; }

.ta_right{ text-align: right; }
.ta_center{ text-align: center; }
.ta_left{ text-align: left; }

.font10px{ font-size: 10px; }
.font11px{ font-size: 11px; }
.font12px{ font-size: 12px; }
.font14px{ font-size: 14px; }
.font16px{ font-size: 16px; }
.font18px{ font-size: 18px; }
.font20px,
.font22px,
.font24px,
.font26px,
.font28px{ font-size: 20px; }
.font30px{ font-size: 22px; }

.font_red{ color: #b3203a; }
.font_bold{ font-weight: bold; }
/* .font_design{ font-family: 'Zen Kaku Gothic New', sans-serif !important; } */


.css_arrow{
	position: relative;
	display: inline-block;
	padding: 0 15px 0 0;
	vertical-align: middle;
}
.css_arrow::before{
	content: "";
	vertical-align: middle;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 8px;
	margin: auto;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.ca_5::before{ 	width: 5px; height: 5px; }
.ca_7::before{ 	width: 7px; height: 7px; right: 13px; }
.ca_10::before{ width: 10px; height: 10px; right: 13px; }
.ca_15::before{ width: 15px; height: 15px; right: 18px; }

.common_btn{
text-align: center;
}
.common_btn a{
display: block;
text-decoration: none;
color: #999;
padding: 15px 0;
margin-top: 5vw;
border: solid 1px #999;
}


/* 中身======================================================================================================== */
/* ヘッダー======================================================================================================== */
#header_new {
background-color: #fff;
text-align: left;
width: 100%;
/* position: fixed; */
position: sticky;
top: 0;
left: 0;
z-index: 11111;
}
#header_new #header_logo{
padding: 15px;
text-align: left;
}
#header_new #header_logo img{
height: 40px;
}

/* グローバルメニュー=============================================== */
#global_menu{
}
#global_menu_inner{
display: none;
}
#global_menu ul li{
}
#global_menu ul li a{
display: block;
font-weight: normal;
text-align: center;
text-decoration: none;
padding: 2.5vw 5vw;
border-bottom: solid 1px #ddd;
}
.sp-hamburger {
	display: block;
	text-align: center;
	z-index: 9500;
	position: absolute;
	top: 15px;
	right: 0px;
	box-sizing: border-box;
	width: 50px;
	height: 40px;
	padding: 0 10px;
	-webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	border: 0;
	outline: 0;
	background-color: transparent;
}
.sp-hamburger:hover {
	cursor: pointer;
}
.sp-hamburger::after {
	width: 100%;
	position: absolute;
	top: 36px;
	content: 'menu';
	font-size: 10px;
	line-height: 1;
	display: block;
	text-align: center;
	left: 0px;
}
.sp_menu-open.sp-hamburger::after {
	content: 'close';
}
.sp-hamburger-icon {
  position: relative;
  display: block;
  margin-top: 0px;
}
.sp-hamburger-icon,
.sp-hamburger-icon:before,
.sp-hamburger-icon:after {
  width: 100%;
  height: 1px;
  -webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  background-color: #111;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
.sp-hamburger-icon:before,
.sp-hamburger-icon:after {
  position: absolute;
  top: -10px;
  left: 0;
  content: '';
}
.sp-hamburger-icon:after {
  top: 10px;
}
.sp_menu-open .sp-hamburger-icon {
  background-color: transparent;
}
.sp_menu-open .sp-hamburger-icon:before,
.sp_menu-open .sp-hamburger-icon:after {
  top: 0;
}
.sp_menu-open .sp-hamburger-icon:before {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.sp_menu-open .sp-hamburger-icon:after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

#header_new #header_freedial{
display: flex;
align-items: center;
justify-content: center;
padding: 4vw 0;
border-bottom: solid 1px #ddd;
}
#header_new #header_freedial p{
font-size: 3vw;
border: solid 1px #111;
padding: 0px 1em;
border-radius: 100px;
margin-right: 1em;
}
#header_new #header_freedial address{
display: flex;
align-items: center;
}
#header_new #header_freedial address .icon img{
height: 20px;
vertical-align: middle;
}
#header_new #header_freedial address a{
text-decoration: underline;
font-size: 5.5vw;
line-height: 1;
font-weight: bold;
}


/* コンテンツ======================================================================================================== */
#container {
}
#contents {
}
.main{
float: none;
width: auto;
padding: 0;
margin: 0;
text-align: center;
}

.contents_size{
margin-right: 5vw;
margin-left: 5vw;
text-align: left;
}
.main_top + div,
.main_top + #login_check + div{
}
.navi{
	font-size: 10px;
	margin: 0 0 10px;
	text-align: left;
}

.page_title{
background: none;
font-size: inherit;
font-weight: inherit;
line-height: inherit;
color: #111;
height: inherit;
margin-bottom: 0;
padding-left: 0;
}

.common_page_title{
font-weight: bold;
padding: 5vw 0;
position: relative;
overflow: hidden;
}
.common_page_title h2{
font-size: 6vw;
}
.common_page_title .en{
display: block;
width: 100%;
color: #eee;
font-size: 8.5vw;
z-index: -1;
white-space: nowrap;
position: absolute;
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
-webkit-transform: translateY(-50%) translateX(-50%);
margin: auto;
}

.sub_title{
text-align: center;
font-size: 5vw;
font-weight: bold;
margin-bottom: 5vw;
}
.sub_title::after{
content: "";
display: block;
margin: 2vw auto 0;
width: 10vw;
height: 3px;
background-color: #b3203a;
}

.sub_title_m{
font-size: 16px;
padding: 10px;
text-align: left;
border: solid 1px #555;
}

.accordion_title{
display: block;
padding-right: 15px;
position: relative;
cursor: pointer;
}
.accordion_title::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 10px;
height: 10px;
position: absolute;
top: 0;
bottom: 0;
right: 3px;
margin: auto;
border-bottom: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
transition: all 0.2s ease;
}
.accordion_title.open::after{
transform: rotate(-135deg);
}
.accordion_title + *{
display: none;
}

form{
	margin: 0px;
	padding: 0px;
}
/* 通常テーブルパターン */
table.normal{
	width: 100%;
	border-collapse:collapse;
	border-spacing: 0;
}
table.normal th,
table.normal td{
padding: 8px;
border-bottom: 1px solid #DDD;
box-sizing: border-box;
}
table.normal th{
padding-left: 0;
font-weight: bold;
text-align: center;
white-space: nowrap;
}
form table.normal th{
	text-align: left;
	vertical-align: top;
}
table.normal td{
padding-right: 0;
}

table.sp_tableflat{}
form .must{
display: inline-block;
vertical-align: middle;
background-color: #b3203a;
padding: 5px;
font-size: 10px;
line-height: 10px;
margin-left: .5em;
color: #FFF;
border-radius: 5px;
}
form .cap{
font-size: 10px;
color: #b3203a;
}
.form_address li{
margin: 5px 0 0;
}
.form_address li.post{
margin: 0;
}
.form_preferred_date{
display: flex;
flex-wrap: wrap;
align-items: center;
}
.form_preferred_date dt{
width: 4.5em;
}
.form_preferred_date dd{
width: calc(100% - 4.5em);
}
form #submit_box,
.mfp_buttons{
margin-top: 30px;
text-align: center;
}
form #submit_box p{
margin: 0 0 10px;
}
form #submit_box input{
font-size: 20px;
margin: 0 10px;
padding: 15px 40px;
min-width: 200px;
background: #b3203a;
color: #fff;
cursor:pointer;
display: inline-block;
-webkit-appearance: none;
border: none;
border-radius: 5px;
}

/* commonフォーム系 */
#form_common_design .cart table{
border: none;
border-collapse: collapse;
border-spacing: 0;
}
#form_common_design .cart th{
border: none;
padding-bottom: 0;
}
#form_common_design .cart td{
background-color: transparent;
border: none;
border-bottom: solid 1px #ddd;
padding: 10px 0;
}
#form_common_design .subgroup_comment{
text-align: center;
}
#form_common_design .cart #SPForm div{
text-align: center;
}


/* 検索のテーブル */
table.serchTbl{
border: solid 1px #DDD;
width: 100%;
text-align: left;
}
table.serchTbl tbody tr:first-child td > div:nth-child(-n+2){
	white-space: normal !important;
	text-indent: 0 !important;
	font-size: 10px;
}
table.serchTbl th, table.serchTbl td{
border: none;
}
table.serchTbl th{
	background-color: #ffe6e6;
	color: #111;
	padding: 10px;
}
table.serchTbl td{
	padding: 10px;
}
table.serchTbl #areabox1,
table.serchTbl #areabox2,
table.serchTbl #railways,
table.serchTbl #stations{
	width: 100% !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	display: block !important;
	vertical-align: middle !important;
	border: none !important;
}
table.serchTbl .rwname{
	background-color: #F3F3F3;
}
table.serchTbl .r_kind_add{
	display: none;
}
table.serchTbl .search_tr_inv select{
	width: 100%;
	font-size: 14px;
	line-height: 1.8;
}
table.serchTbl .search_tr_tiku td{
	display: flex;
	flex-wrap: wrap;
}
table.serchTbl .search_tr_tiku label{
	display: block;
	width: 50%;
	padding: 3px;
}
table.serchTbl .search_tr_tiku br{
	display: none;
}
table.serchTbl .search_tr_walk td{
	display: flex;
	flex-wrap: wrap;
}
table.serchTbl .search_tr_walk label{
	display: block;
	width: 50%;
	padding: 3px;
}
table.serchTbl .search_tr_walk br{
	display: none;
}
table.serchTbl .search_tr_search_id input{
	width: auto;
}
table.serchTbl #search_structure{
display: none;
}
.search_btn_box{
margin-top: 20px;
text-align: center;
}
.search_btn_box input[type="button"]{
	-webkit-appearance: none;
	width: 100%;
	text-decoration: none;
	padding: 10px;
	font-weight: bold;
    color: #FFF;
    background-color: #b3203a;
    border: none;
	border-radius: 5px;
	position: relative;
}
form #submit_box{
	margin-top: 30px;
	text-align: center;
}
form #submit_box p{
	margin: 0 0 10px;
}
form #submit_box button{
	font-size: 20px;
	margin: 0 10px;
	padding: 15px 40px;
	cursor:pointer;
	display: inline-block;
	-webkit-appearance: none;
	border: none;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
form #submit_box button[type="reset"]{ background-color: #CCC; }
form #submit_box button[type="submit"]{ background-color: #b3203a; color: #FFF; }
form #submit_box button[type="reset"]:hover{ background-color: #BBB; }
form #submit_box button[type="submit"]:hover{ background-color: #750002; }

.common_member_banner{
background-image: url(../images/member_banner_bg.jpg);
background-image: -webkit-image-set(url(../images/member_banner_bg.jpg) 1x, url(../images/member_banner_bg@2x.jpg) 2x);
background-repeat: no-repeat;
background-position: center center;
background-size: cover;
padding: 25vw 5vw 5vw;
position: relative;
}
.common_member_banner .common_member_banner_copy{
width: 45%;
position: absolute;
top: -2vw;
right: -3vw;
}
.common_member_banner em{
display: block;
background-color: #a5995e;
color: #fff;
font-size: 6vw;
line-height: 1.4;
font-weight: bold;
padding: 5px 10px;
position: absolute;
top: 2vw;
left: -2vw;
}
.common_member_banner em::after{
content: "";
display: block;
width: 0px;
height: 0px;
border-style: solid;
border-width: 0 2vw 2vw 0;
border-color: transparent #7b713e transparent transparent;
transform: rotate(0deg);
position: absolute;
bottom: -2vw;
left: 0;
}
.common_member_banner .text{
position: relative;
}
.common_member_banner .text p{
font-weight: bold;
margin-bottom: 10px;
}
.common_member_banner .text ul{
display: flex;
justify-content: space-between;
}
.common_member_banner .text ul li{
width: 24%;
}
.common_member_banner .text .tel{
background-color: rgba(255, 255, 255, .5);
padding: 10px;
text-align: center;
}
.common_member_banner .text .tel p{
font-size: 14px;
font-weight: bold;
margin-bottom: 10px;
}
.common_member_banner .text .tel address{
display: flex;
align-items: center;
justify-content: center;
}
.common_member_banner .text .tel address .icon img{
height: 7vw;
vertical-align: middle;
}
.common_member_banner .text .tel address a{
text-decoration: underline;
font-size: 7vw;
line-height: 1;
font-weight: bold;
}
.common_member_banner .text .common_member_banner_img{
width: 35%;
position: absolute;
top: -3vw;
right: 0;
}
.common_member_banner .btn_box{
display: flex;
justify-content: space-between;
text-align: center;
}
.common_member_banner .btn_box .btn{
width: 49%;
position: relative;
margin-top: 5vw;
}
.common_member_banner .btn_box .btn a{
display: block;
text-decoration: none;
padding: 10px 0;
color: #fff;
}
.common_member_banner .btn_box .btn.new a{
background-color: #b3203a;
}
.common_member_banner .btn_box .btn.new span{
display: flex;
justify-content: center;
align-items: center;
width: 40px;
height: 40px;
border-radius: 50%;
font-size: 10px;
line-height: 1.1;
color: #fff;
background-color: #b6a466;
text-align: center;
position: absolute;
left: -10px;
top: -10px;
}
.common_member_banner .btn_box .btn.login a{
background-color: #999;
}

/* swipebox */
#swipebox-close{
width: 100% !important;
height: 100% !important;
background: none !important;
}
#swipebox-close::before{
content: "";
display: block;
width: 30px;
height: 3px;
background-color: #fff;
position: absolute;
top: 30px;
right: 20px;
transform: rotate(45deg);
}
#swipebox-close::after{
content: "";
display: block;
width: 30px;
height: 3px;
background-color: #fff;
position: absolute;
top: 30px;
right: 20px;
transform: rotate(-45deg);
}

/* フッター======================================================================================================== */
#footer_new {
margin-top: 40px;
}

#footer_new #footer_sitemap{
border-top: solid 1px #ddd;
border-bottom: solid 1px #ddd;
margin-bottom: 20px;
}
#footer_new #footer_sitemap em{
display: block;
padding-right: 15px;
position: relative;
cursor: pointer;
padding: 5px 5vw;
text-align: left;
}
#footer_new #footer_sitemap em::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 10px;
height: 10px;
position: absolute;
top: 0;
bottom: 0;
right: 13px;
margin: auto;
border-bottom: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
transition: all 0.2s ease;
}
#footer_new #footer_sitemap em.open::after{
transform: rotate(-135deg);
}
#footer_new #footer_sitemap #footer_sitemap_inner{
padding: 5vw;
display: none;
}
#footer_new #footer_sitemap #footer_sitemap_inner dl{
margin-bottom: 20px;
}
#footer_new #footer_sitemap #footer_sitemap_inner dl:last-child{
margin-bottom: 0px;
}
#footer_new #footer_sitemap #footer_sitemap_inner dt{
font-weight: bold;
}
#footer_new #footer_sitemap #footer_sitemap_inner dd ul{
display: flex;
flex-wrap: wrap;
}
#footer_new #footer_sitemap #footer_sitemap_inner dd ul li{
width: 50%;
font-size: 12px;
margin-top: 5px;
}
#footer_new #footer_sitemap #footer_sitemap_inner dd ul li a{
display: block;
text-decoration: none;
}

#footer_new #footer_company{
display: flex;
flex-direction: column-reverse;
text-align: center;
margin-bottom: 20px;
}
#footer_new #footer_logo{
text-align: center;
}
#footer_new #footer_logo img{
height: 30px;
}
#footer_new #footer_company .banner{
text-align: center;
margin-bottom: 5vw;
}

#footer_new #copy_right{
text-align: center;
font-size: 10px;
margin-bottom: 20px;
}


/* ラフ用＊＊＊＊＊＊＊＊＊＊＊ */
.raf{
min-width: 1100px;
}
.raf .full_size img{
width: 100%;
height: auto;
}
.raf .center_position{
text-align: center;
overflow-x: hidden;
}
.raf .center_position img{
max-width: inherit;
}
/* 印刷用 */
@media print{
.raf{
min-width: 100%;
}
.raf .center_position{
width: 140%;
margin-left: -20% !important;
}
.raf .center_position img{
width: 100%;
height: auto;
}

}
/* ラフ用ここまで＊＊＊＊＊＊＊＊＊＊＊ */

/* スマホのみ======================================================================================================== */
@media print and (max-width: 750px), screen and (max-width: 750px){

.pc_only{ display: none; }
.sp_only{ }

.sp_tel{}

.mt50,.mt60,.mt70,.mt80,.mt90{ margin-top: 40px; } .mt100,.mt150{ margin-top: 60px; }
.mr50,.mr60,.mr70,.mr80,.mr90{ margin-right: 40px; } .mr100,.mr150{ margin-right: 60px; }
.mb50,.mb60,.mb70,.mb80,.mb90{ margin-bottom: 40px; } .mb100,.mb150{ margin-bottom: 60px; }
.ml50,.ml60,.ml70,.ml80,.ml90{ margin-left: 40px; } .ml100,.ml150{ margin-left: 60px; }

.pt30,.pt40,.pt50,.pt60{ padding-top: 20px; }
.pr30,.pr40,.pr50,.pr60{ padding-right: 20px; }
.pb30,.pb40,.pb50,.pb60{ padding-bottom: 20px; }
.pl30,.pl40,.pl50,.pl60{ padding-left: 20px; }

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
textarea {
width: 100%;
}
.form_sp_half{
display: flex;
justify-content: space-between;
}
.form_sp_half input{
width: 49%;
}
input.form_sp_90{
width: 90%;
}
.form_address li{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
align-items: center;
}
.form_address li.post{
display: block;
}
.form_address li span{
width: 5em;
}
.form_address li select,
.form_address li input{
flex: 1;
text-align: left;
}
.form_address li .mfp_err{
width: 100%;
}

input.input_sp_auto{
width: auto !important;
}
form #submit_box button,
.mfp_buttons button{
margin: 0 5px;
padding: 15px 30px;
min-width: 150px;
}

form .name{
display: flex;
align-items: center;
justify-content: space-between;
}
form .name input{
width: calc((98% - 2em) / 2);
}
form .name .p{
width: 2em;
/* white-space: nowrap; */
}

.sp_tableflat th,
.sp_tableflat td,
table#mfp_confirm_table tr th,
table#mfp_confirm_table tr td{
display: block;
}
.sp_tableflat th,
table#mfp_confirm_table tr th{
border-bottom: none !important;
padding: 8px 0px 0px !important;
text-align: left !important;
}
.sp_tableflat td,
table#mfp_confirm_table tr td{
padding: 0px 0px 8px !important;
}


.serchTbl th, .serchTbl td{
display: block;
box-sizing: border-box;
width: 100%;
}





#footer_new_inner{
margin: 0;
}

}

/* PCのみ======================================================================================================== */
@media print and (min-width: 751px), screen and (min-width: 751px){
body{
/* font-family: Arial, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif !important; */
font-family: Arial, "メイリオ", "Meiryo", sans-serif, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro" !important;
	/* padding-top: 120px; */
}
body,
table,
input,
textarea{
	font-size: 14px;
}
a,
a:link,
a:visited {
	-webkit-transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	transition: all 0.2s ease;
}
a:hover {
	color: #b3203a;
}
a:active {
	color: #b3203a;
}
.opct a:hover,
a.opct:hover,
a:hover img.opct{
	opacity: 0.8;
}

.pc_only{ }
.sp_only{ display: none; }

.sp_tel:visited,
.sp_tel:link,
.sp_tel{	pointer-events: none; text-decoration: none; }

.mt50{ margin-top: 50px; }
.mt60{ margin-top: 60px; }
.mt70{ margin-top: 70px; }
.mt80{ margin-top: 80px; }
.mt90{ margin-top: 90px; }
.mt100{ margin-top: 100px; }
.mt150{ margin-top: 150px; }

.mr50{ margin-right: 50px; }
.mr60{ margin-right: 60px; }
.mr70{ margin-right: 70px; }
.mr80{ margin-right: 80px; }
.mr90{ margin-right: 90px; }
.mr100{ margin-right: 100px; }
.mr150{ margin-right: 150px; }

.mb50{ margin-bottom: 50px; }
.mb60{ margin-bottom: 60px; }
.mb70{ margin-bottom: 70px; }
.mb80{ margin-bottom: 80px; }
.mb90{ margin-bottom: 90px; }
.mb100{ margin-bottom: 100px; }
.mb150{ margin-bottom: 150px; }

.ml50{ margin-left: 50px; }
.ml60{ margin-left: 60px; }
.ml70{ margin-left: 70px; }
.ml80{ margin-left: 80px; }
.ml90{ margin-left: 90px; }
.ml100{ margin-left: 100px; }
.ml150{ margin-left: 150px; }

.pt50{ padding-top: 50px; }
.pt60{ padding-top: 60px; }

.pr50{ padding-right: 50px; }
.pr60{ padding-right: 60px; }

.pb50{ padding-bottom: 50px; }
.pb60{ padding-bottom: 60px; }

.pl50{ padding-left: 50px; }
.pl60{ padding-left: 60px; }

.font20px{ font-size: 20px; }
.font22px{ font-size: 22px; }
.font24px{ font-size: 24px; }
.font26px{ font-size: 26px; }
.font28px{ font-size: 28px; }
.font30px{ font-size: 30px; }


.common_btn a{
display: inline-block;
min-width: 300px;
}
.common_btn a:hover{
background-color: #b3203a;
color: #fff;
border-color: #b3203a;
}




/* 中身 */
#header_new{
height: 120px;
display: flex;
align-items: center;
justify-content: space-between;
padding-right: calc(3em + 220px + 3vw);
transition: all 0.2s ease;
}
#header_new #header_logo{
padding: 30px 3vw;
}
#header_new #header_logo img{
height: 60px;
transition: all 0.2s ease;
}
#header_new #header_contents{
}



/* グローバルメニュー */
#global_menu{
}
#global_menu #global_menu_inner{
display: flex;
flex-direction: column-reverse;
}
#global_menu ul{
display: flex;
}
#global_menu ul li{
margin-left: 3em;
}
#global_menu ul li:nth-child(2){
margin-left: 0;
}
#global_menu ul li a{
font-size: 16px;
padding: 0;
border-bottom: none;
}

#header_new #header_freedial{
justify-content: flex-end;
padding: 0;
border-bottom: none;
margin-bottom: 10px;
transition: all 0.2s ease;
}
#header_new #header_freedial p{
font-size: 12px;
}
#header_new #header_freedial address a{
text-decoration: none;
font-size: 24px;
}


#header_new #header_icon_btn{
display: flex;
position: absolute;
top: 20px;
right: 3vw;
transition: all 0.2s ease;
}
#header_new #header_icon_btn li{
margin-left: 20px;
}
#header_new #header_icon_btn li a{
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-decoration: none;
background-color: #a39f9f;
color: #fff;
width: 110px;
height: 110px;
border-radius: 50%;
}
#header_new #header_icon_btn li a:hover{
background-color: #b3203a;
}
#header_new #header_icon_btn li a .icon img{
max-width: 40px;
max-height: 40px;
transition: all 0.2s ease;
}
#header_new #header_icon_btn li a p{
color: #fff;
line-height: 1;
margin-top: 10px;
}

/* ヘッダースリム化 */
.slim#header_new{
height: 90px;
padding-right: calc(3em + 120px + 3vw);
}
.slim#header_new #header_logo{
padding: 20px 3vw;
}
.slim#header_new #header_logo img{
height: 50px;
}
.slim#header_new #header_freedial{
margin-bottom: 5px;
}
.slim#header_new #header_icon_btn{
top: 15px;
}
.slim#header_new #header_icon_btn li a{
width: 60px;
height: 60px;
}
.slim#header_new #header_icon_btn li a .icon img{
max-width: 25px;
max-height: 25px;
}
.slim#header_new #header_icon_btn li a p{
margin-top: 0;
font-size: 10px;
}



/* コンテンツ */
#contents {
}
.contents_size{
margin-right: 8vw;
margin-left: 8vw;
min-width: 1100px;
}
.main_top + div,
.main_top + #login_check + div{
}
.navi{
	font-size: 10px;
}
.common_page_title{
}
.common_page_title h2{
font-size: 40px;
}
.common_page_title .en{
font-size: 110px;
}
.sub_title{
font-size: 30px;
margin-bottom: 40px;
}
.sub_title::after{
width: 50px;
margin: 20px auto 0;
}

table.normal th,
table.normal td{
padding: 15px;
}

form .must{
display: block;
float: right;
margin-top: 3px;
margin-left: 0;
margin-right: 10px;
}

.common_member_banner{
width: 1100px;
margin-right: auto;
margin-left: auto;
padding: 100px 30px 30px;
display: flex;
justify-content: space-between;
}
.common_member_banner .common_member_banner_copy{
width: auto;
top: -30px;
right: 370px;
}
.common_member_banner em{
font-size: 40px;
padding: 5px 10px;
position: absolute;
top: 20px;
left: -10px;
}
.common_member_banner em::after{
border-width: 0 10px 10px 0;
bottom: -10px;
}
.common_member_banner .text{
flex: 1;
margin-right: 30px;
}
.common_member_banner .text p{
font-size: 20px;
margin-bottom: 20px;
}
.common_member_banner .text ul{
justify-content: flex-start;
}
.common_member_banner .text ul li{
width: auto;
margin-right: 10px;
}
.common_member_banner .text .tel{
display: flex;
align-items: center;
justify-content: center;
}
.common_member_banner .text .tel p{
margin-bottom: 0px;
margin-right: 1em;
}
.common_member_banner .text .tel address .icon img{
height: 30px;
}
.common_member_banner .text .tel address a{
text-decoration: none;
font-size: 30px;
}
.common_member_banner .text .common_member_banner_img{
width: auto;
top: inherit;
bottom: 0;
}
.common_member_banner .text .tel + .common_member_banner_img{
bottom: inherit;
top: 25px;
}
.common_member_banner .btn_box{
display: block;
width: 340px;
}
.common_member_banner .btn_box .btn{
width: 100%;
margin: 20px auto 0;
}
.common_member_banner .btn_box .btn a{
padding: 20px 0;
}
.common_member_banner .btn_box .btn.new span{
width: 80px;
height: 80px;
font-size: 16px;
left: -25px;
top: -25px;
}
.common_member_banner .btn_box .btn.new a:hover{
background-color: #fff;
color: #b3203a;
}
.common_member_banner .btn_box .btn.login a:hover{
background-color: #fff;
color: #666;
}


/* 検索のテーブル */
table.serchTbl th,
table.serchTbl td{
	border-bottom: solid 1px #DDD;
}

table.serchTbl #areabox1 ul,
table.serchTbl #areabox2 ul ul,
table.serchTbl #railways ul,
table.serchTbl #stations ul{
	display: flex;
	flex-wrap: wrap;
}
table.serchTbl #areabox1 ul li,
table.serchTbl #areabox2 ul ul li,
table.serchTbl #railways ul li,
table.serchTbl #stations ul li{
	width: 25%;
	padding: 3px;
}

table.serchTbl .search_tr_type label{
	display: inline-block;
	margin-right: 1em;
}
table.serchTbl .search_tr_type br{
	display: none;
}

table.serchTbl .search_tr_kind label{
	display: inline-block;
	margin-right: 1em;
}
table.serchTbl .search_tr_kind br{
	display: none;
}
table.serchTbl .search_tr_inv select{
	width: 200px;
}

table.serchTbl .search_tr_madori ul{
	display: flex;
	flex-wrap: wrap;
}
table.serchTbl .search_tr_madori ul li{
	width: 33.33%;
	padding: 3px;
}
table.serchTbl .search_tr_tiku label{
	width: 25%;
}
table.serchTbl .search_tr_walk label{
	width: 25%;
}
.search_btn_box input[type="button"]{
	width: 300px;
	font-size: 16px;
	padding: 15px;
}
.search_btn_box input[type="button"]:hover{
	cursor: pointer;
    opacity: 0.8;
}

/* RIMSフォーム系 */
table.senddatatable,
table.anqtable{
	margin: 40px 0 0;
}
table.senddatatable td,
table.anqtable td{
}
table.senddatatable th,
table.anqtable th{
	font-size: 18px;
}
table.senddatatable tr td:first-child,
table.anqtable tr td:first-child{
	width: 20%;
}
table.senddatatable .senddata_koumoku,
table.anqtable .senddata_koumoku{
	font-weight: bold;
    border-right: none;
}

#SPForm input[type="submit"],
#SPForm input[type="submit"]{
	cursor: pointer;
}

/* 資料請求ヘッダー部分 */
.inqHead{
	width: 100%;
}
.inqHead > tbody > tr{
	display: block;
}
.inqHead > tbody > tr > th{
	display: block;
	font-size: 18px;
	padding: 5px 10px;
	text-align: left;
	border: solid 1px #555;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	border-radius: 50px;
}
.inqHead > tbody > tr > td{
	display: block;
}
.inqHead > tbody > tr > th .anq_required{
	color: #b3203a;
	font-size: 14px;
	font-weight: bold;
}
.inqHead .inqObjs{
	width: 100%;
}
.inqHead .inqObjs tbody > tr:nth-child(2n-1){
	border-top: solid 1px #DDD;
}
.inqHead .inqObjs tbody > tr:first-child{
	border-top: none;
}
.inqHead .inqObjs tr th.cell-01{
	position: relative;
	line-height: 1;
	color: #FFF;
	width: 30px;
}
.inqHead .inqObjs tr th.cell-01::before{
	content: "";
	display: block;
	background-color: #555;
	color: #FFF;
	text-align: center;
	width: 30px;
	height: 30px;
	-webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;
	position: absolute;
	top: 0px;
	bottom: 0px;
	margin: auto;
	z-index: -1;
}
.inqHead .inqObjs td{
	padding: 10px 0;
	text-align: left;
}
.inqHead .inqObjs .cell-02{
	text-align: center;
}
.inqHead .inqObjs .cell-03{
	padding: 10px 0 0;
}
.inqHead .inqObjs .cell-06{
	padding: 0 0 10px;
}
.inqHead .inqType td{
	padding: 20px 20px 10px 0px;
	text-align: left;
}


form #areabox1,
form #areabox2,
form #railways,
form #stations{
width: 300px;
}


#form_common_design .cart th{
border-bottom: solid 1px #ddd;
padding: 20px 0;
}
#form_common_design .cart td{
padding: 20px 0;
}


/* フッター */
#footer_new {
margin-top: 120px;
}
#footer_new_inner{
display: flex;
justify-content: space-between;
}
#footer_new #footer_sitemap{
flex: 1;
border: none;
margin-bottom: 3vw;
}
#footer_new #footer_sitemap em{
display: none;
}
#footer_new #footer_sitemap #footer_sitemap_inner{
display: flex;
padding: 0;
}
#footer_new #footer_sitemap #footer_sitemap_inner dl{
margin-bottom: 0px;
width: 25%;
}
#footer_new #footer_sitemap #footer_sitemap_inner dt{
font-size: 16px;
}
#footer_new #footer_sitemap #footer_sitemap_inner dd ul li{
width: 100%;
font-size: 14px;
margin-top: 5px;
}

#footer_new #footer_company{
display: block;
margin-bottom: 0;
margin-left: 3vw;
}
#footer_new #footer_logo{
width: 240px;
margin-bottom: 20px;
}
#footer_new #footer_logo img{
height: 60px;
width: auto;
}

#footer_new #footer_company .banner{
text-align: right;
margin-bottom: 0;
}




#footer_new #copy_right{
margin-bottom: 3vw;
width: 100%;
}


}

