@charset "utf-8";

/* -----------------------------------------------------------
TOPページ
-------------------------------------------------------------- */
.scroll-hint-icon {
	z-index: 2;
}

#main {
	--mv-height: clamp(800px, 100vh, 1000px);
	--mv-service-btn-area-padding: clamp(50px, 5vw, 100px);
}

.top-h1 {
	font-size: 1.0rem;
	color: #ccc;
	position: absolute;
	top: calc(var(--mv-height) - 130px);
	width: var(--inner-width);
	text-align: right;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
}

@media screen and (min-width: 769px) {
	.scroll-hint-icon {
		display: none !important;
	}
}

@media screen and (max-width: 768px) {
	#main {
		--mv-height: clamp(400px, 120vw, 600px);
		--mv-service-btn-area-padding: 3vw;
	}

	.top-h1 {
		width: calc(100% - 10vw);
		text-align: left;
		left: 5vw;
		transform: none;
		top: calc(var(--mv-height) - 15vw);
	}
}


/* -----------------------------------------------------------
   mv-area
-------------------------------------------------------------- */
.mv-area {
	height: var(--mv-height);
	background: url(../img/top-mv-pc.jpg) center/cover, no-repeat;
	position: relative;
}

.mv-area .mv-catch-wrap {
	position: absolute;
	top: 55%;
	left: 50%;
	transform: translateX(-50%);
	width: var(--inner-width);
	container-type: inline-size;
}

.mv-area .mv-catch {
	font-size: clamp(3.0rem, 5cqw, 6.8rem);
	line-height: 1.5;
	font-weight: 600;
}

.mv-area .mv-sub-catch {
	color: var(--main);
	font-size: clamp(1.5rem, 1.6cqw, 2.2rem);
	font-weight: 500;
	font-family: var(--en);
	letter-spacing: .15em;
}

@media screen and (max-width: 768px) {
	.mv-area {
		background: url(../img/top-mv-sp.jpg) center/cover, no-repeat;
	}

	.mv-area .mv-catch-wrap {
		top: 55%;
		left: 5vw;
		transform: none;
		width: calc(100% - 10vw);
	}

	.mv-area .mv-sub-catch {
		font-size: clamp(1.2rem, 3.7cqw, 2.0rem);
	}

	.mv-area .mv-catch {
		font-size: clamp(2.8rem, 8.3cqw, 6.8rem);
	}
}



/* -----------------------------------------------------------
	mv-service-btn-area
-------------------------------------------------------------- */
.mv-service-btn-area {
	margin-top: -100px;
	position: relative;
	z-index: 1;
	padding: 0 0 100px;
}

.mv-service-btn-area::before {
	content: "";
	display: block;
	position: absolute;
	top: 100px;
	left: 0;
	width: 100%;
	height: calc(100% - 100px);
	background-color: var(--pale-blue);
	z-index: -1;
}

.mv-service-btn-area .inner {
	background-color: #fff;
	border-radius: 30px;
	padding: 70px var(--mv-service-btn-area-padding);
}


@media screen and (max-width: 768px) {
	.mv-service-btn-area {
		margin-top: -10vw;
		padding: 0;
	}

	.mv-service-btn-area .inner {
		border-radius: 20px;
		padding: 8vw var(--mv-service-btn-area-padding);
		background: var(--pale-blue);
	}

	.mv-service-btn-area .cmn-service-btn-scene-row {
		background-color: #fff;
	}
}

/* -----------------------------------------------------------
   top-btn-area
-------------------------------------------------------------- */
.top-btn-area {
	padding: 60px 0 80px;
	background: url(../img/bg-circle-blue.jpg) center/cover, no-repeat var(--main);
	background-blend-mode: soft-light;
}

.top-btn-block {
	position: relative;
	padding-top: 34px;
}

.top-btn-label {
	align-items: center;
	background: var(--yellow);
	border-radius: 20px;
	display: inline-flex;
	font-size: 1.6rem;
	font-weight: bold;
	gap: 8px;
	left: 0;
	padding: 3px 10px;
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
	white-space: nowrap;
	justify-content: center;
	color: var(--cmn-black) !important;
	width: fit-content;
}

