@charset "utf-8";
@import "common.css";

hr {
	margin: 4px 0;
}
#hbgmenu{
	display: none;
}

/* ==========================
	共通要素ここから
==========================*/
.container {
	width: 100%;
	margin: 0 auto;
	background: #fff;
}
.container main{
	overflow-x: hidden;
	overflow-y: clip;/* 2重スクロールバー対策 */
}
.container section {
	display: block;
	width: 100%;
	max-width: 1300px;
	padding: 0 30px;
	margin: 20px auto 60px;
	position: relative;
}

/* ==========================
	全幅レイアウト用の追加設定
==========================*/
/* sectionの最大幅制限とパディング無効化 */
.full_width_section {
	max-width: none !important;
	padding: 0 !important;
	width: 100% !important;
}
/* 固定枠無視して画面100%表示 */
.map_full_stretch {
	width: 100vw !important;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
}
/* 全幅セクション内でもテキストを中央に寄せるための枠 */
.inner_content {
	max-width: 1300px;
	margin: 0 auto;
	padding: 0 30px;
}

/* -----------------------------------
全ページ共通 h2
----------------------------------- */
.h2_section_head {
	width: 100%;
	margin: 40px auto;
	text-align: center;
}
.h2_section_head h2 {
	all: unset !important;
	position: relative !important;
	display: inline-flex !important; /* 中身の幅に合わせるため */
	flex-direction: column !important;
	align-items: center !important;
	gap: 10px !important;
	margin: 0 auto !important;
	padding: 0 40px !important; /* 線用の左右の余白 */
}
.h2_section_head h2 .h2_text {
	font-size:clamp(18px, 17.143px + 0.357vw, 24px);
	font-weight: bold;
	color: #333;
	letter-spacing: 0.2em;
	line-height: 1.2;
}
.h2_section_head h2 .h2_section_en {
	display: inline-block !important;
	font-family: var(--en);
	font-size: 14px !important;
	font-weight:500;
	letter-spacing: 0.15em !important;
	color: var(--maincolor) !important;
	border: 1.5px solid var(--maincolor) !important;
	border-radius: 20px !important;
	padding: 5px 15px !important;
	background:var(--hover_snow);
	text-transform: lowercase;
	line-height: 1;
}
.h2_section_head h2::before,
.h2_section_head h2::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 2px;
	background-color: var(--maincolor);
}
.h2_section_head h2::before {
	left: 0;
}
.h2_section_head h2::after {
	right: 0;
}
.h2_section_head h2 .h2_text::before {
	left: -20px;
}
.h2_section_head h2 .h2_text::after { 
	right: -20px;
}

/* ==========================
	ヘッダーここから
==========================*/
/* -----------------------------------
	ヘッダー大外
----------------------------------- */
header {
	z-index: 999;
	position: sticky;
	top: 0;
	width: 100%;
	height: 70px;
	background-color: rgba( 249, 250, 251, 0.98);
	box-shadow:  0 3px 10px rgba(0, 0, 0, 0.1);
}
header > div{
	position: relative;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: space-between;
	padding-left: 0;
}
/* -----------------------------------
	ヘッダーロゴ
----------------------------------- */
header > div > a.headlogo h1,
#footerabout div.company a.footlogo h1{
	transition: all .3s;
}
header > div > a.headlogo:hover h1,
#footerabout div.company a.footlogo:hover h1{
	opacity: .65;
}
header > div > a h1{
	position: relative;
	top: 0px;
	width: 320px;
	height: 50px;
	margin: 10px auto;
	background-image: url('../images/common/logo.svg');
	background-repeat: no-repeat;	
	background-position: center;
	background-size: contain;
	text-indent: -9999px;
}
/* -----------------------------------
	ヘッダーメインメニュー
----------------------------------- */
/* ｱｺｰﾃﾞｨｵﾝ */
.site_nav {
	display: flex;
	align-items: center;
	gap: 20px;
}
.nav_item {
	position: relative;
}
.nav_btn {
	display: flex;
	align-items: center;
	gap: 5px;
	padding:5px 10px;
	white-space: nowrap;
	letter-spacing:0.2em;
	font-size: 15px;
	font-weight: 500;
	color: var(--blacksub);
	background: none;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: all 0.2s;
}
.nav_btn:hover, .nav_item.open .nav_btn {
	background: var(--hover_bg);
	color: var(--black);
}
.nav_contact {
	padding: 8px 20px;
	letter-spacing:0.1em;
	color:var(--white);
	background:var(--maincolor);
}
.nav_contact:hover {
	color:var(--white);
	background:var(--maindark);
}
.nav_dropdown {
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	min-width: 320px;
	visibility: hidden;
	background: white;
	border: 1px solid #d4edca;
	border-radius: 14px;
	box-shadow: 0 12px 40px rgba(88,170,68,0.15);
	transform: translateY(-8px);
	transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
	z-index: 200;
	overflow: hidden;
	opacity: 0;
}

.nav_item.open .nav_dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.dropdown_inner {
	display: flex;
	gap: 0;
	padding: 20px;
}
.dropdown_col {
	flex: 1;
	padding: 0 14px;
}
.dropdown_col + .dropdown_col {
	border-left: 1px solid #edf7e8;
}

.dropdown_label {
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.15em;
	color:var(--maincolor);
	margin: 20px auto 10px;
	padding-bottom: 5px;
	border-bottom: 1px solid var(--mainlight);
}
.dropdown_link {
	display: block;
	padding: 7px 8px;
	font-weight: 400;
	font-size: 15px;
	color:var(--blacksub);
	text-decoration: none;
	border-radius: 6px;
	transition: all 0.15s;
}
.dropdown_link:hover {
	padding-left: 14px;
	font-weight: 500;
	color: #1a5010;
	background:var(--sublightlight);
}
.dropdown_link i{
	margin-right:5px;
	color:var(--uguisu);
}

/* overlay to close */
.nav_overlay {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 150;
}
.nav_overlay.active {
	display: block;
}

.header_tel {
	display: flex;
	align-items: center;
	padding: 0 20px;
}
.header_tel div{
	display:flex;
	flex-direction:column;
	align-items: center;
	gap:3px;
}
.header_tel div span {
	display: block;
	margin-right:5px;
	padding:2px 5px;
	line-height:1.2em;
	letter-spacing: 0.05em;
	font-weight: 400;
	font-size: 13px;
	color: var(--blacksub);
	background:var(--sublightlight);
}
.header_tel div span i{
	margin-bottom:5px;
	color:var(--mainlight);
}
.header_tel div a{
	display:block;
	padding:2px 9px;
	line-height:1.2em;
	letter-spacing: 0.15em;
	font-weight: 700;
	font-size: 20px;
	color:var(--maincolor);
	border:solid 1px transparent;
	border-radius:5px;
}
.header_tel div a:hover{
	border:solid 1px var(--uguisu_light);
	background:rgba(148,189,112,.2);
}
@media(max-width:1100px){
	.header_tel {
		display: none;
	}
}

/* ハンバーガー：デフォルトは非表示 */
.hamburger { display: none; }
.mobile_nav { display: none; }
.mobile_nav_overlay { display: none; }

@media (min-width: 1101px){
	.site_nav {
		display: flex;
	}
	.hamburger {
		display: none;
	}
	.mobile_nav {
		display: none;
	}
}
/* ========================================
タブレット (768px)
======================================== */
@media (max-width: 1100px) {
/* --- Header --- */
	header {
		padding: 0 5px;
		height: 70px;
	}
	.header_tel span { display: none; }
	.header_tel { font-size: 15px; gap: 4px; }

	/* ナビ非表示 → ハンバーガーに */
	.site_nav {
		display: none;
	}
	.hamburger {
		display: flex;
		flex-direction: column;
		justify-content: center;
		gap: 8px;
		width: 30px;
		height: 30px;
		margin: 18px 5px 0 0; 
		background: none;
		border: none;
		cursor: pointer;
		border-radius: 6px;
		transition: background 0.2s;
	}
	.hamburger:hover {
		background: var(--hover_snow);
	}
	.hamburger span {
		display: block;
		width: 30px;
		height: 3px;
		background: var(--blacksub);
		border-radius: 5px;
		transition: all 0.3s;
	}
	.hamburger.open span:nth-child(1) {
		transform: translateY(14px) rotate(45deg);
	}
	.hamburger.open span:nth-child(2) {
		opacity: 0;
	}
	.hamburger.open span:nth-child(3){
		transform: translateY(-8px) rotate(-45deg);
	}

	/* モバイルナビドロワー */
	.mobile_nav {
		display: block;
		position: fixed;
		top: 60px;
		right: -100%;
		width: 230px;
		height: calc(100vh - 60px);
		padding: 20px 0 40px;
		background: white;
		box-shadow: -4px 0 24px rgba(0,0,0,0.12);
		overflow-y: auto;
		transition: right 0.3s cubic-bezier(0.4,0,0.2,1);
		z-index: 300;
	}
	.mobile_nav.open {
		right: 0;
	}

	.mobile_nav_overlay {
		display: none;
		position: fixed;
		top: 60px;
		inset: 0;
		background: rgba(0,0,0,0.4);
		z-index: 250;
	}
	.mobile_nav_overlay.open {
		display: block;
	}
	.mobile_nav_section {
		padding: 8px 0;
		border-bottom: 1px solid var(--mainborder);
	}

	.mobile_nav_label {
		padding: 10px 24px 6px;
		letter-spacing: 2px;
		font-weight: 700;
		font-size: 17.5px;
		color: var(--maincolor);
	}
	.mobile_nav a {
		display: flex;
		align-items: center;
		gap: 10px;
		padding: 12px 24px;
		text-decoration: none;
		font-size: 14px;
		color: var(--blacksub);
		transition: background 0.15s;
	}
	.mobile_nav a:hover {
		color: var(--maincolor);
		background: var(--hover_snow);
	}
	.mobile_nav a i {
		width: 16px;
		text-align: center;
		color: var(--uguisu_light);
	}

	.mobile_nav_contact {
		display: block;
		margin: 16px 20px 0;
		padding: 13px !important;
		text-align: center;
		font-weight: 500 !important;
		font-size: 14px !important;
		color:var(--white) !important;
		background: var(--maincolor);
		border-radius: 8px;
	}
	.mobile_nav_contact:hover {
		background: #46922e !important;
	}
	.mobile_nav_contact i{
		color:var(--uguisu_highlight) !important;
	}
}
/* ==========================
	ヘッダーここまで
==========================*/
/* ==========================
	フッターここから
==========================*/
footer {
	width: 100%;
	font-size: 15px;
	color:var(--hover_bg);
	background-color:var(--dgreen);
}
footer a{
	color:var(--hover_snow);
}

#footerabout{
	max-width: 1300px;
	margin: auto;
	padding: 30px;
}
@media(max-width:1024px){
	#footerabout{
/*		width: 95％;*/
		margin: auto;
		padding:clamp(5px, -1.000px + 2.5vw, 30px);
	}
}
/* ==========================
 レイアウト
==========================*/
#footerabout .footer_com_info {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 20px;
	align-items: start;
	padding: 60px 2% 40px;
}

.footer_card{
	position: relative;
	background: none;
	border: none;
	box-shadow: none;
	padding: 0;
}
.footer_card:nth-of-type(2) {
	padding: 5px 10px;
	background-color:rgba(255,255,255,.2);
	border-radius:5px;
}
/* -----------------------------------
	フッター 会社
----------------------------------- */
.footer_company{
	padding-right: 10px;
	line-height: 1.5;
	font-size: 14.5px;
}
.footer_company h1 {
	width: 210px;
	height: 44px;
	margin: 0 0 24px;
	background-image: url('../images/common/logo_lowcolor.svg');
	background-repeat: no-repeat;
	background-position: 0 center;
	background-size: contain;
	text-indent: -9999px;
	transition: all .25s;
}
@media(max-width:768px){
	.footer_company h1 {
		width: 190px;
		height: 36px;
		margin: 0 auto 20px;
	}
}
.footer_company h1:hover{
	opacity: 0.5;
}
.footer_company p{
	margin-bottom: 0.6em;
	font-size: 13px;
	line-height: 1.75;
	color: var(--hover_bg);
}
/* -----------------------------------
	フッター メニュー
----------------------------------- */
.footer_nav_wrap{
	flex: 1;
}

.footermenu{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 30px;
	width: 100%;
}
.footermenu h3{
	margin-bottom:5px;
	padding:5px 0.5em;
	letter-spacing:0.2em;
	font-weight:400;
	font-size:15px;
	color:var(--white);
	background-color:rgba(255,255,255,.1);
	border-radius:3px;
}
.footermenu .nav_label{
	padding:2px 0.5em;
	letter-spacing:0.1em;
	font-weight:500;
	font-size:14.5px;
	color:var(--uguisu_light);
	border-bottom:solid 1px var(--uguisu);
}
.footermenu ul{
	width:calc(100% - 10px);
	margin:10px 5px 20px;
	padding:5px 10px;
	gap: 5px;
	background-color:rgba(255,255,255,.2);
	border-radius:5px;
}
.footermenu ul.ul2column{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}
.footermenu ul.ul1column{
	display: grid;
	grid-template-columns: 1fr;
}

