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

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

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

a,
a:link,
a:visited {
	color: #111;
}
img{
	vertical-align: middle;
}
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;
}
input[type="radio"],
input[type="checkbox"]{
	-webkit-appearance: none;
	background-color: #FFF;
	background-image: url(../images/checkbox_bg_off.svg);
	background-repeat: no-repeat;
	background-position: center center;
	width: 20px;
	height: 20px;
	margin: 0 5px 0 0;
	border-radius: 20px;
	display: inline-block;
	vertical-align: middle;
	border: solid 1px #DDD;
	box-sizing: border-box;
}
input[type="checkbox"]{
	border-radius: 5px;
	cursor: pointer;
}
input[type="radio"]:checked,
input[type="checkbox"]:checked{
	background-image: url(../images/checkbox_bg_on.svg);
	background-color: #1c3a51;
	border: none;
}
select{
/*-webkit-appearance: none;
appearance: none;*/
font-size: 14px;
padding: 5px;
border: solid 1px #999;
border-radius: 5px;
}


label:hover{
	cursor: pointer;
}

/* 2025-03-10 追加 */
.sub-code {
	display: inline-block;
	margin-right: 4px;
}

.opct{}

/* 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_bold{ font-weight: bold; }
.font_red{ color: #C33;}

.clear{
	display: block;
	float: none;
	clear: both;
}

.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 #111;
	border-right: 1px solid #111;
	-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,
.common_btn > *{
display: inline-block;
text-decoration: none;
background-color: #1c3a51;
color: #FFF;
min-width: 200px;
margin: 0 auto;
padding: 10px 40px;
border-radius: 5px;
position: relative;
}
.common_btn a::after,
.common_btn > *::after{
content: "";
width: 10px;
height: 10px;
position: absolute;
top: 0;
bottom: 0;
right: 13px;
margin: auto;
border-top: 2px solid #FFF;
border-right: 2px solid #FFF;
transform: rotate(45deg);

}

/* 中身======================================================================================================== */
#container {
}

/* ヘッダー======================================================================================================== */
#header {
width: 100%;
height: 80px;
padding: 0;
background-color: #FFF;
position: fixed;
top: 0;
left: 0;
z-index: 10001;
}
#header .flex{
padding: 10px 0;
margin: 0 -10px;
}
#header_logo img{
height: 60px;
max-width: 55vw;
}
#header #header_info li{
display: none;
}
#header #header_info li.btn_san{
display: block;
position: absolute;
top: 20px;
right: 50px;
cursor: pointer;
}
#header #header_info li.btn_san a{
display: flex;
align-items: center;
justify-content: center;
width: 40px;
height: 40px;
border: solid 1px #eb5e14;
border-radius: 5px;
}
#header #header_info li.btn_san img{
max-width: 34px;
max-height: 34px;
}

#header #header_info li.btn_limini{
display: block;
position: absolute;
top: 20px;
right: 100px;
}
#header #header_info li.btn_limini img{
max-width: 40px;
max-height: 40px;
}



#san_information{
width: 100%;
height: 100%;
position: fixed;
top: 0;
left: 0;
z-index: 11111;
display: none;
}
#san_information .overlay{
background-color: rgba(255,177,123,0.5);
width: 100%;
height: 100%;
position: fixed;
top: 0;
left: 0;
z-index: 10;
}
#san_information_inner{
background-color: #fff;
box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.2);
width: 90%;
padding: 20px;
position: absolute;
top: 50%;
left: 50%;
z-index: 50;
transform: translateY(-50%) translateX(-50%);
-webkit- transform: translateY(-50%) translateX(-50%);
margin: auto;
}
#san_information .article{
margin-top: 20px;
}
#san_information .article:first-child{
margin-top: 0px;
}
#san_information .article a{
text-decoration: none;
}
#san_information .article .photo{
background-repeat: no-repeat;
background-position: center center;
background-size: cover;
padding-top: 40vw;
}
#san_information .article#san_plus .photo{ background-image: url("../images/sanplus_p.jpg"); }
#san_information .article#san_studio .photo{ background-image: url("../images/sanstudio_p.jpg"); }
#san_information .article .photo img{
display: none;
}
#san_information .article .text{
color: #fff;
background-color: #ec5e14;
padding: 10px;
}
#san_information .article .text dt{
font-size: 20px;
text-align: center;
}
#san_information .article .common_btn{
display: none;
}
#san_information .close{
background-color: #ec5e14;
position: absolute;
top: 0;
right: 0;
width: 40px;
height: 40px;
cursor: pointer;
}
#san_information .close::before{
display: block;
content: "";
width: 1px;
height: 20px;
background-color: #fff;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
margin: auto;
transition: all 0.2s ease;
}
#san_information .close::after{
display: block;
content: "";
width: 1px;
height: 20px;
background-color: #fff;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
margin: auto;
transition: all 0.2s ease;
}
#san_information .close span{
display: none;
}
/* グローバルメニュー=============================================== */
#global_menu{
margin: 0 -20px;
}
#global_menu ul{
display: none;
background-color: #FFF;
}
#global_menu ul li{
border-bottom: solid 1px #DDD;
}
#global_menu ul li a{
display: block;
text-decoration: none;
padding: 10px 20px;
}
#global_menu ul li a .icon{
display: inline-block;
vertical-align: middle;
width: 20px;
text-align: center;
margin-right: 0.5em;
}
#global_menu ul li a .icon img{
max-width: 20px;
max-height: 20px;
}
#global_menu ul li a p{
display: inline-block;
vertical-align: middle;
}

#global_menu ul li a.dropdown{
border-bottom: none;
}
#global_menu .dropdown{
padding: 0 20px;
}
#global_menu .dropdown a{
padding: 10px;
position: relative;
border-bottom: none;
border-top: solid 1px #EEE;
}
#global_menu .dropdown a::before{
content: "";
display: inline-block;
vertical-align: middle;
width: 7px;
height: 7px;
margin: 0 10px 0 0;
border-top: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
}




.sp-hamburger {
	display: block;
	text-align: center;
	z-index: 9500;
	position: absolute;
	top: 20px;
	right: 0px;
	display: block;
	box-sizing: border-box;
	width: 50px;
	height: 30px;
	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: 28px;
	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: 2px;
  -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);
}