.top-btn-label::before {
	content: "";
	-webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	width: 12px;
	height: 6px;
	background-color: var(--yellow);
	bottom: -6px;
	left: 50%;
	transform: translateX(-50%);
	display: block;
	position: absolute;
}

.top-btn-label img {
	width: 15px;
}

.top-btn-grid {
	display: grid;
	gap: 30px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.top-btn-card {
	align-items: center;
	background: #fff;
	border: 1px solid var(--main);
	border-radius: 12px;
	color: var(--cmn-black);
	display: flex;
	flex-direction: column;
	gap: 30px;
	padding: 45px 15px 50px;
	position: relative;
	text-decoration: none;
	transition: border-color .3s, color .3s;
}

.top-btn-icon {
	align-items: center;
	display: inline-flex;
	height: 60px;
	justify-content: center;
	transition: border-color .3s;
}

.top-btn-icon img {
	height: 60px;
	width: auto;
	object-fit: contain;
}

.top-btn-card:hover .top-btn-icon {
	border-color: var(--main);
}

.top-btn-txt {
	font-size: 2.0rem;
	font-weight: bold;
	text-align: center;
}

.top-btn-card .cmn-arrow {
	bottom: 14px;
	position: absolute;
	right: 16px;
}

@media screen and (min-width: 769px) {
	.top-btn-card:hover {
		border-color: var(--main);
		color: var(--main);
		transform: translateY(-5px);
	}
}

@media screen and (max-width: 768px) {
	.top-btn-area {
		padding: 10vw 0;
	}

	.top-btn-block {
		padding-top: 0;
	}

	.top-btn-label {
		font-size: 1.0rem;
		padding: 5px 15px;
		gap: 5px;
		line-height: 1;
		top: -15px;
	}

	.top-btn-label img {
		margin: 0;
		width: 10px;
	}

	.top-btn-grid {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 3vw;
	}

	.top-btn-card {
		border-radius: 8px;
		gap: 4vw;
		padding: 6vw 2vw 8vw;
		width: calc((100% - 6vw) / 3);
	}

	.top-btn-icon {
		height: 8vw;
	}

	.top-btn-icon img {
		height: 100%;
	}

	.top-btn-txt {
		font-size: clamp(1.2rem, 3.5cqw, 1.8rem);
	}

	.top-btn-card .cmn-arrow {
		bottom: 6px;
		right: initial;
		left: 50%;
		transform: translateX(-50%);
		width: 15px;
		height: 15px;
	}

	.cmn-arrow i {
		font-size: 0.9rem;
	}
}

/* -----------------------------------------------------------
   service-area
-------------------------------------------------------------- */
.service-area {
	padding: 100px 0 0;
}

/* .service-area .cmn-h2-title {
	margin-bottom: 100px;
} */

.service-area .service-block .inner {
	display: flex;
	gap: 0 100px;
	flex-wrap: wrap;
	align-items: flex-start;
}

.service-area .service-block {
	position: relative;
	z-index: 2;
	padding: 180px 0 100px;
}

.service-area #bank-billing.service-block {
	padding-top: 60px;
}

.service-area .service-block.gray {
	position: relative;
}

.service-area .service-block.gray::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: max(97%, 1700px);
	height: 100%;
	background-color: #F4F4F4;
	z-index: -1;
	border-radius: 0 40px 40px 0;
}

.service-area .service-block .service-txt-wrap {
	width: 55%;
	container-type: inline-size;
}

.service-area .service-block div:has(> .cmn-bank-billing-figure) {
	width: calc(45% - 100px);
}

.service-area .service-block .cmn-bank-billing-figure {
	width: 100%;
}

.service-area .service-block .service-title {
	font-size: clamp(2.6rem, 7cqw, 5.2rem);
	font-weight: 600;
	color: var(--main);
	position: relative;
	letter-spacing: .1em;
	display: inline-block;
	margin: 0 0 50px;
	line-height: 1.2;
}

.service-area .service-block .service-title .min {
	font-size: 70%;
}

.service-area .service-block .service-title img {
	position: absolute;
	top: -80px;
	right: -220px;
	width: 250px;
	z-index: -1;
}

.service-area .service-block .service-sub-catch {
	font-size: clamp(2.0rem, 2.7cqw, 2.4rem);
	line-height: 1.5;
	margin-bottom: 10px;

	color: var(--main);
	font-weight: 600;
}