.footermenu ul li a{
	display: inline-block;
	padding: 0 0 2px;
	line-height: 1.5;
	font-weight:500;
	color:var(--white);
	position: relative;
}
.footermenu ul li a i{
	margin-right:5px;
	font-size:0.8em;
	color:var(--mainlight);
}

/* hover */
.footermenu ul li a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom:1px;
	width: 0;
	height: 1px;
	background: var(--hover_snow);
	opacity:0.5;
	transition: width 0.25s ease;
}
.footermenu ul li a:hover::after {
	width: 100%;
}
.footermenu ul li a:hover{
	color: var(--white);
}
/* -----------------------------------
	フッターカレンダー
----------------------------------- */
.footer-calendar-wrap {
	max-width: 280px;
	width: 100%;
	margin: 0 auto;
}
.footer-company {
	margin: 20px 0 0;
}
.calendar table{
	width: 100%;
	margin: 10px 0;
}
.cal_holiday span{
	display: none;
}
.calendar caption{
	width: 100%;
	text-align:center;
	font-size:clamp(13px, 12.571px + 0.179vw, 16px);
	letter-spacing: 1px;
	margin-bottom: 5px;
}
.calendar caption > span{
	margin: 0 clamp(10px, 8.720px + 0.533vw, 16px);
	color:var(--white);
}
@media (min-width: 1366px){
	.calendar caption > span{
		margin: 0 16px;
	}
}
@media (min-width: 768px){
	.calendar caption{
		font-size: 16px;
	}
}

.strongmonth{
	padding: 0 2px;
	font-family:var(--en);
	font-weight:600;
	font-size: 26px;
	color:var(--mainlightlight);
}
.calendar caption button{
	padding:0;
	line-height:1;
	font-weight:700;
	font-size:18px;
	color: var(--mainlight);
	background: transparent;
	border: solid 1px transparent;
	border-radius:5px;
	cursor: pointer;
	transition: all .25s;
}
.calendar caption button:hover{
	color:var(--linkcolor);
	background:transparent;
	border:solid 1px var(--maincolor);
}
.calendar table tbody{
	border-right: 1px solid var(--green);
	border-bottom: 1px solid var(--green);
	border-left: 1px solid var(--green);
}

.calendar table tr{
	display: flex;
	border-top: 1px solid var(--green);
}
.calendar table thead tr{
	border-top: none;
	padding-top: 1px;
	padding-bottom: 2px;
}
.calendar table tr > *{
	width: calc(100% / 7);
	font-weight: 400;
	font-size: 13px;
}
:is(.calendar table th,.calendar table td):first-of-type,
.cal_holiday p{
	color: #EB544B;
}
:is(.calendar table th,.calendar table td):last-of-type{
	color: #add5ff;
}
.calendar td{
	position: relative;
	min-height:40px;
}
.calendar td:not(:first-of-type){
	border-left: 1px solid var(--green);
}
.calendar td p{
	text-align:center;
	padding:0;
}
.calendar td i{
	display: block;
	margin:0px 2px 2px 2px;
	padding: 0 0 2px;
	text-align: center;
	font-style: normal;
	font-size:10px;
	color: var(--white);
	background:var(--costred);
	border-radius: 5px;
}
.calendar td br{
	display: none;
}
/* -----------------------------------
	コピーライト
----------------------------------- */
#copyright{
	padding: 15px 20px;
	text-align: center;
	font-size: clamp(13px, 12.857px + 0.06vw, 14px);
	letter-spacing:clamp(1px, 0.857px + 0.06vw, 2px);
	color: rgba(255,255,255,0.8);
	border-top: 1px solid rgba(255,255,255,0.1);
}

/* ==========================
	レスポンシブ
==========================*/
@media(max-width:1100px){
	#footerabout .footer_com_info{
		grid-template-columns: 1fr 1fr;
		gap: 30px;
		justify-items: center;
	}
	.footer-calendar-wrap{
		grid-column: auto;
	}
	.footermenu{
		display: none;
	}
}
@media(max-width:768px){
	#footerabout .footer_com_info{
		grid-template-columns: 1fr;
		gap: 24px;
		padding: 40px clamp(5px, 0.455px + 1.894vw, 15px);
		justify-items: center;
		text-align: center;
	}
	.footer_card{
		width: 100%;
		max-width: 400px;
	}
	/* カレンダー中央寄せ強化 */
	.footer-calendar-wrap{
		margin: 0 auto;
	}
}
/* ==========================
	フッターここまで
==========================*/
/* ==========================
	パンくずここから
==========================*/
#navigate {
	display: flex;
	align-items: center;
	gap: 6px;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin:0;
	padding: 10px 20px;
	background: var(--mainbg);
	border-bottom: 1px solid var(--mainborder);
	font-size: 14px;
	color: var(--blacklight);
}
#navigate a {
	color: var(--maincolor);
	text-decoration: none;
	transition: color 0.2s;
}
#navigate a:hover {
	color: var(--mainlight);
	text-decoration: underline;
}
#navigate span {
	color: var(--blacklight);
}
#navigate .here {
	color: var(--blacksub);
	font-weight: 500;
}
@media(max-width:768px){
	#navigate {
		display:none;
	}
}
/* ==========================
	パンくずここまで
==========================*/
/* -----------------------------------
カレンダー少しだけコンパクト化
----------------------------------- */
.footer-calendar-wrap {
	max-width: 360px; /* ←小さくする */
	font-size: 13px;
}
.strongmonth {
	font-size: 20px;
}
.calendar td {
	min-height: 30px;
}
.calendar td p {
	font-size: 12px;
}
/* -----------------------------------
ナビの詰まり解消
----------------------------------- */
.footermenu ul li a {
	line-height: 1.5;
	font-size: 14px;
}
/* -----------------------------------
全体バランス調整
----------------------------------- */
#footerabout .footer_com_info {
	align-items: flex-start;
}
.footer_company {
	padding-right: 10px;
}
.footer_nav_wrap {
	padding-left: 10px;
}

/* ==========================
	indexここから
============================*/
#index_hero{
	position:relative;
}
#index_hero img{
	width:100%;
	vertical-align: bottom;
}
/*飛び出し1号*/
#index_hero::before {
	content: "";
	position: absolute;
	left:5%;
	top:0px;
	width:90%;
	height:90%;
	aspect-ratio: 1 / 1;
	background-image: url("../images/index/firstview_overtext.svg");
	background-position:center top;
	background-repeat:no-repeat;
	z-index: 4;
	animation: fadeUpAnime 2s forwards;
	animation-delay: 0.3s;
	opacity: 0;
	filter: drop-shadow(1px 1px 2px rgba(163, 119, 91, 0.2));
}
/*飛び出し2号*/
#index_hero::after {
	content: "";
	position: absolute;
	right:9%;
	bottom:9%;
	width:100%;
	height:100%;
	aspect-ratio: 1 / 1;
	background-image: url("../images/index/firstview_overtext_after.svg");
	background-position:center top;
	background-repeat:no-repeat;
	z-index: 3;
	animation: fadeUpAnime 6s forwards;
	animation-delay: 0.3s;
	opacity: 0;
	filter: drop-shadow(1px 1px 2px rgba(163, 119, 91, 0.2));
}

@media (min-width: 769px) {
	#index_hero::before {
		position: absolute;
		left:20%;
		top:0px;
		width:60%;
		background-image: url("../images/index/firstview_overtext.svg");
		background-position:center top;
	}
	#index_hero::after {
		position: absolute;
		left:20%;
		top:0px;
		width:60%;
		background-image: url("../images/index/firstview_overtext_after.svg");
		background-position:center top;
	}
}

@media (min-width: 1366px) {
	#index_hero::before {
		position: absolute;
		left:10%;
		top:0px;
		width:35%;
		background-image: url("../images/index/firstview_overtext.svg");
		background-position:0 0;
	}
	#index_hero::after {
		position: absolute;
		left:10%;
		top:0px;
		width:35%;
	background-image: url("../images/index/firstview_overtext_after.svg");
		background-position:0 0;
	}
}
/* -----------------------------------
	ビッグサーチここから
----------------------------------- */
.search_block {
	padding-top:30px;
	background:var(--white);
	border-bottom: 3px solid #f2fbed;
	box-shadow: 0 8px 40px rgba(88,170,68,0.10);
	position: relative;
	z-index: 10;
}
.search_block_inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0;
}
.search_tabs_big {
	display: flex;
}
.stab {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap:clamp(5px, 4.571px + 0.179vw, 8px);
	margin-bottom: -2px;
	padding:clamp(10px, 8.571px + 0.595vw, 20px) clamp(5px, 4.286px + 0.298vw, 10px);
	line-height:clamp(16px, 15.429px + 0.238vw, 20px);
	letter-spacing: 0.04em;
	text-align: center;
	font-size:clamp(15px, 14.714px + 0.119vw, 17px);
	font-weight: 500;
	font-family: 'Noto Sans JP', sans-serif;
	color:var(--maincolor);
	background:var(--mainborder);
	border: none;
	border-bottom: 3px solid transparent;
	cursor: pointer;
	transition: all 0.2s;
	filter: drop-shadow(2px 2px 3px rgba(111, 111, 111, 0.5));
}
.stab.active {
	color:var(--uguisu_light);
	background:var(--dgreen);
}
.stab:hover {
	border-top: 3px solid var(--maincolor);
	border-bottom: 3px solid var(--maincolor);
}
.stab:hover:not(.active) {
	color:var(--sublight);
	background:var(--uguisu);
}
.stab_icon {
	font-size: 17px;
	width: 20px;
	text-align: center;
}
.search_content {
	padding: 36px clamp(20px, 17.143px + 1.19vw, 40px) 40px;
}
/* -----------------------------------
	ビッグサーチ グリッド
	PC:3列 / iPad:2列 / SP:1列
----------------------------------- */
.search_big_grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 14px;
}
/* 768px以下: 2列 */
@media (max-width: 768px) {
	.search_big_grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
	.sbtn.featured {
		grid-column: span 2;
	}
	.sell_btns {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}
/* 480px以下: 1列 */
@media (max-width: 480px) {
	.search_big_grid {
		grid-template-columns: 1fr !important;
	}
	.sbtn.featured {
		grid-column: span 1;
	}
	.sell_btns {
		grid-template-columns: 1fr !important;
	}
}
.sbtn {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 22px 12px;
	background: #fff;
	border: 2px solid 	var(--maincolor);
	border-radius: 12px;
	text-decoration: none;
	color: #1a4a10;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-size:clamp(15px, 14.571px + 0.179vw, 18px);
	box-shadow: 0 2px 8px rgba(88,170,68,0.08);
	transition: all 0.22s;
	cursor: pointer;
}
.sbtn:hover {
	background: var(--maincolor);
	border-color: var(--maincolor);
	color: #fff;
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(88,170,68,0.3);
}
.sbtn:hover .sbtn_icon,
.sbtn:hover .sbtn_sub {
	color: #fff;
	opacity: 1;
}
.sbtn.featured {
	background: var(--maincolor);
	border-color: var(--maincolor);
	color: white;
	grid-column: span 2;
	flex-direction: row;
	font-size: 15px;
	padding: 22px 24px;
}
.sbtn.featured:hover {
	background: #46922e;
	border-color: #46922e;
}
.sbtn_icon {
	width: 30px;
	line-height: 1;
	text-align: center;
	font-size: 24px;
	color: var(--uguisu);
	transition: color 0.22s;
}
.sbtn:hover .sbtn_icon,
.sbtn_map_wide .sbtn_icon {
	color: var(--sublightlight);
}

.sbtn_label {
	line-height: 1.3;
	text-align: center;
}
.sbtn_sub {
	font-size: 11px;
	font-weight: 400;
	opacity: 0.75;
	margin-top: 2px;
}
.search_divider {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 20px 0 16px;
}
.search_divider::before,
.search_divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: #ddf0d4;
}
.search_divider span {
	font-size:14px;
	font-weight:500;
	color:var(--blacklight);
	letter-spacing: 0.1em;
}
.sell_btns {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
/* hide non-active tabs */
.tab_panel {
	display: none;
}
.tab_panel.active {
	display: block;
}

/* 地図から探す：横幅いっぱいボタン */
.sbtn_map_wide {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	width: 100%;
	padding: 18px 24px;
	margin-bottom: 16px;
	background: linear-gradient(135deg, var(--maincolor), var(--mainlight));
	color: white;
	text-decoration: none;
	border-radius: 10px;
	font-weight: 500;
	font-size: 21px;
	box-sizing: border-box;
	transition: opacity 0.2s, transform 0.2s;
}
.sbtn_map_wide:hover {
	opacity: 0.88;
	transform: translateY(-2px);
	color: white;
}
.sbtn_map_wide .sbtn_icon {
	font-size: 24px;
}
.sbtn_map_wide .sbtn_label {
	text-align: left;
}
.sbtn_map_wide .sbtn_sub {
	margin-top: 2px;
	letter-spacing:0.05em;
	font-size: 13px;
	font-weight: 400;
	opacity: 0.85;
}
/* -----------------------------------
	ビッグサーチｺｺﾏﾃﾞ
----------------------------------- */
/* -----------------------------------
	おすすめｺｺｶﾗ
----------------------------------- */
#index_osusume {
	padding: 60px 0;
	margin: 0 auto;
	width: 85%;
}
/* ブロック間余白 */
.osusume_block {
	margin-bottom: 70px;
}
.osusume_block:last-child {
	margin-bottom: 0;
}