/* ログイン部分======================================================================================================== */
#member_minimenu{
width: 100%;
height: 60px;
background-color: rgb(255,255,255,0.9);
border-top:solid 1px #29abe2;
border-bottom:solid 1px #29abe2;
position: fixed;
top: 80px;
left: 0;
z-index: 10000;
}
#member_minimenu ul{
display: flex;
padding: 0;
text-align: center;
}
#member_minimenu ul li{
width: 25%;
}
.now_login#member_minimenu ul li{
width: 20%;
}
#member_minimenu ul li a{
display: block;
height: 100%;
text-decoration: none;
color: #29abe2;
font-size: 10px;
padding: 12px 0;
}
#member_minimenu ul li a .icon{
height: 20px;
margin-bottom: 4px;
}
#member_minimenu ul li a .icon img{
max-width: 20px;
max-height: 20px;
}
#member_minimenu ul li a p{
display: block;
height: 10px;
}
#member_minimenu ul li a p img{
height: 10px;
vertical-align: top;
}
#member_minimenu ul li.logout{
position: relative;
}
#member_minimenu ul li.logout input{
-webkit-appearance: none;
text-decoration: none;
background-color: transparent;
background-image: url("../images/minimenu_icon-logout.svg");
background-repeat: no-repeat;
background-position: center 12px;
background-size: 20px 20px;
font-size: 10px;
line-height: 1;
color: #29abe2;
display: block;
width: 100%;
height: 100%;
border: none;
padding:0;
margin: 0;
box-sizing: border-box;
}
#member_minimenu ul li.logout::after{
content: "";
display: block;
background-image: url("../images/minimenu_text-logout.svg");
background-repeat: no-repeat;
background-position: center top;
background-size: contain;
width: 100%;
height: 10px;
position: absolute;
bottom: 12px;
right: 0;
z-index: -1;
}
#member_minimenu ul li.logout input:hover{
cursor: pointer;
}



#login_fixed{
width: 200px;
background-color: #fff;
padding: 10px;
border: solid 1px #17384e;
position: fixed;
bottom: 10px;
right: 10px;
border-radius: 5px;
z-index: 10000;
transition: all 0.5s ease;
}
#login_fixed .login_count li{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#login_fixed .login_count li:first-child{
	border-bottom: dotted 1px #FFF;
	margin-bottom: 5px;
	padding-bottom: 5px;
}
#login_fixed .login_count li em{
	color: #1c3a51;
	font-size: 12px;
}
#login_fixed .login_count li p{
	color: #1c3a51;
}
#login_fixed .login_count li p span{
	font-size: 16px;
    font-weight: bold;
	line-height: 1.2;
}
#login_fixed .login_count li.member_only_regist p span{
	color: #e90042;
}
#login_fixed .flex .btn{
	margin-top: 5px;
}
#login_fixed .flex .btn a{
	display: block;
	text-decoration: none;
	color: #FFF;
	font-weight: bold;
	padding: 5px;
	border-radius: 5px;
}
#login_fixed .flex .btn.btn_member a{ background-color: #cc9933; }
#login_fixed .flex .btn.btn_login a{ background-color: #1c3a51; }

#login_fixed .close{
	background-color: #FFF;
	color: #888;
	line-height: 20px;
	width: 20px;
	height: 20px;
	border-radius: 20px;
	text-align: center;
	border: solid 1px #888;
	position: absolute;
	top: -5px;
	right: -5px;
}
#login_fixed .close:hover{
	cursor: pointer;
}


#member_info{
background-color: #e6f7ff;
margin: 0 20px;
padding: 10px;
border-radius: 10px;
text-align:  center;
}
#member_info .title{
padding-bottom: 20px;
margin-bottom: 20px;
border-bottom: solid 1px #999;
}
.login#member_info .title{
padding-bottom: 10px;
}
#member_info .title em{
font-size: 20px;
font-weight: bold;
}
#member_info .title p{
margin-bottom: 10px;
}
#member_info .title .btn{
}
#member_info .title .btn a{
display: block;
text-decoration: none;
background-color: #cc9933;
color: #FFF;
padding: 10px;
border-radius: 5px;
}
#member_info .count{
display: flex;
justify-content: space-between;
}
#member_info .count li{
display: flex;
align-items: center;
}
#member_info .count li em{
	font-size: 3.5vw;
}
#member_info .count li p{
	font-size: 3vw;
}
#member_info .count li p span{
	font-size: 5vw;
    font-weight: bold;
	line-height: 1.2;
	color: #cc9933;
}
#member_info .sign_in .input dl{
display: flex;
flex-wrap: wrap;
margin-top: 10px;
}
#member_info .sign_in .input dt{
background-color: #1c3a51;
color: #FFF;
width: 4em;
text-align: center;
border-radius: 5px 0 0 5px;
}
#member_info .sign_in .input dd{
flex: 1;
background-color: #FFF;
border-radius: 0 5px 5px 0;
}
#member_info .sign_in .input dd input{
border: none;
}
#member_info .sign_in .reissue{
margin: 10px 0;
}
#member_info .sign_in .btn input{
-webkit-appearance: none;
text-decoration: none;
border: none;
display: block;
width: 100%;
cursor: pointer;
background-color: #1c3a51;
color: #FFF;
padding: 10px;
border-radius: 5px;
}


/* コンテンツ======================================================================================================== */
#container {
}
.blog_table{
	width: 100%;
}
/*
.page .topics .navi,
.page .topics .page_title,
.page .topics .blog_index_td,
.page .topics .blog_index,
.page .topics .blog_category_title_view,
.page .topics .blog_navi{
	display: none;
	visibility: hidden;
}
.page .topics .blog_index_td{
	width: 0px;
}
.page .topics .master_date{
	font-weight: bold;
}
.master_title{
	font-weight: normal;
	margin: 0;
	padding: 0;
}
.page .topics .master_contents{
	margin: 0 0 10px;
	padding: 0 0 10px;
	border-bottom: 1px solid #DDD;
}
.page .topics br{
	display: none;
	visibility: hidden;
}
.page .topics .master_contents br{
	display: inline;
}
*/

