@charset "utf-8";
/*************************************************/
/*　メインカラーを置換してください      */
/*　color:#FF9900;　  */
/*************************************************/
/* =========================================================
	 reset
========================================================= */
html,
body,
div,
span,
applet,
object,
iframe,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}
article.btn-Area {
	text-align: right;
	width: 96%;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}
html {
	overflow-y: scroll;
	font-family: "ヒラギノ角ゴ Pro W3";
}
blockquote,
q {
	quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}
input,
textarea {
	margin: 0;
	padding: 0;
}
ol,
ul {
	list-style: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
caption,
th {
	text-align: left;
	vertical-align: middle;
}
a:focus {
	outline: none;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.cf:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.cf {
	min-height: 1px;
}
* html .cf {
	height: 1px;
	/*\*/
	/*/
	height: auto;
	overflow: hidden;
	/**/
}
.both {
	clear: both;
}
.clear {
	clear: both !important;
}
.float_l {
	float: left !important;
}
.float_r {
	float: right !important;
}
.text_l {
	text-align: left !important;
}
.text_r {
	text-align: right !important;
}
.text_c {
	text-align: center !important;
}
.smart_off {
	display: none !important;
}
/* =========================================================
	 Body
========================================================= */
html,
body {
	position: relative;
	overflow: hidden;
	margin: 0;
	width: 100%;
	font-size: 6.25%;
	-webkit-text-size-adjust: 100%;
}
.color_green {
	color: #4cca2a;
}
.color_beige {
	color: #c9b879;
}
.font_lexend {
	font-family: "Lexend Giga", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-style: normal;
}
html {
	overflow-y: scroll;
	font-size: 6.25%;
}
body {
	position: relative;
	width: 100%;
	color: #333;
	font-family: "Zen Kaku Gothic Antique", serif;
	font-weight: 500;
	font-style: normal;
	font-size: 14rem;
	/* 14px */
	background: #fff;
}
ul,
li {
	margin: 0;
	padding: 0;
	list-style: none;
}
.cf:before,
.cf:after {
	content: '';
	display: block;
	overflow: hidden;
}
.cf:after {
	clear: both;
}
article {
	position: relative;
}
section {
	margin: 0;
}
/*main color #4cca2a*/
h1 {
	background: #4cca2a;
}
.head_title {
	background: #4cca2a;
}
.fonticon-color {
	color: #4cca2a;
}
.fonticon-color_inner i {
	color: #4cca2a;
}
.back-color {
	background: #4cca2a;
}
.boder-color {
	border-color: #4cca2a;
}
.boder_top-color {
	border-top-color: #4cca2a;
}
.boder_left-color {
	border-left-color: #4cca2a;
}
.headder_boder-color {
	border-top-color: #4cca2a;
}
.shadow-color {
	box-shadow: #A66400 0px 2px 0px 0px;
	-webkit-box-shadow: #A66400 0px 2px 0px 0px;
	-moz-box-shadow: #A66400 0px 2px 0px 0px;
}
/*sub color*/
.sub_color {
	background: #401000 !important;
}
.sub-border_color {
	border-color: #401000;
}
.sub-border-top_color {
	border-top-color: #401000;
}
.sub-border-bottom_color {
	border-bottom-color: #401000;
}
.tabList li.active {
	background: #401000;
}
.favorite-01 {
	color: #FFBF00;
}
.favorite-02 {
	color: #4cca2a;
}
.favorite-03 {
	color: #663300;
}
.favorite-04 {
	color: #000;
}
.favorite-05 {
	color: #D93600;
}
.favorite-06 {
	color: #684E02;
}
.favorite-07 {
	color: #465614;
}
.slide_list a i,
.slide_list a i {
	color: #4cca2a;
}
/* ----------------------------------------
全体のタイトルスタイル統一
---------------------------------------- */
/* H1 */
.rhs_title_h1 {
	width: 96%;
	margin: 15px auto 15px auto;
	padding: 0 0 10px 0;
	position: relative;
	font-size: 4vw;
	line-height: 24px;
	font-weight: bold;
	letter-spacing: 0.03em;
	border-bottom: 2px solid #DDD;
	background: none !important;
	color: #333 !important;
	text-overflow: clip;
	white-space: normal;
	overflow: initial;
}
.rhs_title_h1:after {
	position: absolute;
	content: ' ';
	border-bottom: solid 2px #4cca2a;
	bottom: -2px;
	width: 15%;
	display: block;
	left: 0px;
}
/* H2 */
.rhs_title_h2 {
	width: 96%;
	margin: 15px auto 15px auto;
	padding: 0 0 10px 0;
	position: relative;
	font-size: 4vw;
	line-height: 24px;
	font-weight: bold;
	letter-spacing: 0.03em;
	border-bottom: 2px solid #DDD;
	background: #fff;
	color: #000;
	text-overflow: clip !important;
	white-space: normal !important;
	overflow: initial;
}
.rhs_title_h2:after {
	position: absolute;
	content: ' ';
	border-bottom: solid 2px #4cca2a;
	bottom: -2px;
	width: 15%;
	display: block;
	left: 0px;
}
/* H3 */
.rhs_title_h3 {
	width: 96%;
	margin: 15px auto 15px auto;
	padding: 0 0 10px 0;
	position: relative;
	font-size: 3.5vw;
	line-height: 24px;
	font-weight: bold;
	letter-spacing: 0.03em;
	border-bottom: 2px solid #DDD;
}
.rhs_title_h3:after {
	position: absolute;
	content: ' ';
	border-bottom: solid 2px #4cca2a;
	bottom: -2px;
	width: 12%;
	display: block;
	left: 0px;
}
/* ----------------------------------------
　学区検索　表示・非表示
---------------------------------------- */
/*
.gakku_comment , .srch_school , .s-school , .sho_school , .sho_school_text , .list_map_school , .sho_catalog_school, .sho_school_ruiji{
	display:none;
}
*/
/* ----------------------------------------
　来店予約システム
---------------------------------------- */
/* ----------------------------------------
　利用する場合はこちらを読み込む
---------------------------------------- */
.on_raiten {
	display: none !important;
}
/* ----------------------------------------
　利用しない場合はこちらを読み込む
---------------------------------------- */
/*
.off_raiten{
	display:none !important;
}
*/
/* ----------------------------------------
フッター固定
---------------------------------------- */
footer {
	width: 100%;
	margin: 10% 0 0 0;
	padding-bottom: 60px;
}
.fixfoot {
	width: 100%;
	position: fixed;
	bottom: -1px;
	height: 60px;
	background-color: #FFF;
	z-index: 999;
	border-top: 2px solid #4cca2a;
	margin: 0px;
	padding: 0px;
	background-color: #f5f5f5;
}
.fixfoot ul {
	width: 100%;
	margin: 0px;
	height: 100%;
	padding: 0px;
	list-style: none;
	display: flex;
}
.fixfoot ul li {
	text-align: center;
	vertical-align: middle;
	height: 100%;
	margin: 0px;
	padding: 0px;
	border-right: 1px solid #ddd;
	flex: 1;
	display: block;
}
.fixfoot ul li a {
	display: block;
	width: 100%;
	height: 100%;
	font-size: 13px;
	padding: 15px 0px 0px 0px;
	margin: 0px;
	color: #333;
}
.fixfoot ul li a img {
	width: 70%;
	max-height: 65px;
}
.fixfoot ul li i {
	width: 100%;
	height: 17px;
	display: block;
	text-align: center;
}
.fixfoot ul li span {
	font-size: 12px;
}
.dra_tl p {
	background: #4cca2a;
	color: #fff;
}
.fixfoot ul li:nth-child(3) i {
	color: #e10000;
}
.fixfoot ul li:nth-child(3) span {
	color: #e10000;
}
/* ----------------------------------------
フッター会員メニュー
---------------------------------------- */
.f_mem_menu {
	background-color: #f5f5f5;
	width: 90%;
	margin: 10px auto 10px auto;
	padding: 0px 0px 15px 0px;
	border-radius: 5px;
	overflow: hidden;
}
.f_mem_menu h2 {
	background-color: #65b820;
	margin: 0 0 10px 0;
	padding: 5px 0;
	font-size: 13px;
	line-height: 20px;
	color: #FFF;
	font-weight: bold;
	text-align: center;
}
.f_mem_menu h3 {
	width: 90%;
	margin: 0px auto 10px auto;
	padding: 10px 0;
	background-color: #FFF;
	border-radius: 3px;
	font-size: 12px;
	line-height: 20px;
	color: #65b820;
	text-align: center;
}
.f_mem_menu ul {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	width: 90%;
	list-style: none;
	margin: 0px auto;
	padding: 0px;
}
.f_mem_menu ul li {
	width: calc((100% - 4px)/2);
	margin: 0px;
	padding: 0px;
}
.f_mem_menu ul li a {
	display: flex;
	align-items: center;
	padding: 6px 4px 6px 4px;
	background: #FFF;
	border: 1px solid #65b820;
	border-radius: 3px;
	font-size: clamp(11px, 3vw, 13px);
	line-height: 20px;
	color: #65b820;
	font-weight: bold;
	text-decoration: none;
	position: relative;
}
.f_mem_menu ul li a:hover {
	background: #65b820;
	color: #FFF;
}
.f_mem_menu ul li a i {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 16px;
	font-size: clamp(12px, 3.2vw, 14px);
	margin: 0 5px 0 0;
}
.f_mem_menu ul li a i.fa-calendar-check {
	font-size: clamp(13px, 3.5vw, 15px);
}
.f_mem_menu ul li a i.fa-arrow-right-from-bracket {
	font-size: clamp(11px, 3vw, 13px);
}
.f_mem_menu ul li a:after {
	content: "";
	width: 4px;
	height: 4px;
	box-sizing: border-box;
	margin: auto;
	border: 4px solid transparent;
	border-left: 4px solid #65b820;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 1px;
	transition: all 0.3s;
}
/* ----------------------------------------
レンタルコンテンツのお問合せボタン
---------------------------------------- */
.rental_inq {
	width: 90%;
	margin: 0 auto;
}
.rental_inq a {
	box-sizing: border-box;
	border: 3px solid #ff7f00;
	background: #ff7f00;
	color: #fff;
	position: relative;
	display: block;
	font-size: 5.5vw;
	line-height: 5vh;
	padding: 5% 0;
	text-decoration: none;
	text-align: center;
	font-weight: bold;
	letter-spacing: 1px;
}
.rental_inq a:after {
	position: absolute;
	bottom: -5px;
	content: "";
	vertical-align: middle;
	right: -5px;
	box-sizing: border-box;
	width: 10px;
	height: 10px;
	border: 10px solid transparent;
	border-left: 10px solid #FFF;
	transform: rotate(45deg);
}
/* hamburger header_fix
---------------------------------------- */
header .logo {
	overflow: hidden;
	max-width: 70%;
	max-height: 52px;
	box-sizing: border-box;
	padding: 5px;
	white-space: nowrap;
	text-align: left;
}
header .logo a {
	display: inline-block;
}
header .logo img {
	display: block;
	width: auto;
	max-width: 100% !important;
	max-height: 42px !important;
}
/*ナビメニューのスタイルを指定*/
.header_Toggle {
	display: block;
	position: fixed;
	right: 12px;
	top: 25px;
	width: 40px;
	height: 40px;
	cursor: pointer;
	z-index: 1001;
	background: #333;
	text-align: center;
	border-radius: 33px;
	padding: 0px;
	margin: 0px;
	border: none;
}
.header_Toggle span {
	position: absolute;
	width: 16px;
	border-bottom: solid 2px #fff;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
	left: 0px;
	right: 0px;
	margin: auto;
}
.header_Toggle span:nth-child(1) {
	top: 13px;
}
.header_Toggle span:nth-child(2) {
	top: 19px;
}
.header_Toggle span:nth-child(3) {
	top: 25px;
}
/* 最初のspanをマイナス45度に */
.acd-check_hamburger:checked~.header_Toggle span:nth-child(1) {
	top: 19px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.acd-check_hamburger:checked~.header_Toggle span:nth-child(2),
.acd-check_hamburger:checked~.header_Toggle span:nth-child(3) {
	top: 19px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
}
.search_menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0 3%;
}
.search_menu li {
	width: 32%;
	margin-bottom: 5px;
}
.search_menu a {
	display: block;
	justify-content: center;
	padding: 10px 0;
	border: 1px solid #ccc;
	background: #f5f5f5;
	border-radius: 5px;
}
.search_menu a i {
	display: block;
	margin-bottom: 5px;
	font-size: 20px;
	color: #666;
}
.search_menu a span {
	display: block;
	font-size: 12px;
	font-weight: 500;
	color: #333;
}
.h_user_name {
	background-color: #eee;
	padding: 10px;
	text-align: left;
	margin-bottom: 15px;
	display: flex;
	gap: 10px;
	align-items: center;
}
.h_user_name span:nth-child(2) {
	display: block;
	background-color: #000;
	color: #fff;
	padding: 3px 10px;
	border-radius: 5px;
}
.other_links {
	margin: 20px 10%;
	width: 80%;
}
.other_links li a {
	font-size: 14px;
	font-weight: bold;
	display: block;
	line-height: 24px;
	text-align: center;
	text-decoration: none;
	margin: 0 auto;
}
.other_links li.other_li_site a {
	border-radius: 4em;
	color: #111;
	background-color: #e7e7dd;
	padding: 15px 10px;
}
.other_links li.other_li_site a i {
	margin-left: 14px;
}
.other_links li.other_li_inq {
	width: 49%;
	float: left;
}
.other_links li.other_li_inq a {
	color: #006DD9;
	border: 2px solid #006DD9;
	padding: 10px;
	background: #F0F8FF;
}
.other_links li.other_li_inq a i {
	margin-left: 4px;
}
.other_links li.other_li_reserve {
	width: 49%;
	float: right;
}
.other_links li.other_li_reserve a {
	color: #ff533a;
	border: 2px solid #ff533a;
	padding: 10px;
	background: #fde6e1;
}
.other_links li.other_li_reserve a i {
	margin-left: 4px;
}
.other_links li:not(:last-child) {
	margin-bottom: 15px;
}
nav.header_NavMenu {
	position: fixed;
	z-index: 1000;
	padding-top: 19px;
	top: 0px;
	left: 0;
	background: #fff;
	color: #000;
	text-align: center;
	width: 100%;
	height: 100%;
	transform: translateY(-103%);
	transition: all 0.5s 0s ease;
	overflow: scroll;
}
.header_NavMenu_box {
	background: none !important;
}
nav.header_NavMenu ul.menu_list {
	background: #fff;
	width: 100%;
	padding: 0;
	margin: 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	border-bottom: none;
	margin-bottom: 20px;
	margin-top: 3px;
}
nav.header_NavMenu ul.menu_list li {
	font-size: 1.1em;
	list-style-type: none;
	padding: 0;
	width: 50%;
	box-sizing: border-box;
}
nav.header_NavMenu ul.menu_list li a {
	display: flex;
	align-items: center;
	font-size: 13px;
	font-weight: normal;
	color: #000;
	text-decoration: none;
	text-align: left;
	line-height: 41px;
	position: relative;
	padding: 0px 11% 0px 5%;
	box-sizing: content-box;
}
nav.header_NavMenu ul.menu_list li a::after {
	content: '\f105';
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	position: absolute;
	margin: 0;
	right: 12px;
	font-size: 13px !important;
}
nav.header_NavMenu .menu_list_title {
	font-weight: bold;
	text-align: left;
	line-height: 40px;
	font-size: 13px;
	border-bottom: 1px solid #ccc;
	background-color: #f7f7f7;
	border-top: 1px solid #555;
}
nav.header_NavMenu .menu_list_title i {
	margin-right: 5px;
	margin-left: 10px;
}
.acd-check {
	display: none;
}
.acd-check_hamburger {
	display: none;
}
.acd-label {
	background: #4cca2a;
	color: #fff;
	display: block;
	padding: 10px;
	position: relative;
	text-align: left;
	border: none;
	width: 100%;
	margin: 0px 0px 1px 0px;
	font-size: 14px;
	line-height: 24px;
	border-radius: 0px;
	float: none;
	box-sizing: border-box;
}
.acd-label:after {
	background: #00000026;
	box-sizing: border-box;
	content: '';
	display: block;
	font-family: "Font Awesome 5 Free";
	height: 44px;
	width: 44px;
	padding: 0px;
	position: absolute;
	right: 0;
	top: 0px;
}
.acd-label::before {
	content: '';
	top: 11px;
	right: 14px;
	width: 12px;
	height: 12px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(135deg);
	position: absolute;
	z-index: 10;
	transition: 0.2s;
}
.acd-content {
	display: block;
}
.acd-check_hamburger:checked~.navmenu_wrap .header_NavMenu {
	transform: translateY(0%);
}
.acd-check:checked+.acd-label:before {
	transform: scale(-1, 1) rotate(315deg);
	top: 17px;
}
.acd-check:checked+.acd-label+.acd-content {
	opacity: 1;
	padding: 20px 10px 0px 10px;
	visibility: visible;
}
.acd-check:checked+.acd-label+.acd-content .menu_list_title {
	line-height: 18px;
	padding-bottom: 10px;
	font-size: 13px;
}
.acd-check:checked+.acd-label+.acd-content .menu_list_title i {
	display: inline-block;
}
.acd-check:checked+.acd-label+.acd-content ul.menu_list {
	margin: 0px auto 20px auto;
	border-left: 1px solid #cccccc;
	border-top: 1px solid #cccccc;
}
.acd-check:checked+.acd-label+.acd-content ul.menu_list li {
	border-bottom: 1px solid #cccccc;
	border-right: 1px solid #cccccc;
}
.acd-check:checked+.acd-label+.acd-content ul.menu_list li a {
	line-height: 20px;
	padding: 15px 16% 15px 6%;
	box-sizing: border-box;
	height: 100%;
	width: 100%;
}
.acd-content_sale {
	margin: 10px 0px 0px 0px;
}
.acd-content_sale ul {
	border-top: solid 1px #ccc;
}
.acd-content_sale ul li {}
.acd-content_sale ul li a {
	display: block;
	text-align: left;
	padding: 12px 0px 12px 10px;
	border-bottom: solid 1px #ccc;
	position: relative;
	font-size: 16px;
	background-color: #f5f5f5;
}
.acd-content_sale ul li a::before {
	content: '';
	top: 20px;
	right: 14px;
	width: 7px;
	height: 7px;
	border-top: 2px solid #333;
	border-right: 2px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	position: absolute;
	z-index: 10;
	transition: 0.2s;
}
/* hamburger header_fix end
---------------------------------------- */
.gallery {
	width: 100%;
	max-width: 620px;
	margin: 10px auto;
}
.gallery-slider {
	width: 100%;
	height: auto;
	margin: 0 0 10px 0;
}
.gallery-slider .swiper-slide {
	width: auto;
	height: auto;
}
.gallery-slider .swiper-slide img {
	display: block;
	width: auto;
	height: 100%;
	margin: 0 auto;
}
.gallery-thumbs {
	width: 100%;
	height: 50px;
	padding: 8px 0 0 0 !important;
	overflow: hidden;
	border-top: 2px solid #555;
}
.gallery-thumbs .swiper-slide {
	width: 90px;
	height: 50px;
	text-align: center;
	overflow: hidden;
	opacity: 0.3;
	text-align: center;
	font-size: 12px;
	font-weight: bold;
}
.gallery-thumbs .swiper-slide-active {
	opacity: 1;
}
.gallery-thumbs .swiper-slide img {
	width: auto;
	height: 100%;
}
.gallery-thumbs i {
	font-size: 20px;
	display: block;
	margin-bottom: 3px;
	line-height: 22px;
}
.swiper-button-next, .swiper-button-prev {
	display: none;
}
.swiper-container-autoheight .swiper-wrapper {
	min-height: calc(100vh - 140px);
}
/**********
2023.03 マイページ改修
******************************/
/* main_mypage_menu */
.main_mypage_menu {
	margin: 0 0 10% 0;
}
.main_mypage_menu.main_mypage_menu_wide {
	width: 96%;
	margin: 0 auto 5% auto;
}
.main_mypage_menu ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 2%;
	margin: 0;
	padding: 0;
	list-style: none;
}
.main_mypage_menu ul li {
	width: 49%;
}
.main_mypage_menu ul li p,
.main_mypage_menu ul li a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 10px 10px 12px;
	box-sizing: border-box;
	border: 1px solid #65b820;
	border-radius: 3px;
	box-shadow: 0px 1px 0px 0px #65b820;
	font-weight: bold;
	text-decoration: none;
}
.main_mypage_menu ul li a {
	color: #65b820;
}
.main_mypage_menu ul li p,
.main_mypage_menu ul li a.mypage_menu_ac {
	background: #65b820;
	color: #FFF;
}
.main_mypage_menu ul li p i.mypage_menu_icon,
.main_mypage_menu ul li a i.mypage_menu_icon {
	font-size: clamp(12px, 4vw, 16px);
}
.main_mypage_menu ul li p span,
.main_mypage_menu ul li a span {
	padding: 0 5px 0 0;
	font-size: clamp(11px, 3.2vw, 15px);
	line-height: clamp(14px, 5vh, 22px);
	font-weight: bold;
	letter-spacing: 0.05em;
}
.main_mypage_menu ul li p i.fa-angle-right,
.main_mypage_menu ul li a i.fa-angle-right {
	font-size: clamp(11px, 3.5vw, 15px);
	color: #65b820;
}
input.member_add_btn {
	background-color: #65b820;
}
h2.mp_title {
	background: #65b820;
}
#mp_bukken .mp_oshirase2 ul.mp_oshirase2_inner .osusume_list .shosai_link_box .shosai_link_tl:after {
	background: #65b820;
}
#mp_bukken .osusume_more a {
	border: 1px solid #65b820;
	box-shadow: 0px 2px 0px 0px #65b820;
	color: #65b820;
}
.f_accordion_icon span{
	background-color:#4cca2a;
}

/* ----------------------------------------
フッター
---------------------------------------- */
.f-tel i{
	transform: none;
}