@charset "utf-8";
/*------------------------------------------------------------------------------
**
**	
**	ご利用の流れ  flow
**	
**
**
------------------------------------------------------------------------------*/
main{scroll-behavior:auto}
/* クロームのみ */
@media screen and (-webkit-min-device-pixel-ratio:0) {
    html{scroll-behavior:auto}
    .pagetopBtn{scroll-behavior: smooth;}
}

:root {
	--subCol3: #FFE99E;
	--subCol4: #6780AD;
}


/*==============================
**  ご利用の流れ
==============================*/

.flow-head {
	background-image: url(../img/all/bg_check_yellow.png);
	background-size: contain;
	background-position: top center;
	margin: 0 auto 58px;
	width: 960px;
	padding-bottom: 20px;
}

/* ご利用の流れ */
.flow-head-h2 {
	background-color: #e3b92c;
	color: #0c2f54;
	font-size: 30px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.3;
	padding: 19px 0;
	text-align: center;
}

/* 家マーク */
.flow-head-h2::before {
	background-image: url(../img/flow/flow_icon_home.svg);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
	display: inline-block;
	height: 40px;
	vertical-align: bottom;
	width: 35px;
}

/* 参加推奨！本のマーク */
.flow-head-icon {
	height: auto;
	line-height: 1;
	margin: 49px auto 33px;
	width: 146px;
}

/* STEP 0 */
.first-flow-step-box {
	margin: 0 auto;
	position: relative;
	width: 600px;
}

