@charset "utf-8";
/* Copyright 2022 FSFIELD All Rights Reserved. */

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

PC、タブレット、スマートフォン共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

/* ------------------------------------------------------------

会議室利用状況

------------------------------------------------------------ */

.sec_calendar{
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 50px;
}

.information{
	background: #FEF8F8;
	margin-bottom: 100px;
	display: flex;
	padding: 40px 30px;
}

.information .col_l{
	width: 160px;
	flex: none;
}

.information .col_l h2{
	font-weight: 700;
	color: #E31B0B;
	font-size: 1.8rem;
	display: flex;
	align-items: center;
}

.information .col_l h2::before{
	content: "";
	background: url("../../img/ico_info01.png") no-repeat 0 0;
	background-size: contain;
	width: 24px;
	height: 24px;
	display: inline-block;
	margin: 0 5px -2px 0;
}

.information .col_r{width: calc(100% - 160px);}

.information .col_r .article{
	display: flex;
	margin-bottom: 15px;
}

.information .col_r .article:last-of-type{margin-bottom: 0;}

.information .col_r time{
	display: inline-block;
	width: 105px;
	line-height: 1;
	margin-top: 5px;
	flex: none;
	font-weight: 700;
}

.information .col_r .content{
	width: calc(100% - 105px);
	color: #E31A0B;
	line-height: 1.6;
}

.information .col_r .content p{
	word-wrap: break-word;
}
.lead_area{
	margin-bottom: 20px;
}

.lead_area .lead{margin-bottom: 15px;}

.lead_area + .list_pdf01{
	margin-bottom: 30px;
}

.ico_circle{
	width: 13px;
	height: 13px;
	vertical-align: 0;
	cursor: pointer;
}

.info{
	display: flex;
}

.info p{margin-right: 25px;}

.info p:last-of-type{margin-right: 0;}

.scroll_tab_room{
	min-width: 794px;
	margin-bottom: 55px;
}

.tab_room_inner{
	display: flex;
	border-bottom: 2px solid #2C5276;
	font-weight: 700;
}

.tab_room_inner .inner{
	background: #F4F4F4;
	width: 11.11%;
	text-align: center;
	line-height: 1.2;
	padding: 13px 0;
	position: relative;
	cursor: pointer;
	transition: background .3s;
}

