@charset "UTF-8";
* {
		padding: 0;
		margin: 0;
}

html {
		height: 100%;
}

body {
		font-family: "Helvetica Neue", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
		line-height: 1.563;
		font-size: 15px;
		font-weight: 400;
		font-feature-settings: "palt" 1;
		letter-spacing: 1px;
		color: #333;
		width: 100%;
		height: 100%;
		background: #F8F8F8;
		overflow-x: hidden;
		word-wrap: break-word;
		line-break: strict;
		-webkit-font-smoothing: subpixel-antialiased;
		box-sizing: border-box;
}

#wrapper {
		width: 100%;
		min-height: 100%;
		height: auto !important;
		height: 100%;
		margin: 0;
		padding: 0;
		position: relative;
		overflow: hidden;
}

.container {
		width: 100%;
		max-width: 1200px;
		margin: 0 auto;
		padding: 0 20px;
}
@media all and (min-width: 576px) {
		.container {
				padding: 0 20px;
		}
}
@media all and (min-width: 768px) {
		.container {
				padding: 0 30px;
		}
}
@media all and (min-width: 992px) {
		.container {
				padding: 0 30px;
		}
}
@media all and (min-width: 1200px) {
		.container {
				padding: 0 30px;
		}
}

main {
		padding-bottom: 170px;
}

article,
section {
		margin: 0;
		padding: 0;
}

img {
		width: 100%;
		max-width: 100%;
		height: auto;
}

a {
		text-decoration: none;
		color: #1CD0AC;
}

a.ib {
		display: inline-block;
}

h4 {
		font-size: 23.445px;
}

h5 {
		font-size: 18.75px;
}

h6 {
		font-size: 15px;
}

.small,
small {
		font-size: 12px;
}

.bold,
strong {
		font-weight: 700;
}

ol {
		list-style: decimal;
		list-style-position: inside;
}

input,
select,
textarea {
		border: 1px solid #dee2e6;
		padding: 0.25rem;
		text-align: left;
}

.btn,
button {
		display: inline-block;
		border-radius: 0.25rem;
		height: 2.59em;
		padding: 0 10px;
		line-height: 1;
		cursor: pointer;
		display: flex;
		justify-content: center;
		align-items: center;
}

.btn.link {
		display: inline-block;
		padding: 1rem 2rem;
		position: relative;
		background-color: #1CD0AC;
		border-radius: 8px;
		border: 1px solid #1CD0AC;
		color: #fff;
		text-align: center;
		font-size: 16px;
		line-height: 1.2;
		width: auto;
		height: auto;
		margin: 0.5rem 0.2rem;
}

.btn.link::before {
		content: "";
		position: absolute;
		width: 9px;
		height: 9px;
		border-right: 1px solid #fff;
		border-top: 1px solid #fff;
		transform: rotate(45deg) translateY(-50%);
		margin-top: 0;
		top: 50%;
		right: 20px;
}

._sp {
		display: none;
}

.c-green {
		color: #1CD0AC;
}

.mt-1rem {
		margin-top: 1rem;
}

.t-red {
		color: red;
}

header {
		background-color: #fff;
}
header .container {
		display: flex;
		padding: 20px 15px;
}
header .container h1 {
		width: 158px;
}
header .container h1 img {
		vertical-align: initial;
}
header .container button {
		margin-left: auto;
		border: 1px solid #e2e2e2;
		transform: translateY(50%);
		color: #adb5bd;
}

footer {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		padding: 2rem 0;
		margin-bottom: 0;
		background-color: #e2e2e2;
		color: #5C5C5C;
		text-align: center;
		font-size: 12px;
}
footer a {
		width: 150px;
		height: auto;
		margin: 0 auto 1rem;
		color: #5C5C5C;
		display: block;
}
footer > div {
		margin-bottom: 2rem;
		font-size: 14px;
}

