@charset "utf-8";
/* ------------------------------
 看護師の1日（PC）
------------------------------ */
.time {
	padding: 25px 0;
	color: var(--recruit-sub-font-color);
	font-family: "Rubik", sans-serif;
	font-size: 2.7rem;
	line-height: 1;
	font-weight: 500;
	text-align: right;
}
.schedule {
	padding: 25px 30px;
	border-radius: 10px;
	background-color: var(--base-color);
}
.schedule.nobg {
	background-color: transparent;
}
.schedule .lead-sub {
	color: var(--recruit-font-color);
	line-height: 27px;
}
.schedule img {
	border-radius: 20px;
}
@media print, screen and (min-width: 768px) {
	.onedayBlock {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		row-gap: 6px;
		width: 980px;
		background: url(../img/oneday_line.png) no-repeat 105px 38px / 6px calc(100% - 114px);
	}
	.cms_block.onedayBlock::after {
		content: none;
	}
	.cms_block.onedayBlock > .cms_text {
		margin-bottom: 0;
	}
	.time {
		width: 85px;
	}
	.schedule {
		position: relative;
		width: 820px;
	}
	.schedule::before {
		content: "";
		display: block;
		position: absolute;
		top: 33px;
		left: -56px;
		z-index: 1;
		width: 8px;
		height: 8px;
		border-radius: 50%;
		background-color: var(--recruit-sub-font-color);
	}
	.schedule::after {
		content: "";
		display: block;
		position: absolute;
		top: 37px;
		left: -50px;
		width: 50px;
		height: 1px;
		border-top: 1px dotted #708b98;
	}
	.schedule:has(.cms_image) {
		display: flex;
		justify-content: space-between;
	}
	.cms_text.schedul::after {
		content: none;
	}
	.schedule > div:not(.cms_image) {
		width: 470px;
	}
	.schedule > .cms_image {
		margin-top: 5px;
		width: 260px !important;
	}
}
/* ------------------------------
 看護師の1日（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.onedayBlock {
		padding-left: 20px;
		background: url(../img/oneday_line.png) no-repeat 0 15px / 6px calc(100% - 100px);
	}
	.time {
		position: relative;
		margin-bottom: 10px;
		padding: 0;
		text-align: left;
	}
	.time::before {
		content: "";
		display: block;
		position: absolute;
		top: 10px;
		left: -21px;
		z-index: 1;
		width: 8px;
		height: 8px;
		border-radius: 50%;
		background-color: var(--recruit-sub-font-color);
	}
	.time::after {
		content: "";
		display: block;
		position: absolute;
		top: 14px;
		left: -20px;
		width: 15px;
		height: 1px;
		border-top: 1px dotted #708b98;
	}
	.schedule {
		margin-bottom: 30px;
		padding: 20px;
	}
	.schedule.nobg {
		padding: 0;
	}
	.schedule > .cms_image {
		margin-top: 15px;
	}
	.schedule img {
		border-radius: 15px;
	}
}