.service-area .service-block .service-catch {
	font-size: clamp(2.2rem, 5.2cqw, 3.6rem);
	margin: 0 0 30px;
	font-weight: 600;
	line-height: 1.7;
}

.service-area .service-block .cmn-txt-box {
	margin-top: 40px;
}

.service-area .service-point-box-wrap {
	display: flex;
	gap: 40px 30px;
	flex-wrap: wrap;
	width: calc(45% - 100px);
}

.service-area .service-point-box-wrap.full {
	width: 100%;
}

.service-area .service-point-box {
	background-color: #F4F4F4;
	border-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	--gap: clamp(20px, 2vw, 30px);
	gap: var(--gap);
	padding: 30px clamp(20px, 1.5vw, 30px);
	position: relative;
	align-items: center;
	width: 100%;
	container-type: inline-size;
}

.service-area .service-block.gray .service-point-box {
	background-color: #fff;
}

.service-area .service-point-num {
	font-size: 1.5rem;
	color: var(--navy);
	font-weight: 600;
	position: absolute;
	top: -17px;
	left: 30px;
	letter-spacing: .1em;
}

.service-area .service-point-num em {
	font-size: 180%;
	line-height: 1;
}

.service-area .service-point-img {
	width: 150px;
}

.service-area .service-point-img img {
	width: 100%;
	object-fit: contain;
}

.service-area .service-point-txt {
	width: calc(100% - (70px + var(--gap)));
}

.service-area .service-point-catch {
	font-size: clamp(1.7rem, 4cqw, 2.1rem);
	line-height: 1.5;
	font-weight: 600;
}

.service-area .service-point-sub-catch {
	font-size: 1.7rem;
	line-height: 1.5;
}

.service-area .service-point-catch .accent {
	color: var(--blue);
}

.service-area .service-point-catch .accent em {
	font-size: 180%;
	font-weight: 500;
	line-height: 1;
}

.service-area .service-point-txt .check-list {
	margin-top: 20px;
}

.service-area .service-point-icon {
	width: 70px;
}

.service-area .service-point-icon img {
	max-height: 50px;
	object-fit: contain;
}

.service-area .btn-more {
	margin-top: 50px;
}

.service-area .service-txt-wrap .btn-more {
	margin-top: 40px;
}

#bank-billing .service-point-box {
	background-color: #fff;
}

@media screen and (min-width: 769px) {

	/*銀行収納代行のみ反映*/

	#bank-billing::before {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 55%;
		background-color: #F4F4F4;
		z-index: -1;
	}

	#bank-billing .service-point-box-wrap {
		margin-top: 80px;
	}

	.service-area .service-point-box.col2 {
		width: calc((100% - 30px) / 2);
	}

	.service-area .service-point-box.col2 .service-point-catch {
		font-size: 2.4rem;
		line-height: 1.5;
		font-weight: 600;
	}

	.service-area .service-point-box.col2 .service-point-txt {
		width: calc(100% - 180px);
	}


	.service-area .service-point-box.col3 {
		width: calc((100% - 60px) / 3);
		gap: 15px 20px;
	}

	.service-area .service-point-box.col3 .service-point-txt {
		width: calc(100% - 70px);
	}

	.service-area .service-point-box.col3 .service-point-catch {
		font-size: clamp(1.7rem, 5.5cqw, 2.0rem);
		letter-spacing: 0;
	}

	.service-area .service-point-box.col3 .service-point-icon {
		width: 50px;
	}
}