#page_container {
	text-align: left;
}
#contents {
}
/*
.main_top + div,
.main_top + #login_check + div{
*/
.main > div{
padding-right: 20px;
padding-left: 20px;
}
.main > .top{
padding-right: 0px;
padding-left: 0px;
}
.contents_size{
padding-right: 20px;
padding-left: 20px;
text-align: left;
}
.h1_tag {
    text-align: left;
}
.navi{
	font-size: 12px;
	margin: 10px 0;
	text-align: left;
}
.next_navi{display: none;}
.page_title{
text-align: center;
margin-bottom: 40px;
}
.page_title > *{
display: inline-block;
font-size: 24px;
font-weight: bold;
letter-spacing: 0.25em;
white-space: normal;
padding-bottom: 10px;
padding-left: 0.25em;
border-bottom: solid 3px #1994d1;
}
.sub_bar{
display: block;
font-size: 24px;
font-weight: bold;
letter-spacing: 0.25em;
text-align: center;
white-space: normal;
padding-left: 0.25em;
margin-bottom: 20px;
}
.sub_bar::after{
content: "";
display: block;
width: 50px;
height: 5px;
margin: 10px auto 0;
background-color: #1c3a51;
border-radius: 5px;
}
.sub_bar_m{
border-left: solid 5px #1c3a51;
font-size: 20px;
line-height: 1.4;
font-weight: bold;
padding: 5px;
margin-bottom: 10px;
text-align: left;
}
.sub_bar_mm{
font-size: 16px;
font-weight: bold;
margin-bottom: 10px;
}
.marker{
background:linear-gradient(transparent 55%, #fff441 55%);
padding-left: 0.3em;
padding-right: 0.3em;
padding-bottom: 0.2em;
}


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

table.normal_line{
width: 100%;
border-collapse:collapse;
border-spacing: 0;
}
.normal_line th,
.normal_line td{
border: 1px solid #DDD;
padding: 8px;
}
.normal_line th {
background-color:#e6f7ff;
text-align: center;
}
.normal_line td {
}




/* 検索のテーブル */
table.serchTbl{
	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{
	background-color: #e6f7ff;
	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;
}
table.serchTbl input[type="button"]{
	-webkit-appearance: none;
	width: 100%;
	text-decoration: none;
	padding: 10px;
	font-weight: bold;
    color: #FFF;
    background-color: #1c3a51;
    border: none;
	border-radius: 5px;
	position: relative;
}
/*  */


form .must{
	display: block;
	background-color: #C00;
	padding: 5px;
	font-size: 10px;
	line-height: 10px;
	color: #FFF;
	float: right;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
	border-radius: 5px;
}form .cap{
	font-size: 10px;
	line-height: 1.5em;
	color: #C00;
}
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: #C00; color: #FFF; }
form #submit_box button[type="reset"]:hover{ background-color: #BBB; }
form #submit_box button[type="submit"]:hover{ background-color: #9A0002; }

/* RIMSフォーム系 */
table.senddatatable,
table.anqtable{
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	box-sizing: border-box;
	text-align: left;
	margin: 20px 0 0;
}
table.senddatatable th,
table.anqtable th{
	width: 100%;
	font-size: 14px;
	box-sizing: border-box;
	padding: 5px 10px;
	text-align: left;
    background-color: #f5f5f5;
	border: solid 1px #DDD;
}
table.senddatatable td,
table.anqtable td{
padding: 10px;
border: solid 1px #DDD;
border-top: none;
box-sizing: border-box;
}
table.senddatatable .anq_required,
table.anqtable .anq_required{
	color: #D10003;
}
#SPForm input.form_input_back{
	-webkit-appearance: none;
	border: none;
	background-color: #CCC;
	width: 40%;
	padding: 15px 0px;
	margin: 0px;
	cursor:pointer;
}
#SPForm input[type="submit"]{
	-webkit-appearance: none;
	border: none;
	background-color: #1c3a51;
	color: #FFF;
	width: 40%;
    border-radius: 5px;
	padding: 15px 0px;
	margin: 0px;
}
form .r_kind_add{
display: none;
}

form .arrow_box {
position: relative;
background: #fff;
padding: 5px 10px;
text-align: center;
border: 1px solid #00b6e8;
color: #00b6e8;
font-size: 14px;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
display: inline-block;
margin-bottom: 10px;
}
form .arrow_box:after,
form .arrow_box:before {
  border: solid transparent;
  content: '';
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  top: 100%;
  left: 7%;
}
form .arrow_box:after {
  border-color: rgba(255, 255, 255, 0);
  border-top-width: 10px;
  border-bottom-width: 10px;
  border-left-width: 5px;
  border-right-width: 5px;
  margin-left: -5px;
  border-top-color: #ffffff;
}
form .arrow_box:before {
  border-color: rgba(255, 0, 0, 0);
  border-top-width: 12px;
  border-bottom-width: 12px;
  border-left-width: 6px;
  border-right-width: 6px;
  margin-left: -6px;
  margin-top: 1px;
  border-top-color: #00b6e8;
}



.common_li_check{
}
.common_li_check li{
padding-left: 30px;
margin-top: 10px;
position: relative;
}
.common_li_check li:first-child{
margin-top: 0;
}
.common_li_check li::before{
content: "";
display: block;
width: 20px;
height: 20px;
background-color: #00b6e8;
position: absolute;
left: 0;
top: 0;
}
.common_li_check li::after{
content: "";
vertical-align: middle;
width: 5px;
height: 10px;
border-bottom: 1px solid #FFF;
border-right: 1px solid #FFF;
transform: rotate(45deg);
position: absolute;
left: 7px;
top: 3px;
}

.common_li_disc li{
list-style: disc;
margin-left: 20px;
}




/* ブログ  */
.main > * .blog_table{
	display: block;
}
.main > * .blog_table > tbody{
	display: block;
}
.main > * .blog_table > tbody > tr{
display: flex;
flex-direction: column-reverse;
justify-content: space-between;
}
.main > * .blog_index_td{
	display: block;
	width: 100%;
}
.main > * .blog_main_td{
	display: block;
	width: 100%;
    text-align: left;
}

