/*===============================
MARK: root 
=================================*/
:root {
	--fz10: 0.625rem;
	--fz12: 0.75rem;
	--fz13: 0.8125rem;
	--fz14: 0.875rem;
	--fz16: 1rem;
	--fz17: 1.0625rem;
	--fz18: 1.125rem;
	--fz20: 1.25rem;
	--fz22: 1.375rem;
	--fz24: 1.5rem;
	--fz26: 1.625rem;
	--fz28: 1.75rem;
	--fz30: 1.875rem;
	--fz32: 2rem;
	--fz34: 2.125rem;
	--fz36: 2.25rem;
	--fz38: 2.375rem;
	--fz40: 2.5rem;
	--transform-center: translate(-50%, -50%);
}

html {
	font-size: 100%;
}

/*===============================
MARK: common
=================================*/
body.l-free-body {
	position: relative;
	overflow-x: hidden;
	font-family: 'Noto Sans JP', 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN',
		'Hiragino Sans', Meiryo, sans-serif;
	font-weight: 500;
	-webkit-font-smoothing: antialiased;
	color: #004f99;
	font-size: inherit;
}

img {
	vertical-align: inherit;
}

a {
	transition: 0.3s;
}

a:hover {
	opacity: 0.8;
}

.d-flex {
	display: flex;
	align-items: start;
	justify-content: start;
}

.tb-content {
	display: none;
}

.sp-content {
	display: none;
}

.indent1em {
	text-indent: -1em;
	margin-left: 1em;
}

.indent2em {
	text-indent: -2em;
	margin-left: 2em;
}

.text-center {
	text-align: center !important;
}

.text-right {
	text-align: right !important;
}

.c-white,
.c-white * {
	color: #fff;
}

.container {
	margin-inline: auto;
	width: min(100%, 1030px);
	padding-inline: 20px;
}

/*===============================
MARK: ボタン
=================================*/

.btn {
	position: relative;
	display: inline-block;
	line-height: 1.5;
	text-decoration: none;
	padding: 0.8em 4em;
	font-size: var(--fz20);
	font-weight: 700;
	background: #004f99;
	color: #fff;
	border-radius: 50em;
	box-shadow: 5px 5px 0px rgb(255, 255, 255);
}

.btn02 {
	background: #f39800;
	background: linear-gradient(0deg, rgba(243, 152, 0, 1) 0%, rgba(238, 134, 168, 1) 100%);
	box-shadow: 5px 5px 0px #004f99;
	padding: 1.3em 5em;
}

.btn.btn02::after {
	content: '';
	display: block;
	width: 1.7em;
	height: 1.7em;
	position: absolute;
	top: 50%;
	right: 5%;
	transform: translateY(-50%);
	background: url(/cms/contents/lp/cp/puv/img/icon_search.svg) no-repeat;
	background-size: contain;
}

.btn::after {
	content: '';
	display: block;
	width: 0.5em;
	height: 1em;
	position: absolute;
	top: 50%;
	right: 4%;
	transform: translateY(-50%);
	background: url(/cms/contents/lp/cp/puv/img/arrow.svg) no-repeat;
	background-size: contain;
}

.btn:hover {
	opacity: 1;
	box-shadow: 0px 0px 0px;
}

/*===============================
MARK: header
=================================*/
.site-header {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0;
	width: 100%;
	z-index: 1;
}

.site-logo h1 {
	display: inline-block;
	width: clamp(61px, 10%, 100px);
}

.site-logo img {
	display: block;
	max-width: 100%;
}

/*===============================
MARK: MV
=================================*/
#mv {
	position: relative;
	width: 100%;
	height: 100%;
	background-image: url(/cms/contents/lp/cp/puv/img/mv_bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.mv-image {
	margin-inline: auto;
	max-width: 990px;
}

.mv-image img {
	max-width: 100%;
	display: block;
}

/*===============================
MARK: TOP-CONTENT
=================================*/
#lead {
	position: relative;
	margin-block: 116px 75px;
	padding-inline: 15px;
}

