/* ============================ */

/* ========================================== */

/* ========================================== */

/* ========================================== */

/* ========================================== */

/* ========================================== */

/*! destyle.css v4.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model and set borders */

/* ============================================ */

*,
::before,
::after {
	border-style: solid;
	border-width: 0;
	box-sizing: border-box;
}

/* Document */

/* ============================================ */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */

html {
	-webkit-text-size-adjust: 100%; /* 2 */
	-webkit-tap-highlight-color: transparent; /* 3*/
	line-height: 1.15; /* 1 */
}

/* Sections */

/* ============================================ */

/**
 * Remove the margin in all browsers.
 */

body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
	display: block;
}

/* Vertical rhythm */

/* ============================================ */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
	margin: 0;
}

/* Headings */

/* ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	font-weight: inherit;
	margin: 0;
}

/* Lists (enumeration) */

/* ============================================ */

ul,
ol {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Lists (definition) */

/* ============================================ */

dt {
	font-weight: bold;
}

dd {
	margin-left: 0;
}

/* Grouping content */

/* ============================================ */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
	border-top-width: 1px;
	box-sizing: content-box; /* 1 */
	clear: both;
	color: inherit;
	height: 0; /* 1 */
	margin: 0;
	overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
	font-family: monospace, monospace; /* 1 */
	font-size: inherit; /* 2 */
}

address {
	font-style: inherit;
}

/* Text-level semantics */

/* ============================================ */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
	background-color: transparent;
	color: inherit;
	text-decoration: none;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
	font-family: monospace, monospace; /* 1 */
	font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Replaced content */

/* ============================================ */

/**
 * Prevent vertical alignment issues.
 */

svg,
img,
embed,
object,
iframe {
	vertical-align: bottom;
}

/* Forms */

/* ============================================ */

/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */

button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none; /* 1 */
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border-radius: 0;
	color: inherit;
	font: inherit;
	margin: 0;
	padding: 0;
	text-align: inherit;
	text-transform: inherit; /* 2 */
	vertical-align: middle;
}

/**
 * Correct cursors for clickable elements.
 */