.tab_room_inner .inner:hover{background: #D7D7D7;}

.tab_room_inner .inner::after{
	content: "";
	display: inline-block;
	background: #DFDFDF;
	width: 1px;
	height: 44px;
	position: absolute;
	top: 10px;
	right: 0;
}

.tab_room_inner .inner.active{
	background: #2C5276;
	color: #FFF;
}

.tab_room_inner .inner:last-of-type::after,
.tab_room_inner .inner.active::after{display: none;}

.tab_panel{display: none;}

.tab_panel.active{display: block;}

.tab_panel_top{
	font-weight: 700;
	margin-bottom: 20px;
}

.tab_panel_top .tab_panel_top_inner{
	padding-bottom: 10px;
	border-bottom: 1px dotted #2C5276;
	position: relative;
}

.nav_panel{
	width: 100%;
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -50%;
}

.nav_panel_inner{
	width: 314px;
	margin: 0 auto;
	text-align: center;
	position: relative;
}

.nav_panel_inner .prev{
	cursor: pointer;
	position: absolute;
	top: 0;
	left: 0;
}

.nav_panel_inner .prev a{color: #333;}

.nav_panel_inner .prev a:hover{opacity: 0.7;}

.nav_panel_inner .prev::before{
	content: "";
	display: inline-block;
	background: url("../../img/ico_arrow03.png") no-repeat 0 0;
	background-size: contain;
	width: 8px;
	height: 12px;
	transform: scale(-1, 1);
	margin: 0 8px 0 0;
}

.nav_panel_inner .next{
	cursor: pointer;
	position: absolute;
	top: 0;
	right: 0;
}

.nav_panel_inner .next a:hover{opacity: 0.7;}

.nav_panel_inner .next::after{
	content: "";
	display: inline-block;
	background: url("../../img/ico_arrow03.png") no-repeat 0 0;
	background-size: contain;
	width: 8px;
	height: 12px;
	margin: 0 0 0 8px;
}

.nav_panel_inner .next a{color: #333;}

.tbl_calendar01{
	width: 100%;
	min-width: 1100px;
	table-layout: fixed;
}

.tbl_calendar01 th,
.tbl_calendar01 td{
	border: 1px solid #EEEEEE;
	padding: 8px 7px;
	line-height: 1;
	font-size: 1.4rem;
	text-align: center;
}

.tbl_calendar01 th{
	background: #2C5276;
	color: #FFF;
	font-weight: 700;
}

.tbl_calendar01 tr:nth-of-type(1) th,
.tbl_calendar01 tr:nth-of-type(2) td{
	background: #F9F9F9;
	color: #333;
}

.tbl_calendar01 td.sun{background: #F4DFDF;}

.tbl_calendar01 td.sat{background: #E0EAF3;}

.tbl_calendar01 .empty{width: 120px;}

.tbl_calendar01 .disabled{filter: opacity(0.2) grayscale(1);}
.sec_calendar .note{
	color: #999999;
	font-size: 1.4rem;
	line-height: 1.6;
	margin-top: 10px;
}

.sec_calendar .btn{
	text-align: center;
	margin-top: 80px;
}

.sec_calendar .btn a{
	display: inline-block;
	text-align: center;
	min-width: 320px;
	padding: 26px 15px;
	background: #003C6B;
	color: #fff;
	font-size: 1.5rem;
	font-weight: bold;
	transition: .3s;
}

.sec_calendar .btn>a>span{
	position: relative;
	padding-left: 30px;
}

.sec_calendar .btn>a>span::before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background: url("../../img/ico_pdf01.svg") no-repeat;
	background-size: contain;
	width: 22px;
	height: 27px;
}
.sec_calendar .btn a:hover{opacity: 0.8;}


/*--ラジオボタン--*/
.wrap_radio{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: -20px;
}

.wrap_radio .radio_item{
	margin: 0 20px 20px 0;
	display: flex;
	align-items: center;
}

.wrap_radio .radio_item input[type="radio"]{display:none;}

.wrap_radio .radio_item input[type="radio"]+label{
	display: inline-block;
	background: url("../../img/img_radio01.png") no-repeat 0 2px;
	background-size: 16px;
	padding: 0 0 0 20px;
	line-height: 1.2;
	min-height: 16px;
	cursor: pointer;
}

.wrap_radio .radio_item input[type="radio"]:checked+label{
	background: url("../../img/img_radio01_on.png") no-repeat 0 2px;
	background-size: 16px;
}
.wrap_radio .radio_item input[type="radio"]:disabled+label{
	color: #DFDFDF;
}
/* ポップアップ
---------------------------------------------- */
/*--予約リクエスト--*/
.modal_request .modal_window{
	width: 600px;
	padding: 0;
	border-radius: 15px;
}

.modal_request .modal_window .ttl{
	background: #E8E8E8;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.2;
	padding: 20px 30px;
	border-top-left-radius: 15px;
	border-top-right-radius: 15px;
}

.modal_request_inner{padding: 0 30px 30px;}

.modal_request .modal_window table{width: 100%;}

.modal_request .modal_window table tr{border-bottom: 1px solid #EEEEEE;}

.modal_request .modal_window table th,
.modal_request .modal_window table td{
	padding: 15px 0;
	height: 80px;
}

.modal_request .modal_window table th{
	width: 150px;
	font-weight: 700;
}

.modal_request .modal_window table td .wrap_selectbox{position: relative;}

.modal_request .modal_window table td .wrap_selectbox::before{
	content: "";
	background: url("../../img/ico_arrow05.png") no-repeat 0 0;
	background-size: contain;
	width: 10px;
	height: 6px;
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -3px;
}

.modal_request .modal_window table td .wrap_selectbox select{
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	font-size: 1.6rem;
	border: 1px solid #DDDDDD;
	padding: 15px 30px 15px 15px;
	border-radius: 0;
}

.modal_request .modal_window table td .note{
	color: #999999;
	font-size: 1.4rem;
	line-height: 1.2;
	margin-top: 15px;
}

.modal_request .modal_window .btn_system_type01 a{min-width: 250px;}

.modal_request .modal_window .btn_close_modal{
	position: absolute;
	top: 24px;
	right: 20px;
}

.modal_request .modal_window .btn_close_modal img{
	width: 15px;
	height: auto;
}

.modal_loading .modal_loading_inner {
	text-align: center;
}

.form-control.is-invalid {
    border-color: #dc3545;
    padding-right: 2.25rem;
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 80%;
    color: #dc3545;
}

.is-invalid~.invalid-feedback {
    display: block;
}

@media only screen and (max-width:1200px){ /* 表示領域が1200px以下の場合に適用するスタイル */
	.lead_area .inner{max-width: 880px;}

}

@media only screen and (max-width:1166px){ /* 表示領域が1166px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	会議室利用状況

	------------------------------------------------------------ */

	.sec_calendar{padding-right: 0;}

	.scroll_tbl_calendar{
		overflow: auto;
		white-space: nowrap;
		margin-left: -50px;
		padding: 0 50px;
		-webkit-overflow-scrolling: touch;
		overflow-scrolling: touch;
	}

	.scroll_tab_room{padding-right: 50px;}

	.tab_panel_top{padding-right: 50px;}

	.scroll_tbl_calendar table{position: relative;}

	.scroll_tbl_calendar table::after{/*右側の余白*/
		content: "";
		background: #FFF;
		display: block;
		width: 50px;
		height: 1px;
		position: absolute;
		top: 0;
		right: -50px;
	}


}/*--@media--*/


@media only screen and (max-width:1024px){ /* 表示領域が1024px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	会議室利用状況

	------------------------------------------------------------ */

	.information{
		margin-bottom: 50px;
		display: block;
		padding: 30px 20px;
	}

	.information .col_l{
		width: 100%;
		padding-top: 0;
		margin-bottom: 15px;
	}

	.information .col_r{width: 100%;}

	.information .col_r .article{display: block;}

	.information .col_r time{
		display: block;
		width: 100%;
		margin: 0 0 8px 0;
	}

	.information .col_r .content{width: 100%;}


}/*--@media--*/


@media only screen and (max-width:970px){ /* 表示領域が970px以下の場合に適用するスタイル */

	.scroll_tab_room{
		min-width: 100%;
		margin-left: -50px;
		margin-right: 50px;
		padding-right: 0;
	}

	.tab_room{width: 903px;}

}

@media only screen and (max-width:920px){ /* 表示領域が920px以下の場合に適用するスタイル */

	.scroll_tab_room{
		overflow: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
		overflow-scrolling: touch;
		margin-right: 0;
	}

	.scroll_tab_room{margin-left: -50px;}

}

@media only screen and (max-width:767px){ /* 表示領域が767px以下の場合に適用するスタイル */
	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	会議室利用状況

	------------------------------------------------------------ */

	.lead_area{
		margin-bottom: 15px;
	}

	.lead_area + .list_pdf01 li{
		max-width: 256px;
	}

	.sec_calendar{padding: 0 15px;}

	.information .col_l h2{font-size: 1.6rem;}

	.information .col_l h2::before{
		width: 19px;
		height: 19px;
	}

	.scroll_tab_room{
		width: calc((100% + 30px));
		margin-left: -15px;
		margin-bottom: 30px;
	}

	.tab_room{width: 750px;}

	.tab_room_inner .inner{
		font-size: 1.4rem;
		padding: 6px 0;
	}

	.tab_room_inner .inner::after{height: 25px;}

	.tab_panel_top{padding-right: 0;}

	.tab_panel_top .tab_panel_top_inner{
		width: calc(100% + 30px);
		margin-left: -15px;
		display: flex;
		flex-direction: column;
	}

	.room_name{
		text-align: center;
		margin-bottom: 5px;
	}

	.nav_panel{
		position: unset;
		margin-left: 0;
	}

	.nav_panel_inner{width: 260px;}

	.scroll_tbl_calendar{
		width: calc(100% + 30px);
		padding: 0 15px;
		margin-left: -15px;
	}

	.scroll_tbl_calendar table::after{/*右側の余白*/
		width: 15px;
		right: -15px;
	}

	.tbl_calendar01 .empty{width: 46px;}

	.tbl_calendar01 tr:nth-of-type(n+3) th{
		font-size: 1.3rem;
		padding: 3px;
	}

	.sec_calendar .note{
		font-size: 1.2rem;
		line-height: 1.4;
		margin-top: 5px;
	}

	.sec_calendar .btn{margin-top: 40px;}

	.sec_calendar .btn a{
		width: 100%;
		min-width: 240px;
		max-width: 290px;
		padding: 20px 0;
		font-size: 1.4rem;
	}

	.sec_calendar .btn>a>span{padding-left: 30px;}

	.sec_calendar .btn>a>span::before{
		width: 18px;
		height: 22px;
	}

	/*--ラジオボタン--*/
	.wrap_radio .radio_item input[type="radio"]+label{
		background-size: 13px;
		padding: 0 0 0 18px;
		min-height: 13px;
	}

	.wrap_radio .radio_item input[type="radio"]:checked+label{background-size: 13px;}

	/* ポップアップ
	---------------------------------------------- */
	/*--予約リクエスト--*/
	.modal_request .modal_window{
		width: 100%;
		border-radius: 10px;
	}

	.modal_request .modal_window .ttl{
		font-size: 1.5rem;
		padding: 15px 20px;
		border-top-left-radius: 10px;
		border-top-right-radius: 10px;
	}

	.modal_request_inner{padding: 0 20px 25px;}

	.modal_request .modal_window table th,
	.modal_request .modal_window table td{height: 70px;}

	.modal_request .modal_window table th{width: 100px;}

	.modal_request .modal_window table td .wrap_selectbox::before{right: 10px;}

	.modal_request .modal_window table td .wrap_selectbox select{padding: 10px 20px 10px 10px;}

	.modal_request .modal_window table td .note{font-size: 1.2rem;}

	.modal_request .modal_window .btn_system_type01 a{min-width: 225px;}

	.modal_request .modal_window .btn_close_modal{top: 15px;}


}/*--@media--*/