#index_osusume > .osusume_block {
	position: relative;
}
#index_osusume > .osusume_block:first-of-type {
	padding-top: 60px;
}
#index_osusume > .osusume_block:last-of-type {
	padding-bottom: 60px;
}
#index_osusume > .osusume_block::before,
#index_osusume > .osusume_block::after {
	content: '';
	position: absolute;
	display: block;
	width: calc(100vw - 100%);
	height: 48%;
}
#index_osusume > .osusume_block::before {
	background:transparent;
	left: calc(100% + 30px);
	top: 0;
}
#index_osusume > .osusume_block::after {
	background:transparent;
	right: calc(100% + 30px);
	bottom: 0;
}

/*おすすめ切り替えボタン */
.osusume_head {
	position:relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 28px;
	padding:10px;
	background-color:var(--hover_snow);
}
/* 見出しエリア */
.osusume_title {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.osusume_title h2 {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: clamp(18px, 2.5vw, 24px);
	font-weight: 700;
	color: var(--black);
	padding-left: 14px;
	border-left: 4px solid var(--maincolor);
	line-height: 1.3;
}
.osusume_badge {
	position:relative;
	top:2px;
	display: inline-block;
	padding: 2px 10px;
	line-height: 1.6;
	letter-spacing: 0.1em;
	font-family: var(--en);
	font-weight: 700;
	font-size: 13px;
	color: var(--maincolor);
	border: 1.5px solid var(--maincolor);
	border-radius: 20px;
	background-color:rgba(148,189,112,.2);
}
@media (max-width: 480px) {
	.osusume_badge {
		display:none;
	}
}

/* タイトル右側ボタン */
.btn_viewmore {
	display: inline-block;
	padding: 8px clamp(5px, -10.000px + 6.25vw, 20px);
	font-size:13px;
	font-weight:500;
	color:var(--maincolor);
	background-color:var(--white);
	border:1px solid var(--maincolor);
	white-space: nowrap;
	transition: all 0.22s;
}
.btn_viewmore:hover {
	background: var(--maincolor);
	color: #fff;
}

/* 物件リスト */
.osusume_inner {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap:clamp(20px, -0.043px + 2.606vw, 50px);
	width: 100%;
	max-width: 1240px;
	margin: 0 auto 60px;
}
#index_osusume > .osusume_block:first-of-type .osusume_inner {
	margin: 0 auto 120px;
}
#index_osusume > .osusume_block:last-of-type .osusume_inner {
	margin: 0 auto;
}
.osusume_datum{
}
.osusume_cell {
	display: block;
	width: 100%;
	max-width: 100%;
	margin-bottom: 0;
	padding:2px 2px 3px;
	line-height: 1.5;
	color: var(--black);
	background:rgba(255,255,255,1);
	border:solid 1px var(--mainborder);
	filter: drop-shadow(3px 3px 6px rgba(100,100,100,0.2));
	transition: all .25s;
}
.osusume_cell:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 30px rgba(88, 170, 68, 0.18);
	border-color: var(--mainlight);
}
.osusume_datum > span {
	display: none;
}
.osusume_photo {
	width: 100%;
	height: auto;
	overflow: hidden;
	transition: all .25s;
	position: relative;
}
.osusume_photo img {
	width: 100%;
	height: auto;
	object-fit: cover;
	transition: all .25s;
}

.osusume_inner > a:hover .osusume_photo img {
	transform: scale(1.1);
}
.osusume_inner > a .osusume_photo::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0);
	z-index: 1;
	transition: all .25s;
}
.osusume_inner > a .osusume_photo::after {
	content: '\f00e  詳細を見る';
	font-family: 'Noto Sans JP', 'Font Awesome 6 Free', sans-serif;
	position: absolute;
	display: block;
	width: 100%;
	height: 1em;
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 3px;
	text-align: center;
	top: 50%;
	left: 0%;
	transform: translateY(-50%);
	color: transparent;
	z-index: 2;
	transition: all .25s;
}
.osusume_inner > a:hover .osusume_photo::before {
	background: rgba(0, 0, 0, 0.4);
}
.osusume_inner > a:hover .osusume_photo::after {
	color: #fff;
}

:is(.osusume_syubetu-madori, .osusume_cost, .osusume_addr)::before {
	font-family: 'Font Awesome 6 Free';
	font-weight: 700;
	display: inline-block;
	margin-right: 10px;
	min-width: 18px;
	text-align: center;
}
.osusume_syubetu-madori::before {
	content: '\f015';
	color: var(--maincolor);
}
.osusume_cost::before {
	content: '\f157';
	color: var(--maincolor);
}
.osusume_addr::before {
	content: '\f3c5';
	color: var(--maincolor);
}
.osusume_cost span {
	font-size: 18px;
	color: var(--maincolor);
	font-weight: bold;
	line-height: 1.5;
}
.osusume_syubetu-madori,
.osusume_addr,
.osusume_cost,
.osusume_catch {
	font-size: 15px;
	line-height: 1.5;
}
.osusume_info {
	margin-top: 10px;
	padding: 0 clamp(5px, -5.022px + 1.303vw, 20px) 5px;
}
.osusume_info p{
	width:90%;
	margin:0 auto;
}
.osusume_words {
	margin-top: 8px;
	letter-spacing: 1px;
}
.osusume_name {
	width: 100%;
	margin-bottom: 10px;
	padding-bottom: 3px;
	letter-spacing: 1px;
	text-align: center;
	font-size: 1.1em;
	color: var(--maincolor);
	border-bottom: solid 1px var(--maincolor);
}

/* NEWマーク */
.osusume_isnew{
	position: absolute;
	top:5px;
	left:-1px;
	padding: 4px 8px;
	font-size: 11px;
	font-weight: bold;
	color: var(--white);
	background:  #e60023;
	animation: newPulse 1.8s infinite;
	box-shadow: 0 2px 6px rgba(0,0,0,0.2);
	border-radius: 20px;
	z-index: 10;
}
.osusume_isnew::before {
	animation: newPulse 1.8s infinite;
}
@keyframes newPulse {
	0%   { transform: scale(1); opacity: 1; }
	50%  { transform: scale(1.1); opacity: 0.85; }
	100% { transform: scale(1); opacity: 1; }
}
/* NEW!!ｺｺﾏﾃﾞ */

/* レスポンシブ */
/* 768px以下: 2カラム */
@media (max-width: 768px) {
	.osusume_inner {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
}
/* 480px以下: 1カラム */
@media (max-width: 480px) {
	.osusume_inner {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}
/* -----------------------------------
	おすすめｺｺﾏﾃﾞ
----------------------------------- */
/* -----------------------------------
	お知らせｺｺｶﾗ
----------------------------------- */
#indexnews_container {
	background: var(--maincolor);
	width: 100%;
	max-width: initial;
	padding: 40px 0 50px;
	margin: 0 auto;
}
#indexnews_wrap {
	width: 92%;
	max-width: 1240px;
	margin: 0 auto;
}
#indexnews_wrap h2 {
	display:flex;
	flex-direction: column;
	align-items: center;
	gap:10px;
	margin-bottom: clamp(20px, 3.846vw, 45px);
	line-height: 1.25;
	color:var(--sublightlight);
}
#indexnews_wrap h2 span.en {
	padding:0 0.5em;
	font-size: clamp(32px, 6.1538vw, 50px);
	font-weight: 400;
	letter-spacing: 2px;
	border:solid 1px var(--sublightlight);
	border-radius:35px;
}
#indexnews_wrap h2 span:not(.en) {
	font-size: clamp(16px, 3.0769vw, 20px);
	letter-spacing: 1px;
}
#index_news {
	background: #fcfcfc;
	padding-top: clamp(20px, 3.846vw, 35px);
	padding-left: clamp(25px, 4.807vw, 105px);
	padding-right: clamp(25px, 4.807vw, 105px);
	padding-bottom: clamp(20px, 3.846vw, 35px);
	max-height: 280px;
	min-height: 120px;
	overflow-y: auto;
}
#index_news::-webkit-scrollbar {
	width: 20px;
}
#index_news::-webkit-scrollbar-thumb {
	border-top: solid 7px #fff;
	border-right: solid 10px #fff;
	border-bottom: solid 7px #fff;
	background: var(--subcolor);
}
.infotr {
	display: flex;
	border-bottom:1px solid var(--uguisu_light);
	column-gap:50px;
	padding-bottom: 18.5px;
}
.infotr:not(:first-of-type) {
	margin-top: 16.5px;
}
.infotr .info_date {
	width: 120px;
	font-size: 17px;
	font-weight: 500;
	color:var(--maincolor);
	font-family:var(--en);
}
.infotr .info_body {
	width: calc(100% - 160px);
	font-size: 15px;
	line-height: 1.5;
}
.infotr .info_body{
	color:var(--black);
}
.infotr .info_body a{
	position: relative;
	color: var(--black);
}
.infotr .info_body a:after{
	display: inline-block;
	position: absolute;
	right: -24px;
	bottom: 4px;
	content: "\f14c";
	width: 18px;
	height: 18px;
	font-family: "Font Awesome 5 Free";
	font-weight: 700;
	font-size: 18px;
	color: var(--uguisu);
}
.infotr .info_body a:hover,
.infotr .info_body a:hover::after{
	color:var(--maincolor);
}
.infotr .info_body a:hover{
	background-color:var(--sublightlight);
	text-decoration: underline;
}
@media (max-width: 768px) {
	.infotr {
		flex-direction: column;
		column-gap: 0;
		row-gap: 10px;
	}
	.infotr .info_body {
		width: 100%;
		font-size: 14.5px;
	}
	#index_news {
		max-height: 200px;
	}
}
/* -----------------------------------
	お知らせｺｺﾏﾃﾞ
----------------------------------- */
/* ==========================
	indexここまで
==========================*/
/* ==========================
	会社概要ここから
==========================*/
#companybody {
	overflow-x: hidden;
}
.company_hero {
	background: var(--mainbg);
	border-bottom: 3px solid var(--mainborder);
	padding: clamp(40px, 7vw, 80px) 0 clamp(30px, 5vw, 60px);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.company_hero::before {
	content: '';
	position: absolute;
	top: 0; left: 0;
	width: 6px;
	height: 100%;
	background: linear-gradient(to bottom, var(--maincolor), var(--subcolor));
}
.company_hero_inner {
	position: relative;
	z-index: 1;
}

.company_hero_en {
	max-width: 100%;
	overflow: hidden;
	font-family: var(--en);
	font-size: clamp(60px, 12vw, 120px);
	font-weight: 700;
	color: var(--mainborder);
	letter-spacing: 0.1em;
	line-height: 1;
	margin-bottom: -20px;
word-break: break-word;
}
.company_hero_title {
	padding:0 40px;
	letter-spacing:clamp(1px, 0.571px + 0.179vw, 4px);
	line-height: 1.3;
	font-size: clamp(24px, 4vw, 40px);
	font-weight: 700;
	color: var(--black);
}
.company_hero_title::first-letter {
	color: var(--maincolor);
}
.company_hero_sub {
	margin-top: 12px;
	font-size: clamp(13px, 2vw, 16px);
	color: var(--blacklight);
	letter-spacing: 2px;
}

@media (max-width: 768px) {
	.company_hero {
		padding: clamp(40px, 7vw, 80px) 10px clamp(30px, 5vw, 60px);
	}
}

/* 全体 */
#company_info {
	width: 92%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 60px 0 80px;
	display: flex;
	flex-direction: column;
	gap: 70px;
}
#accessmap {
	margin: 0 auto;
}


/* 外観写真 */
.company_photos {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 30px;
}
company_photo_item {
	border-radius: 12px;
	overflow: hidden;
	box-shadow: var(--shadow);
	aspect-ratio:1;
	background: var(--mainbg);
}
.company_photo_item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s;
}
.company_photo_item:hover img {
	transform: scale(1.04);
}
#accessmap div div .company_section_head {
	width: 92%;
	max-width: 1000px;
	margin: 0 auto 20px;
}

/* 会社概要 */
#company_text {
	overflow: hidden;
	box-shadow: var(--shadow_light);
}
#company_text dl {
	display: flex;
	border-bottom: 1px solid var(--mainborder);
}
#company_text dl:last-of-type {
	border-bottom: none;
}

#company_text dl dt {
	width:30%;
	max-width:240px;
	padding: 18px 20px 18px 28px;
	font-weight:500;
	font-size: 15px;
	letter-spacing: 0.2em;
	color: var(--black);
	background: var(--mainbg);
	display: flex;
	align-items: center;
}
#company_text dl dd {
	min-width: 0;
}
#company_text dl dd {
	flex: 1;
	padding: 25px 30px;
	font-size: 15px;
	line-height: 1.8em;
	letter-spacing: 0.1em;
	background:var(--white);
	color: var(--blacksub);
}