/* 下向き矢印 */
.first-flow-step-box::after,
.flow-step-box:not(:last-child)::after {
	background-image: url(../img/flow/flow_arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
	display: block;
	height: 33px;
	margin: 0 auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -20px;
	width: 74px;
}

.flow-step-heading {
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin: 0 auto 20px;
	position: relative;
}

/* ヨコ ライン */
.flow-step-heading::after {
	background-color: #0c2f54;
	border-radius: 2px;
	content: '';
	display: block;
	height: 4px;
	margin: 0 auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 4px;
	width: 100%;
}

.flow-step-figure {
	color: #0c2f54;
	font-size: 42px;
	font-style: italic;
	letter-spacing: 0.05em;
}


/* タテ ライン */
.flow-step-figure::after {
	background-color: #0c2f54;
	border-radius: 1px;
	content: '';
	display: inline-block;
	height: 54px;
	margin-left: 20px;
	margin-right: 26px;
	margin-bottom: 4px;
	vertical-align: middle;
	width: 2px;
}

.flow-step-number {
	margin-left: 15px;
}

.first-flow-step-box .flow-step-txt {
	font-size: 30px;
	font-weight: 700;
}


.flow-step-head-pic {
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 23px auto 0;
	width: 100%;
}

.flow-step-head-pic-inner {
	height: 0;
	overflow: hidden;
	padding-bottom: 35.4%;
	position: relative;
	width: calc((100% - 40px) / 2);
}

.flow-step-head-pic-img {
	height: 100%;
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}


/* 詳しく見る　ボタン */
.more-button {
	margin: 40px auto 0;
	padding-bottom: 53px;
	text-align: center;
}

.more-button-link {
	border: solid 2px #0c2f54;
	border-radius: 10px;
	background-color: #fff;
	color: #0c2f54;
	display: inline-block;
	font-size: 18px;
	font-weight: 700;
	line-height: 30px;
	padding: 2px 68px;
}

.more-button-link:hover {
	background-color: #0c2f54;
	color: #fff;
	opacity: 1;
}

@media only screen and (min-width:768px) and (max-width:1300px){
	.flow-head{width:calc(100% - 320px)}
}

@media only screen and (max-width: 1000px) {
	.flow-head{width:90%}
}
@media only screen and (max-width: 767px) {
	.flow-head {
		background-size: cover;
		width: 100%;
	}

	.flow-head-h2 {
		font-size: 18px;
		padding: 12px 0;
	}

	.flow-head-h2::before {
		height: 25px;
		margin-right: 8px;
		width: 22px;
	}

	.flow-head-icon {
		margin: 28px auto 20px;
		width: 88px;
	}

	.first-flow-step-box {
		width: 90%;
	}

	.first-flow-step-box::after,
	.flow-step-box:not(:last-child)::after {
		bottom: -14px;
		height: 20px;
		width: 44px;
	}

	.flow-step-heading {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
		margin: 0 auto 10px;
	}

	.flow-step-heading::after {
		display: none;
	}

	.flow-step-figure {
		border-bottom: solid 2px #0c2f54;
		font-size: 24px;
		line-height: 1.2;
		margin: 0 auto 8px;
		width: 100%;
	}

	.flow-step-figure::after {
		background-color: #0c2f54;
		background-image: none;
		height: 31px;
		margin-bottom: 0;
		vertical-align: bottom;
		width: 1px;
	}

	.flow-step-number {
		margin-left: 8px;
	}

	.first-flow-step-box .flow-step-txt {
		font-size: 22px;
	}

	.flow-step-head-pic-inner {
		width: calc((100% - 22px) / 2);
	}

	.more-button {
		margin: 20px auto 0;
		padding-bottom: 30px;
	}

	.more-button-link {
		font-size: 14px;
		padding: 5px 30px;
	}
}


/*==============================
**  STEP
==============================*/
.flow-step-container {
	margin: 0 auto 90px;
}

.flow-step-box {
	background-image: url(../img/all/bg_check.png);
	background-size: cover;
	border: solid 2px #0c2f54;
	margin: 0 auto;
	padding: 37px 0 45px;
	position: relative;
	width: 100%;
}

.flow-step-box:not(:last-child) {
	margin-bottom: 60px;
}

.flow-step-inner {
	margin: 0 auto;
	width: 600px;
}

.flow-step-info {
	line-height: 1.8;
}

.flow-step-txt {
	color: #0c2f54;
	font-size: 25px;
}

@media only screen and (max-width: 767px) {
	.flow-step-container {
		margin: 0 auto 50px;
	}

	.flow-step-box {
		background-size: 900px;
		padding: 25px 20px;
	}

	.flow-step-box:not(:last-child) {
		margin-bottom: 30px;
	}

	.flow-step-inner {
		width: 100%;
	}

	.flow-step-txt {
		font-size: 22px;
		font-weight: 700;
	}
}


/*==============================
**  勉強会　予約
==============================*/

.seminar-reservation-box {
	margin: 0 auto 100px;
}

.flow-sub-title {
	color: #0c2f54;
	font-size: 36px;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0 auto 36px;
	text-align: center;
}

.flow-sub-title-en {
	display: block;
	font-size: 14px;
	font-style: italic;
	font-weight: 500;
}

@media only screen and (max-width: 767px) {
	.flow-sub-title {
		font-size: 20px;
		margin: 0 auto 20px;
	}

	.flow-sub-title-en {
		font-size: 10px;
	}
}

/* ----- ココカラ -----　無料！勉強会予約（seminar.cssと共通） */
.reserve_box {
	margin: 80px auto;
	color: #0c2f54;
}

.reserve_box h3 {
	font-size: 36px;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0 auto 36px;
	text-align: center;
}

.reserve_ttl_en {
	display: block;
	font-size: 14px;
	font-style: italic;
	font-weight: 500;
}

.reserve_list {
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}

.reserve_list dl {
	border-bottom: solid 1px #e3b92c;
	border-left: solid 1px #e3b92c
}

.reserve_list dl:first-child {
	border-top: solid 1px #e3b92c;
}

.reserve_list dt,
.reserve_list dd {
	font-size: 20px;
	display: table-cell;
	vertical-align: middle;
	width: 300px;
	border-right: solid 1px #e3b92c;
	text-align: center;
	padding: 15px;
}

.reserve_list dd.detail {
	width: 40%;
	padding-left: 25px;
	text-align: left;
}

.reserve_list dt {
	font-size: 22px;
	font-weight: 700;
	font-feature-settings: 'palt';
}

.reserve_add {
	font-size: 16px;
}

.reserve_add a {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	background: linear-gradient(transparent 60%, #e3b92c 40%);
	margin-left: 20px;
}

.reserve_add a:hover {
	filter: alpha(opacity=75);
	-moz-opacity: .75;
	opacity: .75;
}

.reserve_btn,
.reserve_btn_link a {
	display: inline-block;
	width: 160px;
	line-height: 1;
	font-weight: 700;
	border-radius: 6px;
	background: #e3b92c;
	padding: 6px 0;
}

.reserve_btn {
	background: #999;
	color: #fff;
}

.btn_end {
	background: #000;
}

/* 応募終了のとき color を#999999 */
.end-color {
	color: #999999;
}

@media screen and (max-width: 767px) {
	.reserve_box {
		margin: 80px auto;
	}

	.reserve_box h3 {
		font-size: 20px;
		margin: 0 auto 20px;
	}

	.reserve_ttl_en {
		font-size: 10px;
	}

	.reserve_list dl {
		border-right: solid 1px #e3b92c;
		padding: 10px 0 14px 14px;
		position: relative;
		width: 100%;
	}

	.reserve_list dl::after {
		background-color: #e3b92c;
		content: '';
		display: block;
		height: 100%;
		position: absolute;
		top: 0;
		right: calc(100% - 58%);
		width: 1px;
	}

	.reserve_list dt,
	.reserve_list dd {
		border-right: 0;
		font-feature-settings: 'palt';
	}

	.reserve_list dt {
		box-sizing: border-box;
		display: inline-block;
		font-size: 16px;
		padding: 0 10px 0 0;
		text-align: left;
		width: 56.3%;
	}

	.reserve_list dd {
		font-size: 14px;
		padding: 0;
		margin: 0;
	}

	.reserve_list dd.detail {
		box-sizing: border-box;
		padding: 5px 10px 0 0;
		width: 56.3%;
	}

	.reserve_list dd:not(.detail) {
		vertical-align: top;
	}

	.reserve_btn,
	.reserve_btn_link a {
		box-sizing: border-box;
		max-width: 120px;
		width: 85%;
	}

	.reserve_add {
		display: none;
	}
}


/*==============================
**  カウンター相談　予約
==============================*/

.counter-reservation-box {
	line-height: 1.7;
	margin: 80px auto;
	padding-top: 100px;
}

.counter-calendar {
	margin: 0 auto 50px;
}

.counter-memo {
	color: #6780AD;
	font-size: 20px;
	margin: 0 auto 27px;
}

.counter-memo-sub {
	font-size: 14px;
	line-height: 1.8;
	margin-bottom: 50px;
}

.calendar-rule {
	font-size: 26px;
	line-height: 1;
	margin-bottom: 15px;
	text-align: center;
}

.mark-circle {
	margin-right: 30px;
}

.mark-circle::before {
	background-image: url(../img/all/mark-circle.svg);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
	display: inline-block;
	height: 22px;
	vertical-align: baseline;
	width: 22px;
}

.mark-cross::before {
	background-image: url(../img/all/mark-cross.svg);
	background-repeat: no-repeat;
	background-size: contain;
	content: '';
	display: inline-block;
	height: 18px;
	width: 18px;
}

@media only screen and (max-width: 767px) {
	.counter-reservation-box {
		margin: 80px auto;
		padding-top: 50px;
	}

	.counter-memo {
		font-size: 14px;
		margin: 0 auto 10px;
	}

	.counter-memo-sub {
		font-size: 10px;
		margin-bottom: 20px;
	}
	
	.calendar-rule {
		font-size: 20px;
	}

	.mark-circle::before {
		height: 15px;
		width: 15px;
	}

	.mark-cross::before {
		height: 14px;
		width: 14px;
	}
}



.tablenav .view-switch,
.tablenav.top .actions,
.tablenav.top .displaying-num {
	display: block !important;
}

.wp-list-table a {
	width: 200px;
}

.mw-wp-form-wp-list-table .column-wpfc_column_clear_cache,
.mw-wp-form-wp-list-table .column-admin_mail_to,
.mw-wp-form-wp-list-table .column-title {
	display: none;
}

.mw-wp-form-wp-list-table #response_status,
.mw-wp-form-wp-list-table .response_status {
	display: none;
}


/*==============================
**  カレンダー　css
==============================*/

/* フォント */
.monthly-calendar * {
	font-family: "Noto Sans JP","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.week-title:not(.sat),
.week-title:not(.sun) {
    color: #0c2f54;
}

.calendar-title {
	display: none;
}

#creserve_consul table {
	border-right: solid 1px #6780AD;
	margin-bottom: 20px;
}

caption.calendar-caption {
	border-top: solid 1px #6780AD;
	border-left: solid 1px #6780AD;
	border-right: solid 1px #6780AD;
	color: #0c2f54;
	padding: 40px;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.05em;
}

td,
th {
	border-bottom: solid 1px #6780AD;
}

td {
	border-left: solid 1px #6780AD;
	border-right: solid 1px #6780AD;
}

tr:first-child {
	border-left: solid 1px #6780AD;
	border-right: solid 1px #6780AD;
}

/* 日付 */
.day-box {
	height: 60px;
}

.day-box.no-day {
	padding: 0;
	margin: 0;
}

.day-number {
	font-weight: 700;
}

/* デフォルト（予約不可日） */
td.disable {
	filter: alpha(opacity=40);
	-moz-opacity: .40;
	opacity: .40;
}

td.disable .calendar-mark {
	visibility: hidden;
}

/* monthly-prev　の　no-link*/
.no-link {
	opacity: .3;
	padding-left: 10px;
}

/* プラグインCSSを上書き */
.list-monthly-calendar table,
.mix-calendar table,
.timetable-calendar table,
.multiple-calendar table,
.monthly-calendar table {
	width: 100% !important;
}

/* 年月日 */
.monthly-prev-next {
	margin: 10px auto 0;
}

.monthly-next *,
.monthly-prev * {
	color: #0c2f54;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.05em;
}


.monthly-next a:after{
	content: '＞';
	font-size: 20px;
	padding: 0 5px 0 0;
}
.monthly-prev a:before{
	content: '＜';
	font-size: 20px;
	padding: 0 0 0 5px;
}



@media screen and (max-width: 767px) {
	caption.calendar-caption {
		padding: 20px 0 15px;
	}
	.monthly-next *,
	.monthly-prev * {
		font-size: 14px;
		font-weight: bold;
		letter-spacing: 0.05em;
	}
	
	.monthly-next a:after {
		font-size: 14px;
		padding: 0 10px 0 0;
	}
	
	.monthly-prev a:before {
		font-size: 14px;
		padding: 0 0 0 10px;
	}

}