.main > * .blog_index{
	font-size: 14px;
	line-height: 1.8;
	text-align: center;
}
.main > * .blog_calendar table{
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
.main > * .blog_calendar th,
.main > * .blog_calendar td{
	border: solid 1px #CCC;
	text-align: center;
	padding: 5px;
	box-sizing: border-box;
}
.main > * .blog_category_title,
.main > * .monthly_archive_title{
	color: #00b6e8;
	border-bottom: solid 1px #00b6e8;
	padding-bottom: 5px;
	margin-bottom: 5px;
}

.main > * .blog_master_line1{
	border-top: solid 1px #00b6e8;
	padding-top: 20px;
}

.main > * .master_date{
	/* display: block; */
	display: none;
	font-size: 14px;
	color: #00b6e8;
	border-top: solid 1px #00b6e8;
	padding-top: 5px;
	margin-top: 5px;
}
.main > * .master_title{
	font-size: 20px;
	color: #00b6e8;
}
.main > * .master_title a{
	color: #00b6e8;
	/*
	pointer-events: none;
	text-decoration: none;
	*/
}

.main > * .blog_main_td > .blog_master_view .master_contents{
	white-space: nowrap;
	width: 100%;
	height: 1.8em;
	overflow: hidden;
	text-overflow: ellipsis;
}



/* 画像つきブログ */
.blog_img_list{
margin-bottom: 40px;
}
.blog_img_list ul{
margin-bottom: 20px;
}
.blog_img_list li{
text-align: center;
margin-top: 20px;
letter-spacing: 0.01em;
line-height: 1.2em;
font-weight: 600;
padding: 3.5px;
}
.blog_img_list li.hidden {
display: none;
}
.blog_img_list li .blog_latest_date{
display: none;
}
.blog_img_list li .blog_latest_title img{
min-height: 59vw;
max-height: 59vw;
display: block;
margin: 0 auto 10px;
}

.blog_img_list .more_btn{
cursor: pointer;
padding: 10px;
border: solid 1px #111;
text-align: center;
}
.blog_img_list .more_btn::after{
content: "";
display: block;
vertical-align: middle;
width: 15px;
height: 15px;
margin: 0 auto;
border-bottom: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
}





/* 会員の案内 */
.common_new_member{
background-color: #FFF;
position: relative;
padding-top: 20px;
}
.common_new_member h3{
background-image: url("../images/new_member_copy_sp.svg");
background-repeat: no-repeat;
background-position: left top;
background-size: 100% auto;
width: 70vw;
height: 15vw;
margin: 0 0 20px 20px;
}
.common_new_member h3 span{
display: none;
}
.common_new_member .point{
background-color: #cc0000;
color: #FFF;
display: flex;
align-items: center;
justify-content: center;
text-align: center;
width: 80px;
height: 80px;
border-radius: 80px;
font-size: 10px;
line-height: 1.1;
font-weight: bold;
position: absolute;
right: -10px;
top: -40px;
z-index: 10;
}
.common_new_member .point span{
}
.common_new_member .point::before{
content: "";
display: block;
width: 0;
height: 0;
border-style: solid;
border-width: 20px 7.5px 0 7.5px;
border-color: #cc0000 transparent transparent transparent;
position: absolute;
left: 0px;
bottom: 0px;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
z-index: -1;
}
.common_new_member .copy02{
display: flex;
justify-content: center;
align-items: center;
padding: 0 0 20px;
border-bottom: solid 2px #cc9933;
}
.common_new_member .copy02 p{
background-image: url("../images/new_member_copy02_sp.svg");
background-repeat: no-repeat;
background-position: left top;
background-size: 100% auto;
width: 45vw;
height: 20vw;
margin-right: 2vw;
}
.common_new_member .copy02 p span{
display: none;
}
.common_new_member .copy02::after{
content: "";
display: block;
background-image: url("../images/new_member_present.png");
background-repeat: no-repeat;
background-position: right top;
background-size: 100% auto;
width: 25vw;
height: 20vw;
}
.common_new_member .point_list{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 0 0 20px;
}
.common_new_member .point_list dl{
width: 50%;
text-align: center;
margin-top: 20px;
}
.common_new_member .point_list dt{
font-size: 16px;
color: #cc9933;
}
.common_new_member .point_list dl dt::before{
content: "";
display: block;
background-repeat: no-repeat;
background-position: center center;
background-size: contain;
width: 15vw;
height: 15vw;
margin: 0 auto 10px;
}
.common_new_member .point_list dl:nth-child(1) dt::before{ background-image: url("../images/icon-member01.svg"); }
.common_new_member .point_list dl:nth-child(2) dt::before{ background-image: url("../images/icon-member02.svg"); }
.common_new_member .point_list dl:nth-child(3) dt::before{ background-image: url("../images/icon-member03.svg"); }
.common_new_member .point_list dl:nth-child(4) dt::before{ background-image: url("../images/icon-member04.svg"); }

.common_new_member .point_list dt em{
content: "";
display: block;
background-repeat: no-repeat;
background-position: center center;
background-size: contain;
width: 100%;
height: 10vw;
margin-bottom: 10px;
}
.common_new_member .point_list dl:nth-child(1) dt em{ background-image: url("../images/new_member_01_title_sp.svg"); }
.common_new_member .point_list dl:nth-child(2) dt em{ background-image: url("../images/new_member_02_title_sp.svg"); }
.common_new_member .point_list dl:nth-child(3) dt em{ background-image: url("../images/new_member_03_title_sp.svg"); }
.common_new_member .point_list dl:nth-child(4) dt em{ background-image: url("../images/new_member_04_title_sp.svg"); }
.common_new_member .point_list dt em span{
display: none;
}
.common_new_member .point_list dd{
content: "";
display: block;
background-repeat: no-repeat;
background-position: center center;
background-size: contain;
width: 100%;
height: 8vw;
margin: auto;
}
.common_new_member .point_list dl:nth-child(1) dd{ background-image: url("../images/new_member_01_text.svg"); }
.common_new_member .point_list dl:nth-child(2) dd{ background-image: url("../images/new_member_02_text.svg"); }
.common_new_member .point_list dl:nth-child(3) dd{ background-image: url("../images/new_member_03_text.svg"); }
.common_new_member .point_list dl:nth-child(4) dd{ background-image: url("../images/new_member_04_text.svg"); }
.common_new_member .point_list dd span{
display: none;
}



/* main_bottom======================================================================================================== */
#main_bottom_container{
padding-top: 70px; /* 40→70へ変更20240204 */
padding-right: 20px;
padding-left: 20px;
}
#main_bottom_link {
margin-bottom: 20px;
}
#main_bottom_link ul{
}
#main_bottom_link li{
margin-bottom: 5px;
}
#main_bottom_link li a{
display: block;
text-decoration: none;
background-color: #00b6e8;
color: #FFF;
font-weight: bold;
padding: 10px;
}
#main_bottom_link li a::before{
border-color: #FFF;
}
#facebook_plugin {
}
#facebook_plugin iframe{
vertical-align: top;
}