@media screen and (max-width: 768px) {
	.service-area {
		padding: 10vw 0 0;
	}

	.service-area .service-block {
		padding: 10vw 0;
	}

	.service-area #bank-billing.service-block {
		padding-top: 5vw;
	}

	.service-area .service-block .service-txt-wrap {
		width: 100%;
	}

	.service-area .service-block .cmn-bank-billing-figure {
		width: 100%;
	}

	.service-area .service-block .service-title {
		font-size: clamp(2.0rem, 8cqw, 3.0rem);
		letter-spacing: .05em;
		margin: 0 0 20px;
		width: 100%;
		text-shadow: var(--text-shadow-white);
		position: relative;
	}

	.service-area .service-block .service-sub-catch {
		font-size: clamp(1.5rem, 4.5cqw, 2.4rem);
		text-shadow: var(--text-shadow-white);
		margin: 0 0 5px;
	}

	.service-area .service-block .service-catch {
		font-size: clamp(1.8rem, 6cqw, 2.6rem);
		margin: 0 0 20px;
		text-shadow: var(--text-shadow-white);
	}

	.service-area .service-block .service-title img {
		position: absolute;
		top: 0;
		right: 0;
		/* width: clamp(120px, 50vw, 250px); */
		height: 40vw;
		width: auto;
		z-index: -1;
		animation: fuwa 2s ease-in-out 0s infinite alternate;
	}

	.service-area .service-block div:has(> .cmn-bank-billing-figure) {
		width: 100%;
		margin: 40px 0;
	}

	.service-area .service-block .cmn-txt-box {
		margin-top: 20px;
	}

	.service-area .service-point-num {
		font-size: 1.1rem;
		top: -10px;
		left: 15px;
	}

	.service-area .service-point-box-wrap {
		gap: 7vw;
		width: 100%;
		margin-top: 0;
		padding: 5vw 0 0;
	}

	.service-area .service-point-box-wrap.full {
		padding-top: 10vw;
	}

	.service-area .service-point-box {
		gap: 5vw;
		padding: 5vw;
	}

	.service-area .check-list {
		display: none;
	}

	.service-area .service-point-img {
		width: 20vw;
	}

	.service-area .service-point-txt {
		width: calc(100% - 25vw);
	}

	.service-area .service-point-box-wrap.full {
		position: relative;
	}

	.service-area .service-point-box-wrap.full::before {
		content: "";
		display: block;
		position: absolute;
		top: -10vw;
		left: -5vw;
		width: calc(100% + 10vw);
		height: calc(100% + 20vw);
		background-color: #F4F4F4;
		z-index: -1;
	}

	#bank-billing .btn-more {
		margin-top: 0;
	}

	.service-area .service-point-icon {
		width: 15vw;
		margin-right: auto;
	}

	.service-area .service-point-icon img {
		max-height: 12vw;
	}

	.service-area .service-point-sub-catch {
		font-size: clamp(1.2rem, 5cqw, 1.8rem);
	}

	.service-area .service-point-catch {
		font-size: clamp(1.6rem, 5.5cqw, 2.4rem);
		line-height: 1.5;
		font-weight: 600;
	}

	.service-area .btn-more {
		margin-top: 0;
	}
}

/* -----------------------------------------------------------
   oem-area
-------------------------------------------------------------- */
.oem-area {
	padding: 100px 0 200px;
	position: relative;
}

.oem-area::before {
	content: "";
	display: block;
	position: absolute;
	top: 25%;
	left: 50%;
	transform: translateX(-50%);
	width: clamp(1600px, 95%, 1800px);
	height: calc(75% - 100px);
	background-color: #f8f8f8;
	z-index: -1;
	border-radius: 50px;
}

.oem-area .inner {
	display: flex;
	gap: 10%;
	flex-wrap: wrap;
	align-items: center;
}

.oem-area .cmn-h2-title {
	width: 100%;
}

.oem-area .oem-intro-txt-wrap {
	width: 60%;
	container-type: inline-size;
}

.oem-area .oem-intro-img {
	width: 30%;
}

.oem-area .oem-intro-catch {
	font-size: clamp(3.0rem, 5cqw, 5.0rem);
	font-weight: 600;
	line-height: 1.7;
	margin-bottom: 30px;
}

.oem-area .oem-intro-catch em {
	font-size: 125%;
	color: var(--main);
}

.oem-area .cmn-img-list .cmn-img-list-num {
	background-color: #F8F8F8;
	color: var(--main);
}

.oem-area .oem-block-wrap {
	margin-top: 100px;
	width: 100%;
}

.oem-area .oem-block {
	padding: clamp(60px, 4vw, 100px);
	background-color: #fff;
	border-radius: 40px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0 5%;
	width: 100%;
}

.oem-area .oem-block+.oem-block {
	margin-top: 60px;
}

.oem-area .oem-block .ill-wrap {
	width: 32%;
}

.oem-area .oem-block .ill-wrap img {
	width: 100%;
	max-height: 400px;
	object-fit: contain;

}

