@charset "utf-8";
/* =====================================
■mainView
===================================== */
.mainView {
	padding-top: 69px;
	position: relative;
}
.mainView .inner {
	max-width: 1300px;
	margin: 0 auto;
	padding: 0 30px;
}
.mainView:after {
	content: "";
	width: 50%;
	height: 88px;
	background-color: #fff;
	position: absolute;
	bottom: -1px;
	left: 50%;
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
}
.mainView .storeBtn {
	width: 84%;
}
.mainView img {
	width: 100%;
}

@media screen and (min-width: 768px) {
	.mainView .inner {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
	}
	.mainView .leftWrap {
		width: 48.6%;
		max-width: 602px;
		padding-bottom: 29px;
	}
	.mainView .rightWrap {
		width: 38.5%;
		max-width: 477px;
		padding: 0 28px;
	}
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.mainView {
		padding-top: 45px;
	}
	.mainView .rightWrap {
		width: 40.5%;
		max-width: 370px;
		padding: 0 18px;
	}
}

@media screen and (max-width: 767px) {
	.mainView {
		padding-top: 30px;
	}
	.mainView:after {
		width: 100%;
		height: 150px;
		left: 0;
	}
	.mainView .rightWrap {
		padding: 8px 22px 0;
	}
	.mainView .storeBtn {
		display: none;
	}
}

/* =====================================
■storeBtn
===================================== */
.storeBtn {
	display: flex;
	column-gap: 24px;
	max-width: 503px;
	margin: 0 auto;
}

/* =====================================
■TITLE
===================================== */
h2 {
	font-size: 34px;
	font-weight: 800;
	letter-spacing: 0.04em;
	line-height: 150%;
	text-align: center;
	padding-bottom: 24px;
	position: relative;
}
h2:after {
	content: "";
	width: 134px;
	height: 8px;
	background: #EB8F91;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
}

@media screen and (max-width: 767px) {
	h2 {
		font-size: 18px;
		padding-bottom: 6px;
	}
	h2:after {
		width: 80px;
		height: 6px;
	}
}