/* フッター======================================================================================================== */
#footer {
padding-top: 40px;
}
#footer_description{
font-size: 12px;
padding-bottom: 40px;
}
#page_top_btn{
position: absolute;
top: -10px;
right: 10px;
z-index: 10;
}
#page_top_btn a{
display: block;
text-decoration: none;
background-color: #1c3a51;
color: #FFF;
font-size: 12px;
width: 60px;
height: 60px;
padding: 32px 0 0;
text-align: center;
position: relative;
}
#page_top_btn a::before{
	content: "";
	vertical-align: middle;
	width: 15px;
	height: 15px;
	position: absolute;
	top: 20px;
	left: 0;
    right: 0;
	margin: 0 auto;
	border-top: 1px solid #FFF;
	border-right: 1px solid #FFF;
	transform: rotate(-45deg);
}
#footer_sitemap{
background-color: #8ABCCB;
color: #fff;
position: relative;
}#footer_sitemap a{
color: #fff;
}
#footer_sitemap .accordion_title{
cursor: pointer;
padding: 20px 0;
position: relative;
}
#footer_sitemap .accordion_title::after{
	content: "";
    display: inline-block;
	vertical-align: middle;
	width: 10px;
	height: 10px;
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
    margin-left: 10px;
    margin-bottom: 5px;
	transition: all 0.2s ease;
}
#footer_sitemap .accordion_title.open::after{
	transform: rotate(-135deg);
    margin-bottom: -5px;
}
#footer_sitemap .accordion_title .icon{
display: inline-block;
vertical-align: middle;
margin-right:  0.5em;
}
#footer_sitemap .accordion_title p{
display: inline-block;
vertical-align: middle;
font-size: 16px;
font-weight: bold;
}
#footer_sitemap .accordion_container{
display: none;
padding-bottom: 20px;
}
#footer_sitemap em{
display: block;
font-weight: bold;
}
#footer_sitemap .inner{
display: flex;
flex-wrap: wrap;
}
#footer_sitemap dl{
width: 50%;
margin-top: 1em;
}
#footer_sitemap dt{
font-weight: bold;
margin-top: 3px;
}
#footer_sitemap dd + dt{
margin-top: 8px;
}
#footer_sitemap dd{
margin-top: 3px;
font-size: 12px;
}
#footer_sitemap dd::before{
	content: "";
    display: inline-block;
	vertical-align: middle;
	width: 5px;
	height: 5px;
    margin-right: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
}



#footer_company{
background-color: #e6f7ff;
color: #1c3a51;
padding: 40px 0;
}
#footer_company a{
color: #1c3a51;
}
#footer_logo{
text-align: center;
margin-bottom: 20px;
}
#footer_logo img{
height: 25px;
margin-bottom: 5px;
}

#footer_info{
margin-bottom: 40px;
}
#footer_mail{
margin-bottom: 20px;
}
#footer_mail a{
display: block;
text-decoration: none;
background-color: #cc9933;
font-weight: bold;
color: #fff;
padding: 10px;
border-radius: 5px;
text-align: center;
}
#footer_mail a .icon{
display: inline-block;
vertical-align: middle;
margin-right: 5px;
}
#footer_mail a p{
display: inline-block;
vertical-align: middle;
}
#footer_info ul{
display: block;
text-align: center;
}
#footer_info li{
display: inline-block;
vertical-align: middle;
margin: 0 5px;
}
#footer_info li img{
max-width: 50px;
max-height: 50px;
}

#footer_shop_list{
}
#footer_shop_list li{
display: flex;
justify-content: space-between;
border-bottom: 1px solid rgba(0,0,0,0.1);
padding-bottom: 20px;
margin-bottom: 20px;
}
#footer_shop_list li .map{
margin-right: 10px;
}
#footer_shop_list li .map iframe{
width: 40vw;
height: 40vw;
}
#footer_shop_list li .text{
flex: 1;
}
#footer_shop_list li .text .outline{
}
#footer_shop_list li .text .title{
}
#footer_shop_list li .text .title em{
display: block;
font-weight: bold;
}
#footer_shop_list li .text .point{
}
#footer_shop_list li .text .point p{
font-size: 2.5vw;
line-height: 1;
color: #fff;
display: inline-block;
padding: 5px;
border-radius: 5px;
}
#footer_shop_list li .text .point p.buy{ background-color: #00b6e8; }
#footer_shop_list li .text .point p.sell{ background-color: #dd0025; }
#footer_shop_list li .text .point p.owner{ background-color:#434AC0; }
#footer_shop_list li .text .point p.rent{ background-color: #bb8000; }
#footer_shop_list li .text .point p.studio{ background-color: #ff6600; }
#footer_shop_list li .text .contact{
}
#footer_shop_list li .text .contact a{
font-size: 3vw;
}
#footer_shop_list li .text .contact a .icon{
display: inline-block;
vertical-align: middle;
margin-right: 5px;
}
#footer_shop_list li .text .contact a p{
display: inline-block;
vertical-align: middle;
}

#footer_shop_list li .tel{
}
#footer_shop_list li .tel{
}
#footer_shop_list li .tel a{
font-size: 4vw;
font-weight: bold;
color: #cc9933;
}
#footer_shop_list li .tel a .icon{
display: inline-block;
vertical-align: middle;
margin-right: 5px;
}
#footer_shop_list li .tel a .icon img{
height: 12px;
}
#footer_shop_list li .tel a p{
display: inline-block;
vertical-align: middle;
}

#footer_company .eigyo_area{
background-color: #FFF;
margin-bottom: 40px;
}
#footer_company .eigyo_area dl{
}
#footer_company .eigyo_area dt{
text-align: center;
font-weight: bold;
background-color: #CCC;
padding: 5px;
color: #111;
}
#footer_company .eigyo_area dd{
color: #111;
font-weight: bold;
padding: 10px;
}

#footer #copy_right{
	text-align: center;
	font-size: 10px;
}


/* スマホのみ======================================================================================================== */
@media print and (max-width: 750px), screen and (max-width: 750px){
img {
	max-width: 100%;
	height: auto;
	width /***/: auto;
}
.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; }


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


/* RIMSフォーム系 */
table.senddatatable td,
table.anqtable td{
display: block;
}
table.senddatatable td.senddata_koumoku,
table.anqtable td.senddata_koumoku{
border-bottom: none;
font-weight: bold;
width: 100%;
}

input[type="text"],
input[type="email"],
input[type="password"],
textarea {
	width: 100%;
}
input[mode="hiragana"]{
	width: 90%;
}
.senddata10 .form_required {
	display: block;
}
input[type="tel"]{
	width: 90%;
	display: block;
}
.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{
	padding: 15px 30px;
	margin: 0 5px;
}

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

/* 資料請求ヘッダー部分 */
.inqHead{
	width: 100%;
}
.inqHead th,
.inqHead td{
	display: block;
}
.inqHead > tbody > tr > th{
	font-size: 14px;
	padding: 5px 10px;
	text-align: left;
	border: solid 1px #555;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	border-radius: 50px;
}
.inqHead > tbody > tr > th .anq_required{
	color: #D10003;
	font-size: 12px;
	font-weight: bold;
}
.inqHead .inqObjs{
	width: 100%;
}
.inqHead .inqObjs tr th.cell-01{
	line-height: 1;
	color: #FFF;
	padding: 18px 0;
	border-top: solid 1px #DDD;
	position: relative;
}
.inqHead .inqObjs tr:first-child th.cell-01{
	border-top: none;
}
.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: 8px;
	left: 0px;
	right: 0px;
	margin: auto;
	z-index: -1;
}
.inqHead .inqObjs .cell-07{
	padding: 0 0 8px;
}
.inqHead .inqType{
	width: 100%;
}
.inqHead .inqType td{
	display: block;
	padding: 8px 0;
	border-bottom: solid 1px #EEE;
	text-align: left;
}