.oem-area .oem-block .oem-block-catch-wrap {
	width: 63%;
	container-type: inline-size;
}

.oem-area .oem-block .oem-block-fukidashi {
	padding: 10px 20px;
	font-size: 1.6rem;
	font-weight: bold;
	margin: 0 0 10px;
	line-height: 1.2;
	background: var(--blue);
	border-radius: 30px;
	color: #fff;
	display: inline-block;
}

.oem-area .oem-block .oem-block-title {
	font-size: clamp(3.0rem, 6cqw, 5rem);
	font-weight: 600;
	line-height: 1.5;
	margin: 0 0 30px;
	color: var(--main);
	letter-spacing: .1em;
}

.oem-area .oem-block .oem-block-catch {
	font-size: clamp(2.2rem, 5cqw, 3.8rem);
	font-weight: 600;
	line-height: 1.6;
	/* color: var(--main); */
}

.oem-area .oem-block .oem-block-catch+.basic-txt {
	margin-top: 30px;
}

.oem-area .oem-block .icon-list {
	margin: 30px 0 0;
	padding: 30px;
	background-color: #f8f8f8;
	border-radius: 15px;
}

.oem-area .oem-block .icon-list .icon-item {
	display: flex;
	align-items: center;
	gap: 20px;
}

.oem-area .oem-block .icon-list .icon-item .icon-txt {
	font-size: 2.0rem;
	font-weight: 600;
	line-height: 1.6;
}

.oem-area .oem-block .icon-list .icon-item .icon-txt em {
	color: var(--main);
}

.oem-area .oem-block .icon-list .icon-wrap {
	width: 40px;
}

.oem-area .oem-block .icon-list .icon-wrap img {
	width: 100%;
	max-height: 40px;
	object-fit: contain;
}

.oem-area .oem-block .icon-list .icon-item+.icon-item {
	margin-top: 20px;
}

@media screen and (max-width: 768px) {
	.oem-area {
		padding: 10vw 0 0;
	}

	.oem-area::before {
		display: none;
	}

	.oem-area .inner {
		gap: 0;
		justify-content: center;
	}

	.oem-area .cmn-h2-title {
		order: 1;
		margin: 0 5vw;
	}

	.oem-area .oem-intro-txt-wrap {
		width: 100%;
		order: 3;
		padding: 0 5vw;
	}

	.oem-area .oem-intro-img {
		width: 50%;
		order: 2;
		margin: 0 0 5vw;
	}

	.oem-area .oem-intro-catch {
		font-size: clamp(2.0rem, 6.2cqw, 5.0rem);
		margin-bottom: 20px;
		letter-spacing: 0;
	}

	.oem-area .cmn-img-list {
		order: 4;
		padding: 10vw 5vw 5vw;
		background-color: #f8f8f8;
		margin: 8vw 0 0;
	}

	.oem-area .cmn-img-list .cmn-img-list-num {
		background-color: transparent;
	}

	.oem-area .oem-block-wrap {
		margin-top: 0;
		padding: 5vw;
		background-color: #f8f8f8;
		order: 5;
	}

	.oem-area .oem-block+.oem-block {
		margin-top: 5vw;
	}

	.oem-area .oem-block {
		padding: 5vw 5vw 7vw;
		border-radius: 10px;
		gap: 5vw;
		position: relative;
		z-index: 1;
	}

	.oem-area .oem-block .oem-block-catch-wrap {
		width: 100%;
	}

	.oem-area .oem-block .ill-wrap {
		width: auto;
		height: 30vw;
		position: absolute;
		top: 10vw;
		right: 5vw;
		z-index: -1;
		opacity: .9;
	}

	.oem-area .oem-block .ill-wrap img {
		width: auto;
		height: 100%;
		max-height: initial;
	}

	.oem-area .oem-block .oem-block-title {
		font-size: clamp(2.0rem, 8.5cqw, 3rem);
		margin: 0 0 5vw;
		text-shadow: var(--text-shadow-white);
	}

	.oem-area .oem-block .oem-block-title.min {
		font-size: clamp(1.7rem, 7.5cqw, 2.6rem);
		letter-spacing: 0;
	}

	.oem-area .oem-block .oem-block-catch {
		font-size: clamp(1.7rem, 6.3cqw, 2.6rem);
		text-shadow: var(--text-shadow-white);
	}

	.oem-area .oem-block .icon-list {
		margin: 5vw 0 0;
		padding: 5vw;
		border-radius: 10px;
	}

	.oem-area .oem-block .icon-list .icon-item {
		align-items: flex-start;
		gap: 3vw;
	}

	.oem-area .oem-block .icon-list .icon-wrap {
		width: 8vw;
		flex-shrink: 0;
	}

	.oem-area .oem-block .icon-list .icon-item .icon-txt {
		font-size: clamp(1.6rem, 4cqw, 2.0rem);
		line-height: 1.5;
	}

	.oem-area .oem-block .btn-more {
		margin: 0 auto;
	}
}