#company_text dl dd a {
	position: relative;
	color: var(--blacksub);
	font-weight: normal;
	transition: color 0.2s;
}
#company_text a.company_text_btn{
	display: inline-block;
	margin-top:10px;
	padding: 2px 5px 2px 15px;
	font-size:14px;
	color:var(--maincolor);
	border:solid 1.5px var(--maincolor);
	border-radius:20px;
	box-shadow: var(--shadow_light);
}
#company_text dl dd a.icon_arrow:after{
	display: inline-block;
	position: absolute;
	right: -24px;
	bottom: 4px;
	content: "\f14c";
	width: 18px;
	height: 18px;
	font-family: "Font Awesome 5 Free";
	font-weight: 700;
	font-size: 18px;
	color: var(--uguisu);
}
#company_text dl dd a:hover {
	color: var(--maindark);
}
#company_text a.company_text_btn:hover {
	color:var(--mainborder);
	background:var(--maincolor);
	border:solid 1.5px var(--maincolor);
}

.company_note {
	font-size: 12px;
	color: var(--costred);
	display: block;
	margin-top: 4px;
}
.domain::before {
	content: '@';
}

/* アクセスマップ */
#companymap_wrap {
	border-radius: 12px;
	overflow: hidden;
	box-shadow: var(--shadow);
}
#companymap {
	width: 100%;
	height: clamp(300px, 50vw, 480px);
}

/* -----------------------------------
	レスポンシブ
----------------------------------- */
@media (max-width: 768px) {
	#company_info {
		padding: 40px 0 60px;
		gap: 50px;
	}
	.company_photos {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	#company_text dl{
		display: flex;
		flex-direction: column;
	}
	#company_text dl dt,
	#company_text dl dd{
		width:100%;
		max-width:100%;
	}
	#company_text dl dt {
		min-width: unset;
		padding: 12px 20px;
		font-size: 13px;
	}
	#company_text dl dd {
		padding: 12px 20px 16px;
		font-size: 14px;
		border-top:none;
	}
}
@media (max-width: 480px) {
	.company_hero_en {
		font-size:clamp(30px, 4.000px + 10.833vw, 56px);
	}
	.company_hero_title {
		font-size:clamp(20px, 16.000px + 1.667vw, 24px);
	}
	#company_info {
		width: 95%;
	}
	.sp_font_feature{
		letter-spacing:0px;
	}
}
/* ==========================
	会社概要ここまで
==========================*/
/* ==========================
	お問い合わせここから
==========================*/
.container section#contact{
	padding:0 clamp(20px,3.8461vw,30px);
}
#contactbody main{
	background: linear-gradient(90deg,  #fff 0% 30%, var(--gray) 30%);
	padding-bottom:60px;
}
#contact p,
#form_table {
	width: 95%;
	max-width:1000px;
}
#contact p {
	margin: 0 auto 5px;
	line-height: 1.5;
}
#form_table {
	margin: 20px auto 30px;
}
#form_table dl {
	display: table;
	width: 100%;
	border-collapse: separate;
	border-spacing: 0px 0px;
	padding:15px 20px;
}
@media (min-width: 1025px) {
	#form_table dl:not(:last-of-type) {
		border-bottom:solid 1.5px var(--mainborder);
	}
}
#form_table dt,
#form_table dd {
	display: table-cell;
	vertical-align: middle;
}
#form_table dt {
	width: 30%;
	padding: 8px 15px 8px 40px;
	font-size:clamp(14px, 13.571px + 0.179vw, 17px);
}
#form_table dd {
	width: 70%;
	padding: 8px 30px;
	position: relative;
}
#form_table dd input[type='text'],
#form_table dd input[type='tel'],
#form_table dd input[type='email'],
#form_table dd textarea {
	width: 100%;
	padding: 5px 5px 5px 10px;
	line-height: 30px;
	color: var(--black);
	font-size:clamp(14px,2.6923vw,16px);
	border: 1px solid var(--uguisu);
	border-radius: 2px;
}
#form_table dd textarea {
	height: 8em;
}
#form_table dd button {
	margin: 10px 0;
	padding: 0 20px;
	font-size: 16px;
	border:none;
	background-color: transparent;
}
#form_table dd button.stop,
#form_table dd button.okgo {
	margin-bottom: 20px;
}
#form_table dd button[type='reset'] {
	color: #f00;
}

#contact div.form39 p {
	margin-bottom:1em;
	padding: 0;
	line-height: 1.5;
	letter-spacing: 1px;
	font-size: clamp(15.5px,2.9807vw,17px);
}
/* 説明文の中央よせ */
.intrtext{
	width:90%;
	margin:0 auto;
	font-size:15px;
	line-height: 1.5;
	letter-spacing:0.1em;
}
.intrtext a span{
	color:var(--linkcolor);
}
#contact .intrtext p{
	margin-bottom:10px;
	line-height: 1.5;
}
.intrtext:last-of-type{
	margin-top: 30px;
}
/*必須項目*/
.hissu{
	display: inline-block;
	padding: 2px 8px;
	background: var(--costred);
	color: #fff;
	border-radius: 0;
	font-size: clamp(10.5px,2.0192vw,13px);
	position: relative;
	margin: 0 15px;
}
p .hissu{
	margin:0 10px 0 0;
}

.send-button-wrapper span{
	display:inline-block;
	transition: all 0.3s;
	position: relative;
	text-align: center;
	padding:1rem 2rem;
	cursor: pointer;
}
.send-button-wrapper.okgo span{
	color:var(--green);
}
.send-button-wrapper.stop span{
	color:var(--textred);
}
.send-button-wrapper span::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background-color: rgba(148,189,112,0.2);
	transition: all 0.3s;
}
.send-button-wrapper span:hover::before {
	opacity: 0;
	transform: scale(0.4, 0.4);
}
.send-button-wrapper span::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	opacity: 0;
	transition: all 0.3s;
	border: 1px solid var(--uguisu);
	transform: scale(1.2, 1.2);
}
.send-button-wrapper span:hover::after {
	opacity: 1;
	transform: scale(1, 1);
}
.send-button-wrapper.stop span::before{
	background-color: rgba(170, 34, 52, 0.15);
}
.send-button-wrapper.stop span::after {
	border: 1px solid rgba(170, 34, 52, 0.4);
}
.formlast a{
	color:var(--linkcolor);
	line-height: 1.5;
}
@media(max-width:600px){
	#form_table .formlast > dd{
		padding:0;
	}
	.formlast > dd > div{
		display: flex;
		flex-direction: column;
		margin-top: 20px;
		margin-bottom:20px;
	}
	#form_table dd button.stop, #form_table dd button.okgo{
		margin-bottom:0;
		padding:0;
	}
	#form_table dd button.stop, #form_table dd button.okgo,
	#form_table dd button.stop span, #form_table dd button.okgo span{
		width:100%;
	}
}
#form_table.chkform dl.chklist{
	display:flex;
	flex-direction:column;
	padding:0 10px;
}
#form_table.chkform dl.chklist dt,
#form_table.chkform dl.chklist dd{
	width:100%;
}
#form_table.chkform dl.chklist dt{
	margin-top:25px;
	padding:0 5px 5px;
	line-height:1.5;
	letter-spacing:0.1em;
	font-weight:normal;
	color:var(--uguisu_dark);
	border-bottom:1px solid var(--uguisu_light);
}
#form_table.chkform dl.chklist dd{
	padding:5px 15px;
	line-height:1.5;
}
.backhomelink{
	display: flex;
	justify-content: center;
	width: fit-content;
	margin: 30px auto 0;
	transition: all .25s;
}
.backhomelink:hover{
	color:var(--green);
}
/* お問合わせステップバー */
.progressbar {
	position: relative;
	margin: clamp(20px,3.8461vw,30px) auto 40px;
	padding: 5px 0 10px;
	background:#fff;
	border-radius:50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	box-shadow:var(--shadow);
}
@media(max-width:290px){
	.progressbar {
		display: none;
	}
}
.progressbar li {
	position: relative;
	list-style-type: none;
	text-align: center;
	text-transform: uppercase;
	width: 33.333%;
	color: #999999;
	font-size:14px;
	letter-spacing: 1px;
	counter-increment: steps;
}
.progressbar li:before {
	display: block;
	width: 26px;
	height: 26px;
	margin: 7px auto 2px auto;
	content: '';
	line-height: 26px;
	font-size: 12px;
	text-align: center;
	border-radius: 50%;
	background-color: #e5e5e5;
	content: counter(steps);
	z-index: 2;
	position: inherit;
}
.progressbar li:after {
	position: absolute;
	z-index: 1;
	top: 19px;
	left: -50%;
	width: 100%;
	height: 2px;
	content: '';
	background-color: var(--dgray);
}
.progressbar li:first-child:after {
	content: none;
}
.progressbar li.active,
.progressbar li.complete{
	color: var(--maindark);
}
.progressbar li.active:before,
.progressbar li.complete:before {
	background-color: var(--green);
	color:var(--white);
}
.progressbar li.active:after,
.progressbar li.complete:after {
	background-color: var(--green);
}
/* 入力ヒント */
.form_hint {
	color: var(--costred);
	font-size:14px;
	display: block;
	opacity: 0;
	position: absolute;
	top: -1.25em;
	transition: all .2s;
}
#form_table input:focus + .form_hint {
	opacity: 1;
}
@media(max-width:1024px){/* dtとddを横並びから縦並びにするポイント */
	#form_table dd {
		display: flex;
		flex-direction: column-reverse;
		gap: 5px;
	}
	.form_hint {
		font-size:13px;
		position: initial;
		top: initial;
		display: none;
	}
	#form_table input:focus + .form_hint {
		display: block;
	}
}
/* ==========================
	お問い合わせここまで
==========================*/
/* ==========================
	プライバシーポリシーここから
==========================*/
.container section#privacy{
	padding:0 clamp(20px,3.8461vw,30px);
}
#privacybody main{
	background: linear-gradient(90deg,  #fff 0% 20%, var(--gray) 20%);
	padding-bottom:60px;
}
#privacy > div.privacy_sec {
	margin-bottom:200px;
}
#privacy > div > p{
	margin-bottom:10px;
	line-height: 1.5;
	letter-spacing:0.2em;
	text-align:center;
	font-size:clamp(16px, 15.571px + 0.179vw, 19px);
}
#privacy_list > div{
	display: flex;
	flex-direction: column;
	position: relative;
	margin-top:40px;
	gap:10px;
}
#privacy_list > div > span{
	padding-left:5px;
	letter-spacing:3px;
	font-weight:bold;
	font-size:clamp(24px,4.6153vw,32px);
	color:var(--uguisu_dark);
	border-bottom:1px solid var(--uguisu);
}
#privacy_list > div > p,
#privacy_list > ol{
	font-size:clamp(14px, 13.857px + 0.06vw, 15px);
	line-height:1.75em;
	letter-spacing:0.1em;
}
#privacy_list > div > p{
	padding:0 15px;
}
#privacy_list > ol{
	margin: 15px 0;
	padding:0 20px;
}
#privacy_list > ol > li{
	margin-bottom:10px;
}
#privacy_list ul{
	margin-top:10px;
	margin-left:30px;
	list-style-type:circle;
	color:var(--uguisu_dark);
	font-size:14.5px;
	line-height: 1.5;
	letter-spacing: .5px;
}
#privacy_list ul li a{
	position: relative;
	color: var(--black);
}
#privacy_list ul li a:after{
	display: inline-block;
	position: absolute;
	right: -24px;
	bottom: 4px;
	content: "\f14c";
	width: 16px;
	height: 16px;
	font-family: "Font Awesome 5 Free";
	font-weight: 700;
	font-size: 15px;
	color: var(--uguisu);
}
#privacy_list ul li a:hover{
	color:var(--maincolor);
}
/* ==========================
	プライバシーポリシーここまで
==========================*/
/* ==========================
	物件一覧ここから
==========================*/
span.cb_subttl{
	display: inline-block;
	font-size: clamp(15px,2.8846vw,30px);
}
.total_num {
	display: flex;
	justify-content: right;
	align-items: center;
	position: relative;
	width: 100%;
	margin:15px 0 30px;
	font-size: 15px;
	color: var(--black);
	text-align: right;
}
.total_num > span{
	display: inline-block;
	position: relative;
	padding-left: 2em;
	padding-right: 1.5em;
	text-align: center;
	line-height: 1.5;
}
.total_num > span::before{
	font-family: 'Font Awesome 6 Free';
	font-weight: 700;
	display: inline-block;
	margin-right:10px;
	min-width: 18px;
	text-align: center;
	content: '\f03a';
	color: var(--maincolor);
}
.total_num > span >span{
	display: inline-block;
}
@media(min-width:521px){
	.navi_pages{
		display: none !important;
	}
}
/* -----------------------------------
	並び替えボタン
----------------------------------- */
.order_button {
	width: 100%;
	margin-bottom: 20px;
}
.order_button label,
.order_button input {
	display: none;
}
.order_button ul {
	list-style-type: none;
	width: 100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 15px;
}
.order_button ul li {
	display: inline-block;
}
.order_button button {
	width: 100%;
	letter-spacing: 1px;
	background-color:var(--white);
	border: 1.5px solid var(--uguisu_dark);
	border-radius:10px;
	filter:drop-shadow(1px 3px 3px rgba(0, 0, 0, 0.1));
}
.order_button button span{
	display:inline-block;
	font-size: 15px;
	color:var(--black);
	transition: all 0.25s;
	position: relative;
	text-align: center;
	padding:8px 20px;
	border-radius:10px;
	cursor: pointer;
	z-index: 2;
}
.order_button button span:hover{
	color:#fff;
	background:var(--uguisu_dark);
}