#lead .inner {
	max-width: 634px;
	margin-inline: auto;
	padding: 0 15px 45px;
	border: 3px solid #004f99;
	border-radius: 40px;
	box-shadow: 10px 10px 0 rgba(0, 79, 153, 0.4);
}

#lead .heading {
	position: relative;
	z-index: 1;
	margin-inline: auto;
	width: min(56%, 356px);
	transform: translateY(-60%);
}

#lead .heading img {
	max-width: 100%;
}

#lead h3 {
	font-size: var(--fz28);
	margin-block: -0.8em 0.8em;
}

#lead p {
	font-size: var(--fz18);
	line-height: 2;
}

#lead p .marker {
	background: linear-gradient(0deg, #fff460 0.6em, transparent 0.4em);
}

#point {
	position: relative;
	padding-block: 81px;
}

.curve {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	overflow: hidden;
	line-height: 0;
	transform: rotate(180deg);
	z-index: -1;
}

.curve svg {
	position: relative;
	display: block;
	width: calc(100% + 1.3px);
	height: 81px;
}

.curve .shape-fill {
	fill: #b2ddef;
}

.curve.--down {
	top: unset;
	bottom: 0;
	transform: rotate(0);
}

#point .inner {
	background-color: #b2ddef;
	padding-block: 50px 0;
	padding-inline: 15px;
}

.item-container {
	position: relative;
	width: min(100%, 990px);
	padding: 25px 30px 35px 30px;
	margin-inline: auto;
	margin-bottom: 114px;
	background: #fff;
	border-radius: 20px;
}

.item-container:nth-child(3) {
	margin-bottom: 90px;
}

.item-container:nth-child(2) .item-img {
	max-width: 100px;
}

.item-ttl {
	position: relative;
	width: 176px;
	flex-shrink: 0;
}

.item-ttl img {
	max-width: 176px;
	display: block;
	position: absolute;
	top: -39px;
	left: 0;
}

.item-explain {
	padding-inline: 25px;
}

.item-explain h3 {
	font-size: var(--fz28);
	display: inline-block;
	border-bottom: 2px dashed #004f99;
	padding-bottom: 10px;
}

.item-explain p {
	line-height: 2.2;
	margin-top: 20px;
}

.item-img {
	margin-left: auto;
	width: min(100%, 130px);
}

.item-img img {
	display: block;
	width: 100%;
}

#notice {
	padding-block: 114px 120px;
}

#notice .d-flex {
	gap: 40px;
}

.txt-box {
	flex: 1;
}

.box-heading {
	background: #004f99;
	border-radius: 20px 20px 0 0;
	padding: 1.5rem 10px 1.2rem;
	margin-bottom: 5px;
}

.box-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border: 2px dashed #004f99;
	border-radius: 0 0 20px 20px;
	padding: 10px 15px;
	font-size: var(--fz26);
	height: 120px;
}

.notes {
	font-size: var(--fz12);
	display: block;
	margin-top: 8px;
}

.attention {
	max-width: 608px;
	margin-inline: auto;
	margin-block: 40px 120px;
	display: flex;
	align-items: stretch;
	border: 1px solid #004f99;
	border-radius: 10px;
	padding: 10px 20px;
}

.attention .ttl {
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: var(--fz18);
}

.attention .border {
	width: 1px;
	background-color: #004f99;
	margin-inline: 20px 15px;
}

.attention .list {
	line-height: 1.8;
}

#notice .btn-wrap {
	text-align: center;
}

#notice .btn-wrap h4 {
	margin-bottom: 40px;
}

/*===============================
MARK: footer
=================================*/

.copyright {
	background: #333;
	padding-block: 40px;
	font-size: var(--fz12);
	text-align: center;
	color: #fff;
	font-weight: 400;
}


/*===============================
fix
=================================*/
.l-free-wrapper div:has(#js-unt-getAjaxHeader),
.l-free-wrapper div:has(#js-unt-getAjaxFooter),
.u-pc-only,
.u-sp-only {
  display: none !important;
}
.l-free-main > .forcms_block:not(.p-lensComSearchStore):last-of-type {
  padding-bottom: 0;
}