/*-------------------------------------
    .beginner-area
-------------------------------------*/
.beginner-area {
	padding: 0 0 100px;
}

.beginner-area .bg-wrap {
	width: 100%;
	height: clamp(500px, 40vw, 800px);
	/* background: url(../img/top-beginner-mv.jpg) center/cover no-repeat; */
	position: relative;
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	background-image: url("../img/top-beginner-mv.jpg");
}

.beginner-area .bg-wrap.copy-wework::after {
	top: 10px;
	right: 10px;
	bottom: initial;
}

.beginner-area .bg-wrap .cmn-marquee-wrap {
	bottom: -30px;
	top: initial;
}

.beginner-area .inner {
	display: flex;
	flex-wrap: wrap;
	--gap: clamp(60px, 5vw, 120px);
	gap: var(--gap);
	padding: 100px 0 0;
	align-items: center;
}

.beginner-area .beginner-txt-wrap {
	width: calc(70% - var(--gap));
	container-type: inline-size;
}

.beginner-area .beginner-title {
	color: var(--main);
	margin: 0 0 30px;
	font-weight: bold;
	line-height: 1.6;
	font-size: clamp(2.4rem, 5cqw, 5.0rem);
}

.beginner-area .beginner-title img {
	width: 35px;
	margin-right: 10px;
	vertical-align: -.8rem;
}

.beginner-area .sub-catch {
	font-size: clamp(2.0rem, 2.2cqw, 3.0rem);
	line-height: 1.6;
	font-weight: bold;
	margin: 0 0 10px;
	color: var(--main);
}

.beginner-area .catch {
	font-size: clamp(3.0rem, 3.6cqw, 4.0rem);
	line-height: 1.6;
	font-weight: bold;
	margin: 0 0 30px;
}

.beginner-area .ill-wrap {
	width: 30%;
}

.beginner-area .cmn-img-list {
	margin: 0;
}

.beginner-area .cmn-img-list .cmn-img-list-num {
	background-color: #fff;
	color: var(--main);
}

.beginner-area .btn-more {
	margin-top: 0;
}

@media screen and (max-width: 768px) {
	.beginner-area {
		padding: 0 0 8vw;
	}

	.beginner-area .bg-wrap {
		width: 100%;
		height: 56vw;
		background-attachment: initial;
	}

	.beginner-area .bg-wrap .cmn-marquee-wrap {
		bottom: -15px;
	}

	.beginner-area .inner {
		--gap: 5vw;
		padding: 10vw 5vw 0;
		position: relative;
	}

	.beginner-area .cmn-img-list {
		margin-top: 5vw;
	}

	.beginner-area .beginner-txt-wrap {
		width: 100%;
	}

	.beginner-area .beginner-title {
		margin: 0 0 20px;
		font-size: clamp(2.4rem, 8cqw, 4.0rem);
		text-shadow: var(--text-shadow-white);
	}

	.beginner-area .sub-catch {
		font-size: clamp(1.6rem, 4cqw, 2.2rem);
		text-shadow: var(--text-shadow-white);
	}

	.beginner-area .catch {
		font-size: clamp(2.0rem, 6.0cqw, 3.0rem);
		text-shadow: var(--text-shadow-white);
		letter-spacing: 0;
	}

	.beginner-area .ill-wrap {
		width: 40%;
		position: absolute;
		top: 5vw;
		right: 0;
		z-index: -1;
		opacity: .7;
	}

	.beginner-area .beginner-title img {
		width: 6vw;
		margin-right: 10px;
		vertical-align: -.8rem;
	}

	.beginner-area .cmn-img-list .cmn-img-list-num {
		background-color: transparent;
	}

	.beginner-area .btn-more {
		margin-top: 5vw;
	}
}