form #areabox1,
form #areabox2,
form #railways,
form #stations{
	width: 100% !important;
	margin: 1% !important;
	padding: 0 !important;
	float: none !important;
	display: block !important;
	vertical-align: middle !important;
}
.anqtable div[style*="white-space"]{
	white-space: normal !important;
}


.blog_table .master_contents table{
width: 100%;
}



.sp_raf{
margin: 0 -20px;
}

.main > * .master_contents{
	word-break: break-all;
}

#global_menu ul {
  display: none;
  background-color: #FFF;
  max-height: calc(100vh - 80px); 
  height: 100vh;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch; /* スムーズスクロールを有効化 (モバイル用) */
  position: absolute; 
  top: 80px;
  left: 0;
  right: 0;
  z-index: 9999; 
}


}

/* PCのみ======================================================================================================== */
@media print and (min-width: 751px), screen and (min-width: 751px){
body{
	font-family: 'Noto Sans JP', 'Arial', "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    padding-top: 0px;
	min-width: 1100px;
}
body.body_template2{
	min-width: inherit;
}
body,
table,
input,
textarea{
	font-size: 14px;
}
a,
a img,
a .common_btn,
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: #1c3a51;
}
a:active {
	color: #1c3a51;
}
.opct a:hover,
a.opct:hover,
a.opct:hover img,
a.opct:hover .common_btn,
a:hover img.opct{
	opacity: 0.8;
    -moz-opacity:0.8;
    filter: alpha(opacity=80);
}

.pc_only{ }
.pc_only img { width: 100%; } /* 狭山不動産追記*/
.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:hover{
color: #FFF;
}

/* 中身 */
#header {
height: auto;
position: inherit;
top: inherit;
left: inherit;
}
#header .flex{
padding: 30px 0 10px;
margin: 0;
display: flex;
justify-content: space-between;
align-items: center;
position: relative;
}
#header_logo a{
}
#header_logo img{
height: 60px;
display: inline-block;
vertical-align: middle;
}
#header_logo p{
display: inline-block;
vertical-align: middle;
font-size: 12px;
font-weight: bold;
margin-left: 10px;
}
#header #header_info ul{
display: flex;
}
#header #header_info li{
display: block;
margin-left: 10px;
}
#header #header_info li img{
max-width: 50px;
max-height: 50px;
}
#header #header_info li.btn_san{
position: inherit;
top: inherit;
right: inherit;
}
#header #header_info li.btn_san a{
width: 50px;
height: 50px;
}

#header #header_info li.btn_limini{
position: inherit;
top: inherit;
right: inherit;
}
#header #header_info li.btn_limini img{
max-width: 50px;
max-height: 50px;
}

#header #header_info li.btn_mail{
}
#header #header_info li.btn_mail a{
display: block;
text-decoration: none;
background-color: #dd0025;
color: #FFF;
text-align: center;
height: 50px;
line-height: 50px;
padding: 0 20px;
border-radius: 5px;
}
#header #header_info li.btn_mail a .icon{
display: inline-block;
vertical-align: baseline;
margin-right: 10px;
}
#header #header_info li.btn_mail a p{
display: inline-block;
vertical-align: middle;
}

#san_information .article a{
display: flex;
align-items: center;
width: 100%;
}
#san_information .article a:hover{
background-color: #FDEEE6;
}
#san_information .article:nth-child(odd) a{
flex-direction: row-reverse;
}

#san_information_inner{
width: 80%;
}
#san_information .article .photo{
background-image: none;
padding-top: 0;
width: 60%;
}
#san_information .article .photo img{
display: block;
max-width: 100%;
height: auto;
}
#san_information .article .text{
flex: 1;
text-align: center;
background-color: transparent;
color: #111;
padding: 0 5%;
}
#san_information .article .text dt{
font-size: 30px;
text-align: center;
}
#san_information .article .text dd{
font-size: 16px;
margin-bottom: 40px;
}
#san_information .article .common_btn{
display: inline-block;
}
#san_information .article .common_btn span{
background-color: #ec5e14;
}
#san_information .close{
transition: all 0.2s ease;
}
#san_information .close:hover{
background-color: #E74406;
}
#san_information .close:hover::before,
#san_information .close:hover::after{
height: 30px;
}





.h1_tag{
line-height: 20px;
height: 20px;
white-space: nowrap;
width: 100%;
overflow: hidden;
text-overflow: ellipsis;
}


/* グローバルメニュー */
#global_menu{
margin: 0;
padding: 10px 0 20px;
width: 100%;
background-color: #fff;
position: relative;
z-index: 10001;
}
#global_menu.fixed{
position: fixed;
top: 0;
left: 0;
right: 0;
margin: 0 auto;
}
#global_menu ul{
display: flex;
height: 60px;
width: 1060px;
margin: 0 auto;
}
#global_menu ul li{
width: 12.5%;
border-bottom: none;
border-right: solid 1px #111;
}
#global_menu ul li a{
height: 60px;
padding: 5px 0 0;
text-align: center;
}
#global_menu ul li a:hover{
padding: 10px 0 0;
}
#global_menu ul li:first-child a{
border-left: solid 1px #111;
}
#global_menu ul li a .icon{
display: flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
margin: 0 auto;
text-align: center;
}
#global_menu ul li a .icon img{
max-width: 30px;
max-height: 30px;
}
#global_menu ul li a p{
display: block;
}

#global_menu ul li a.dropdown_btn{
cursor: pointer;
position: relative;
}
#global_menu .dropdown{
display: none;
padding: 0;
background-color: #fff;
border-bottom: solid 1px #EEE;
border-right: solid 1px #EEE;
border-left: solid 1px #EEE;
font-size: 12px;
z-index: 11111;
}
#global_menu .dropdown a,
#global_menu .dropdown a:hover{
padding: 10px 0;
height: auto;
border-right: none;
}
#global_menu .dropdown a:hover{
background-color: #e6f7ff;
}
#global_menu .dropdown a::before{
display: none;
}



/* ログイン部分 */
#member_minimenu{
height: 30px;
position: relative;
top: inherit;
left: inherit;
}
#member_minimenu.fixed{
position: fixed;
top: 90px;
left: 0;
}
#member_minimenu ul{
justify-content: flex-end;
align-items: center;
}
#member_minimenu ul li{
width: auto;
margin-left: 2em;
}
.now_login#member_minimenu ul li{
width: auto;
}
#member_minimenu ul li a{
font-size: 14px;
padding: 0;
}
#member_minimenu ul li a .icon{
display: inline-block;
vertical-align: middle;
height: auto;
margin-bottom: 0px;
margin-right: 5px;
}
#member_minimenu ul li a p{
display: inline-block;
vertical-align: middle;
line-height: 28px;
}
#member_minimenu ul li.logout input{
background-position: left center;
font-size: 14px;
line-height: 28px;
padding: 0 0 0 25px;
width: 80px;
}
#member_minimenu ul li.logout::after{
width: 50px;
height: 12px;
bottom: 9px;
}