/* 物件情報ページネーション */
div.navi {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width:600px;
	max-height: 52px;
	margin:0 auto 20px;
	padding:5px;
	background:var(--white);
	border: 1px solid var(--mainborder);
	border-radius:20px;
	cursor: pointer;
	transition: all 0.2s;
}
.navi a,
.navi span,
.navi i {
	display: inline-flex;
	align-items: center;
	height: 100%;
}
.navi_prev,
.navi_number,
.navi_pages,
.navi_next {
	display: flex;
	align-items: center;
}
div.navi_prev,
div.navi_next,
div.navi_number {
	display: block;
}
div.navi_prev,
div.navi_next {
	font-size: 15px;
	font-weight:bold;
}
div.navi_next {
	text-align: right;
}
div.navi_prev a,
div.navi_next a {
	display: inline-block;
	margin: 0 5px;
	padding: 6px 10px;
	font-weight: bold;
	color: var(--maincolor);
	background:transparent;
	border:1px solid transparent;
	border-radius: 50%;
	line-height:1;
	transition: all .25s;
}
div.navi_number {
	flex-grow: 1;
	text-align: center;
	font-size: 14px;
	font-family: var(--en);
	line-height: 1;
}
div.navi_number span,
div.navi_number a {
	display: inline-block;
	margin: 0 5px;
	padding:9px 5px 0;
	color: var(--blacksub);
	border-radius: 50%;
	border:2px solid var(--uguisu);
	transition: all .25s;
	border-radius:50%;
	line-height:1;
}
div.navi_number span {
	color: var(--white);
	background-color: var(--uguisu);
	border-left: 2px solid var(--uguisu);
	border-right: 2px solid var(--uguisu);
	border-top: 2px solid var(--uguisu);
	border-bottom: 2px solid var(--uguisu);
	border-radius:50%;
}

/*
ページネーションの表示数を制限するCSSここから
 （:has()が使えるようになったので試験運用）
※レスポンシブのブレイクポイント箇所は768pxと420pxの2箇所に有り。
520pxでdiv.navi_prev a, div.navi_next aをいったん非表示にしてます。
*/
div.navi_number a{
	display:none;
}
div.navi_number a:first-child,
div.navi_number a:last-child,
div.navi_number span +a,
div.navi_number span +a+a,
div.navi_number a:has(+span),
div.navi_number a:has(+a+span){
	display:inline-block;
}
div.navi_number a:first-child{
	margin-right:20px;
	position:relative;
}
div.navi_number a:first-child::after{
	content: '...';
	display: inline-block;
	pointer-events: none;
	position: absolute;
	right: -17px;
}
div.navi_number a:first-child:hover::after{
	color:initial;
}
div.navi_number a:first-child:has(+span),
div.navi_number a:first-child:has(+a+span){
	margin-right:5px;
}
div.navi_number a:first-child:has(+span)::after,
div.navi_number a:first-child:has(+a+span)::after{
	content: none;
}
div.navi_number a:last-child{
	margin-left:20px;
	position:relative;
}
div.navi_number a:last-child::before{
	content: '...';
	display: inline-block;
	pointer-events: none;
	position: absolute;
	left: -17px;
}
div.navi_number a:last-child:hover::before{
	color: initial;
}
div.navi_number span +a:last-child,
div.navi_number span +a+a:last-child{
	margin-left:5px;
}
div.navi_number span +a:last-child::before,
div.navi_number span +a+a:last-child::before{
	content: none;
}
/*ページネーションの表示数を制限するCSSここまで*/

div.navi_prev a:hover,
div.navi_next a:hover,
div.navi_number a:hover {
	background-color: var(--dgreen);
	border:2px solid var(--dgreen);
	color:var(--white);
	filter: var(--shadow);
}
/* 下側のページネーション */
.footnavi-wrap{
	display: block;
	width:100%;
}
div.navi.footnavi{
	margin:0  auto 40px;
}
/* 登録なしの１文 */
.no-num {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 100%;
	min-height: 200px;/* フッターの下に虚無が生まれるの防止 */
	margin-bottom: 30px;
	font-size: clamp(15px,2.8846vw,17.5px);
	color: var(--costred);
}
.no-num > span{
	display: inline-block;
	position: relative;
	text-align: center;
	line-height:1.5;
}
.no-num::before,
.no-num::after{
	display: inline-block;
	width: 80px;
	height:30px;
}

/* ==========================
	物件一覧 CSS（clist / blist 共通）
	osusumeカードデザイン合わせ
==========================*/
/* 物件一覧section部分 */
.cblist {
	width: 92%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 0 80px;
}

/* 件数・並び順表示 */
.total_num {
	font-size: 14px;
	color: var(--blacklight);
	margin-bottom: 16px;
}
.total_num span span {
	font-size: 13px;
	color: var(--blacklight);
}

/* 並び順ボタン */
.order_button {
	margin: 20px 0;
}
.order_button label {
	display: block;
	padding: 5px;
	text-align: center;
	font-size: 15px;
	color: var(--sublight);
	background: var(--uguisu_dark);
	border: 1.5px solid var(--uguisu_dark);
	border-radius: 20px;
	filter:drop-shadow(2px 3px 3px rgba(0, 0, 0, 0.1));
	cursor: pointer;
	transition: all 0.2s;
}
.order_button label:hover {
	color: var(--maindark);
	background: var(--sublightlight);
	filter:drop-shadow(1px 2px 2px rgba(0, 0, 0, 0.2));
}
.order_button input[type="checkbox"] {
	display: none;
}
.order_button .clist_grid {
	display: none;
	flex-wrap: wrap;
	gap: 8px;
	padding: 12px 0 4px;
}
.order_button input[type="checkbox"]:checked + .clist_grid {
	display: flex;
}


/* ページナビ */
.navi {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 28px;
	flex-wrap: wrap;
}
.navi_prev,
.navi_next {
	font-size: 18px;
}
.navi_prev a,
.navi_next a,
.navi_number a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 6px;
	color: var(--maincolor);
	border: 1.5px solid var(--mainborder);
	font-size: 13px;
	font-weight: 700;
	transition: all 0.2s;
}
.navi_number a:hover,
.navi_prev a:hover,
.navi_next a:hover {
	background: var(--maincolor);
	color: #fff;
	border-color: var(--maincolor);
}
.navi_number span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 6px;
	background: var(--maincolor);
	color: #fff;
	font-size: 13px;
	font-weight: 700;
}

/* 物件カードgrid */
.cblist_inner {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
/* 物件カード */
.cblist_link {
	display: block;
	width: 100%;
	max-width: 100%;
	margin-bottom: 0;
	padding:2px 2px 3px;
	line-height: 1.5;
	color: var(--black);
	background:rgba(255,255,255,1);
	border:solid 1px var(--mainborder);
	filter: drop-shadow(3px 3px 6px rgba(100,100,100,0.2));
	transition: all .25s;
}
.cblist_link:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 30px rgba(88, 170, 68, 0.18);
	border-color: var(--mainlight);
}
.cblist_tbl {
	display: flex;
	flex-direction: column;
	height: 100%;
}

/* 写真 */
.cblist_photo {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--mainbg);
}
.cblist_photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s;
}
.cblist_link:hover .cblist_photo img {
	transform: scale(1.06);
}
/* UXアイコン（動画/VRなど） */
.uxicon {
	position: absolute;
	bottom: 5px;
	right: 10px;
	font-size: 13px;
	padding: 3px 10px;
	border-radius: 20px;
	background: rgba(0,0,0,0.55);
	color: #fff;
	letter-spacing: 0.05em;
	z-index: 1;
}
/* テキストエリア */
.cblist_list {
	padding:clamp(5px, 3.429px + 0.655vw, 16px);
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1;
}
.cblist_list dl dd{
	width: 90%;
	margin: 0 auto;
}
.bukken_name {
	width: 100%;
	margin-bottom: 10px;
	padding-bottom: 3px;
	letter-spacing: 1px;
	text-align: center;
	font-size:clamp(16px, 15.714px + 0.119vw, 18px);
	color: var(--maincolor);
	border-bottom: solid 1px var(--maincolor);
}
:is(.bukken_syubetu-madori, .bukken_cost, .bukken_addr)::before {
	font-family: 'Font Awesome 6 Free';
	font-weight: 700;
	display: inline-block;
	margin-right: 10px;
	min-width: 18px;
	text-align: center;
}
.bukken_syubetu-madori::before {
	content: '\f015';
	color: var(--maincolor);
}
.bukken_cost::before {
	content: '\f157';
	color: var(--maincolor);
}
.bukken_addr::before {
	content: '\f3c5';
	color: var(--maincolor);
}
.bukken_cost span.cost {
	font-size: 18px;
	color: var(--maincolor);
	font-weight: bold;
	line-height: 1.5;
}
.bukken_catch {
	margin-top: 3px;
	padding: 5px;
	line-height: 1.25em;
	text-align:center;
	font-weight:500;
	font-size: 15px;
	color: var(--maindark);
	background: var(--hover_snow);
}

/* ==========================
	地図検索ｺｺｶﾗ
==========================*/
.cmap_section {
	max-width: 1300px;
	padding: 0 30px;
	margin: 20px auto 0px !important;
}

/* 絞り込み */
.cmap_filter {
	background: var(--mainbg);
	border: 1.5px solid var(--mainborder);
	border-radius: 12px;
	padding: 20px 25px;
}
.cmap_filter_inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-around;
	gap: 8px 20px;
}
.cmap_filter_row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
}
.cmap_filter_label {
	white-space: nowrap;
	font-weight: 500;
	color:var(--maindark);
}
.cmap_filter_checks {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	fomt-size:15px;
}
.cmap_filter_checks label {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	white-space: nowrap;
}
.cmap_select {
	max-width: 140px;
	height: 42px;
	padding: 0 12px;
	border: 1px solid #ccc;
	border-radius: 6px;
	background: #fff;
	font-size: 14px;
}
.cmap_filter_sep {
	display: inline-block;
	padding: 0 4px;
}
.cmap_select {
	padding: 6px 10px;
	font-size: 13px;
	border: 1.5px solid var(--mainborder);
	border-radius: 6px;
	background: #fff;
	color: var(--blacksub);
	cursor: pointer;
	transition: border-color 0.2s;
}
.cmap_select:focus {
	outline: none;
	border-color: var(--maincolor);
}
/* ボタン下中央 */
.cmap_filter_actions {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin-top: 6px;
}
.cmap_filter_btn,
.cmap_filter_clear {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	height: 46px;
	padding: 0 15px;
	font-size: 14px;
	color:var(--blacksub);
	border-radius: 6px;
	box-sizing: border-box;
	text-decoration: none;
}
.cmap_filter_btn {
	background: var(--mainborder);
	border: 1px solid var(--maincolor);
	cursor: pointer;
}
.cmap_filter_btn i{
	margin-right:10px;
}
.cmap_filter_btn:hover {
	color:var(--white);
	background: var(--maincolor);
}
.cmap_filter_clear {
	background: #f3f3f3;
	border: 1px solid #ccc;
	color: #333;
}
.cmap_filter_clear:hover {
	background: #e9e9e9;
	color: #111;
}
@media (max-width: 768px) {
	.cmap_filter_inner {
		display: block;
	}
	.cmap_filter_row {
		margin-bottom: 14px;
	}
	.cmap_filter_actions {
		justify-content: center;
		flex-wrap: wrap;
	}
	.cmap_filter_btn,
	.cmap_filter_clear {
		width: 100%;
		max-width: 280px;
	}
}

@media (max-width: 480px) {
	.cmap_select {
		padding: 6px 25px;
	}
	.cmap_filter_checks {
		padding-bottom:15px;
		border-bottom: dashed 2px var(--uguisu_light);
	}
	.cmap_filter_row {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 10px 14px;
		justify-content: center;
	}
	.cmap_filter_selects {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 4px;
	}
	.cmap_filter_selects .cmap_select {
		width: 100%;
		max-width: 240px;
	}
	.cmap_filter_sep {
		display: none; /* 〜 を消す */
	}
	/* バランス悪いのでテキストで補足 */
	.cmap_filter_selects::before {
		content: "最低賃料";
		font-size: 12px;
		color: #666;
	}
	.cmap_filter_selects::after {
		content: "最高賃料";
		font-size: 12px;
		color: #666;
	}
}

/* ピン凡例 */
.cmap_legend {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 15px;
	margin:10px 2px;
	font-size: 13px;
	color: var(--blacksub);
}
.cmap_legend span {
	display: flex;
	align-items: center;
	gap: 6px;
}
.cmap_legend img {
	height: 40px;
	width: auto;
}