button,
[type=button],
[type=reset],
[type=submit] {
	cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
	cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */

:-moz-focusring {
	outline: auto;
}

select:disabled {
	opacity: inherit;
}

/**
 * Remove padding
 */

option {
	padding: 0;
}

/**
 * Reset to invisible
 */

fieldset {
	margin: 0;
	min-width: 0;
	padding: 0;
}

legend {
	padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
	overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * Correct the outline style in Safari.
 */

[type=search] {
	outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type=search]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */

::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */

[type=number] {
	-moz-appearance: textfield;
}

/**
 * Clickable labels
 */

label[for] {
	cursor: default;
}

/* Interactive */

/* ============================================ */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
	display: list-item;
}

/*
 * Remove outline for editable content.
 */

[contenteditable]:focus {
	outline: auto;
}

/* Tables */

/* ============================================ */

/**
1. Correct table border color inheritance in all Chrome and Safari.
*/

table {
	border-collapse: collapse;
	border-color: inherit; /* 1 */
}

caption {
	text-align: left;
}

td,
th {
	padding: 0;
	vertical-align: top;
}

th {
	font-weight: bold;
	text-align: left;
}

/* ============================ */

html {
	scroll-behavior: smooth;
	scroll-padding-top: 4.5625rem;
}

body {
	color: #333;
	font-family: "M PLUS 1p", sans-serif;
	font-weight: 800;
}

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

a {
	display: block;
	transition: all 0.3s 0s ease-in-out;
}

a:hover {
	opacity: 0.7;
}

.--sp-only {
	display: none;
}

/* ============================ */

/* ============================ */

/* ============================
header
 ========================= */

.l-header {
	height: 5.8125rem;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 100;
}

.l-header.is-active .l-header__nav-link {
	color: #333;
	text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF;
}

.l-header__inner {
	display: flex;
	height: 100%;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 82.25rem;
	padding: 0 0.875rem;
	width: 100%;
}

.l-header__logo {
	-moz-column-gap: clamp(0.6875rem, 0.2381432896rem + 1.9172552977vw, 1.875rem);
	align-items: center;
	background-color: #fff;
	border-radius: 0 0 0.625rem 0.625rem;
	column-gap: clamp(0.6875rem, 0.2381432896rem + 1.9172552977vw, 1.875rem);
	display: flex;
	padding: 1.0625rem clamp(1rem, -1.7372278057rem + 5.6951423786vw, 3.125rem);
}

.l-header__logo-item {
	flex-shrink: 0;
}

.l-header__logo-item:first-of-type {
	width: clamp(2.1875rem, 1.9036957619rem + 1.2108980827vw, 2.9375rem);
}

.l-header__logo-item:last-of-type {
	width: clamp(6.3125rem, 5.5320383451rem + 3.3299697275vw, 8.375rem);
}

.l-header__logo-link {
	font-size: clamp(1.125rem, 1.0776992936rem + 0.2018163471vw, 1.25rem);
	font-weight: 700;
	letter-spacing: 2px;
	line-height: 130%;
}

.l-header__drawer-button {
	display: none;
	height: 1rem;
	position: relative;
	width: 3.125rem;
	z-index: 1;
}

.l-header__drawer-bar {
	background-color: #6cb32a;
	height: 0.09375rem;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	transition: transform 0.5s ease 0s;
	width: 3.125rem;
}

.l-header__drawer-bar.--top {
	top: 0;
}

.l-header__drawer-bar.--middle {
	display: block;
	top: 50%;
	transform: translate(-50%, -50%);
}

.l-header__drawer-bar.--bottom {
	bottom: 0;
}

.l-header__drawer-bar.is-active {
	background-color: #fff;
}

.l-header__drawer-bar.is-active.--top {
	top: 50%;
	transform: translate(-50%, -50%) rotate(-15deg);
}

.l-header__drawer-bar.is-active.--middle {
	display: none;
}

.l-header__drawer-bar.is-active.--bottom {
	top: 50%;
	transform: translate(-50%, -50%) rotate(15deg);
}

.l-header__content {
	-moz-column-gap: 2.5rem;
	align-items: center;
	column-gap: 2.5rem;
	display: flex;
}

.l-header__nav {
	flex-shrink: 0;
}

.l-header__nav-list {
	-moz-column-gap: clamp(1rem, -0.932160804rem + 4.0201005025vw, 2.5rem);
	align-items: center;
	column-gap: clamp(1rem, -0.932160804rem + 4.0201005025vw, 2.5rem);
	display: flex;
	justify-content: space-between;
}

.l-header__nav-item {
	text-align: center;
	width: 100%;
}

.l-header__nav-link {
	color: #fff;
	cursor: pointer;
	font-size: 0.9375rem;
	line-height: 180%;
	transition: opacity 0.3s 0s ease-in-out;
	transition: all 0.3s 0s ease-in-out;
	white-space: nowrap;
}

.l-header__nav-link:hover {
	opacity: 0.7;
}

.l-header__contact-text {
	line-height: 160%;
	margin-bottom: 1rem;
	text-align: center;
}

/* ========================================== */

/* spのみ */

.l-header__content--sp {
	background-color: #fff;
	display: none;
	flex: 1;
	padding: 6.25rem 0.875rem 1.25rem;
	width: 100%;
}

.l-header__content--sp ul {
	-moz-column-gap: 1rem;
	align-items: center;
	column-gap: 1rem;
	display: flex;
	justify-content: center;
	margin: 0 auto;
	margin-bottom: 1.5rem;
	max-width: 20.3125rem;
	width: 100%;
}

.l-header__content--sp li {
	width: calc(33.3% - 0.6666666667rem);
}

.l-header__content--sp p {
	font-size: 0.625rem;
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
}

.l-header__content--sp p:not(:last-of-type) {
	margin-bottom: 0.375rem;
}

.l-header__content--sp p img {
	vertical-align: baseline;
	width: 0.625rem;
}

.l-header__content--sp-head {
	margin: 0 auto 1.5rem;
	width: 6.25rem;
}

.l-header__content--sp-logo {
	-moz-column-gap: 1.875rem;
	align-items: center;
	column-gap: 1.875rem;
	display: flex;
	justify-content: center;
	margin-bottom: 0.75rem;
}

.l-header__content--sp-logo-item:first-of-type {
	width: 1.875rem;
}

.l-header__content--sp-logo-item:last-of-type {
	width: 5.125rem;
}

/* ============================ */

/* ============================
main
 ========================= */

.l-main {
	background: url(../img/bg/bg_pc.webp) no-repeat center top/cover;
}

/* inner1200px */

.l-main__inner {
	margin: 0 auto;
	max-width: 64.25rem;
	padding: 0 0.875rem;
	width: 100%;
}

/* ============================ */

.l-footer {
	padding-top: clamp(2.9375rem, 2.1570383451rem + 3.3299697275vw, 5rem);
}

.l-footer__bg {
	background-color: #fff;
	border-radius: 50%/100% 100% 0 0;
	margin: 0 auto;
	max-width: 60rem;
	padding-top: clamp(1.25rem, -0.1690211907rem + 6.0544904137vw, 5rem);
	width: 100%;
}

.l-footer__inner {
	margin: 0 auto;
	max-width: 44.5rem;
	padding: 0 0.875rem;
	width: 100%;
}

.l-footer__content {
	padding: 0 0.875rem 1.25rem;
}

.l-footer__content ul {
	-moz-column-gap: clamp(1.1875rem, 0.8327447023rem + 1.5136226034vw, 2.125rem);
	align-items: center;
	column-gap: clamp(1.1875rem, 0.8327447023rem + 1.5136226034vw, 2.125rem);
	display: flex;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.l-footer__content li {
	width: calc(33.3% - 0.6666666667rem);
}

.l-footer__content p {
	font-size: clamp(0.625rem, 0.4830978809rem + 0.6054490414vw, 1rem);
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
}

.l-footer__content p:not(:last-of-type) {
	margin-bottom: 0.375rem;
}

.l-footer__content p img {
	vertical-align: baseline;
	width: 0.625rem;
}

.l-footer__content-head {
	margin: 0 auto clamp(1.5rem, 0.9560418769rem + 2.3208879919vw, 2.9375rem);
	width: clamp(6.4375rem, 4.5454717457rem + 8.072653885vw, 11.4375rem);
}

.l-footer__content-logo {
	-moz-column-gap: 1.875rem;
	align-items: center;
	column-gap: 1.875rem;
	display: flex;
	justify-content: center;
	margin-bottom: clamp(0.75rem, 0.3715943491rem + 1.614530777vw, 1.75rem);
}

.l-footer__content-logo-item:first-of-type {
	width: clamp(1.875rem, 1.0235872856rem + 3.6326942482vw, 4.125rem);
}

.l-footer__content-logo-item:last-of-type {
	width: clamp(5.125rem, 2.7126639758rem + 10.2926337033vw, 11.5rem);
}

/*/* ============================ */

/* ============================ */

/* ============================
ボタン
 ========================= */

.c-button {
	-moz-column-gap: clamp(0.3125rem, 0.052346115rem + 1.1099899092vw, 1rem);
	align-items: center;
	background: linear-gradient(90deg, #FE5E00 0%, #FDB800 91%);
	border: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem) solid #E66F28;
	border-radius: 4.1875rem;
	box-shadow: 2px 4px 9px 0px rgba(0, 0, 0, 0.33);
	column-gap: clamp(0.3125rem, 0.052346115rem + 1.1099899092vw, 1rem);
	display: flex;
	justify-content: center;
	overflow: hidden;
	padding: clamp(0.8125rem, 0.3867936428rem + 1.8163471241vw, 1.9375rem) clamp(0.8125rem, -0.1808148335rem + 4.2381432896vw, 3.4375rem);
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.c-button::before {
	background-color: #fff;
	content: "";
	display: block;
	height: 70%;
	left: 0;
	opacity: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: cubic-bezier(0.32, 0, 0.67, 0);
	width: 30px;
}

.c-button::after {
	background: url(../img/svg/button.svg) no-repeat center center/cover;
	content: "";
	height: 100%;
	left: 50%;
	position: absolute;
	position: absolute;
	top: 0.0625rem;
	transform: translateX(-50%);
	width: 100%;
}

.c-button:hover {
	opacity: 1;
}

.c-button:hover::before {
	animation: kiran 0.5s linear;
}

.c-button img {
	flex-shrink: 0;
	width: clamp(1.875rem, 0.9053355197rem + 4.137235116vw, 4.4375rem);
}

.c-button span {
	color: #FFF;
	flex-shrink: 0;
	font-size: clamp(1.3125rem, 0.5793390515rem + 3.1281533804vw, 3.25rem);
	font-weight: 600;
	text-shadow: 0px 0px 14px #FE5F00;
}

.c-button span.--small {
	font-size: clamp(1.3125rem, 0.6739404642rem + 2.7245206862vw, 3rem);
}

.c-button.--header {
	padding: clamp(0.375rem, 0.2094475277rem + 0.7063572149vw, 0.8125rem) clamp(0.625rem, 0.3884964682rem + 1.0090817356vw, 1.25rem);
}

.c-button.--header img {
	width: clamp(1.25rem, 0.7060418769rem + 2.3208879919vw, 2.6875rem);
}

.c-button.--header span {
	font-size: clamp(0.875rem, 0.472943996rem + 1.7154389506vw, 1.9375rem);
}

.c-button.--header span .--small {
	font-size: clamp(0.8125rem, 0.4340943491rem + 1.614530777vw, 1.8125rem);
}

.c-button.--form {
	background: linear-gradient(-90deg, #FE5E00 0%, #FDB800 100%);
	margin: auto;
	padding: 1.125rem 1rem;
	transition: background 0.3s 0s ease-in-out;
	width: clamp(15.25rem, 10.2361251261rem + 21.3925327952vw, 28.5rem);
	z-index: 1;
}

.c-button.--form::before {
	background: linear-gradient(90deg, #FE5E00 0%, #FDB800 100%);
	bottom: 0;
	content: "";
	height: 100%;
	height: 100%;
	left: 0;
	opacity: 1;
	position: absolute;
	position: absolute;
	right: 0;
	top: 0;
	transform: none;
	transition: all 1s ease-out;
	width: 100%;
	z-index: -1;
}

.c-button.--form:hover::before {
	animation: none;
	opacity: 0;
}

.c-button.--form span {
	color: #fff;
	font-size: clamp(1.1875rem, 0.9036957619rem + 1.2108980827vw, 1.9375rem);
}

.c-button.--form span .--small {
	font-size: clamp(0.8125rem, 0.4340943491rem + 1.614530777vw, 1.8125rem);
}

.c-button.--prev {
	background: #ccc;
	border-color: #ccc;
	color: #333;
	font-size: clamp(0.875rem, 0.472943996rem + 1.7154389506vw, 1.9375rem);
}

.c-button.--prev::before,
.c-button.--prev::after {
	display: none;
}

/* ============================ */

/* ============================
c-heading_セクションタイトル
 ========================= */

.c-heading {
	color: #6cb32a;
	font-size: clamp(1.4375rem, 0.9171922301rem + 2.2199798184vw, 2.8125rem);
	margin-bottom: clamp(1.0625rem, 0.3529894046rem + 3.0272452069vw, 2.9375rem);
	padding-bottom: clamp(0.9375rem, 0.4171922301rem + 2.2199798184vw, 2.3125rem);
	position: relative;
	text-align: center;
}

.c-heading::after {
	background-color: #6cb32a;
	border-radius: 0.625rem;
	bottom: 0;
	content: "";
	height: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem);
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: clamp(1.9375rem, 1.3698915237rem + 2.4217961655vw, 3.4375rem);
}

/* ============================ */

/* ============================
cta
 ========================= */

.c-cta__heading {
	align-items: center;
	background: linear-gradient(90deg, #0D9BCE 71.5%, #1D4E8E 100%);
	color: #fff;
	display: flex;
	font-weight: 800;
	justify-content: center;
	padding: clamp(0.375rem, 0.114846115rem + 1.1099899092vw, 1.0625rem) 0.875rem;
}

.c-cta__heading p {
	font-size: clamp(1.25rem, 0.587790111rem + 2.8254288597vw, 3rem);
	letter-spacing: 7.68px;
}

.c-cta__heading p .--small {
	font-size: clamp(0.9375rem, 0.4408425832rem + 2.1190716448vw, 2.25rem);
	letter-spacing: 5.76px;
}

.c-cta__heading-count {
	align-items: center;
	display: flex;
}

.c-cta__content {
	background: url(../img/bg/cta-bg_pc.webp) no-repeat center center/cover;
}

.c-cta__content-inner {
	margin: 0 auto;
	max-width: 1232px;
	padding: 3.25rem 1rem 2.625rem;
	width: 100%;
}

.c-cta__heading-title {
	display: flex;
	flex-direction: column;
	margin-bottom: 1.25rem;
	row-gap: clamp(0.5rem, 0.3107971746rem + 0.8072653885vw, 1rem);
}

.c-cta__heading-title span.--text {
	display: block;
	font-weight: 800;
	line-height: 1;
	overflow: hidden;
	transform-origin: bottom;
}

.c-cta__heading-title span.--text.--first {
	-webkit-background-clip: text;
	background: linear-gradient(180deg, #1265A6 0%, #020B1B 62%);
	background-clip: text;
	color: transparent;
	font-size: clamp(1.5rem, 0.7195383451rem + 3.3299697275vw, 3.5625rem);
}

.c-cta__heading-title span.--text.--first.is-animation {
	transform: translateY(120%) scaleY(0);
}

.c-cta__heading-title span.--text.--first.is-animation.is-active {
	animation: text-up 0.8s ease-in-out forwards 0.4s;
}

.c-cta__heading-title span.--text.--second {
	-webkit-background-clip: text;
	background: linear-gradient(180deg, #1265A6 0%, #020B1B 62%);
	background-clip: text;
	color: transparent;
	font-size: clamp(2.125rem, 1.0134334006rem + 4.7426841574vw, 5.0625rem);
}

.c-cta__heading-title span.--text.--second.is-animation {
	transform: translateY(120%) scaleY(0);
}

.c-cta__heading-title span.--text.--second.is-animation.is-active {
	animation: text-up 0.8s ease-in-out forwards 0.6s;
}

.c-cta__heading-title span.--text.--third {
	-webkit-background-clip: text;
	background: linear-gradient(180deg, #1265A6 0%, #020B1B 62%);
	background-clip: text;
	color: transparent;
	font-size: clamp(1.3125rem, 0.1536326942rem + 4.9445005045vw, 4.375rem);
}

.c-cta__heading-title span.--text.--third.is-animation {
	transform: translateY(120%) scaleY(0);
}

.c-cta__heading-title span.--text.--third.is-animation.is-active {
	animation: text-up 0.8s ease-in-out forwards 0.8s;
}

.c-cta__heading-title span.--bg {
	overflow: hidden;
}

.c-cta__heading-title span.--bg.is-animation {
	display: block;
	padding: 0.375rem 0.3125rem;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
	z-index: 1;
}

.c-cta__heading-title span.--bg.is-animation.is-active {
	animation: bg 1s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.c-cta__heading-title span.--bg.is-animation.is-active::after {
	animation: bgExpand 2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
	background-color: #fff;
	border-radius: 0.1875rem;
	content: "";
	height: 100%;
	left: 0;
	padding: 0.125rem 0.375rem;
	position: absolute;
	top: 0;
	transform: scaleX(0);
	transform-origin: left;
	width: 100%;
	z-index: -1;
}

/* 背景色アニメーション */

/* ============================ */

/* ============================ */

/* ============================
アニメーション
 ========================= */

/* スライドインアップ */

/* フェードイン */

/* スライドインアップ */

/* ============================
p-fv
 ========================= */

/* ============================
p-about
 ========================= */

.p-about {
	padding: clamp(1.875rem, 1.4492936428rem + 1.8163471241vw, 3rem) 0 clamp(2rem, 1.1012865792rem + 3.8345105954vw, 4.375rem);
}

.p-about__wrap {
	-moz-column-gap: clamp(1rem, -2.5422948074rem + 7.3701842546vw, 3.75rem);
	align-items: center;
	column-gap: clamp(1rem, -2.5422948074rem + 7.3701842546vw, 3.75rem);
	display: flex;
	justify-content: space-between;
}

.p-about__wrap-content {
	flex: 1;
}

.p-about__heading {
	margin-bottom: clamp(1.5rem, 0.8850908174rem + 2.6236125126vw, 3.125rem);
	width: clamp(13.4375rem, 8.5891775984rem + 20.6861755802vw, 26.25rem);
}

.p-about__wrap-img {
	width: clamp(3.5625rem, 0.3224016145rem + 13.824419778vw, 12.125rem);
}

/* ============================
p-fun
 ========================= */

.p-fun {
	margin-bottom: clamp(2.5rem, 1.0809788093rem + 6.0544904137vw, 6.25rem);
}

.p-fun p {
	margin-bottom: clamp(1rem, 0.739846115rem + 1.1099899092vw, 1.6875rem);
	text-align: center;
}

.p-fun__heading {
	color: #6cb32a;
	font-size: clamp(1.4375rem, 0.9171922301rem + 2.2199798184vw, 2.8125rem);
	margin-bottom: clamp(1rem, 0.3614404642rem + 2.7245206862vw, 2.6875rem);
	text-align: center;
}

.p-fun__list {
	-moz-column-gap: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem);
	align-items: center;
	column-gap: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem);
	display: flex;
	justify-content: space-between;
}

/* ============================
p-cta
 ========================= */

.p-cta {
	margin-bottom: clamp(2.5rem, 1.1519298688rem + 5.751765893vw, 6.0625rem);
}

.p-cta ul {
	-moz-column-gap: clamp(1.5rem, 0.175580222rem + 5.6508577195vw, 5rem);
	align-items: center;
	column-gap: clamp(1.5rem, 0.175580222rem + 5.6508577195vw, 5rem);
	display: flex;
	justify-content: center;
}

.p-cta p {
	font-size: clamp(0.875rem, 0.6384964682rem + 1.0090817356vw, 1.5rem);
	margin-bottom: clamp(1.5rem, 0.9323915237rem + 2.4217961655vw, 3rem);
	text-align: center;
}

.p-cta__inner {
	border: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem) solid #6cb32a;
	border-radius: clamp(0.9375rem, 0.2989404642rem + 2.7245206862vw, 2.625rem);
	padding: clamp(1.0625rem, 0.400290111rem + 2.8254288597vw, 2.8125rem) clamp(1.0625rem, 0.2820383451rem + 3.3299697275vw, 3.125rem);
}

.p-cta__inner ul {
	-moz-column-gap: clamp(1.5rem, 0.2228809284rem + 5.4490413724vw, 4.875rem);
	align-items: center;
	column-gap: clamp(1.5rem, 0.2228809284rem + 5.4490413724vw, 4.875rem);
	display: flex;
	justify-content: center;
}

.p-cta__inner ul li {
	align-items: center;
	display: flex;
	flex-direction: column;
	max-width: clamp(6.25rem, 1.6381811302rem + 19.6770938446vw, 18.4375rem);
	row-gap: clamp(1rem, 0.6215943491rem + 1.614530777vw, 2rem);
}

.p-cta__heading {
	color: #6cb32a;
	font-size: clamp(1.25rem, 0.3039858729rem + 4.0363269425vw, 3.75rem);
	margin-bottom: clamp(0.75rem, 0.6553985873rem + 0.4036326942vw, 1rem);
	text-align: center;
}

.p-cta__qr {
	width: clamp(5rem, 2.1619576186rem + 12.1089808274vw, 12.5rem);
}

/* ============================
p-howto
 ========================= */

.p-howto {
	margin-bottom: clamp(1.875rem, 0.6924823411rem + 5.0454086781vw, 5rem);
}

/* ============================
p-step
 ========================= */

.p-step__inner {
	margin: 0 auto;
	max-width: 75.5625rem;
	padding: 0 0.875rem;
	width: 100%;
}

.p-step__heading {
	margin: 0 auto clamp(2.5rem, 0.8917759839rem + 6.8617558022vw, 6.75rem);
	width: clamp(17.375rem, -3.9812689203rem + 91.1200807265vw, 73.8125rem);
}

.p-step__wrap {
	margin: 0 auto;
	max-width: 62.875rem;
	width: 100%;
}

.p-step__content {
	background-color: #cce559;
	border-radius: clamp(0.375rem, 0.2330978809rem + 0.6054490414vw, 0.75rem);
	margin-bottom: clamp(2.8125rem, 0.7785696266rem + 8.6781029263vw, 8.1875rem);
	padding: clamp(1.75rem, 0.9931886983rem + 3.229061554vw, 3.75rem) clamp(1.0625rem, 0.4475908174rem + 2.6236125126vw, 2.6875rem) 0;
	position: relative;
}

.p-step__content-heading {
	background-color: #6cb32a;
	border-radius: clamp(0.8125rem, 0.2685418769rem + 2.3208879919vw, 2.25rem);
	color: #fff;
	font-size: clamp(1rem, 0.5506432896rem + 1.9172552977vw, 2.1875rem);
	left: 50%;
	letter-spacing: 0.1em;
	padding: clamp(0.4375rem, 0.0827447023rem + 1.5136226034vw, 1.375rem) clamp(1rem, 0.3614404642rem + 2.7245206862vw, 2.6875rem);
	position: absolute;
	text-align: center;
	top: 0;
	transform: translate(-50%, -50%);
	white-space: nowrap;
	width: -moz-fit-content;
	width: fit-content;
}

.p-step__list {
	-moz-column-gap: clamp(0.5rem, -0.466080402rem + 2.0100502513vw, 1.25rem);
	column-gap: clamp(0.5rem, -0.466080402rem + 2.0100502513vw, 1.25rem);
	display: flex;
	justify-content: center;
	position: relative;
}

.p-step__list::after {
	background: url(../img/common/illustration01.webp) no-repeat center center/cover;
	bottom: -3.125rem;
	content: "";
	height: clamp(4.5rem, 1.2599016145rem + 13.824419778vw, 13.0625rem);
	left: clamp(42.5rem, 24.7885259631rem + 36.850921273vw, 56.25rem);
	position: absolute;
	position: absolute;
	transform: translateY(50%);
	width: clamp(3.5625rem, 0.9846115035rem + 10.9989909183vw, 10.375rem);
}

.p-step__list-item {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.p-step__list-item-content {
	border-bottom: 0.25rem dotted #fff;
	margin-bottom: 0.75rem;
	padding-bottom: 0.75rem;
}

.p-step__list-item-content div {
	color: #006837;
	font-size: clamp(0.75rem, 0.6080978809rem + 0.6054490414vw, 1.125rem);
	font-weight: 700;
	margin-bottom: clamp(0.625rem, 0.5776992936rem + 0.2018163471vw, 0.75rem);
	text-align: center;
}

.p-step__list-item-content p {
	font-size: clamp(0.875rem, 0.8276992936rem + 0.2018163471vw, 1rem);
	line-height: 1.7;
	text-align: center;
}

.p-step__list-item-img {
	max-width: clamp(6rem, 3.1856079717rem + 12.0080726539vw, 13.4375rem);
	width: 100%;
}

.p-step__bottom {
	max-width: 60.5625rem;
	width: 100%;
}

/* ============================
p-area
 ========================= */

.p-area {
	padding: clamp(2.125rem, 2.527056004rem - 1.7154389506vw, 1.0625rem) 0 clamp(3.0625rem, 1.5961781029rem + 6.2563067608vw, 6.9375rem);
}

.p-area__heading {
	color: #6cb32a;
	font-size: clamp(1.4375rem, 0.9171922301rem + 2.2199798184vw, 2.8125rem);
	margin-bottom: clamp(1.0625rem, 0.3529894046rem + 3.0272452069vw, 2.9375rem);
	padding-bottom: clamp(0.9375rem, 0.4171922301rem + 2.2199798184vw, 2.3125rem);
	position: relative;
	text-align: center;
}

.p-area__heading::after {
	background-color: #6cb32a;
	border-radius: 0.625rem;
	bottom: 0;
	content: "";
	height: clamp(0.125rem, 0.0540489405rem + 0.3027245207vw, 0.3125rem);
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: clamp(1.9375rem, 1.3698915237rem + 2.4217961655vw, 3.4375rem);
}

.p-area__tabs {
	-moz-column-gap: 1rem;
	align-items: center;
	column-gap: 1rem;
	display: flex;
	justify-content: center;
	margin-bottom: clamp(3.4375rem, 2.4678355197rem + 4.137235116vw, 6rem);
}

.p-area__tabs-item {
	color: #fff;
	font-size: clamp(0.75rem, 0.3242936428rem + 1.8163471241vw, 1.875rem);
	text-align: center;
	width: calc(33.3% - 0.6666666667rem);
}

.p-area__tabs-link {
	border-radius: 6.25rem;
	padding: clamp(0.5625rem, 0.0658425832rem + 2.1190716448vw, 1.875rem) 0.5rem;
	position: relative;
}

.p-area__tabs-link::after {
	bottom: 0;
	content: "";
	height: clamp(1.25rem, 0.4695383451rem + 3.3299697275vw, 3.3125rem);
	left: 50%;
	position: absolute;
	transform: translate(-50%, 50%);
	width: clamp(1.25rem, 0.4695383451rem + 3.3299697275vw, 3.3125rem);
}

.p-area__tabs-item.--seibu .p-area__tabs-link {
	background-color: #3783c5;
}

.p-area__tabs-item.--seibu .p-area__tabs-link::after {
	background: url(../img/common/arrow-blue01.webp) no-repeat center center/cover;
}

.p-area__tabs-item.--tohbu .p-area__tabs-link {
	background-color: #44ae35;
}

.p-area__tabs-item.--tohbu .p-area__tabs-link::after {
	background: url(../img/common/arrow-green01.webp) no-repeat center center/cover;
}

.p-area__tabs-item.--nanbu .p-area__tabs-link {
	background-color: #d74490;
}

.p-area__tabs-item.--nanbu .p-area__tabs-link::after {
	background: url(../img/common/arrow-pink01.webp) no-repeat center center/cover;
}

.p-area__box {
	border-radius: clamp(0.3125rem, 0.1942482341rem + 0.5045408678vw, 0.625rem);
	margin-bottom: clamp(3.125rem, 2.3208879919rem + 3.4308779011vw, 5.25rem);
	padding: clamp(2rem, 0.6282795156rem + 5.8526740666vw, 5.625rem) clamp(0.875rem, 0.0235872856rem + 3.6326942482vw, 3.125rem) clamp(0.9375rem, 0.2279894046rem + 3.0272452069vw, 2.8125rem);
	position: relative;
}

.p-area__box:last-of-type {
	margin-bottom: clamp(1.5625rem, 0.8293390515rem + 3.1281533804vw, 3.5rem);
}

.p-area__box.--seibu {
	background-color: #b9dbf3;
}

.p-area__box.--tohbu {
	background-color: #cce559;
}

.p-area__box.--nanbu {
	background-color: #f0c5db;
}

.p-area__box-heading {
	border-radius: 6.25rem;
	color: #fff;
	font-size: clamp(1.125rem, 0.722943996rem + 1.7154389506vw, 2.1875rem);
	left: 50%;
	padding: clamp(0.4375rem, 0.3428985873rem + 0.4036326942vw, 0.6875rem) 0.375rem;
	position: absolute;
	text-align: center;
	top: 0;
	transform: translate(-50%, -50%);
	width: clamp(9.5rem, 5.9997477296rem + 14.9344096872vw, 18.75rem);
}

.p-area__box.--seibu .p-area__box-heading {
	background-color: #3783c5;
}

.p-area__box.--tohbu .p-area__box-heading {
	background-color: #44ae35;
}

.p-area__box.--nanbu .p-area__box-heading {
	background-color: #d74490;
}

.p-area__box-list {
	display: flex;
	flex-wrap: wrap;
	gap: 3rem 1.875rem;
}

.p-area__box-item {
	width: calc(33.3% - 1.25rem);
}

.p-area__box-item p {
	font-size: clamp(0.875rem, 0.7330978809rem + 0.6054490414vw, 1.25rem);
	line-height: 1.4;
	text-align: center;
	white-space: nowrap;
}

.p-area__box-item:nth-of-type(1),
.p-area__box-item:nth-of-type(4) {
	margin-top: 2.5rem;
}

.p-area__box-item:nth-of-type(3),
.p-area__box-item:nth-of-type(6) {
	margin-top: -2.5rem;
}

.p-area__box.--seibu p {
	color: #0054a5;
}

.p-area__box.--tohbu p {
	color: #008642;
}

.p-area__box.--nanbu p {
	color: #d61873;
}

.p-area__box-img {
	margin-bottom: clamp(0.9375rem, 0.6300454087rem + 1.3118062563vw, 1.75rem);
	position: relative;
}

.p-area__box-img::after {
	border-radius: clamp(0.4375rem, 0.2246468214rem + 0.9081735621vw, 1rem);
	bottom: 0;
	color: #fff;
	content: attr(data-point);
	display: grid;
	font-size: clamp(0.75rem, 0.5607971746rem + 0.8072653885vw, 1.25rem);
	font-weight: 700;
	height: clamp(1.125rem, 0.8175454087rem + 1.3118062563vw, 1.9375rem);
	left: 50%;
	place-content: center;
	position: absolute;
	transform: translate(-50%, 50%);
	width: clamp(3rem, 1.7701816347rem + 5.2472250252vw, 6.25rem);
}

.p-area__box.--seibu .p-area__box-img::after {
	background-color: #0054a5;
}

.p-area__box.--tohbu .p-area__box-img::after {
	background-color: #008642;
}

.p-area__box.--nanbu .p-area__box-img::after {
	background-color: #d61873;
}

.p-area__bottom-text {
	font-size: clamp(0.75rem, 0.6553985873rem + 0.4036326942vw, 1rem);
	font-weight: 500;
}

/* ============================
p-campaign
 ========================= */

.p-campaign {
	margin-bottom: clamp(4.1875rem, 2.8867305752rem + 5.5499495459vw, 7.625rem);
	padding-top: clamp(3.0625rem, 1.5961781029rem + 6.2563067608vw, 6.9375rem);
	position: relative;
	z-index: 1;
}

.p-campaign::before {
	background: url(../img/bg/bg_pc02.webp) no-repeat center top/cover;
	content: "";
	height: 100%;
	left: 50%;
	position: absolute;
	top: 0;
	transform: translateX(-50%);
	width: 100%;
	z-index: -1;
}

.p-campaign__howto {
	background-color: #fbe3c3;
	border-radius: clamp(0.25rem, 0.0607971746rem + 0.8072653885vw, 0.75rem);
	margin-bottom: clamp(1.125rem, 0.6756432896rem + 1.9172552977vw, 2.3125rem);
	overflow: hidden;
}

.p-campaign__howto-heading {
	background-color: #6cb32a;
	color: #fff;
	font-size: clamp(1.125rem, 0.8411957619rem + 1.2108980827vw, 1.875rem);
	padding: 0.625rem 0;
	text-align: center;
}

.p-campaign__howto-list {
	padding: clamp(0.625rem, 0.1992936428rem + 1.8163471241vw, 1.75rem) clamp(0.875rem, 0.1418390515rem + 3.1281533804vw, 2.8125rem) clamp(0.9375rem, 0.4171922301rem + 2.2199798184vw, 2.3125rem);
}

.p-campaign__howto-item:not(:last-of-type) {
	margin-bottom: clamp(0.75rem, 0.5607971746rem + 0.8072653885vw, 1.25rem);
}

.p-campaign__howto-item p {
	font-size: clamp(0.875rem, 0.8276992936rem + 0.2018163471vw, 1rem);
	font-weight: 500;
	line-height: 1.4;
}

.p-campaign__howto-item p small {
	display: inline-block;
	font-size: 0.75rem;
	margin-left: clamp(0.125rem, -0.3480070636rem + 2.0181634712vw, 1.375rem);
}

.p-campaign__howto-item .--flex {
	display: none;
	margin: 0.625rem 0;
}

.p-campaign__howto-item .--flex p {
	font-size: 0.625rem;
}

.p-campaign__howto-item .--img {
	aspect-ratio: 93/25;
	height: 100%;
	max-width: 5.8125rem;
	overflow: hidden;
	width: 100%;
}

.p-campaign__howto-item-heading {
	-moz-column-gap: clamp(0.5rem, 0.4053985873rem + 0.4036326942vw, 0.75rem);
	align-items: center;
	column-gap: clamp(0.5rem, 0.4053985873rem + 0.4036326942vw, 0.75rem);
	display: flex;
	margin-bottom: clamp(0.5rem, 0.2634964682rem + 1.0090817356vw, 1.125rem);
}

.p-campaign__howto-item-heading h4 {
	color: #003881;
}

.p-campaign__howto-item-heading div {
	border-top: clamp(0.25rem, 0.2263496468rem + 0.1009081736vw, 0.3125rem) dotted #fff;
	flex: 1;
}

.p-campaign__about {
	border-radius: clamp(0.25rem, 0.0607971746rem + 0.8072653885vw, 0.75rem);
	color: #fff;
	padding: clamp(0.625rem, 0.3884964682rem + 1.0090817356vw, 1.25rem) clamp(0.875rem, 0.1418390515rem + 3.1281533804vw, 2.8125rem) clamp(0.9375rem, 0.4171922301rem + 2.2199798184vw, 2.3125rem);
}

.p-campaign__about.--green {
	background-color: #47a738;
	margin-bottom: clamp(1.125rem, 0.6756432896rem + 1.9172552977vw, 2.3125rem);
}

.p-campaign__about.--blue {
	background-color: #3783c5;
}

.p-campaign__about.--blue .p-campaign__about-content-img {
	border-radius: 0.625rem;
	overflow: hidden;
}

.p-campaign__about-heading {
	-moz-column-gap: clamp(0.5rem, 0.3107971746rem + 0.8072653885vw, 1rem);
	align-items: center;
	border-bottom: clamp(0.25rem, 0.2263496468rem + 0.1009081736vw, 0.3125rem) dotted #fff;
	column-gap: clamp(0.5rem, 0.3107971746rem + 0.8072653885vw, 1rem);
	display: flex;
	margin-bottom: clamp(0.875rem, 0.8276992936rem + 0.2018163471vw, 1rem);
	padding-bottom: clamp(0.875rem, 0.8276992936rem + 0.2018163471vw, 1rem);
}

.p-campaign__about-heading h3 {
	font-size: clamp(1.125rem, 0.8411957619rem + 1.2108980827vw, 1.875rem);
}

.p-campaign__about-heading-number {
	align-items: center;
	background-color: #ffe800;
	border-radius: 50%;
	color: #004096;
	display: flex;
	flex-direction: column;
	height: 5.9375rem;
	justify-content: center;
	white-space: nowrap;
	width: 5.9375rem;
}

.p-campaign__about-heading-number span {
	font-emphasize: 700px;
	display: block;
	font-family: "M PLUS Rounded 1c", sans-serif;
	line-height: 1;
}

.p-campaign__about-heading-number .--small {
	font-size: 0.625rem;
	margin-top: 0.3125rem;
}

.p-campaign__about-heading-number .--big {
	font-size: 0.9375rem;
}

.p-campaign__about-heading-number .--number {
	font-size: clamp(1.75rem, 1.7026992936rem + 0.2018163471vw, 1.875rem);
}

.p-campaign__about-content {
	-moz-column-gap: clamp(1.25rem, -0.9236809045rem + 4.5226130653vw, 2.9375rem);
	align-items: center;
	column-gap: clamp(1.25rem, -0.9236809045rem + 4.5226130653vw, 2.9375rem);
	display: flex;
}

.p-campaign__about-content p {
	font-size: clamp(0.875rem, 0.7330978809rem + 0.6054490414vw, 1.25rem);
	line-height: 1.5;
}

.p-campaign__about-content small {
	display: block;
	font-size: clamp(0.75rem, 0.6317482341rem + 0.5045408678vw, 1.0625rem);
	margin-top: clamp(1rem, 0.9053985873rem + 0.4036326942vw, 1.25rem);
}

.p-campaign__about-content-text {
	flex: 1;
}

.p-campaign__about-content-img {
	max-width: 16.75rem;
}

/* ============================
p-course
 ========================= */

.p-course {
	position: relative;
	z-index: 1;
}

.p-course::after {
	background: url(../img/common/illustration02.webp) no-repeat center center/cover;
	content: "";
	height: clamp(5.3125rem, 1.0554364279rem + 18.1634712412vw, 16.5625rem);
	left: clamp(39.375rem, 3.9520519263rem + 73.7018425461vw, 66.875rem);
	position: absolute;
	top: -1.9375rem;
	transform: translateY(-50%);
	width: clamp(4.75rem, 0.9186427851rem + 16.3471241171vw, 14.875rem);
}

.p-course__box {
	border-radius: clamp(0.1875rem, 0.0219475277rem + 0.7063572149vw, 0.625rem);
	margin-bottom: clamp(1.125rem, 0.202636226rem + 3.9354187689vw, 3.5625rem);
	padding: clamp(0.5rem, 0.0506432896rem + 1.9172552977vw, 1.6875rem) clamp(0.875rem, 0.0235872856rem + 3.6326942482vw, 3.125rem) clamp(0.9375rem, 0.1097376387rem + 3.5317860747vw, 3.125rem);
}

.p-course__box.--tohbu {
	padding-bottom: clamp(0.9375rem, 0.7482971746rem + 0.8072653885vw, 1.4375rem);
}

.p-course__box.--nanbu {
	margin-bottom: clamp(1.5625rem, 0.8056886983rem + 3.229061554vw, 3.5625rem);
}

.p-course__box p {
	align-items: center;
	display: flex;
	font-size: clamp(0.625rem, 0.3884964682rem + 1.0090817356vw, 1.25rem);
	justify-content: center;
	line-height: 1.4;
	text-align: center;
	white-space: nowrap;
}

.p-course__box.--seibu {
	background-color: #b9dbf3;
}

.p-course__box.--tohbu {
	background-color: #cce559;
}

.p-course__box.--nanbu {
	background-color: #f0c5db;
}

.p-course__box-heading {
	margin: 0 auto clamp(0.625rem, 0.2702447023rem + 1.5136226034vw, 1.5625rem);
	width: clamp(4.375rem, 2.8140766902rem + 6.6599394551vw, 8.5rem);
}

.p-course__box-list {
	-moz-column-gap: 1.5625rem;
	column-gap: 1.5625rem;
	display: flex;
}

.p-course__box-item {
	width: calc(33.3% - 1.0416666667rem);
}

.p-course__box-item:last-of-type .p-course__box-item-img::before {
	display: none;
}

.p-course__box-item-img {
	margin-bottom: clamp(0.75rem, 0.3952447023rem + 1.5136226034vw, 1.6875rem);
	position: relative;
}

.p-course__box-item-img::before {
	content: "";
	height: clamp(0.625rem, 0.1519929364rem + 2.0181634712vw, 1.875rem);
	position: absolute;
	right: -2.375rem;
	top: 50%;
	transform: translateY(-50%);
	width: clamp(1.125rem, 0.2735872856rem + 3.6326942482vw, 3.375rem);
	z-index: 1;
}

.p-course__box-item-img::after {
	border: clamp(0.0625rem, 0.0388496468rem + 0.1009081736vw, 0.125rem) solid #fff;
	border-radius: clamp(0.4375rem, 0.2246468214rem + 0.9081735621vw, 1rem);
	bottom: 0;
	color: #fff;
	content: attr(data-point);
	display: grid;
	font-size: clamp(0.75rem, 0.5607971746rem + 0.8072653885vw, 1.25rem);
	font-weight: 700;
	height: clamp(1.125rem, 0.8175454087rem + 1.3118062563vw, 1.9375rem);
	left: 50%;
	place-content: center;
	position: absolute;
	transform: translate(-50%, 50%);
	width: clamp(3rem, 1.7701816347rem + 5.2472250252vw, 6.25rem);
}

.p-course__box.--seibu .p-course__box-item-img::before {
	background: url(../img/common/arrow-blue02.webp) no-repeat center center/cover;
}

.p-course__box.--seibu .p-course__box-item-img::after {
	background-color: #0054a5;
	border-color: #b9dbf3;
}

.p-course__box.--tohbu .p-course__box-item-img::before {
	background: url(../img/common/arrow-green02.webp) no-repeat center center/cover;
}

.p-course__box.--tohbu .p-course__box-item-img::after {
	background-color: #008642;
	border-color: #cce559;
}

.p-course__box.--nanbu .p-course__box-item-img::before {
	background: url(../img/common/arrow-pink02.webp) no-repeat center center/cover;
}

.p-course__box.--nanbu .p-course__box-item-img::after {
	background-color: #d61873;
	border-color: #f0c5db;
}

.p-course__box.--seibu p {
	color: #0054a5;
}

.p-course__box.--tohbu p {
	color: #008642;
}

.p-course__box.--nanbu p {
	color: #d61873;
}

.p-course__bottom p {
	font-size: clamp(0.875rem, 0.8276992936rem + 0.2018163471vw, 1rem);
	font-weight: 500;
	line-height: 1.5;
}

/* ========================================== */

/* ============================
アニメーション
 ========================= */

/* スライドインアップ */

.is-animation {
	opacity: 0;
}

.is-animation.is-active {
	animation: slide-in-up 0.4s ease-in-out forwards 0.1s;
}

/* ============================ */

/* ============================ */

/* ============================
u-font
 ========================= */

.u-font--base {
	font-size: clamp(0.875rem, 0.6621468214rem + 0.9081735621vw, 1.4375rem);
	letter-spacing: 0.05em;
	line-height: 1.8;
}

.u-font--orange {
	color: #ffe800;
}

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

html {
	font-size: 1.1713030747vw;
}

}

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

html {
	font-size: max(1.1713030747vw, 14px);
}

}

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

.p-step__list::after {
	bottom: 0;
}

}

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

html {
	scroll-padding-top: 4.875rem;
}

.l-header {
	background-color: #fff;
	height: 3.75rem;
}

.l-header.is-active .l-header__nav-link {
	color: #fff;
	text-shadow: none;
}

.l-header__inner {
	align-items: center;
}

.l-header__logo {
	padding: 0;
}

.l-header__drawer-button {
	display: block;
}

.l-header__content {
	background: #6cb32a;
	flex-direction: column;
	height: 100svh;
	left: 0;
	position: fixed;
	top: 0;
	transform: translateX(105%);
	transition: transform 0.5s ease 0s;
	width: 100%;
}

.l-header__content.is-visible {
	overflow-x: scroll;
	transform: translateX(0);
}

.l-header__nav {
	padding: 6.5rem 0.875rem 0;
	width: 100%;
}

.l-header__nav-list {
	align-items: flex-start;
	flex-direction: column;
	row-gap: 1.5rem;
}

.l-header__content--sp {
	background: url(../img/bg/footer-bg_sp.webp) no-repeat center -1.875rem/cover;
	display: block;
}

.l-main {
	margin-top: 3.75rem;
}

}

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

html {
	font-size: max(4.2666666667vw, 14px);
}

.--pc-only {
	display: none;
}

.--sp-only {
	display: block;
}

.l-header__nav-link {
	font-size: 1.125rem;
}

.l-header__content--sp {
	background: url(../img/bg/footer-bg_sp.webp) no-repeat center top/cover;
}

.l-main {
	background: url(../img/bg/bg_pc.webp) no-repeat center -11.1875rem/cover;
}

.l-footer {
	background: url(../img/bg/footer-bg_sp.webp) no-repeat center top/cover;
}

.l-footer__bg {
	border: none;
}

.c-button::before {
	transition: all 0.6s cubic-bezier(0.32, 0, 0.67, 0);
}

.c-button::after {
	background: url(../img/svg/button_sp.svg) no-repeat center center/cover;
}

.c-cta__heading p {
	letter-spacing: 2.218px;
}

.c-cta__heading p .--small {
	letter-spacing: 1.663px;
}

.c-cta__content-inner {
	padding: 1.6875rem 1rem 1.125rem;
}

.p-about__wrap {
	flex-direction: column-reverse;
	row-gap: 1.5rem;
}

.p-about__heading {
	margin: 0 auto 1.5rem;
}

.p-fun p {
	text-align: left;
}

.p-step__content {
	padding-bottom: 1rem;
}

.p-step__list::after {
	bottom: 0;
	left: auto;
	right: -1.25rem;
}

.p-step__list {
	flex-direction: column;
}

.p-step__list-item {
	-moz-column-gap: 1.875rem;
	border-bottom: 0.25rem dotted #fff;
	column-gap: 1.875rem;
	flex-direction: row;
	justify-content: space-between;
	padding: 0.375rem 1.875rem 0;
}

.p-step__list-item-content {
	align-items: center;
	border-bottom: none;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-bottom: 0;
}

.p-area__tabs {
	-moz-column-gap: 0.375rem;
	column-gap: 0.375rem;
}

.p-area__tabs-item {
	width: calc(33.3% - 0.25rem);
}

.p-area__box-list {
	gap: 0.9375rem 0.375rem;
}

.p-area__box-item {
	width: calc(50% - 0.1875rem);
}

.p-area__box-item:nth-of-type(1),
.p-area__box-item:nth-of-type(4),
.p-area__box-item:nth-of-type(3),
.p-area__box-item:nth-of-type(6) {
	margin-top: 0;
}

.p-campaign::before {
	background-image: url(../img/bg/bg_sp02.webp);
	top: -3.125rem;
}

.p-campaign__howto-item .--flex {
	-moz-column-gap: 0.75rem;
	align-items: center;
	column-gap: 0.75rem;
	display: flex;
}

.p-campaign__about-heading {
	flex-direction: column;
	row-gap: 0.5rem;
}

.p-campaign__about-content {
	flex-direction: column-reverse;
	row-gap: 1.5rem;
}

.p-campaign__about-content-img {
	max-width: 100%;
}

.p-course::after {
	left: 17.5rem;
}

.p-course__box-list {
	-moz-column-gap: 0.625rem;
	column-gap: 0.625rem;
}

.p-course__box-item {
	width: calc(33.3% - 0.4166666667rem);
}

.p-course__box-item-img::before {
	right: -0.875rem;
}

.u-font--base {
	line-height: 1.7;
}

}

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

.p-course__box p {
	white-space: wrap;
}

}

@keyframes kiran {

0% {
	opacity: 0;
	transform: scale(2) rotate(45deg);
}

20% {
	opacity: 0.6;
	transform: scale(20) rotate(45deg);
}

40% {
	opacity: 0.4;
	transform: scale(30) rotate(45deg);
}

80% {
	opacity: 0.2;
	transform: scale(45) rotate(45deg);
}

100% {
	opacity: 0;
	transform: scale(50) rotate(45deg);
}

}

@keyframes bgExpand {

0% {
	transform: scaleX(0);
}

100% {
	transform: scaleX(1);
}

}

@keyframes slide-in-up {

from {
	opacity: 0;
	transform: translate3d(0, 100%, 0);
	visibility: visible;
}

to {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}

}

@keyframes fade-in {

from {
	opacity: 0;
}

to {
	opacity: 1;
}

}

@keyframes slide-in-up-mv {

from {
	opacity: 0;
	transform: translate3d(0, 100%, 0) scale(var(--scale-value));
	visibility: visible;
}

to {
	opacity: 1;
	transform: translate3d(0, 0, 0) scale(var(--scale-value));
}

}

@keyframes slide-in-up {

from {
	opacity: 0;
	transform: translateY(20px);
	visibility: visible;
}

to {
	opacity: 1;
	transform: translateY(0);
}

}