#login_fixed .title em{
font-size: 16px;
font-weight: bold;
display: block;
margin-bottom: 10px;
}
#login_fixed .title p{
text-align: left;
line-height: 1.4;
margin-bottom: 10px;
}
#login_fixed .login_count li p span{
	font-size: 20px;
}


#member_info{
margin: 0 auto;
padding: 30px;
display: flex;
align-items: center;
}
#member_info .title{
width: 350px;
text-align: center;
padding: 0px;
margin: 0px;
border-bottom: none;
border-right: solid 1px #999;
}
#member_info .title em{
font-size: 30px;
line-height: 1.4;
}
#member_info .title p{
}
#member_info .title .btn a{
display: inline-block;
font-size: 16px;
font-weight: bold;
}
#member_info .count{
justify-content: flex-start;
margin-bottom: 10px;
}
#member_info .count li:first-child{
margin-right: 30px;
}
#member_info .count li em{
	font-size: 14px;
}
#member_info .count li p{
	font-size: 20px;
}
#member_info .count li p span{
	font-size: 40px;
}
#member_info .sign_in{
flex: 1;
padding: 0 0 0 20px;
}
#member_info .sign_in .flex{
display: flex;
justify-content: space-between;
}
#member_info .sign_in .input{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
width: 450px;
}
#member_info .sign_in .input dl{
margin-top: 0px;
}
#member_info .sign_in .input dt{
color: #FFF;
width: 50px;
height: 50px;
line-height: 50px;
}
#member_info .sign_in .input dd{
width: 170px;
height: 50px;
}
#member_info .sign_in .input dd input{
width: 170px;
height: 50px;
}
#member_info .sign_in .input p{
display: block;
width: 100%;
text-align: left;
}

#member_info .sign_in .btn input{
width: 160px;
height: 50px;
font-size: 20px;
padding: 10px 0;
transition: all 0.2s ease;
}
#member_info .sign_in .btn input:hover{
opacity: 0.8;
}

/* コンテンツ */
#contents {
}
/*
.main_top + div,
.main_top + #login_check + div{
*/
.main > div{
padding-right: 0px;
padding-left: 0px;
width: 1000px;
margin-right: auto;
margin-left: auto;
}
.main > .top{
width: auto;
}
.contents_size{
padding-right: 0px;
padding-left: 0px;
width: 1060px;
margin-right: auto;
margin-left: auto;
}
.main .contents_size{
width: 1000px;
}
/*
.main_top + div .contents_size,
.main_top + #login_check + div .contents_size{
width: 1000px;
}
*/
.navi{
}
.page_title{
margin-bottom: 80px;
}
.page_title > *{
font-size: 30px;
}

.sub_bar{
font-size: 30px;
margin-bottom: 40px;
}
.sub_bar_m{
font-size: 24px;
margin-bottom: 20px;
}


/* 検索のテーブル */
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%;
}
table.serchTbl td[colspan="2"]{
	border: none;
}
table.serchTbl input[type="button"]{
	width: 300px;
	font-size: 16px;
	padding: 15px;
}
table.serchTbl 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: #D10003;
	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;
}

.sp_raf{
width: 375px;
margin: 0 auto;
}
.sp_raf img{
width: 100%;
height: auto;
}


/* ブログ  */
.main > * .blog_table > tbody > tr{
	flex-direction: row-reverse;
}
.main > * .blog_index_td{
	width: 200px;
}
.main > * .blog_main_td{
	width: 760px;
    text-align: left;
}
.main > * .master_title{
	font-size: 24px;
}
.blog_table img{
/* max-width: 100%;
height: auto; */
width: auto;
height: auto;
max-width: 760px;
max-height: 570px;
}



/* 画像つきブログ */
.blog_img_list{
margin-bottom: 80px;
}
.blog_img_list ul{
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
}
.blog_img_list li{
width: 30%;
margin-left: 5%;
margin-top: 50px;
}
.blog_img_list li:nth-child(3n-2){
margin-left: 0;
}
.blog_img_list li .blog_latest_title img{
min-height: 200px;
max-width: 300px;
max-height: 200px;
}

.blog_img_list .more_btn{
width: 360px;
margin-right: auto;
margin-left: auto;
padding: 20px;
}


/* 会員の案内 */
.common_new_member{
padding: 80px;
margin-bottom: 0;
}
.common_new_member h3{
background-image: url("../images/new_member_copy.svg");
width: auto;
height: 45px;
}
.common_new_member .point{
width: 100px;
height: 100px;
border-radius: 100px;
font-size: 12px;
right: -20px;
top: -40px;
}
.common_new_member .point span{
font-size: 14px;
}
.common_new_member .copy02{
}
.common_new_member .copy02 p{
padding: 0px;
background-image: url("../images/new_member_copy02.svg");
width: 770px;
height: 105px;
margin-right: 20px;
}
.common_new_member .copy02::after{
width: 160px;
height: 125px;
}

.common_new_member .point_list{
padding: 20px 0 0;
}
.common_new_member .point_list dl{
width: 25%;
margin-top: 0;
}
.common_new_member .point_list dt{
}
.common_new_member .point_list dl dt::before{
width: 60px;
height: 60px;
}
.common_new_member .point_list dt em{
height: 20px;
}
.common_new_member .point_list dl:nth-child(1) dt em{ background-image: url("../images/new_member_01_title_pc.svg"); }
.common_new_member .point_list dl:nth-child(2) dt em{ background-image: url("../images/new_member_02_title_pc.svg"); }
.common_new_member .point_list dl:nth-child(3) dt em{ background-image: url("../images/new_member_03_title_pc.svg"); }
.common_new_member .point_list dl:nth-child(4) dt em{ background-image: url("../images/new_member_04_title_pc.svg"); }
.common_new_member .point_list dd{
height: 40px;
}





/* main_bottom */
#main_bottom_container{
padding-top: 80px;
padding-right: 0px;
padding-left: 0px;
width: 1060px;
margin-right: auto;
margin-left: auto;
display: flex;
justify-content: space-between;
}
#main_bottom_link{
width: 720px;
}
#main_bottom_link ul{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#main_bottom_link li{
margin-bottom: 10px;
width: 355px;
}
#main_bottom_link li a{
padding: 20px;
}