/* 地図本体 */
/* 地図だけ外へ広げる */
#search_map {
	width: 100vw;
	height: calc(100vh - 220px);
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}
/* 地図上の余白調整 */
.cmap_legend {
	margin-bottom: 15px;
}
@media (max-width: 768px) {
	#search_map {
		height: calc(100vh - 180px);
	}
}

/* 吹き出し */
.balloon {
	font-size: 13px;
	line-height: 1.5;
	width: 100%;
	min-width: 0;
	max-width: 320px;
	color: var(--blacksub);
}
.balloon_card {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	width: 100%;
	padding: 6px 0 !important;
	border-bottom:dashed 2px var(--uguisu_light);
	box-sizing: border-box;
}
.balloon_thumb {
	flex: 0 0 76px;
	width: 76px;
	height: 76px;
	display: block;
	overflow: hidden;
	background: #f5f5f5;
	border: 1px solid #e5e5e5;
}
.balloon_thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.balloon_body {
	flex: 1 1 auto;
	min-width: 0;
}
.balloon_title_wrap {
	margin-bottom: 6px;
}
.balloon_type {
	margin: 0 0 2px;
	font-size: 11px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--maincolor);
}
.balloon_title {
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.25;
	color: var(--black);
	word-break: break-word;
}
.balloon_addr,
.balloon_madori,
.balloon_cost {
	margin:0 0 1px;
	font-size: 12px;
	line-height: 1.15;
	word-break: break-word;
}
.balloon_addr {
	color: var(--blacksub);
}
.balloon_madori {
	color: var(--blacklight);
}
.balloon_cost {
	font-size: 13px;
	font-weight: 700;
	color: var(--costred);
}
.balloon_link {
	display:flex;
	align-items: center;
	justify-content: center;
	margin-top: 5px;
	padding: 5px 12px;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	text-decoration: none;
	background: var(--maincolor);
	border: 1px solid var(--maindark);
	border-radius: 999px;
	transition: 0.2s;
}
.balloon_link:hover {
	background: var(--maindark);
	color: #fff;
}
/* Google Maps InfoWindow 内の余白や横幅を調整 */
.gm-style .gm-style-iw-c {
	padding: 0px 10px 8px !important;
	border-radius: 12px !important;
	max-width: 340px !important;
}
.gm-style .gm-style-iw-d {
	overflow: hidden !important;
	max-width: 320px !important;
}
.gm-style .gm-style-iw-ch {
	padding: 0 !important;
	margin: 0 !important;
	height: 0 !important;
}
/* 閉じるボタンの押しやすさ確保 */
.gm-ui-hover-effect {
	top: 4px !important;
	right: 4px !important;
	opacity: 1 !important;
}
.balloon_addr i {
	margin-right:2px;
	color: var(--uguisu);
	font-size: 13px;
}
@media (max-width: 768px) {
	.balloon {
		max-width: 280px;
	}
	.balloon_card {
		gap: 10px;
	}
	.balloon_thumb {
		flex: 0 0 68px;
		width: 68px;
		height: 68px;
	}
	.balloon_title {
		font-size: 13px;
	}
	.balloon_addr,
	.balloon_madori,
	.balloon_cost {
		font-size: 11.5px;
	}
	.balloon_link {
		padding: 6px 10px;
		font-size: 11px;
	}
}
/* -----------------------------------
	閉じるボタン調整
----------------------------------- */
/* ボタン本体 */
.gm-ui-hover-effect {
	display: flex !important;
	justify-content: center;
	align-items: center;
	width: 26px !important;
	height: 26px !important;
	top: 15px !important;
	right: 0px !important;
	background: rgba(204, 204, 204, 0.85) !important;
	border-radius: 50%;
	opacity: 1 !important;
	box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
/* ×アイコン */
.gm-ui-hover-effect span {
	margin: 0 !important;
}
.gm-ui-hover-effect:hover {
	background: #bbb;
}

@media (max-width: 768px) {
	.cmap_section {
		width: 95%;
		padding: 30px 5px 0px !important;
	}
	.cmap_filter {
		padding: 18px 16px;
	}
	.cmap_filter_inner {
		flex-direction: column;
		align-items: flex-start;
	}
	.cmap_filter_row {
		flex-wrap: wrap;
	}
	#search_map {
		height: clamp(300px, 80vw, 500px);
	}
}
/* -----------------------------------
	賃貸地図検索ｺｺﾏﾃﾞ
----------------------------------- */
/* 物件なし */
.no-num {
	padding: 60px 0;
	color: var(--blacklight);
	font-size: 15px;
}
/* フッターナビ */
.footnavi-wrap {
	grid-column: 1 / -1;
	padding-top: 20px;
}
.footnavi {
	justify-content: center;
}
/* -----------------------------------
	レスポンシブ ２列１列
----------------------------------- */
/* max:1024 2カラム */
@media (max-width: 1024px) {
	.cblist_inner {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
}
@media (max-width: 768px) {
	.cblist_inner {
		gap:clamp(10px, -8.764px + 3.745vw, 20px);
	}

}
/* max:500 1カラム */
@media (max-width: 500px) {
	.cblist {
		width: 95%;
		padding: 0 clamp(7.5px, -36.346px + 18.269vw, 55px) !important;
	}
	.cblist_inner {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.cblist_link {
		display: flex;
	}
	.cblist_photo {
		width: 100%;
		min-width: 120px;
		aspect-ratio: unset;
	}
	.cblist_list {
		padding: 10px 12px;
	}
	.bukken_cost .cost {
		font-size: 16px;
	}
}
/* ==========================
	物件一覧ここまで
==========================*/
/* ==========================
	物件詳細ここから sp版含む
==========================*/
#meisaibody main{
	background: linear-gradient(90deg,  #fff 0% 20%, var(--gray) 20%);
	padding-bottom:60px;
}
.container main#meisai_article h1 {
	position: relative;
}
.container section#meisai{
	margin:0 auto 60px;
}
.kousinbi{
	font-size:clamp(13px,2.3076vw,15px);
}
#meisai p {
	margin-bottom: 10px;
}
#meisai p.meisai_catch {
	margin-top: 1.5em;
	margin-bottom: 40px;
	letter-spacing: 1px;
	line-height:1.5;
	font-size: clamp(15px,2.8846vw,17.5px);
	color: var(--black);
	position: relative;
	padding: 20px;
	border-radius: 15px;
	background: #fff;
	filter: var(--shadow_short);
}
#meisai p.meisai_catch i{
	color:var(--maincolor);
	font-size:1.15em;
	margin-right:5px;
}
#goback {
	margin-bottom: 10px;
}
#goback button {
	padding: 10px 20px;
	font-weight: 400;
	font-size: clamp(15px,2.8846vw,16px);
	background-color: var(--maincolor);
	color:#fff;
	border-radius: 5px;
	border:none;
	transition: all .25s;
	cursor: pointer;
	margin-top: 20px;
	box-shadow: var(--shadow);
}
#goback button:hover {
	background-color: var(--maindark);
}
.toiawasebtn{
	display: flex;
	width:100%;
	margin-right: 0;
	margin-bottom: 20px;
	justify-content: flex-end;
}
.toiawasebtn button{
	padding: 10px 20px;
	font-size:clamp(15px, 14.571px + 0.179vw, 18px);
	color:#fff;
	background:var(--maincolor);
	border: none;
	border-radius: 5px;
	filter:drop-shadow(3px 3px 3px rgba(99,99,99, 0.3));
	cursor: pointer;
	transition: all .25s;
}
.toiawasebtn button:hover{
	background: var(--maindark);
	border: none;
}
.meisai-top-container{
	display: flex;
	flex-direction: row-reverse;
	flex-wrap: wrap;
	justify-content: space-between;
	column-gap:2%;
	margin-bottom:40px;
}
.meisai-topinfo-container{
	width:55%;
	flex-grow: 1;
}
.meisai_topinfo_photo{
	width:40%;
}
.meisai-topinfo-wrap{
	padding:20px 20px 15px;
	border-bottom:3px solid var(--uguisu_light);
}
.meisai-topinfo-wrap dl{
	display: flex;
	column-gap: 20px;
	margin-bottom:10px;
	align-items: baseline;
}
.meisai-topinfo-wrap dl dt{
	font-size:15px;
	letter-spacing: 1px;
	white-space: nowrap;
}
.meisai-topinfo-wrap dl dt::before{
	font-family: 'Font Awesome 6 Free'; /* 追記したコード */
	font-weight: 700; /* 追記したコード */
	color: var(--uguisu);
	font-size:20px;
	display: inline-block;
	width:24px;
	text-align: center;
	transition:all .25s;
	margin-right: 10px;
}
.topinfo-syozai dt::before{
	content: '\f3c5';
}
.topinfo-madori dt::before{
	content: '\f015';
}
.meisai-topinfo-wrap .topinfo-tinryou dt::before{
	content: '\f157';
	color:var(--costred);
}
.meisai-topinfo-wrap dl dd{
	font-size:clamp(15px, 13.714px + 0.536vw, 24px);
	letter-spacing: 1px;
}
.meisai-topinfo-wrap dl dd span.cost{
	color:var(--costred);
	font-size: clamp(20px,3.8461vw,32px);
	font-weight:700;
	margin-right:5px;
}
.meisai-subinfo-wrap{
	display: flex;
	width:95%;
	max-width:700px;
	margin:30px auto;
	flex-wrap: wrap;
	justify-content: flex-start;
	column-gap:4%;
}
.meisai-subinfo-wrap dl{
	width:48%;
	margin-bottom:25px;
	padding:10px;
	border-radius:10px;
	background:#f2f2f2;
	color:#afafaf;
	text-align: center;
}
.meisai-subinfo-wrap dl.hasinfo{
	background:var(--mainlight);
	color:var(--sublightlight);
}
.meisai-subinfo-wrap dl dt{
	font-size:clamp(13px,2.5vw,14px);
	letter-spacing: 1px;
}
.meisai-subinfo-wrap dl dd{
	font-size:clamp(15px,2.8846vw,17px);
}
.meisai_body {
	width: 100%;
	margin-bottom: 60px;
	background: #fff;
	border: 1px solid #f3f3f3;
	font-size: 14px;
	border-collapse: collapse;
	box-shadow: 0 0 15px rgba(180,180,180,.10) ;
}
.meisai_body th{
	padding: 15px;
	border-bottom: solid 1px var(--white);
	font-weight: 400;
	/*background: #f9fafb;*/
	background: var(--hover_bg);
}
.meisai_body td {
	padding:15px;
	border-bottom: solid 1px var(--uguisu_light);
}
.meisai_body td button {
	display: inline-block;
	padding: 10px 20px;
	font-size: 16px;
	border: none;
	border-radius: 3px;
	letter-spacing: 1px;
	color:#fff;
	background-color: var(--maincolor);
	transition: all .25s;
	cursor: pointer;
}
.meisai_body td button:hover{
	background-color: var(--maindark);
}
p.genkyou{
	line-height:1.5;
	font-size:clamp(14px,2.6923vw,15px);
}
#meisai_photo,
#meisai_moviebox,
#meisai_vrbox,
#meisai_photo_thumb {
	width: 100%;
	margin: 0 auto;
}
#meisai_moviebox,
#meisai_vrbox {
	text-align: center;
}
#meisai_photo {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: space-between;
}
#meisai_photo p {
	display: block;
	width: 95%;
	text-align: center;
}
@media(max-width:786px){
	#meisai_photo {
		justify-content: center;
		gap:20px;
	}
	#meisai_photo p {
		display: block;
		width: 100%;
		text-align: center;
	}
}

#meisai_photo p.displaynone{
	display: none;/* 登録写真がない時の空要素のレイアウト崩し予防 */
}
#meisai_photo p a:hover img{
	transform: scale(1.05);
}
#meisai_photo p:first-of-type{
	margin-bottom:20px;
}
#meisai_photo p img {
	width: 100%;
/*	max-width: 320px;*/
	object-fit: cover;
	margin: 0 auto;
	transition: all .25s;
	box-shadow:var(--shadow);
}
#meisai_photo_thumb{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	column-gap:2%;
	row-gap:10px;
	overflow: hidden;
	max-width: 900px;/* なんとなくの数値です */
	padding:20px;
	margin-bottom:40px;
	background:var(--gray);
}
#meisai_photo_thumb a:hover img{
	transform: scale(1.1);
}
#meisai_photo_thumb a{
	width:15%;
	height:auto;
	box-shadow:var(--shadow);
}
#meisai_photo_thumb img {
	width: 100%;
	display: block;
	object-fit: cover;
	transition: all .25s;
}