main .container {
		padding-bottom: 120px;
}
main .cont-wrapper {
		max-width: 880px;
		margin: 0 auto;
}
main .cont-wrapper p {
		margin-bottom: 0.5em;
		font-size: 15px;
		line-height: 1.8;
}
main .main-img {
		max-width: 1200px;
		margin: 0 auto;
}
main h2 {
		text-align: left;
		margin: 2rem 0.5rem;
		font-size: 22px;
		font-weight: bold;
		display: flex;
		justify-content: center;
		align-items: center;
}
@media all and (max-width: 480px) {
		main h2 {
				display: block;
				text-align: center;
		}
}
main h3 {
		margin: 1.5rem 0 1rem;
		padding-left: 1rem;
		border-left: 4px solid #1CD0AC;
		font-size: 18px;
}
main .btn {
		height: 3.5rem;
		margin: 0 auto 1rem;
		text-align: center;
		padding: 1rem;
		color: #fff;
		width: 530px;
		border-radius: 2em;
		background-color: #1CD0AC;
}
main .btn.reset {
		border: 1px solid #1CD0AC;
		background-color: transparent;
		color: #1CD0AC;
}
main .cont-wrapper .note {
		padding: 1em;
		border: 1px solid #1CD0AC;
		font-size: 90%;
}

.section {
		margin: 1rem auto 2rem;
		padding: 2rem 2rem 1.5rem;
		border-radius: 0.8rem;
		background-color: #fff;
}

.text-area .title {
		font-size: 16px;
		font-weight: 600;
		border-bottom: 1px solid #e2e2e2;
		display: block;
		margin-bottom: 0.5rem;
		margin-top: 1rem;
}

.section.item .title:after {
		content: "応募受付中";
		color: #1CD0AC;
		border: 1px solid #1CD0AC;
		padding: 0.3rem;
		font-weight: 400;
		font-size: 14px;
		display: inline-block;
		line-height: 1;
		margin-left: 0.5rem;
		border-radius: 2px;
		letter-spacing: normal;
}
.section.item .before .title:after {
		content: "応募受付前";
		color: red;
		border: 1px solid red;
}
.section.item .after .title:after {
		content: "応募受付終了";
		color: #6c757d;
		border: 1px solid #6c757d;
}
.section.item .pause .title:after {
		content: "一時応募受付停止中";
		color: #6c757d;
		border: 1px solid #6c757d;
}

.three {
		background-color: #F69DB6;
}

.two {
		background-color: #99CC33;
}

.one {
		background-color: #91D0CD;
}

.one,
.three,
.two {
		font-size: 18px;
		font-weight: bold;
		padding: 1rem 2rem;
		color: #fff;
		margin-bottom: 1rem;
		margin-left: -2rem;
		margin-right: -2rem;
}

.item {
		position: relative;
		padding-top: 0;
		overflow: hidden;
}
.item .category {
		display: inline-block;
		margin-bottom: 0.5rem;
		padding: 4px 0.8rem;
		border: 1px solid #F69DB6;
		color: #F69DB6;
		font-size: 70%;
}
.item .title {
		padding-left: 1rem;
		border-left: 4px solid #1CD0AC;
		font-weight: bold;
}
.item li {
		padding: 2.5rem 0;
}
.item li:first-child {
		padding-top: 1rem;
}
.item li:last-child {
		padding-bottom: 1rem;
}
.item li + li {
		border-top: 1px solid #dee2e6;
}

.hide-wrap .hide-item {
		display: none;
}
.hide-wrap .hide-item .title {
		margin-top: 1.5rem;
		margin-bottom: 1.5rem;
		border-left: 4px solid #b3b3b3;
}
.hide-wrap .hide-item .title:after {
		display: none;
}

.btn-acordion {
		display: block;
		max-width: 500px;
		margin: 1rem auto 0;
		border: 1px solid #1CD0AC;
		color: #1CD0AC;
		text-align: center;
		padding: 0.5rem;
		cursor: pointer;
}
.btn-acordion:before {
		display: none;
}