#facebook_plugin {
width: 300px;
}


/* フッター */
#footer {
padding-top: 80px;
}
#footer_description{
font-size: 14px;
padding-bottom: 80px;
}
#footer_sitemap .accordion_title{
}
#footer_sitemap .accordion_title::after{
width: 20px;
height: 20px;
}
#footer_sitemap .accordion_title p{
font-size: 24px;
}
#footer_sitemap dl{
width: 20%;
}


#footer_company{
padding: 80px 0 40px;
}
#footer_company .contents_size > .flex{
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 40px;
}
#footer_logo{
margin-bottom: 0px;
}
#footer_logo a{
display: inline-block;
vertical-align: middle;
}
#footer_logo img{
height: 30px;
margin-bottom: 0px;
margin-right: 10px;
}
#footer_logo p{
display: inline-block;
vertical-align: middle;
text-align: left;
}

#footer_info{
margin-bottom: 0px;
display: flex;
}

#footer_mail{
margin-bottom: 0px;
margin-right: 10px;
}
#footer_mail a{
padding: 0 10px;
line-height: 50px;
}


#footer_shop_list{
margin: 0;
}
#footer_shop_list li .map iframe{
width: 160px;
height: 160px;
}
#footer_shop_list li .text{
display: flex;
justify-content: space-between;
align-items: center;
}
#footer_shop_list li .text .title em{
font-size: 22px;
display: inline-block;
vertical-align: middle;
}
#footer_shop_list li .text .point{
display: inline-block;
vertical-align: middle;
}
#footer_shop_list li .text .point p{
font-size: 10px;
}
#footer_shop_list li .text .detail,
#footer_shop_list li .text .contact,
#footer_shop_list li .text .tel_second{
display: inline-block;
margin-right: 2em;
}
#footer_shop_list li .text .detail a{
font-size: 16px;
font-weight: bold;
}
#footer_shop_list li .text .contact a{
font-size: 16px;
font-weight: bold;
}
#footer_shop_list li .text .tel_second{
font-size: 16px;
font-weight: bold;
}
#footer_shop_list li .tel{
text-align: right;
}
#footer_shop_list li .tel a{
font-size: 30px;
line-height: 1.4;
}

#footer_company .eigyo_area dl{
display: flex;
}
#footer_company .eigyo_area dt{
width: 160px;
padding: 10px;
}



}


/* ブログ施工実例用 ======================================================================================================== */
.main > div.sanplus_works_detail{
padding-top: 20px;
}
.sanplus_works_detail .blog_master_line1,
.sanplus_works_detail .blog_index_td{
display: none;
}


/* PCのみ======================================================================================================== */
@media print and (min-width: 751px), screen and (min-width: 751px){

.main > div.sanplus_works_detail{
width: 760px;
padding-top: 40px;
}

.sanplus_works_detail .blog_main_td{
width: 100%;
}

}



#consultation .alpha h3{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	}
	#consultation .alpha .text{
	text-align: center;
	margin-bottom: 20px;
	}
	#consultation .alpha .text p{
	text-align: left;
	}
	#consultation .alpha h4{
	text-align: center;
	display: inline-block;
	font-size: 18px;
	font-weight: bold;
	}
	#consultation .alpha .count ul{
	}
	#consultation .alpha .count li{
	display: flex;
	align-items: center;
	margin-top: 10px;
	}
	#consultation .alpha .count li em{
	display: block;
	width: 50%;
	text-align: center;
	border: solid 1px #111;
	}
	#consultation .alpha .count li.two_years_ago em{ color: #1c3a51; border-color: #1c3a51; }
	#consultation .alpha .count li.one_years_ago em{ color: #e90042; border-color: #e90042; }
	#consultation .alpha .count li p{
	display: block;
	width: 50%;
	text-align: right;
	}
	#consultation .alpha .count li p span{
	font-size: 30px;
	line-height: 1;
	font-weight: bold;
	}
	#consultation .alpha .count li.year2019 p span{ color: #1c3a51; }
	#consultation .alpha .count li.year2020 p span{ color: #e90042; }

	#consultation .beta .text{
	margin-bottom: 20px;
	}
	#consultation .beta .img{
	margin-bottom: 20px;
	}
    section#consultation {
		padding: 0;
	}
	@media print and (min-width: 751px), screen and (min-width: 751px){
	#consultation .alpha h3{
		font-size: 30px;
		}
		#consultation .alpha .inner{
		display: flex;
		justify-content: space-between;
		}
		#consultation .alpha .text{
		margin-bottom: 0px;
		width: 480px;
		}
		#consultation .alpha .count li{
		justify-content: center;
		}
		#consultation .alpha .count li em{
		width: 200px;
		font-size: 18px;
		margin-right: 20px;
		}
		#consultation .alpha .count li p{
		width: auto;
		font-size: 20px;
		}
		#consultation .alpha .count li p span{
		font-size: 60px;
		}
		#consultation .alpha .img{
		margin-bottom: 0px;
		width: 500px;
		}
		#consultation .alpha .img img{
		max-width: 100%;
		height: auto;
		}


		#consultation .beta .inner{
		display: flex;
		justify-content: space-between;
		margin-bottom: 40px;
		}
		#consultation .beta .text{
		margin-bottom: 0px;
		margin-right: 40px;
		flex: 1;
		}
		#consultation .beta .img{
		margin-bottom: 0px;
		width: 300px;
		}
		#consultation .beta .img img{
		max-width: 100%;
		height: auto;
		}
	}


	/* 241009 オウチノコトメンバーポップアップ非表示（TOPのみ表示→top.cssにも記述追加してます）   ======================================================================================================== */
	div#login_fixed {
	  display: none;
	}

	/* 241202 狭山不動産様　ハンバーガーメニューの改修依頼   ======================================================================================================== */
	/* PCのみ======================================================================================================== */
	.dropdown_btn span{
		display: none;
	}
	/* スマホのみ======================================================================================================== */
@media print and (max-width: 750px), screen and (max-width: 750px){
	.dropdown_btn{
		position: relative;
		cursor: pointer;
	}
	
	.dropdown_btn span{
		font-size: 16px;
		align-items: center;
		display: inline-block;
		position: absolute;
		right: 0;
		margin-right: 20px;
	}

	.dropdown{
		display: none;
	}

	/* 初期状態 */
.toggle_icon {
    display: inline-block; /* 回転を適用するために必要 */
    transition: transform 0.3s ease; /* 回転のアニメーション */
}

/* メニューが開いた状態 */
.dropdown_open .toggle_icon {
    transform: rotate(45deg); /* ＋を×に変える */
}
}