/* タブレットは lightbox の上に前へ・次へを表示 */
@media (hover: none) and (pointer: coarse) {
	#lightbox-nav {
		opacity: 1 !important;
		display: block !important;
	}
	#lightbox-nav-btnPrev,
	#lightbox-nav-btnNext {
		display: block !important;
		opacity: 1 !important;
		visibility: visible !important;
	}
	#lightbox-nav-btnPrev {
		left: 0 !important;
	}
	#lightbox-nav-btnNext {
		right: 0 !important;
	}
	/* 押しやすく */
	#lightbox-nav-btnPrev,
	#lightbox-nav-btnNext,
	#lightbox-secNav-btnClose {
		min-width: 44px;
		min-height: 44px;
	}
	#lightbox-container-image:hover #lightbox-nav,
	#lightbox-container-image:hover #lightbox-nav-btnPrev,
	#lightbox-container-image:hover #lightbox-nav-btnNext {
		opacity: 1 !important;
		visibility: visible !important;
		display: block !important;
	}
	#lightbox-nav a {
		opacity: 1 !important;
	}
}

#meisai_moviebox iframe,
#meisai_vrbox iframe {
	width: 100%;
	height: 400px;
	border: 0 none;
}
#map {
	width: 100%;
	height: clamp(350px,67.307vw,450px);
}
/* VRとか用の記述
#meisai_moviebox h2,
#meisai_vrbox h2 {
	width: 920px;
	height: 40px ;
	margin: 0 auto;
	line-height: 40px ;
	letter-spacing: 7px;
	text-indent: 35px;
	text-align: center;
	font-family: 'M PLUS 1p', sans-serif;
	font-size: 20px;
	font-weight: 300;
	color: #fff;
	border: 0;
}
#meisai_moviebox h2 {
	background-image: url(../images/osusume_movie_icon.png);
	background-position: 350px center;
	background-repeat: no-repeat;
	background-color: #091641;
	background-size: 33px;
}
#meisai_vrbox h2 {
	background-image: url(../images/osusume_vr_icon.png);
	background-position: 330px center;
	background-repeat: no-repeat;
	background-color: #091641;
	background-size: 32px;
}
*/

/* ==========================
	物件詳細ここまで
==========================*/
/* ==========================
	adminここから
==========================*/
#adminbody p{
	line-height: 1.5;
}
#adminbody .backhomelink a{
	color:var(--sublightlight);
	transition: all .25s;
	padding: 5px 10px;
	border-radius:15px;
	background:var(--maindark);
}
#admin-kanrikoumoku{
	width:95%;
	max-width: 400px;
	margin:0 auto 3em;
	padding-left: 2em;
}
#admin-kanrikoumoku li{
	list-style-type: circle;
	margin-bottom:.5em;
}
#admin-kanrikoumoku li a{
	display: block;
	color:var(--maincolor);
	transition: all .25s;
	font-size: clamp(15.5px,2.9807vw,17.5px);
	letter-spacing: .5px;
}
#admin-kanrikoumoku li::marker{
	color:var(--maincolor);
}
#admin-kanrikoumoku li a:hover{
	color:var(--uguisu);
	background: var(--dgreen);
}
#adminbody .backhomelink a:hover{
	background: var(--costred);
}
section#admin_block {
	width: 100%;
	margin: 0 auto;
	padding: 10px 15px;
}
section#admin_block table {
	width: 100%;
	margin-bottom: 15px;
	border: solid 1px #999;
}
section#admin_block table th {
	background: var(--gray);
}
section#admin_block table td {
	background: #fff;
}
section#admin_block table th,
section#admin_block table td {
	padding: 5px;
	border: solid 1px #999;
	text-align: center;
	font-size: 0.9em;
}
.linkcolor a{
	color:var(--linkcolor);
	transition: all .25s;
}
.linkcolor a:hover{
	color:var(--mainlight);
}
section#admin_block table td input[type='text'],
section#admin_block table td input[type='file'],
section#admin_block table td textarea {
	width: 100%;
	margin-bottom: 5px;
	padding: 3px;
	border: solid 1px #ccc;
	font-size: 1em;
}
section#admin_block table td button {
	padding: 3px 6px;
	font-size: 1em;
}
section#admin_block table#holiday_calendar caption {
	padding: 5px 0;
	font-size: 1em;
	text-align: center;
	margin-bottom:2em;
}
section#admin_block table#holiday_calendar caption button,
section#admin_block table#holiday_calendar caption span {
	font-size: 1.2em;
}
section#admin_block table#holiday_calendar caption button{
	padding:7px 15px;
	background: var(--gray);
	box-shadow: var(--shadow);
	border-radius: 10px;
	border:1px solid #ddd;
	cursor: pointer;
	transition: all .25s;
}
section#admin_block table#holiday_calendar caption button:hover{
	color:var(--uguisu);
	background: var(--dgreen);
	border:1px solid var(--dgreen);
}
section#admin_block table input{
	cursor: pointer;
}
section#admin_block table#holiday_calendar th {
	width: 14.285%;
}
section#admin_block table#holiday_calendar tr > td:nth-child(7) {
	background: #eef;
	color: #33f;
}
section#admin_block table#holiday_calendar tr > td:nth-child(1),
section#admin_block table#holiday_calendar tr > td.cal_holiday {
	background: #fee;
	color: #f33;
}
section#admin_block table#holiday_calendar td p {
	line-height: 1.3em;
	text-align: left;
}
section#admin_block table#holiday_calendar td p label {
	display: block;
	color: #000;
}
section#admin_block table td.slideimg img {
	width: 100%;
}

/* ==========================
	レスポンシブここから
==========================*/
#menuwrapper-sticky_wrap{
	display:none;
}
.overlay {
	display:none;
}
@media(max-width:1024px){
/* ==========================
	ハンバーガーメニューここから
==========================*/
	/* 
		ハンバーガーボタンクリックで画面を暗く
		.overlayクリックでメニュー以外の領域クリックしたときにハンバーガーメニューを閉じる
		.overlayの設定はcommon.jsにもあるのでid名等注意
	*/
	.overlay {
		background-color: #000;
		cursor: pointer;
		height: 100vh;
		left: 0;
		opacity: 0;
		position: fixed;
		top: 0;
		transition: all 0.5s;
		visibility: hidden;
		width: 100vw;
		z-index: 999;/* ハンバーガーボタンより下になるように注意 */
		display: block;
	}
	.nav-open .overlay {
		opacity: 0.5;
		visibility: visible;
		cursor:default;
		-webkit-tap-highlight-color:rgba(0,0,0,0);
	}
	header nav{
		display: none;
	}
	#menuwrapper-sticky_wrap{
		display: block;
		right: 0;
		position: fixed;
		top: 0;
		z-index: 1001;/* ページトップボタンより上になるように注意 */
	}
	input#hamburger {
		display: none;
	}
	/*
	 * ハンバーガーボタン用
	 * */
	 .menu_button {
		width: 50px;
		height: 50px;
		display: flex;
		position: absolute;
		top: 5px;
		right: 15px;
		background: 0 0;
		z-index: 1002;
		justify-content: center;
		flex-direction: column;
		align-items: center;
		cursor: pointer;
	}
	.menu_button span,
	.menu_button span::before,
	.menu_button span::after {
		content: '';
		display: block;
		height: 3px;
		width: 35px;
		border-radius: 5px;
		background: var(--maincolor);
		transition: all .3s;
		position: absolute;
		top: 10px;
	}
	.menu_button span:before {
		top: 10px;
		left: 0;
		background: var(--maincolor);
	}
	.menu_button span:after {
		top: 20px;
		left: 0;
		background: var(--maincolor);
	}
	.menu_button:after {
		content: 'MENU';
		display: inline-block;
		position: absolute;
		bottom: -5px;
		color: #f00;
		font-family: 'Montserrat',sans-serif;
		font-size: 10px;
		transition: all .3s;
	}
	.menu_button.active span {
		background: rgba(255,255,255,0);
	}
	.menu_button.active span:before {
		bottom: 0;
		transform: rotate(45deg);
		background:var(--pincolor);
	}
	.menu_button.active span:after {
		top: 10px;
		transform: rotate(-45deg);
		background:var(--pincolor);
	}
	.menu_button.active:after {
		content: 'CLOSE';
	}
	/*
	 * レスポンシブメニュー用
	 * */	
	 #responsive-menuwrap{
		position:fixed;
		z-index: 99;
		top:0;
		right: -150%;
		width:clamp(250px,83.3333vw,300px);
		/* clampの変更点横幅300px 250/300*100 */
		height: 100vh!important;
		color:#fff;
		background:rgba(7,22,47,.9);
		transition: all 0.5s;
	}
	#responsive-menuwrap.open{
		right: 0;
	}
	#responsive-menuwrap > div{/*スクロールバーなしでスクロールさせる記述*/
		position: fixed;
		z-index: 999; 
		width:clamp(250px,83.3333vw,300px);
		/* clampの変更点横幅300px 250/300*100 */
		height: 100%;
		margin-top:0;
		padding-top:10vh;/*フッターと共通のcssを打ち消し*/
		padding-bottom:5vh;/*フッターと共通のcssを打ち消し*/
		overflow: auto;
	}
	#responsive-menuwrap > div >ul{
		margin: 0;
		padding: 0;
	}
	#responsive-menuwrap > div >ul >li {
		border-bottom: 1px solid #fff;
		padding-left:1.5em;
		font-size:15px;
	}
	#responsive-menuwrap > div >ul >li a{
		display:inline-block;
		width:clamp(220px,73.3333vw,240px);
		/* clampの変更点横幅300px 220/300*100 */
		padding-top:20px;
		padding-bottom:20px;
		position:relative;
		color:#fff;
		transition:all .25s;
		cursor:pointer;
		letter-spacing: 1px;
	}
	#responsive-menuwrap > div >ul >li a.close{
		color:var(--pincolor);
	}
	#responsive-menuwrap > div >ul >li a:hover{
		color:var(--pincolor);
	}
	#responsive-menuwrap > div >ul >li:not(.menu-item-has-children) >a:hover{
		text-indent:10px;
	}
	#responsive-menuwrap > div >ul >li >ul >li{
		font-size:14px;
		display: flex;
		align-items: center;
	}
	#responsive-menuwrap > div >ul >li >ul >li:hover{
		color:var(--pincolor);
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children ul li a{
		display: flex;
		align-items: center;
		padding-top: 10px;
		padding-bottom:10px;
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children ul li:last-of-type a{
		padding-bottom:20px;
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children ul li a::before{
		content:'';
		display:inline-block;
		margin-right:15px;
		width:10px;
		height:1.5px;
		background:#fff;
		transition:all .25s;
	}
	#responsive-menuwrap > div >ul >li >ul >li a:hover{
		text-indent:10px;
	}
	#responsive-menuwrap > div >ul >li >ul >li a:hover::before{
		background:var(--pincolor);
	}
	/* 
		アコーディオン開閉 */
	#responsive-menuwrap > div >ul >li >ul.sub-menu{
		display:none;
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a::before,
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a::after{
		position: absolute;
		content:'';
		width: 15px;
		height: 2px;
		background-color: #fff;
		transition:all .25s;
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a::before{
		top:48%;
		right: 15px;
		transform: rotate(0deg);
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a::after{    
		top:48%;
		right: 15px;
		transform: rotate(90deg);
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a.close::before{
		transform: rotate(45deg);
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a.close::after{
		transform: rotate(-45deg);
	}
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a:hover::before,
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a:hover::after,
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a.close::before,
	#responsive-menuwrap > div >ul >li.menu-item-has-children >a.close::after{
		background-color:var(--pincolor);
	}
	/*
		ここまでハンバーガーメニュー
	=======================================*/
	/* お問い合わせ */
	#form_table dl {
		display: flex;
		flex-direction: column;
		padding:0;
	}
	#form_table dt,
	#form_table dd {
		width:100%;
		padding: 8px 5px;
	}
}
@media(max-width:768px){
	/* -----------------------------------
		index内
	----------------------------------- */
	.infotr{
		flex-direction: column;
		column-gap: 0;
		row-gap:10px;
	}
	.infotr .info_body{
		width:100%;
		font-size:14.5px;
	}
	#index_news{
		max-height:200px;
	}
	/* -----------------------------------
		物件一覧ここから
	----------------------------------- */
	.order_button input {
		display: none;
	}
	.order_button ul {
		list-style-type: none;
		display: block;
		width: 100%;
		-webkit-transition: all 0.5s;
		-moz-transition: all 0.5s;
		-ms-transition: all 0.5s;
		-o-transition: all 0.5s;
		transition: all 0.5s;
	}
	.order_button input + ul {
		height: 0;
		overflow: hidden;
		opacity: 0;
		transition:all .3s;
	}
	.order_button input:checked{
		color:red;
	}
	.order_button input:checked + ul {
		height: auto;
		opacity: 1;
		overflow: visible;
	}
	.order_button ul li{
		display: block;
		width:80%;
		height:36px;
		letter-spacing: 1px;
		text-align: center;
		font-size: 15px;
		margin:0 auto 10px;
	}
	.order_button button{
		height:100%;
	}
	.order_button button span{
		display: flex;
		width: 100%;
		height: 100%;
		margin-bottom: 5px;
		font-size: 15px;
		justify-content: center;
		align-items: center;
		background:#fff;/* 背景色と合わせる、これが無いと謎の黒枠が生まれる */
		border-radius: 10px
	}
	.order_button button span::before{
		border-radius: 25px;
	}
	.order_button button:hover{
		background-color: var(--black);
	}
	.order_button button:hover span {
		color: #fff;
	}
	.order_button .button-wrapper span{
		color: var(--maincolor);
		padding:0!important;
	}
	/* -----------------------------------
		物件詳細ここから
	----------------------------------- */
	.meisai-top-container{
		flex-direction: column-reverse;
	}
	.meisai_topinfo_photo,
	.meisai-topinfo-container{
		width: 100%;
	}

	#meisai_photo{
		flex-direction: row;
		flex-wrap: nowrap;
	}
	#meisai_photo p{
		width: 48%;
	}
	#meisai_photo_thumb{
		column-gap: 4%;
		padding:0;
		border-radius: 0;
	}
	#meisai_photo_thumb a{
		width: 22%;
	}

	.meisai_body tr{
		display: flex;
		flex-direction: column;
	}
	.meisai_body tr th,
	.meisai_body tr td{
		width:100%;
		text-align: center;
		min-height: 51px;
	}

	/* lightbox */
	#jquery-lightbox{
		width: 90%!important;
		left:5%!important;
	}
	#jquery-lightbox div{
		width: 100%!important;
	}
	#lightbox-container-image{
		padding:0!important;
	}
	#lightbox-image{
		width:90%!important;
		margin-top:20px;
	}
	#lightbox-container-image-data-box{
		padding:0!important;
	}
	#lightbox-container-image-data{
		padding:0!important;
	}
	#lightbox-image-details-currentNumber{
		padding-left: 1em;
	}
	#lightbox-secNav-btnClose{
		margin-right:1em;
	}
}