/* -------------------------------------------------------------
    news-area   標準仕様
-------------------------------------------------------------- */
#top .ninews-area {
	margin: 60px 0 90px;
}

#top .ninews-area .ninews-inner {
	gap: 100px;
}

#top .ninews-area .ninews-head {
	margin-top: 20px;
}

#top .ninews-area .ninews-head-link {
	border: 1px solid var(--border1);
	color: var(--cmnblack);
	gap: 5px;
	font-size: 1.5rem;
	padding: 10px 30px 10px 20px;
	margin: 25px 0 0;
	border-radius: 20px;
	position: relative;
}

#top .ninews-area .ninews-head-link::after {
	content: "\f061";
	font-family: var(--webicon);
	font-weight: bold;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 10px;
	color: var(--main);
}

#top .ninews-area .ninews-head-link:hover {
	background: var(--main);
	border-color: var(--main);
	color: #fff;
}

#top .ninews-area .ninews-head-link:hover::after {
	color: #fff;
}

#top .ninews-area .ninews-list {
	width: calc(100% - 145px - 20px);
}

#top .ninews-area .ninews-list .ninews-item:nth-child(n+3) {
	display: none;
}

#top .ninews-area .ninews-date {
	font: 500 1.5rem /1 var(--en);
	letter-spacing: .05em;
}

#top .ninews-area .ninews-cate-wrap .ninews-cate:nth-child(n+3) {
	display: none;
}

#top .ninews-area .ninews-title {
	color: var(--cmnblack);
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: .07em;
	line-height: 1.5;
}

@media screen and (max-width: 768px) {
	#top .ninews-area {
		margin: 10vw 0;
	}

	#top .ninews-area .ninews-head {
		margin: 0 0 20px;
		width: 100%;
	}

	#top .ninews-area .ninews-head-link {
		font-size: 1.4rem;
		margin: 0;
		gap: 5px;
		padding: 10px 22px 10px 15px;
	}

	#top .ninews-area .ninews-list {
		width: 100%;
	}

	#top .ninews-area .ninews-date {
		font-size: 1.3rem;
	}

	#top .ninews-area .ninews-title {
		font-size: 1.5rem;
	}

	#top .ninews-area .ninews-head-link::after {
		font-size: 1.2rem;
		right: 7px;
	}
}

/* -------------------------------------------------------------
    news-area   ninews-no-thumb サムネイルなし
-------------------------------------------------------------- */
#top .ninews-no-thumb .ninews-title::before {
	content: "\f061";
	color: var(--main);
	font: 900 1.8rem/1 var(--webicon);
	right: 7px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

#top .ninews-no-thumb .ninews-item a {
	border-bottom: 1px solid var(--border2);
	gap: 20px;
	padding: 30px 0 30px 10px;
}

#top .ninews-no-thumb .ninews-item a::before {
	background: var(--main);
	bottom: -1px;
	content: "";
	width: 0;
	height: 1px;
	position: absolute;
	left: 0;
	transition: .5s;
}

#top .ninews-no-thumb .ninews-item a:hover::before {
	width: 100%;
	transition: .5s;
}

#top .ninews-no-thumb .ninews-title {
	padding: 0 35px 0 0;
}

#top .ninews-no-thumb .ninews-item a:hover .ninews-title::before {
	right: 0;
}

#top .ninews-no-thumb .ninews-date {
	width: 100px;
}

#top .ninews-no-thumb .ninews-elements {
	gap: 20px;
}

@media screen and (max-width: 768px) {
	#top .ninews-no-thumb .ninews-item:not(:last-child) {
		margin-bottom: 18px;
	}

	#top .ninews-no-thumb .ninews-item a {
		padding: 0 0 18px;
	}

	#top .ninews-no-thumb .ninews-elements {
		gap: 10px;
	}

	#top .ninews-no-thumb .ninews-title {
		margin: 8px 0 0 0;
		padding: 0 18px 0 0;
	}

	#top .ninews-area .ninews-title::before {
		font-size: 1.3rem;
		top: 53%;
	}
}

/* -----------------------------------------------------------
   
-------------------------------------------------------------- */

@media screen and (max-width: 768px) {}