/* =====================================
■スキマメディカルはどんなサービス？
===================================== */
.serviceSec {
	margin-bottom: 80px;
	position: relative;
	z-index: 2;
}
.serviceSec:before {
    content: "";
    width: 100%;
    height: 302px;
    background: url(/wp-content/uploads/top_bg03.png) no-repeat bottom center;
    background-size: cover;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
}
.serviceSec:after {
    content: "";
    width: 100%;
    height: 424px;
    background: url(/wp-content/uploads/top_bg04.png) no-repeat center center;
	background-size: 100% 100%;
    position: absolute;
    left: 50%;
    bottom: 88px;
    transform: translateX(-50%);
}
.serviceSec .titArea {
	padding-top: 78px;
	margin-bottom: 56px;
	position: relative;
	z-index: 2;
}
.sukimaArea {
    position: relative;
    z-index: 2;
}
.sukimaArea .inner {
	display: flex;
	justify-content: space-between;
	column-gap: 35px;
	width: 85.1%;
	max-width: 954px;
	margin: 0 auto;
}
.sukimaArea .picWrap {
	width: 30.6%;
	max-width: 291px;
}
.sukimaArea .txtWrap {
	align-self: center;
	width: 69.5%;
	max-width: 557px;
	font-size: 28px;
	font-weight: 700;
	line-height: 180%;
	letter-spacing: 0.04em;
}
.sukimaArea .txtWrap .bgLine {
	background: linear-gradient(transparent 80%, #F5F6BC 80%);
	font-size: 32px;
	line-height: 175%;
}
.sukimaArea .txtWrap small {
	font-size: 28px;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.serviceSec:after {
		height: 335px;
	}
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
	.sukimaArea .txtWrap {
		max-width: 390px;
		font-size: 18px;
	}
	.sukimaArea .txtWrap .bgLine {
		font-size: 24px;
	}
	.sukimaArea .txtWrap small {
		font-size: 18px;
	}
}

@media screen and (max-width: 767px) {
	.serviceSec {
		margin-bottom: 36px;
	}
	.serviceSec:before {
		height: 207px;
		background: url(/wp-content/uploads/top_bg03_sp.png) no-repeat bottom center;
		background-size: cover;
	}
	.serviceSec:after {
		height: 378px;
		background: url(/wp-content/uploads/top_bg04_sp.png) no-repeat center center;
		background-size: 100% 100%;
		bottom: 120px;
	}
	.serviceSec .titArea {
		padding-top: 0;
		margin-bottom: 24px;
	}
	.sukimaArea .inner {
		flex-wrap: wrap;
		row-gap: 22px;
		width: 100%;
		max-width: 100%;
	}
	.sukimaArea .picWrap {
		width: 100%;
		max-width: 150px;
		margin: 0 auto;
		order: 10;
	}
	.sukimaArea .txtWrap {
		width: 100%;
		max-width: 100%;
		font-size: 14px;
		line-height: 170%;
		text-align: center;
	}
	.sukimaArea .txtWrap .bgLine {
		font-size: 18px;
		line-height: 170%;
	}
	.sukimaArea .txtWrap small {
		font-size: 14px;
	}
}

/* -------------------------------------
* featuresArea
------------------------------------- */
.featuresArea {
    position: relative;
    z-index: 2;
}
.serviceSec .featuresArea .detailsWrap {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 36px;
}
.serviceSec .featuresArea .item {
	background: #fff;
	border: 1px solid #EB8F91;
	border-radius: 8px;
	text-align: center;
	padding: 23px;
}
.serviceSec .featuresArea .item h3 {
	font-size: 22px;
	font-weight: 700;
	line-height: 150%;
	margin-bottom: 10px;
}
.serviceSec .featuresArea .item h3 .num {
	display: block;
	font-family: "Helvetica", sans-serif;
	font-size: 32px;
	font-weight: 700;
	color: #EB8F91;
	margin: 7px 0 18px;
}
.serviceSec .featuresArea .item .pic {
	width: 60%;
	max-width: 180px;
	margin: 0 auto 10px;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.serviceSec .featuresArea .detailsWrap {
		gap: 20px;
	}
	.serviceSec .featuresArea .item {
		padding: 20px;
	}
	.serviceSec .featuresArea .item h3 {
		font-size: 18px;
	}
	.serviceSec .featuresArea .item h3 .num {
		font-size: 28px;
	}
	.serviceSec .featuresArea .item .txt {
		font-size: 15px;
	}
}

@media screen and (max-width: 767px) {
	.serviceSec .featuresArea .detailsWrap {
		grid-template-columns: repeat(1, 1fr);
		gap: 24px;
	}
	.serviceSec .featuresArea .item {
		padding: 15px;
	}
	.serviceSec .featuresArea .item h3 {
		font-size: 18px;
		margin-bottom: 8px;
	}
	.serviceSec .featuresArea .item h3 .num {
		font-size: 28px;
		margin: 5px 0 12px;
	}
	.serviceSec .featuresArea .item .pic {
		max-width: 170px;
		margin-bottom: 8px;
	}
	.serviceSec .featuresArea .item .txt {
		font-size: 14px;
	}
}


/* =====================================
■面接なしですぐに看護師の求人に応募できます
===================================== */
.ctaSec .inner {
	max-width: 1270px;
	margin: 0 auto;
	position: relative;
}
.ctaSec .inner:before,
.ctaSec .inner:after {
	content: "";
	width: 53px;
	height: 64px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.ctaSec .inner:before {
	background: url(/wp-content/uploads/top_bg02.png) no-repeat right center;
	background-size: contain;
	left: 15px;
}
.ctaSec .inner:after {
	background: url(/wp-content/uploads/top_bg01.png) no-repeat left center;
	background-size: contain;
	right: 15px;
}
.ctaArea {
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 24px;
	background: #FFF2EC;
	border-radius: 8px;
	width: 83%;
	max-width: 1046px;
	margin: 0 auto;
	padding: 48px;
}
.ctaArea .picWrap {
	max-width: 150px;
}
.ctaArea .txtWrap {
	padding: 0 24px;
}
.ctaArea .txtWrap p {
	font-size: 28px;
	font-weight: 700;
	line-height: 150%;
	margin-bottom: 36px;
	text-align: center;
}
.ctaArea .storeBtn {
	width: 86%;
}

@media screen and (max-width: 1120px) and (min-width: 768px) {
	.ctaArea .txtWrap {
		padding: 0 20px;
	}
	.ctaArea .txtWrap p {
		font-size: 24px;
	}
}


@media screen and (max-width: 1023px) and (min-width: 768px) {
	.ctaSec .inner:before,
	.ctaSec .inner:after {
		width: 33px;
		height: 34px;
	}
}

@media screen and (max-width: 767px) {
	.ctaSec.white {
		background: #fff;
		padding: 36px 0;
	}
	.ctaSec .inner:before,
	.ctaSec .inner:after {
		width: 16px;
		height: 21px;
	}
	.ctaSec .inner:before {
		left: 12px;
	}
	.ctaSec .inner:after {
		right: 12px;
	}
	.ctaArea {
		flex-wrap: wrap;
		width: calc(100% - 80px);
		padding: 24px 20px;
	}
	.ctaArea .picWrap {
		max-width: 80px;
	}
	.ctaArea .txtWrap {
		width: 100%;
		padding: 0;
		margin-top: 24px;
	}
	.ctaArea .txtWrap p {
		font-size: 14px;
		margin-bottom: 24px;
	}
	.ctaArea .txtWrap p .half {
		display: block;
	}
	.ctaArea .storeBtn {
		width: 100%;
		max-width: 267px;
		column-gap: 8px;
	}
}


/* =====================================
■スキマメディカルアプリの使い方
===================================== */
.flowSec {
	margin: 80px 0;
}
.flowArea {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px 36px;
	margin-top: 58px;
}
.flowArea .item {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	background: #fff;
	border-radius: 8px;
}
.flowArea .txtWrap {
	padding: 24px 20px 14px;
}
.flowArea .txtWrap .heading p {
	font-family: "Helvetica", sans-serif;
	font-size: 32px;
	font-weight: 700;
	letter-spacing: 0;
	color: #F9C7BE;
	margin-bottom: 19px;
}
.flowArea .txtWrap .heading p span {
	font-size: 16px;
	letter-spacing: 0.12em;
	margin-right: 6px;
	vertical-align: middle;
	top: -1px;
	position: relative;
}
.flowArea .txtWrap .heading h3 {
	font-size: 22px;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: #EB8F91;
}
.flowArea .txtWrap .txt {
	max-width: 290px;
	font-size: 14px;
	line-height: 150%;
	margin-top: 12px;
}
.flowArea .picWrap img {
	display: block;
	width: 55.5%;
	max-width: 194px;
	margin: 0 auto;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.flowArea {
		gap: 25px 20px;
	}
}

@media screen and (max-width: 1024px) and (min-width: 960px) {
	.flowArea .txtWrap .heading h3 {
		font-size: 20px;
		letter-spacing: 0.05em;
	}
}

@media screen and (max-width: 959px) and (min-width: 768px) {
	.flowArea .txtWrap {
		padding: 20px 15px 14px;
	}
	.flowArea .txtWrap .heading p {
		font-size: 28px;
		margin-bottom: 12px;
	}
	.flowArea .txtWrap .heading p span {
		font-size: 14px;
	}
	.flowArea .txtWrap .heading h3 {
		font-size: 16px;
		letter-spacing: 0.03em;
	}
	.flowArea .txtWrap .txt {
		font-size: 13px;
	}
}

@media screen and (max-width: 767px) {
	.flowSec {
		margin: 36px 0 68px;
	}
	.flowArea {
		grid-template-columns: repeat(1, 1fr);
		gap: 24px;
		margin-top: 24px;
	}
	.flowArea .txtWrap {
		padding: 22px 20px 14px;
	}
	.flowArea .txtWrap .heading p {
		font-size: 28px;
		margin-bottom: 15px;
	}
	.flowArea .txtWrap .heading p span {
		font-size: 14px;
	}
	.flowArea .txtWrap .heading h3 {
		font-size: 18px;
	}
	.flowArea .picWrap img {
		width: 58.8%;
	}
}


/* =====================================
■こんな方にオススメ
===================================== */
.recommendationSec {
	background: #fff;
	padding: 20px 0 62px;
}
.recommendationSec h2 {
	padding-left: 112px;
	padding-bottom: 0;
}
.recommendationSec h2:after {
	display: none;
}
.recommendationSec h2 img {
	max-width: 369px;
}
.recommendationList li {
	font-size: 16px;
	font-weight: 700;
	padding-left: 62px;
	position: relative;
}
.recommendationList li:before {
	content: "";
	width: 42px;
	height: 42px;
	background: url(/wp-content/uploads/icon-check.png) no-repeat left top;
	background-size: 42px 42px;
	position: absolute;
	left: 0;
	top: -9px;
}
.recommendationList li span {
	font-size: 22px;
}

@media screen and (min-width: 768px) {
	.recommendationSec .inner {
		display: flex;
		justify-content: space-between;
		max-width: 898px;
		margin: 49px auto 0;
	}
	.recommendationList li:not(:first-child) {
		margin-top: 35px;
	}
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
	.recommendationList li {
		font-size: 14px;
		padding-left: 56px;
	}
	.recommendationList li span {
		font-size: 20px;
	}
}

@media screen and (max-width: 767px) {
	.recommendationSec {
		padding: 20px 0 24px;
	}
	.recommendationSec h2 {
		padding-left: 62px;
		margin-bottom: 32px;
	}
	.recommendationSec h2 img {
		max-width: 260px;
	}
	.recommendationSec .rightWrap {
		margin-top: 16px;
	}
	.recommendationList li {
		font-size: 14px;
		padding-left: 48px;
	}
	.recommendationList li span {
		font-size: 16px;
	}
	.recommendationList li:before {
		width: 24px;
		height: 24px;
		background-size: 24px 24px;
		top: 1px;
	}
	.recommendationList li:not(:first-child) {
		margin-top: 16px;
	}
}

/* =====================================
■スキマメディカルにはこんなお仕事があります！
===================================== */
.jobSec {
	margin: 80px 0;
}
.jobArea {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	column-gap: 36px;
	row-gap: 58px;
	margin-top: 58px;
}
.jobArea .item {
	width: calc((100% - 72px) / 3);
	background: #fff;
	border-radius: 8px;
	padding: 24px 0;
}
.jobArea .item .txtWrap {
	padding: 9px 24px 0;
}
.jobArea .item h3 {
	font-size: 22px;
	font-weight: 700;
	line-height: 150%;
	color: #EB8F91;
	text-align: center;
	margin-bottom: 10px;
}
.jobArea .item img {
	width: 100%;
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
	.jobArea {
		column-gap: 20px;
		row-gap: 40px;
	}
	.jobArea .item {
		width: calc((100% - 40px) / 3);
		padding: 15px 0;
	}
	.jobArea .item .txtWrap {
		padding: 9px 10px 0;
	}
	.jobArea .item h3 {
		font-size: 18px;
		margin-bottom: 8px;
	}
	.jobArea .item .txt {
		font-size: 14px;
	}
}

@media screen and (max-width: 767px) {
	.jobSec {
		margin: 36px 0;
	}
	.jobArea {
		row-gap: 24px;
		margin-top: 24px;
	}
	.jobArea .item {
		width: 100%;
	}
	.jobArea .item h3 {
		font-size: 18px;
	}
	.jobArea .item .txt {
		font-size: 14px;
	}
}


/* =====================================
■早速、空いた時間に働ける仕事を探してみませんか？
===================================== */
.conversionSec {
	background: linear-gradient(45deg, #DD5E89, #F7BB97);
	padding-top: 48px;
}
.conversionSec .inner {
	display: flex;
	justify-content: space-between;
	column-gap: 48px;
	max-width: 1214px;
	margin: 0 auto;
	padding: 0 30px;
}
.conversionSec .leftWrap {
	width: 74%;
	align-self: center;
	text-align: center;
	padding-bottom: 49px;
}
.conversionSec .leftWrap p {
	font-size: 32px;
	font-weight: 700;
	line-height: 150%;
	letter-spacing: 0.06em;
	color: #fff;
}
.conversionSec .leftWrap .storeBtn {
	width: 61%;
}
.conversionSec .rightWrap {
	width: 26%;
	max-width: 280px;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.conversionSec {
		padding-top: 40px;
	}
	.conversionSec .leftWrap {
		padding-bottom: 40px;
	}
	.conversionSec .leftWrap p {
		font-size: 26px;
	}
}

@media screen and (max-width: 767px) {
	.conversionSec {
		padding-top: 36px;
	}
	.conversionSec .inner {
		flex-wrap: wrap;
	}
	.conversionSec .leftWrap {
		width: 100%;
		padding-bottom: 20px;
	}
	.conversionSec .leftWrap p {
		font-size: 14px;
		margin-bottom: 20px;
	}
	.conversionSec .leftWrap p .half {
		display: block;
	}
	.conversionSec .leftWrap .storeBtn {
		column-gap: 8px;
		width: 100%;
		max-width: 267px;		
	}
	.conversionSec .rightWrap {
		width: 100%;
		max-width: 100px;
		margin: 0 auto;
	}
}