.btn-close {
		display: none;
		max-width: 500px;
		margin: 1rem auto;
		border: 1px solid #1CD0AC;
		color: #1CD0AC;
		text-align: center;
		padding: 0.5rem;
		cursor: pointer;
}
.btn-close:before {
		display: none;
}

.member-list p {
		font-weight: 600;
		border-bottom: 2px solid #E8E8E8;
}
.member-list li {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		padding: 0.5rem 0;
}
.member-list li .app {
		color: #1CD0AC;
		border-bottom: none;
		font-weight: normal;
		margin-bottom: 0;
		margin-left: auto;
		text-align: center;
		margin-right: 0.25em;
		width: 150px;
}
@media all and (max-width: 420px) {
		.member-list li .app {
				width: auto;
		}
}
.member-list li .app span {
		display: inline-block;
		line-height: 1.2;
		font-size: 95%;
		font-weight: bold;
}
.member-list li .app span br.sp {
		display: none;
}
@media all and (max-width: 420px) {
		.member-list li .app span br.sp {
				display: inline;
		}
}
.member-list li .app.fin {
		display: none;
		color: red;
		text-align: center;
		margin-right: 0;
}
.member-list li.fin .app {
		display: none;
}
.member-list li.fin .app.fin {
		display: block;
}
.member-list li + li {
		border-top: 1px solid #e8e8e8;
}
.member-list img {
		height: 63px;
		width: auto;
		margin-right: 0.5rem;
}

@media screen and (max-width: 880px) {
		._sp {
				display: block;
		}

		._pc {
				display: none;
		}

		header .container {
				padding: 4px 15px;
		}
		header .container h1 {
				width: 120px;
				font-size: 35px;
		}
		header button {
				font-size: 12px;
		}

		main .container {
				padding-bottom: 50px;
		}
		main .btn {
				width: 100%;
				max-width: 480px;
				height: 3.5rem;
				margin: 0 auto 0.7rem;
				text-align: center;
				padding: 1rem;
				color: #fff;
				line-height: 1.5;
				border-radius: 2em;
				background-color: #1CD0AC;
		}
		main .form {
				padding: 3rem 0.8rem;
		}
		main .cont-wrapper p {
				margin-bottom: 1em;
		}
		main h2 {
				font-size: 20px;
		}
		main h3 {
				font-size: 17px;
		}

		.section {
				margin-bottom: 1rem;
				padding-left: 1rem;
				padding-right: 1rem;
		}
}
.sakurazaka202012 main h2:before {
		content: "";
		width: 80px;
		height: 80px;
		display: inline-block;
		background: url("../img/logo_sakurazaka.png");
		background-repeat: no-repeat;
		background-position: center;
		background-size: contain;
		margin-right: 1rem;
}
@media all and (max-width: 480px) {
		.sakurazaka202012 main h2:before {
				width: 70px;
				height: 70px;
				display: block;
				margin: 0 auto 1rem;
		}
}

.lgm202101 main h2 {
		display: block;
		text-align: center;
}
.lgm202101 main h2 .br01,
.lgm202101 main h2 .br03 {
		display: none;
}
.lgm202101 main h2:before {
		content: "";
		width: 100%;
		height: 70px;
		display: block;
		background: url("../img/logo_lgm.svg");
		background-repeat: no-repeat;
		background-position: center;
		background-size: contain;
		margin-bottom: 2rem;
}
@media screen and (max-width: 600px) {
		.lgm202101 main h2 .br01,
.lgm202101 main h2 .br03 {
				display: inline;
		}
		.lgm202101 main h2 .br02 {
				display: none;
		}
}
@media screen and (max-width: 420px) {
		.lgm202101 main h2 .br01,
.lgm202101 main h2 .br02,
.lgm202101 main h2 .br03 {
				display: none;
		}
}
/*# sourceMappingURL=products.css.map */