@media(max-width:768px){
	/* -----------------------------------
		物件詳細ここから
	----------------------------------- */

	.container main#meisai_article h1 {
		position: relative;
	}
	.container section#meisai{
		margin:0 auto 60px;
	}
	.kousinbi{
		font-size:clamp(13px,2.3076vw,15px);
	}
/*
	#meisai p {
		margin-bottom: 10px;
		font-size:clamp(14px,4vw,15px);
		line-height: 1.5;
	}
*/
	#meisai p.meisai_catch {
		width:95%;
		margin:25px auto;
	}

	/* 戻るボタン */
	#goback {
		margin-bottom: 10px;
	}
	#goback button {
		padding: 8px 16px;
		font-weight: 400;
		font-size: clamp(14px,2.6923vw,16px);
		background-color: var(--maincolor);
		color:#fff;
		border-radius: 5px;
		border:none;
		transition: all .25s;
		cursor: pointer;
		margin-top: 20px;
		box-shadow: var(--shadow);
	}
	#goback button:hover {
		background-color:var(--pincolor);
	}
	/* お問合わせボタン */
	.toiawasebtn{
		display: flex;
		width:100%;
		margin-right: 0;
		margin-bottom: 20px;
		justify-content: flex-end;
	}
	.toiawasebtn button{
		padding: 10px 20px;
		background:var(--maincolor);
		border: none;
		color:#fff;
		transition: all .25s;
		border-radius: 3px;
		box-shadow: var(--shadow);
		cursor: pointer;
	}
	.toiawasebtn button:hover{
		background: var(--pincolor);
		border: none;
	}
	/* 明細上部 */
	.meisai-top-container{
		display: flex;
		flex-direction: column-reverse;
		flex-wrap: wrap;
		justify-content: center;
		column-gap:2%;
		margin-bottom:0;
	}
	.meisai-topinfo-container{
		width:100%;
		flex-grow: 1;
	}
	.meisai_topinfo_photo{
		width:100%;
	}
	#meisai_photo{
		width:100%;
	}
	#meisai_photo img{
		width:100%;
	}
	.meisai-topinfo-wrap{
		padding:10px clamp(5px, -15.455px + 8.523vw, 50px) 0;
	}
	.meisai-topinfo-wrap dl{
		display: flex;
		column-gap: 20px;
		margin-bottom:10px;
		align-items: baseline;
		flex-direction: column;
	}
	.meisai-topinfo-wrap dl dt{
		font-size:15px;
		letter-spacing: 1px;
		white-space: nowrap;
	}
	.meisai-topinfo-wrap dl dt::before{
		font-size:18px;
		width:20px;
	}
	.topinfo-syozai dt::before{
		content: '\f3c5';
	}
	.topinfo-madori dt::before{
		content: '\f015';
	}
	.meisai-topinfo-wrap .topinfo-tinryou dt::before{
		content: '\f157';
		color:var(--costred);
	}
	.meisai-topinfo-wrap dl dd{
		font-size:clamp(15px,2.8846vw,17px);
		letter-spacing: 1px;
		padding-left: 2em;
	}
	.meisai-topinfo-wrap .meisai-subinfo-wrap dl dd{
		padding-left: 0;
	}
	.meisai-topinfo-wrap dl dd span.cost{
		color:var(--costred);
		font-size: clamp(20px,3.8461vw,32px);
		font-weight:700;
		margin-right:5px;
	}
	.meisai-subinfo-wrap{
		display: flex;
		width:98%;
		max-width:700px;
		margin:20px auto 0;
		flex-wrap: wrap;
		justify-content: flex-start;
		column-gap:4%;
	}
	.meisai-subinfo-wrap dl{
		width:48%;
		margin-bottom:15px;
		padding:5px;
		border-radius:10px;
		background:#f2f2f2;
		color:#afafaf;
		text-align: center;
		flex-direction: column;
		align-items: center;
	}
	.meisai-subinfo-wrap dl dt{
		font-size:clamp(13px,2.5vw,14px);
		letter-spacing: 1px;
	}
	.meisai-subinfo-wrap dl dd{
		font-size:clamp(15px,2.8846vw,17px);
	}
	/* 下部テーブル */
	.meisai_body {
		width: 100%;
		margin-bottom: 40px;
		background: #fff;
		border: 1px solid #f3f3f3;
		font-size: 14px;
		border-collapse: collapse;
		box-shadow: 0 0 15px rgba(180,180,180,.10) ;
	}
	.meisai_body tr{
		display: flex;
		flex-direction: column;
	}
	.meisai_body th{
		width: 100%;
		text-align: center;
		padding: 15px;
		border-bottom: solid 1px #efefef;
	}
	.meisai_body td {
		width: 100%;
		text-align: center;
		padding:15px;
		border-bottom: solid 1px #efefef;
		min-height:51px;
	}
	.meisai_body th {
		color: var(--white);
		background: var(--uguisu);
	}
	.meisai_body .button-wrapper{
		margin-top: 10px;
	}
	.meisai_body td button {
		display: inline-block;
		padding: 10px 20px;
		font-size: 16px;
		border: none;
		border-radius: 3px;
		letter-spacing: 1px;
		color:#fff;
		background-color: var(--maincolor);
		transition: all .25s;
		cursor: pointer;
	}
	.meisai_body td button:hover{
		background-color: var(--pincolor);
	}
	#meisai p.genkyou{
		line-height:1.5;
		font-size:clamp(14px,2.6923vw,15px);
		margin-bottom:20px;
		text-align: left;
	}
	#meisai_photo,
	#meisai_moviebox,
	#meisai_vrbox,
	#meisai_photo_thumb {
		width: 100%;
		margin: 0 auto;
	}
	#meisai_moviebox,
	#meisai_vrbox {
		text-align: center;
	}
	#meisai_photo {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		justify-content: space-between;
		width:90%;
		max-width:750px;
		margin-bottom:15px;
		box-shadow: var(--shadow);
	}
	#meisai_photo p {
		display: block;
		width: 95%;
		text-align: center;
	}
	#meisai_photo p a:hover img{
		transform: scale(1.05);
	}
	#meisai_photo p:first-of-type{
		margin-bottom:20px;
	}
	#meisai_photo p img {
		width: 100%;
		max-width: 480px;
		object-fit: cover;
		margin: 0 auto;
		transition: all .25s;
		box-shadow:var(--shadow);
	}
	#meisai_photo_thumb{
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		column-gap:2%;
		row-gap:10px;
		overflow: hidden;
		max-width: 900px;/* なんとなくの数値です */
		padding:20px;
		margin-bottom:40px;
		background:var(--gray);
	}
	#meisai_photo_thumb a:hover img{
		transform: scale(1.1);
	}
	#meisai_photo_thumb a{
		width:15%;
		height:auto;
		filter:var(--shadow);
	}
	#meisai_photo_thumb img {
		width: 100%;
		display: block;
		border-radius:5px 0 5px 0;
		object-fit: cover;
		transition: all .25s;
	}
	#meisai_moviebox iframe,
	#meisai_vrbox iframe {
		width: 100%;
		height: 400px;
		border: 0 none;
	}
	#map {
		width: 100%;
		height: clamp(350px,67.307vw,450px);
	}
}


@media(max-width:520px){
	/* -----------------------------------
		物件一覧ここから
	----------------------------------- */
	div.navi{
		align-items:center;
	}
	div.navi_number{
		display: none;
	}
	div.navi_number > a:last-of-type{
		display: none;
	}
	div.navi_prev a, div.navi_next a{
		line-height:1;
	}
	div.navi_number span, div.navi_number a{
		font-size:13px;
		padding:8px 8px;
		line-height:1;
	}
	.navi_pages{
		display: block;
		color:var(--maincolor);
		font-size:14px;
		font-family: var(--en);
		font-weight:500;
	}
	/**/
	#meisai_photo{
		flex-direction: column;
	}
	#meisai_photo p{
		width: 100%;
	}
	.meisai-topinfo-wrap dl{
		flex-direction: column;
	}
	.meisai-topinfo-wrap dl dd{
		padding-left: 2em;
	}
}
@media(max-width:350px){
	header > div > a h1{
		width:185px;
	}
}

/* 動画ありVRあり詳細の非表示 */
@media(max-width:768px){
	.list_movievr,
	.list_movie,
	.list_vr,
	.list_normal{
		display: none;
	}

	/* VR用の記述(タイトル) *//*
	#meisai_moviebox h2,
	#meisai_vrbox h2 {
		width: 920px;
		height: 40px ;
		margin: 0 auto;
		line-height: 40px ;
		letter-spacing: 7px;
		text-indent: 35px;
		text-align: center;
		font-family: 'M PLUS 1p', sans-serif;
		font-size: 20px;
		font-weight: 300;
		color: #fff;
		border: 0;
	}
	#meisai_moviebox h2 {
		background-image: url(../images/osusume_movie_icon.png);
		background-position: 350px center;
		background-repeat: no-repeat;
		background-color: #091641;
		background-size: 33px;
	}
	#meisai_vrbox h2 {
		background-image: url(../images/osusume_vr_icon.png);
		background-position: 330px center;
		background-repeat: no-repeat;
		background-color: #091641;
		background-size: 32px;
	}*/
	/* VR用の記述(リスト用アイコン等) ※使用するサイトに適用 *//*
	#cblist div.cblist_inner a.cblist_link span.list_movievr,
	#cblist div.cblist_inner a.cblist_link span.list_movie,
	#cblist div.cblist_inner a.cblist_link span.list_vr,
	#cblist div.cblist_inner a.cblist_link span.list_normal {
		z-index: 99;
		display: block;
		position: absolute;
		top: -5px;
		left: 0px;
		width: 80px;
		height: 80px;
		padding: 53px 7px 10px 7.5px;
		line-height: 18px;
		text-align: center;
		font-size: 13px;
		color: var(--darkblue);
		box-shadow: 0 5px 10px 0 rgb(100 100 100 / 50%);
		backdrop-filter: blur( 4.0px );
		-webkit-backdrop-filter: blur( 4.0px );
		background-position: center 8px;
		background-repeat: no-repeat;
		background-color: rgba( 246, 250, 255, 0.9);
		opacity:0.85;
		backdrop-filter: blur( 4.0px );
		-webkit-backdrop-filter: blur( 4.0px );
		transition: all 0.2s;
		border-radius: 5px;
	}
	#cblist div.cblist_inner a.cblist_link span.list_movievr {
		background-image: url(../images/icon-movie-vr.svg);
		background-size: 30px;
	    background-position: center 13px;
	}
	#cblist div.cblist_inner a.cblist_link span.list_movie {
		background-image: url(../images/icon-movie.svg);
		background-size: 30px;
	    background-position: center 13px;
	}
	#cblist div.cblist_inner a.cblist_link span.list_vr {
		background-image: url(../images/icon-vr.svg);
		background-size: 30px;
	    background-position: center 13px;
	}
	#cblist div.cblist_inner a.cblist_link span.list_normal {
		background-image: url(../images/icon-syousai.svg);
		background-size: 30px;
	    background-position: center 13px;
	}
	#cblist div.cblist_inner a.cblist_link:hover span.list_movievr,
	#cblist div.cblist_inner a.cblist_link:hover span.list_movie,
	#cblist div.cblist_inner a.cblist_link:hover span.list_vr,
	#cblist div.cblist_inner a.cblist_link:hover span.list_normal {
		position: absolute;
		top: 0px;
		left: 0px;
		background-color: var(--mainlight);
		opacity:1;
		border-radius: 0px;
		box-shadow: initial;
	}
*/
}
/* ==========================
	レスポンシブここまで
==========================*/
