@charset "UTF-8";

:root {
    --white: #fff;
    --black: #000;
    --gray01: #F9F9F9;
    --gray02: #F2F2F2;
    --gray03: #E6E6E6;
    --gray04: #CCC;
    --gray05: #B3B3B3;
    --gray06: #999;
    --gray07: gray;
    --gray08: #666;
    --gray09: #4D4D4D;
    --gray10: #333;
    --red01: #ff0001;
    --blue01: #1ca6d0;
    --green01: #15c39a;
    --border: var(--gray04);
    --accent: var(--red01);
    --inactive: var(--gray06);
    --disabled: var(--gray06);
    --japanese-sans-serif: "IBM Plex Sans JP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Arial, sans-serif;
    --english-sans-serif: "Poppins", var(--japanese-sans-serif);
    --space-xs: clamp(1.25rem, 0.1389rem + 2.3148vw, 1.875rem);
    --space-sm: calc(var(--space-xs) * 1.5);
    --space-md: calc(var(--space-xs) * 2);
    --space-lg: calc(var(--space-xs) * 3);
    --space-xl: calc(var(--space-xs) * 4);
    --easeOutQuint: cubic-bezier(.22, 1, .36, 1)
}

*,
*::before,
*::after {
    box-sizing: border-box
}

html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    scroll-behavior: auto
}

body {
    color: var(--black);
    font-family: var(--english-sans-serif);
    font-optical-sizing: auto;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.8;
    text-align: left;
    margin: 0;
    background-color: #fff
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
a {
    display: block
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0
}

p {
    margin: 0
}

p a {
    display: inline-block
}

abbr[title],
abbr[data-original-title] {
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
    -webkit-text-decoration-skip-ink: none;
    text-decoration-skip-ink: none
}

address {
    font-style: normal;
    line-height: inherit;
    margin: 0
}

ol,
ul,
dl,
ol ol,
ul ul,
ol ul,
ul ol {
    padding: 0;
    margin: 0
}

ol li,
ul li {
    list-style-position: inside;
    padding: 0
}

ul li,
ol li {
    list-style: none
}

dt {
    font-weight: 700
}

dd {
    margin: 0
}

blockquote {
    margin: 0 0 1rem
}

b,
strong {
    font-weight: bolder
}

small {
    font-size: 80%
}

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

a,
p a {
    color: var(--active);
    display: block;
    text-decoration: none;
    background-color: transparent
}

a:hover {
    color: var(--active)
}

a:not([href]):not([class]) {
    color: inherit;
    text-decoration: none
}

a:not([href]):not([class]):hover {
    color: inherit;
    text-decoration: none
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre,
code,
kbd,
samp {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 1em
}

pre {
    margin: 0;
    overflow: auto
}

figure {
    margin: 0
}

img {
    width: 100%;
    max-width: 100%;
    height: auto;
    vertical-align: top;
    border-style: none
}

svg {
    overflow: hidden;
    vertical-align: middle
}

table {
    width: 100%;
    border-collapse: collapse
}

caption {
    color: var(--black);
    text-align: left;
    caption-side: bottom
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent
}

label {
    display: inline-block;
    margin: 0
}

button {
    border-radius: 0
}

button:focus:not(:focus-visible) {
    outline: 0
}

input,
button,
select,
optgroup,
textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit
}

button,
input {
    overflow: visible;
    vertical-align: top;
    padding: .2rem .5rem
}

button,
select {
    text-transform: none
}

[role=button] {
    cursor: pointer
}

select {
    word-wrap: normal
}

button,
[type=button],
[type=reset],
[type=submit] {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button
}

button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
    cursor: pointer
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
    padding: 0;
    border-style: none
}

input[type=radio],
input[type=checkbox] {
    box-sizing: border-box;
    padding: 0
}

input[type=text],
input[type=tel],
input[type=email],
input[type=search],
input[type=submit] {
    outline: none;
    border: 1px solid var(--border)
}

textarea {
    overflow: auto;
    resize: vertical
}

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

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin: 0 0 .5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal
}

progress {
    vertical-align: baseline
}

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

[type=search] {
    outline-offset: -2px;
    -webkit-appearance: none
}

input[type=search]::-webkit-search-cancel-button {
    cursor: pointer
}

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

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button
}

output {
    display: inline-block
}

summary {
    display: list-item;
    cursor: pointer
}

template {
    display: none
}

[tabindex="-1"]:focus:not(:focus-visible) {
    outline: 0 !important
}

button,
input[type=submit],
input[type=button] {
    border: none;
    outline: none;
    background: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

button,
select,
input {
    color: var(--black);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0
}

button::-moz-placeholder,
select::-moz-placeholder,
input::-moz-placeholder {
    color: var(--black)
}

button::placeholder,
select::placeholder,
input::placeholder {
    color: var(--black)
}

::-webkit-scrollbar {
    width: 15px
}

::-webkit-scrollbar-track {
    border-radius: 10px;
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .1)
}

::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, .5);
    border-radius: 10px;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .5)
}

.l-wrapper {
    overflow: hidden
}

.l-header {
    color: var(--black);
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 101;
    padding: 12px 0 0;
    transition: all 0.8s var(--easeOutQuint)
}

.l-header.is-active {
    background-color: rgba(255, 255, 255, .95)
}

.l-header.is-show {
    top: -150px
}

.l-header__inner {
    display: flex;
    align-items: center;
    max-width: 1300px;
    padding-left: 15px;
    padding-right: 20px;
    margin-left: auto;
    margin-right: auto
}

.l-header__logo {
    width: 32%;
    margin: 0 auto 0 0
}

.l-header__gnav {
    display: none;
    margin-right: 2.8%
}

.l-header__button {
    display: none
}

@media screen and (min-width:500px) {
    .l-header {
        padding: 18px 0 0
    }

    .l-header__inner {
        padding-left: 20px;
        padding-right: 35px
    }

    .l-header__logo {
        width: 28%
    }
}

@media screen and (min-width:1024px) {
    .l-header {
        position: fixed;
        padding: 18px 0
    }

    .l-header__inner {
        padding-left: 50px;
        padding-right: 50px
    }

    .l-header__logo {
        width: 17%;
        max-width: 171px
    }

    .l-header__gnav {
        display: block
    }

    .l-header__button {
        display: block
    }
}

@media screen and (min-width:1200px) {
    .l-header__logo {
        width: 428px
    }
}

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

.c-logo>img {
    width: 86%;
    max-width: 171px
}

.c-logo>span {
    display: inline-block;
    line-height: 1;
    font-size: 12px;
    font-size: .75rem;
    font-size: clamp(.75rem, 0.5681818182rem + 0.9090909091vw, 1.25rem);
    font-weight: 400;
    margin-left: .8em;
    white-space: nowrap
}

a.c-logo {
    transition: all 0.35s ease
}

a.c-logo:hover {
    color: var(--blue01);
    opacity: .5
}

.c-globalNavi__list {
    display: flex
}

.c-globalNavi__item {
    font-size: 5px;
    font-size: .3125rem;
    font-size: clamp(.3125rem, 0.0625rem + 1.25vw, 1rem);
    margin: 0
}

.c-globalNavi__item a {
    color: var(--black);
    line-height: 1;
    position: relative;
    font-size: inherit;
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap
}

.c-globalNavi__item a:hover:after {
    transform: scale(1, 1);
    transform-origin: top left
}

.c-globalNavi__item a:after {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--black);
    transform: scale(0, 1);
    transform-origin: top right;
    transition: transform 0.2s;
    position: absolute;
    bottom: -8px;
    left: 0
}

.c-globalNavi__item+* {
    margin-left: 1.4em
}

.c-offcanvas {
    width: 100%;
    height: 100%
}

.c-offcanvas.is-active .c-offcanvas__button::before {
    width: 87px;
    visibility: visible;
    transform: rotate(0deg)
}

.c-offcanvas.is-active .c-offcanvas__button::after {
    transform: rotate(90deg)
}

.c-offcanvas.is-active .c-offcanvas__hamburger {
    background-color: transparent
}

.c-offcanvas.is-active .c-offcanvas__hamburger::before {
    width: 32px;
    margin-top: 8px;
    left: calc(50% - 16px);
    transform: rotate(135deg)
}

.c-offcanvas.is-active .c-offcanvas__hamburger::after {
    width: 32px;
    margin-top: 8px;
    left: calc(50% - 16px);
    transform: rotate(-135deg)
}

.c-offcanvas.is-active .c-offcanvas__body {
    right: 0
}

.c-offcanvas.is-active .c-offcanvas__menu {
    top: calc(32% + 32px)
}

.c-offcanvas__button {
    transform: scale(.5);
    transform-origin: top right;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    width: 85px;
    height: 85px;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2003;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    transition: all 0.35s ease
}

.c-offcanvas__button::before {
    content: "";
    display: block;
    width: 0;
    visibility: hidden;
    height: 87px;
    background: url(../img/bg-ofc-close.png) no-repeat 0 0/cover;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -2;
    transform: rotate(-90deg);
    transform-origin: top right;
    transition: all 0.2s ease
}

.c-offcanvas__button::after {
    content: "";
    display: block;
    width: 105px;
    height: 105px;
    background: url(../img/bg-ofc-menu.png) no-repeat 0 0/cover;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    transform: rotate(0deg);
    transform-origin: top right;
    transition: all 0.2s ease
}

.c-offcanvas__hamburger {
    display: block;
    width: 36px;
    height: 3px;
    margin: 30% auto auto;
    background-color: #FFF;
    transform-origin: center;
    transition: all 0.35s var(--easeOutQuint)
}

.c-offcanvas__hamburger::before,
.c-offcanvas__hamburger::after {
    display: block;
    content: "";
    width: 36px;
    height: 3px;
    background-color: #FFF;
    transform-origin: center;
    transition: all 0.35s ease 0.1s;
    position: absolute;
    top: calc(32% - 1.5px);
    left: calc(50% - 18px)
}

.c-offcanvas__hamburger::before {
    transform: translateY(13px)
}

.c-offcanvas__hamburger::after {
    transform: translateY(-13px)
}

.c-offcanvas__menu {
    color: #FFF;
    display: block;
    line-height: 1;
    font-size: 16px;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0;
    position: absolute;
    top: calc(32% + 27px);
    left: 50%;
    transform: translateX(-50%);
    transition: all 0.35s var(--easeOutQuint)
}

.c-offcanvas__body {
    width: 100vw;
    height: 100dvh;
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 11% 11%;
    background: #FFF;
    transition: all 0.5s ease;
    position: fixed;
    right: -120%;
    top: 0;
    z-index: 2002
}

.c-offcanvas__overlay {
    opacity: 0;
    visibility: hidden;
    cursor: pointer;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, .8);
    transition: all 0.5s ease;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2001
}

.c-offcanvas__overlay.is-visible {
    opacity: 1;
    visibility: visible
}

.c-offcanvas__list {
    width: 100%;
    display: flex;
    flex-direction: column;
    margin: 0 auto
}

.c-offcanvas__item {
    font-size: 17px;
    font-size: 1.0625rem;
    font-size: clamp(1.0625rem, 0.5rem + 2.8125vw, 1.625rem);
    font-weight: 800;
    letter-spacing: 0;
    list-style: none;
    padding: 0
}

.c-offcanvas__item a {
    color: var(--black);
    display: block;
    padding: .6em 0;
    border-bottom: 1px solid #707070;
    transition: all 0.35s ease
}

.c-offcanvas__item a.is-current {
    color: var(--accent)
}

.c-offcanvas__item a:hover {
    opacity: .5
}

.c-offcanvas__footer {
    margin-top: var(--space-lg)
}

.c-offcanvas__title {
    color: #FF4442;
    position: relative;
    display: table;
    line-height: 1;
    font-size: 17px;
    font-size: 1.0625rem;
    font-size: clamp(1.0625rem, 0.125rem + 4.6875vw, 2rem);
    font-weight: 700;
    text-align: center;
    white-space: nowrap;
    letter-spacing: 0;
    text-indent: .1em;
    margin: 0 auto .8em
}

.c-offcanvas__title::before,
.c-offcanvas__title::after {
    content: "";
    display: block;
    width: 3px;
    height: 30px;
    border-radius: 10px;
    background-color: #FF4442;
    position: absolute;
    top: 50%;
    transform-origin: center center
}

.c-offcanvas__title::before {
    right: calc(100% + 18px);
    transform: translateY(-50%) rotate(-30deg)
}

.c-offcanvas__title::after {
    left: calc(100% + 18px);
    transform: translateY(-50%) rotate(30deg)
}

@media screen and (min-width:375px) {
    .c-offcanvas__button {
        transform: scale(.6)
    }
}

@media screen and (min-width:500px) {
    .c-offcanvas__button {
        transform: scale(.8)
    }

    .c-offcanvas__body {
        padding: 100px 11%
    }
}

@media screen and (min-width:641px) {
    .c-offcanvas__button {
        transform: scale(.9)
    }

    .c-offcanvas__footer {
        margin-top: 75px
    }

    .c-offcanvas__footer .c-buttonUnit__item a {
        min-height: 80px
    }
}

@media screen and (min-width:820px) {
    .c-offcanvas__button {
        transform: scale(1)
    }
}

@media screen and (min-width:1024px) {
    .c-offcanvas {
        display: none
    }
}

.c-buttonUnit {
    max-width: 480px;
    margin: 0 auto
}

.c-buttonUnit__list {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0 auto
}

.c-buttonUnit__item {
    width: 100%;
    margin: 5px 0
}

.c-buttonUnit__button {
    color: var(--white);
    width: 100%;
    height: 50px;
    line-height: 1;
    position: relative;
    overflow: hidden;
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    padding: .2em 0;
    border-width: 3px;
    border-style: solid;
    border-radius: 50px;
    transition: all 0.35s ease
}

.c-buttonUnit__button svg path {
    transition: all 0.35s ease
}

.c-buttonUnit__button--entry {
    border-color: #FF4442;
    background-color: #FF4442
}

.c-buttonUnit__button--entry:hover {
    color: #FF4442;
    border-color: #FF4442;
    background-color: var(--white)
}

.c-buttonUnit__button--entry:hover svg path {
    fill: #FF4442
}

.c-buttonUnit__button--tel {
    border-color: #2D2D2D;
    background-color: #2D2D2D
}

.c-buttonUnit__button--tel:hover {
    color: #2D2D2D;
    border-color: #2D2D2D;
    background-color: var(--white)
}

.c-buttonUnit__button--tel:hover svg path {
    fill: #2D2D2D
}

.c-buttonUnit__text {
    font-size: 15px;
    font-size: .9375rem;
    font-size: clamp(.9375rem, 0.5511363636rem + 1.9318181818vw, 2rem);
    font-weight: 700;
    text-align: center
}

.c-buttonUnit__text--en {
    font-size: 18px;
    font-size: 1.125rem;
    font-size: clamp(1.125rem, 0.7840909091rem + 1.7045454545vw, 2.0625rem);
    font-weight: 600
}

.c-buttonUnit__text--en>span {
    display: block;
    font-size: 8px;
    font-size: .5rem;
    font-size: clamp(.5rem, 0.3636363636rem + 0.6818181818vw, .875rem);
    font-weight: 400;
    margin-top: .4em
}

.c-buttonUnit__iconMail {
    display: block;
    width: 18px;
    line-height: 1
}

.c-buttonUnit__iconMail svg {
    width: 100%;
    height: auto
}

.c-buttonUnit__iconArrow {
    display: block;
    width: 18px;
    line-height: 1
}

.c-buttonUnit__iconArrow svg {
    width: 100%;
    height: auto
}

.c-buttonUnit__iconTel {
    display: block;
    width: 15px;
    line-height: 1
}

.c-buttonUnit__iconTel svg {
    width: 100%;
    height: auto
}

@media screen and (min-width:641px) {
    .c-buttonUnit__button {
        height: 60px;
        gap: 10px
    }

    .c-buttonUnit__iconMail {
        width: 27px
    }

    .c-buttonUnit__iconArrow {
        width: 24px
    }

    .c-buttonUnit__iconTel {
        width: 27px
    }
}

@media screen and (min-width:1024px) {
    .c-buttonUnit {
        max-width: 936px
    }

    .c-buttonUnit__list {
        flex-direction: row;
        margin: 20px -8px 0
    }

    .c-buttonUnit__item {
        width: calc(50% + 16px);
        margin: 0 8px
    }

    .c-buttonUnit__button {
        height: 70px;
        gap: 12px;
        padding: 0
    }

    .c-buttonUnit__text {
        font-size: 24px;
        font-size: 1.5rem
    }

    .c-buttonUnit__text--en {
        font-size: 28px;
        font-size: 1.75rem
    }

    .c-buttonUnit__text--en>span {
        font-size: 12px;
        font-size: .75rem
    }

    .c-buttonUnit__iconMail {
        width: 31px
    }

    .c-buttonUnit__iconArrow {
        width: 28px
    }

    .c-buttonUnit__iconTel {
        width: 31px
    }
}

.u-container {
    width: 100%;
    max-width: 1300px;
    padding-left: 20px;
    padding-right: 20px;
    margin-left: auto;
    margin-right: auto
}

.u-container--max1000 {
    max-width: 1100px
}

.u-container--max950 {
    max-width: 1050px
}

.u-container--max900 {
    max-width: 1000px
}

.u-container--max850 {
    max-width: 950px
}

.u-container--max800 {
    max-width: 900px
}

@media screen and (min-width:500px) {
    .u-container {
        padding-left: 35px;
        padding-right: 35px
    }
}

@media screen and (min-width:1024px) {
    .u-container {
        padding-left: 50px;
        padding-right: 50px
    }
}

.p-scroll {
    background-color: #FFF;
    overflow: hidden
}

.p-scroll div {
    display: flex;
    width: 4500px;
    gap: 50px
}

.p-scroll ul {
    display: flex;
    align-items: center;
    gap: 50px;
    padding: 40px 0;
    width: 1500px;
    animation: scroll-logos 30s linear infinite
}

.p-scroll li {
    display: inline-flex;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content
}

.p-scroll img {
    width: auto;
    height: inherit
}

@keyframes scroll-logos {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(calc(-100% - 50px))
    }
}

.p-genre {
    max-width: 800px;
    padding-top: var(--space-md);
    margin: 0 auto
}

.p-genre__inner {
    display: flex;
    flex-direction: column
}

.p-genre__header {
    width: 100%
}

.p-genre__headingGroup {
    display: flex;
    flex-direction: column
}

.p-genre__heading {
    width: 73.2%;
    max-width: 439px
}

.p-genre__tag {
    width: 84.33%;
    max-width: 506px;
    margin: var(--space-md) 0 0
}

.p-genre__desc {
    color: var(--black);
    line-height: 2.1;
    font-size: 13px;
    font-size: .8125rem;
    font-size: clamp(.8125rem, 0.6988636364rem + 0.4848484848vw, 1.0625rem);
    font-weight: 400;
    letter-spacing: 0;
    text-align: justify;
    margin: 2em 0 0
}

.p-genre__body {
    width: 82%;
    max-width: 428px;
    margin: var(--space-sm) auto 0
}

.p-genre__thumbnail {
    transform: translateX(4.9%)
}

@media screen and (min-width:641px) {
    .p-genre {
        padding-top: 60px
    }

    .p-genre__tag {
        margin: 55px 0 0
    }

    .p-genre__body {
        margin: 28px auto 0
    }
}

@media screen and (min-width:1024px) {
    .p-genre {
        max-width: -webkit-fit-content;
        max-width: -moz-fit-content;
        max-width: fit-content;
        padding-top: 53px
    }

    .p-genre__inner {
        flex-direction: row
    }

    .p-genre__header {
        width: 56.8%
    }

    .p-genre__headingGroup {
        flex-direction: row;
        align-items: flex-end;
        padding-top: 43px
    }

    .p-genre__heading {
        width: 65%
    }

    .p-genre__tag {
        width: 23.5%;
        max-width: 156px;
        margin: 0 0 0 auto
    }

    .p-genre__desc {
        line-height: 2;
        font-size: 17px;
        font-size: 1.0625rem
    }

    .p-genre__body {
        width: 36%;
        margin: 0 0 0 auto
    }

    .p-genre__thumbnail {
        transform: translateX(0)
    }
}

.c-cardPoint {
    min-height: 360px;
    position: relative;
    padding: var(--space-md) 6% var(--space-xs);
    border-radius: 5px;
    border: 1px solid #FF4442;
    background-color: transparent
}

.c-cardPoint::after {
    content: "";
    display: block;
    width: 38%;
    min-width: 100px;
    max-width: 190px;
    background: #fff;
    height: 5px;
    position: absolute;
    top: -4px;
    left: 4%;
    z-index: 1
}

.c-cardPoint__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-top: -26px
}

.c-cardPoint__content {
    width: 100%
}

.c-cardPoint__titleGroup {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.c-cardPoint__number {
    color: #FF4442;
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    line-height: 1;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0.5284090909rem + 0.7954545455vw, 1.125rem);
    font-weight: 600;
    letter-spacing: 0;
    padding: 0 1em 0 .5em;
    margin: -3em 0 2em -.5em
}

.c-cardPoint__number::after {
    content: "";
    display: block;
    width: 87%;
    height: auto;
    aspect-ratio: 296/26;
    background: url(../img/line-point-number-sp.png) no-repeat 0 0/cover;
    position: absolute;
    left: 50%;
    top: 100%;
    transform: translate(-50%, 0)
}

.c-cardPoint__number i {
    font-size: 32px;
    font-size: 2rem;
    font-size: clamp(2rem, 1.2727272727rem + 3.6363636364vw, 4rem);
    font-style: normal;
    margin-left: .1em
}

.c-cardPoint__title {
    color: var(--black);
    line-height: 1.5;
    font-size: 18px;
    font-size: 1.125rem;
    font-size: clamp(1.125rem, 0rem + 5.625vw, 2.25rem);
    font-weight: 700;
    letter-spacing: 0
}

.c-cardPoint__title span {
    display: block
}

.c-cardPoint__title br {
    display: none
}

.c-cardPoint__desc {
    color: var(--black);
    line-height: 2.1;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0.125rem + 2.8125vw, 1.25rem);
    font-weight: 400;
    text-align: justify;
    letter-spacing: 0;
    margin: 0
}

.c-cardPoint__thumbnailSp {
    display: block;
    width: 80%;
    margin: var(--space-xs) auto
}

.c-cardPoint__thumbnail {
    display: block;
    width: 90%;
    margin: 40px auto 0
}

.c-cardPoint__thumbnail--point01,
.c-cardPoint__thumbnail--point02 {
    margin-bottom: 40px
}

@media screen and (min-width:641px) {
    .c-cardPoint {
        border: 2px solid #FF4442;
        border-radius: 8px
    }

    .c-cardPoint__title {
        font-size: clamp(1.25rem, 1.0681818182rem + 0.9090909091vw, 1.75rem)
    }

    .c-cardPoint__desc {
        font-size: clamp(.875rem, 0.8068181818rem + 0.3409090909vw, 1.0625rem)
    }
}

@media screen and (min-width:1024px) {
    .c-cardPoint {
        padding: 48px 6.65%;
        border-radius: 10px
    }

    .c-cardPoint::after {
        display: none
    }

    .c-cardPoint--tertiary {
        padding: 10px 2% 10px 3%
    }

    .c-cardPoint__inner {
        flex-direction: row;
        align-items: center;
        margin-top: 0
    }

    .c-cardPoint__content {
        width: 55%
    }

    .c-cardPoint__titleGroup {
        flex-direction: row;
        align-items: center
    }

    .c-cardPoint__number {
        flex-direction: column;
        font-size: 18px;
        font-size: 1.125rem;
        white-space: nowrap;
        padding: 0;
        margin: 0
    }

    .c-cardPoint__number::after {
        width: 13px;
        height: 70px;
        background: url(../img/line-point-number.png) no-repeat 0 0/cover;
        left: calc(100% + 20px);
        top: 50%;
        transform: translate(0, -50%)
    }

    .c-cardPoint__number i {
        font-size: 64px;
        font-size: 4rem;
        margin-left: 0
    }

    .c-cardPoint__title {
        font-size: 28px;
        font-size: 1.75rem;
        padding-left: 52px
    }

    .c-cardPoint__title span {
        display: none
    }

    .c-cardPoint__title br {
        display: block
    }

    .c-cardPoint__desc {
        margin: 1.8em 0 0
    }

    .c-cardPoint__thumbnailSp {
        display: none
    }

    .c-cardPoint__thumbnail {
        width: 40%;
        max-width: 426px;
        aspect-ratio: 1/.8;
        display: block;
        margin: -30px 0 -30px auto
    }

    .c-cardPoint__thumbnail picture {
        display: block;
        width: 100%;
        height: 100%
    }

    .c-cardPoint__thumbnail img {
        width: 100%;
        height: 100%;
        object-fit: contain
    }
}

@media screen and (max-width:1023px) {
    .c-cardPoint__thumbnail {
        display: none
    }
}

.p-point {
    position: relative;
    z-index: 1;
    margin: 0 auto;
    background-color: var(--white)
}

.p-point::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 45px 0 45px;
    border-color: #DDD transparent transparent transparent;
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 0;
    transform: translateX(-50%)
}

.p-point__heading {
    width: 79%;
    max-width: 450px;
    margin: 0 auto 0 0
}

.p-point__label {
    width: 100%;
    margin: 30px 0 0
}

.p-point__leadGroup {
    display: flex;
    flex-direction: column
}

.p-point__lead {
    color: var(--black);
    line-height: 2.1;
    font-family: var(--japanese-sans-serif);
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0.3125rem + 1.875vw, 1.0625rem);
    font-weight: 400;
    letter-spacing: 0;
    margin: 1.5em 0 0
}

.p-point__image {
    max-width: 428px;
    width: 80%;
    margin: var(--space-sm) auto 0;
    transform: translateX(3%)
}

.p-point__list {
    display: flex;
    flex-direction: column;
    margin-top: var(--space-md)
}

.p-point__item:not(:first-of-type) {
    margin-top: var(--space-md)
}

.p-point__visuals>* {
    position: absolute;
    z-index: -1
}

.p-point__visuals>*.left-01 {
    width: 54%;
    max-width: 345px;
    top: 24%;
    left: -13%
}

.p-point__visuals>*.left-02 {
    display: none;
    width: 347px
}

.p-point__visuals>*.right-01 {
    width: 61%;
    max-width: 390px;
    top: 3.5%;
    right: -16%
}

.p-point__visuals>*.right-02 {
    display: none;
    width: 340px
}

.p-point__visuals>*.left-sp-01 {
    width: 54%;
    max-width: 345px;
    top: 60%;
    left: -11%
}

.p-point__visuals>*.right-sp-01 {
    width: 61%;
    max-width: 390px;
    top: 37%;
    right: -16%
}

.p-point__visuals>*.right-sp-02 {
    width: 61%;
    max-width: 390px;
    top: 73%;
    right: -17%
}

@media screen and (min-width:641px) {
    .p-point__list {
        margin-top: 70px
    }

    .p-point__item:not(:first-of-type) {
        margin-top: 60px
    }
}

@media screen and (min-width:1024px) {
    .p-point {
        padding-top: 115px
    }

    .p-point::before {
        border-width: 50px 72.5px 0 72.5px
    }

    .p-point__heading {
        width: 100%;
        max-width: 797px
    }

    .p-point__label {
        width: 100%;
        max-width: 480px;
        margin: 30px 0 0
    }

    .p-point__leadGroup {
        flex-direction: row;
        align-items: flex-end;
        padding-bottom: 4em;
        margin-top: -220px
    }

    .p-point__lead {
        width: 57%;
        text-align: justify;
        margin: 100px 0 0
    }

    .p-point__image {
        width: 100%;
        margin: 0 0 0 auto;
        transform: none
    }

    .p-point__item:not(:first-of-type) {
        margin-top: 48px
    }

    .p-point__visuals>*.left-01 {
        width: 100%;
        top: 455px;
        right: calc(50% + 488px)
    }

    .p-point__visuals>*.left-02 {
        display: block;
        top: 1120px;
        right: calc(50% + 510px)
    }

    .p-point__visuals>*.right-01 {
        width: 100%;
        top: 30px;
        right: inherit;
        left: calc(50% + 402px)
    }

    .p-point__visuals>*.right-02 {
        display: block;
        top: 1410px;
        left: calc(50% + 478px)
    }

    .p-point__visuals>*.left-sp-01,
    .p-point__visuals>*.right-sp-01,
    .p-point__visuals>*.right-sp-02 {
        display: none
    }
}

@media screen and (max-width:1023px) {
    .p-point {
        padding-top: 110px
    }

    .c-cardPoint__inner {
        display: block
    }
}

.p-quality {
    max-width: 800px;
    position: relative;
    z-index: 2;
    padding-top: var(--space-md);
    padding-bottom: 18%;
    margin: 0 auto
}

.p-quality__inner {
    position: relative;
    display: flex;
    flex-direction: column
}

.p-quality__title {
    width: 100%;
    max-width: 570px;
    margin: 0 auto 0 0
}

.p-quality__desc {
    color: var(--black);
    line-height: 2.2;
    font-size: 10.5px;
    font-size: .65625rem;
    font-size: clamp(.65625rem, 0.0625rem + 2.96875vw, 1.25rem);
    font-weight: 400;
    letter-spacing: 0;
    text-align: justify;
    margin: 2em 0 0
}

.p-quality__visuals {
    position: relative;
    width: 100%;
    margin: 5% 0 0 0
}

@media screen and (min-width:641px) {
    .p-quality {
        padding-top: 80px;
        padding-bottom: 20%
    }

    .p-quality__desc {
        font-size: clamp(.9375rem, 0.8920454545rem + 0.2272727273vw, 1.0625rem)
    }

    .p-quality__visuals {
        margin: 12% 0 0 0
    }
}

@media screen and (min-width:1024px) {
    .p-quality {
        max-width: inherit;
        padding-top: 110px;
        padding-bottom: 100px
    }

    .p-quality__inner {
        flex-direction: row
    }

    .p-quality__title {
        max-width: 588px
    }

    .p-quality__desc {
        max-width: 610px;
        margin: 2.3em 0 0
    }

    .p-quality__visuals {
        max-width: 565px;
        height: 100%;
        margin: auto 0 auto auto
    }
}

.c-actionPuzzles {
    position: relative;
    width: 100%;
    height: 100%;
    aspect-ratio: 479/409
}

.c-actionPuzzles.is-active>*.pz-left {
    top: -10px;
    transition: top 0s ease 2s
}

.c-actionPuzzles.is-active>*.pz-right {
    top: 10px;
    transition: top 0s ease 2s
}

.c-actionPuzzles>* {
    display: block;
    position: absolute
}

.c-actionPuzzles>*.pz-left {
    width: 65%;
    top: 0;
    left: 0
}

.c-actionPuzzles>*.pz-left img {
    padding-top: 20px
}

.c-actionPuzzles>*.pz-right {
    width: 65%;
    top: 0;
    right: 0
}

.c-actionPuzzles>*.pz-right img {
    padding-bottom: 20px
}

.c-actionPuzzles>*.pz-spark {
    width: 20%;
    top: 50%;
    left: 50%;
    transform: translate(-154%, -181%)
}

@media screen and (min-width:641px) {
    .c-actionPuzzles>*.pz-spark {
        transform: translate(-154%, -165%)
    }
}

@media screen and (min-width:1024px) {
    .c-actionPuzzles>*.pz-spark {
        transform: translate(calc(-50% - 120px), calc(-50% - 120px))
    }
}

.c-actionPaths {
    width: 100%;
    height: auto;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.c-actionPaths>svg {
    width: 100%;
    height: auto
}

.c-listCareer {
    margin: 18px 0 0
}

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

.c-listCareer__item:not(:last-of-type) .c-listCareer__year::after {
    content: "";
    display: block;
    width: 1px;
    height: 170%;
    background-color: #707070;
    position: absolute;
    top: 50%;
    left: calc(50% - 0.5px);
    z-index: -1
}

.c-listCareer__year {
    color: var(--black);
    position: relative;
    width: 3.8em;
    height: 3.8em;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0rem + 3.4375vw, 1.375rem);
    font-weight: 400;
    letter-spacing: 0;
    border-radius: 100%;
    border: 2px solid #525252;
    background-color: #fff
}

.c-listCareer__desc {
    color: var(--black);
    width: 100%;
    line-height: 1.6;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0rem + 3.4375vw, 1.375rem);
    font-weight: 400;
    text-align: justify;
    letter-spacing: 0;
    padding: 1em 0;
    border-bottom: 2px dotted #C9C9C9;
    margin: 0 0 0 15px
}

@media screen and (min-width:641px) {
    .c-listCareer__item:not(:last-of-type) .c-listCareer__year::after {
        height: 100%
    }

    .c-listCareer__year {
        font-size: 17px;
        font-size: 1.0625rem
    }

    .c-listCareer__desc {
        font-size: 16px;
        font-size: 1rem;
        margin: 0 20px 0 22px
    }
}

.c-listCompany {
    display: flex;
    flex-direction: column;
    margin: var(--space-xs) 0 0
}

.c-listCompany__thumbnail {
    width: 33%;
    margin: 0 auto
}

.c-listCompany__table {
    width: 100%;
    margin: 12px 0 0
}

.c-listCompany__table tbody tr th,
.c-listCompany__table tbody tr td {
    color: var(--black);
    line-height: 1.5;
    font-family: var(--japanese-sans-serif);
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0rem + 3.4375vw, 1.375rem);
    font-weight: 400;
    text-align: justify;
    letter-spacing: 0;
    padding: .5em 0;
    border-bottom: 1px solid var(--white)
}

.c-listCompany__table tbody tr th {
    min-width: 7em
}

@media screen and (min-width:641px) {
    .c-listCompany {
        flex-direction: row;
        margin: 32px 0 0
    }

    .c-listCompany__thumbnail {
        width: 148px;
        margin: 0
    }

    .c-listCompany__table {
        width: calc(100% - 168px);
        margin: -.8em 0 0 auto
    }

    .c-listCompany__table tbody tr th,
    .c-listCompany__table tbody tr td {
        font-size: 16px;
        font-size: 1rem;
        padding: .8em 0
    }
}

.p-message {
    position: relative;
    z-index: 3;
    padding-bottom: var(--space-md);
    background-color: #F9ED03
}

.p-message__heading {
    position: relative;
    z-index: 2;
    width: calc(100% + 40px);
    transform: translateX(-20px)
}

.p-message__message {
    position: relative;
    z-index: 1;
    padding: 1.5em 5%;
    margin: -6% 0 0;
    border-radius: 5px;
    background-color: var(--white)
}

.p-message__message>p {
    color: var(--black);
    line-height: 2;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0rem + 3.4375vw, 1.375rem);
    font-weight: 500;
    letter-spacing: 0;
    line-break: strict;
    text-align: justify
}

.p-message__message>p+* {
    margin-top: 1em
}

.p-message__message>p>strong {
    color: #FF4442;
    display: inline-block;
    font-weight: 600;
    padding-bottom: .2em;
    margin-bottom: .5em;
    border-bottom: 2px solid #FF4442
}

.p-message__content {
    display: flex;
    flex-direction: column;
    margin: 0 0 0
}

.p-message__column {
    width: 100%;
    margin: var(--space-sm) 0 0
}

.p-message__title {
    color: var(--white);
    display: block;
    line-height: 1.3;
    font-size: 14px;
    font-size: .875rem;
    font-size: clamp(.875rem, 0rem + 4.375vw, 1.75rem);
    font-weight: 500;
    letter-spacing: 0;
    border-bottom: 1px solid #FF4442
}

.p-message__title span {
    display: table;
    padding: .5em 1.5em .4em;
    margin: 0 auto;
    border-radius: 5px 5px 0 0;
    background-color: #FF4442
}

.p-message__visuals {
    display: none
}

.p-message__visuals>* {
    position: absolute;
    z-index: -1
}

.p-message__visuals>*.bg-message-after {
    width: 50%;
    max-width: 596px;
    top: 0;
    right: -25%
}

@media screen and (min-width:500px) {
    .p-message__heading {
        width: calc(100% + 70px);
        transform: translateX(-35px)
    }
}

@media screen and (min-width:641px) {
    .p-message {
        padding-bottom: var(--space-lg)
    }

    .p-message__message {
        padding: 40px 6%
    }

    .p-message__message>p {
        font-size: clamp(1rem, 0.9772727273rem + 0.1136363636vw, 1.0625rem)
    }

    .p-message__content {
        margin: 30px 0 0
    }

    .p-message__column {
        margin: 36px 0 0
    }

    .p-message__title {
        font-size: clamp(1.25rem, 1.2045454545rem + 0.2272727273vw, 1.375rem)
    }
}

@media screen and (min-width:820px) {
    .p-message__body {
        max-width: 800px;
        padding: 0 35px;
        margin: 0 auto
    }
}

@media screen and (min-width:1024px) {
    .p-message {
        padding-bottom: 76px
    }

    .p-message__header {
        position: relative
    }

    .p-message__heading {
        width: 64%;
        max-width: 758px;
        margin: 0 auto 0 0;
        transform: none
    }

    .p-message__message {
        padding: 40px 4.3%;
        margin: 35px 0 0
    }

    .p-message__message::after {
        content: "";
        display: block;
        width: 23%;
        max-width: 262px;
        height: auto;
        aspect-ratio: 524/753;
        background: url(../img/img-message-manager.webp) no-repeat 0 0/cover;
        position: absolute;
        bottom: calc(100% - 32px);
        left: 65%
    }

    .p-message__body {
        max-width: -webkit-fit-content;
        max-width: -moz-fit-content;
        max-width: fit-content;
        padding: 0;
        margin: 0
    }

    .p-message__content {
        flex-direction: row;
        margin: 68px -26px 0
    }

    .p-message__column {
        width: calc(50% - 52px);
        margin: 0 26px
    }

    .p-message__title span {
        margin: 0
    }

    .p-message__visuals {
        display: block
    }
}

@media screen and (max-width:1023px) {
    .p-message__message {
        font-feature-settings: "palt"
    }
}

.c-cardFlow {
    height: 100%;
    position: relative;
    border: 2px solid #FF4442;
    border-radius: 5px
}

.c-cardFlow--next::after {
    content: "";
    display: block;
    width: 10.5%;
    height: auto;
    aspect-ratio: 60/30;
    background: url(../img/icon-flow-arrow-sp.png) no-repeat 0 0/cover;
    position: absolute;
    top: calc(100% + 18px);
    left: 50%;
    transform: translate(-50%, 0)
}

.c-cardFlow__inner {
    height: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 5% var(--space-sm)
}

.c-cardFlow__inner::before,
.c-cardFlow__inner::after {
    content: "";
    display: block;
    width: 23px;
    height: 2px;
    background-color: var(--white);
    position: absolute
}

.c-cardFlow__inner::before {
    top: -2px;
    left: 15px
}

.c-cardFlow__inner::after {
    bottom: -2px;
    right: 15px
}

.c-cardFlow__thumbnail {
    display: block;
    width: 50%;
    margin: 0 auto;
    transform: translateY(-15px)
}

.c-cardFlow__text {
    margin-top: -15px
}

.c-cardFlow__titleGroup {
    display: flex;
    align-items: center;
    padding-left: 10px
}

.c-cardFlow__number {
    color: #FF4442;
    display: block;
    position: absolute;
    top: 18px;
    left: 6%;
    z-index: 1;
    line-height: 1.6;
    font-size: 24px;
    font-size: 1.5rem;
    font-size: clamp(1.5rem, 1.1136363636rem + 1.9318181818vw, 2.5625rem);
    font-weight: 500;
    font-style: normal;
    letter-spacing: 0
}

.c-cardFlow__number::after {
    content: "";
    display: block;
    width: 3px;
    height: 70px;
    background-color: #F8DE16;
    transform: rotate(35deg) translate(0, -42%);
    transform-origin: center center;
    position: absolute;
    left: 72%;
    top: 50%
}

.c-cardFlow__title {
    color: var(--black);
    display: block;
    line-height: 1.6;
    font-size: 17px;
    font-size: 1.0625rem;
    font-size: clamp(1.0625rem, 0.375rem + 3.4375vw, 1.75rem);
    font-weight: 600;
    text-align: center;
    letter-spacing: 0;
    margin: .5em auto 0;
    position: relative;
    z-index: 2
}

.c-cardFlow__desc {
    color: var(--black);
    display: block;
    position: relative;
    z-index: 2;
    line-height: 1.6;
    font-size: 10px;
    font-size: .625rem;
    font-size: clamp(.625rem, 0rem + 3.125vw, 1.25rem);
    font-weight: 400;
    text-align: justify;
    letter-spacing: 0;
    margin-top: .5em
}

.c-cardFlow__buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin: 1em 0 0
}

.c-cardFlow__buttons>* {
    color: var(--white);
    width: 100%;
    max-width: 480px;
    height: 50px;
    line-height: 1;
    position: relative;
    overflow: hidden;
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    font-size: .9375rem;
    font-size: clamp(.9375rem, 0rem + 4.6875vw, 1.875rem);
    font-weight: 700;
    text-align: center;
    letter-spacing: 0;
    border: 2px solid #FFF;
    border-radius: 50px;
    transition: all 0.35s ease
}

.c-cardFlow__buttons>*:hover {
    opacity: 1
}

.c-cardFlow__buttons>*:hover.btn-entry {
    color: #FF4442;
    border-color: #FF4442;
    background-color: var(--white)
}

.c-cardFlow__buttons>*:hover.btn-tel {
    color: #2D2D2D;
    border-color: #2D2D2D;
    background-color: var(--white)
}

.c-cardFlow__buttons>*:hover .icon-mail>svg path,
.c-cardFlow__buttons>*:hover .icon-arrow>svg path {
    fill: #FF4442
}

.c-cardFlow__buttons>*:hover .icon-tel>svg path {
    fill: #2D2D2D
}

.c-cardFlow__buttons>*.btn-entry {
    border-color: #FF4442;
    background-color: #FF4442
}

.c-cardFlow__buttons>*.btn-tel {
    font-size: 18px;
    font-size: 1.125rem;
    font-size: clamp(1.125rem, 0.7840909091rem + 1.7045454545vw, 2.0625rem);
    border-color: #2D2D2D;
    background-color: #2D2D2D
}

.c-cardFlow__buttons>*.btn-tel .text {
    display: inline-flex;
    flex-direction: column
}

.c-cardFlow__buttons>*.btn-tel .textSpOnly {
    display: block;
    font-size: 8px;
    font-size: .5rem;
    font-size: clamp(.5rem, 0.3636363636rem + 0.6818181818vw, .875rem);
    font-weight: 400;
    margin-top: .4em
}

.c-cardFlow__buttons>* .icon-mail>svg,
.c-cardFlow__buttons>* .icon-arrow>svg,
.c-cardFlow__buttons>* .icon-tel>svg {
    width: 100%;
    height: auto
}

.c-cardFlow__buttons>* .icon-mail>svg path,
.c-cardFlow__buttons>* .icon-arrow>svg path,
.c-cardFlow__buttons>* .icon-tel>svg path {
    transition: all 0.35s ease
}

.c-cardFlow__buttons>* .icon-mail {
    width: 18px
}

.c-cardFlow__buttons>* .icon-arrow {
    width: 18px
}

.c-cardFlow__buttons>* .icon-tel {
    width: 15px
}

@media screen and (min-width:375px) {
    .c-cardFlow--next::after {
        top: calc(100% + 22px)
    }
}

@media screen and (min-width:641px) {
    .c-cardFlow--next::after {
        top: calc(100% + 45px)
    }

    .c-cardFlow__inner {
        padding: 0 6% 40px
    }

    .c-cardFlow__title {
        font-size: clamp(1.25rem, 1.2045454545rem + 0.2272727273vw, 1.375rem)
    }

    .c-cardFlow__desc {
        font-size: clamp(.9375rem, 0.9147727273rem + 0.1136363636vw, 1rem)
    }

    .c-cardFlow__buttons {
        gap: 18px;
        margin: 2em 0 0
    }

    .c-cardFlow__buttons>* {
        height: 60px;
        font-size: clamp(.9375rem, 0.5965909091rem + 1.7045454545vw, 1.875rem);
        padding: .2em 0
    }

    .c-cardFlow__buttons>* .icon-mail {
        width: 27px
    }

    .c-cardFlow__buttons>* .icon-arrow {
        width: 24px
    }

    .c-cardFlow__buttons>* .icon-tel {
        width: 22px
    }

    .c-cardFlow__number::after {
        width: 5px;
        height: 128px;
        transform: rotate(35deg) translate(0, -35%);
        transform-origin: center center;
        left: 100%;
        top: 50%
    }
}

@media screen and (min-width:1024px) {
    .c-cardFlow--next::after {
        width: 33px;
        height: 61px;
        aspect-ratio: inherit;
        background: url(../img/icon-flow-arrow.png) no-repeat 0 0/cover;
        top: 50%;
        left: 100%;
        transform: translate(0, -50%)
    }

    .c-cardFlow__inner {
        padding: 0 5.5% 34px
    }

    .c-cardFlow__thumbnail {
        width: 100%;
        max-width: 234px
    }

    .c-cardFlow__text {
        margin-top: 0
    }

    .c-cardFlow__number {
        position: relative;
        top: 0;
        left: 0
    }

    .c-cardFlow__number::after {
        width: 5px;
        height: 80px;
        transform: rotate(35deg) translate(0, -50%)
    }

    .c-cardFlow__title {
        text-align: left;
        padding-left: 2.2em;
        margin: 0
    }

    .c-cardFlow__desc {
        margin-top: -.3em
    }

    .c-cardFlow__buttons {
        gap: 12px;
        margin: 15px 0 0
    }

    .c-cardFlow__buttons>* {
        width: 70%;
        height: auto;
        font-size: 14px;
        font-size: .875rem;
        padding: 1em 0
    }

    .c-cardFlow__buttons>*.btn-tel {
        font-size: 14px;
        font-size: .875rem
    }

    .c-cardFlow__buttons>*.btn-tel .textSpOnly {
        display: none
    }

    .c-cardFlow__buttons>* .icon-arrow,
    .c-cardFlow__buttons>* .icon-tel {
        width: auto
    }

    .c-cardFlow__buttons>* .icon-arrow>svg,
    .c-cardFlow__buttons>* .icon-tel>svg {
        width: auto
    }

    .c-cardFlow__buttons>* .icon-mail {
        display: none
    }

    .c-cardFlow__buttons>* .icon-arrow {
        width: 28px
    }

    .c-cardFlow__buttons>* .icon-tel {
        width: 28px
    }

    .c-cardFlow__buttons>* .icon-tel .textSpOnly {
        display: none
    }
}

@media screen and (min-width:1200px) {
    .c-cardFlow__buttons {
        flex-direction: row;
        gap: 8px
    }

    .c-cardFlow__buttons>* {
        width: 50%;
        height: 44px;
        gap: 4px;
        font-size: 15px;
        font-size: .9375rem
    }

    .c-cardFlow__buttons>* .icon-arrow,
    .c-cardFlow__buttons>* .icon-tel {
        width: auto
    }

    .c-cardFlow__buttons>* .icon-arrow>svg,
    .c-cardFlow__buttons>* .icon-tel>svg {
        width: auto
    }
}

.p-flow {
    padding-top: var(--space-md);
    padding-bottom: var(--space-lg);
    margin: 0 auto
}

.p-flow__heading {
    display: flex;
    flex-direction: column;
    margin: 0 auto 0 0
}

.p-flow__heading__sub {
    color: #FF4442;
    line-height: 1;
    font-size: 13px;
    font-size: .8125rem;
    font-size: clamp(.8125rem, 0.25rem + 2.8125vw, 1.375rem);
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap
}

.p-flow__heading>img {
    width: 66%;
    max-width: 380px;
    margin-top: 25px
}

.p-flow__list {
    display: flex;
    flex-direction: column;
    margin: 0
}

.p-flow__item {
    width: 100%;
    margin: 0
}

.p-flow__item:not(:first-of-type) {
    margin: 18.5% 0 0
}

.p-flow__body {
    margin-top: var(--space-sm)
}

@media screen and (min-width:641px) {
    .p-flow {
        padding-top: var(--space-lg)
    }

    .p-flow__body {
        margin-top: 55px
    }
}

@media screen and (min-width:1024px) {
    .p-flow {
        padding-top: 100px;
        padding-bottom: 100px
    }

    .p-flow__heading {
        width: 100%
    }

    .p-flow__list {
        flex-direction: row;
        margin: 0 -24px
    }

    .p-flow__item {
        width: calc(33.3333% - 48px);
        margin: 0 24px
    }

    .p-flow__item:not(:first-of-type) {
        margin: 0 24px
    }

    .p-flow__body {
        margin-top: 45px
    }
}

.p-faq {
    padding-top: var(--space-md);
    padding-bottom: var(--space-md);
    margin: 0 auto;
    background-color: #FAFAFA
}

.p-faq__heading {
    display: block;
    width: 78%;
    max-width: 444px;
    margin: 0 auto 0 0
}

.p-faq__heading__sub {
    color: #FF4442;
    line-height: 1;
    font-size: 13px;
    font-size: .8125rem;
    font-size: clamp(.8125rem, 0.25rem + 2.8125vw, 1.375rem);
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap
}

.p-faq__heading>img {
    margin-top: 15px
}

.p-faq__body {
    margin-top: 28px
}

.p-faq__item:not(:first-of-type) {
    margin-top: 20px
}

.p-faq__trigger {
    cursor: pointer;
    position: relative;
    display: block;
    padding: .6em 1em .6em 1em;
    border: 1px solid #D3D3D3;
    background-color: var(--white);
    box-shadow: 0 3px 6px rgba(157, 157, 157, .16);
    transition: all 0.35s ease
}

.p-faq__trigger:hover {
    opacity: .5
}

.p-faq__trigger:focus {
    outline: none
}

.p-faq__question {
    font-size: 12px;
    font-size: .75rem;
    font-size: clamp(.75rem, 0.5454545455rem + 1.0227272727vw, 1.3125rem);
    margin: 0
}

.p-faq__questionContent {
    padding-left: 1.5em
}

.p-faq__questionTitle {
    font-size: 1.375rem;
    line-height: 1.7;
    font-weight: 500;
    letter-spacing: 0
}

.p-faq__iconQuestion {
    width: 1.5em;
    height: auto;
    position: absolute;
    top: 50%;
    left: 1em;
    transform: translateY(-50%)
}

.p-faq__target {
    opacity: 0;
    width: 100%;
    max-height: 0;
    position: relative;
    overflow: hidden;
    font-size: 11px;
    font-size: .6875rem;
    font-size: clamp(.6875rem, 0.5738636364rem + 0.5681818182vw, 1rem);
    background-color: #F4F4F4;
    margin: 0;
    transition: all 0.2s ease-out
}

.p-faq__iconAnswer {
    width: 1.2em;
    height: auto;
    position: absolute;
    top: 1.6em;
    left: 1.4em
}

.p-faq__answerContent {
    padding: 1.2em 2em 1.2em 1.2em
}

.p-faq__answerDesc {
    line-height: 2;
    font-size: inherit;
    font-weight: 400;
    text-align: justify;
    letter-spacing: 0;
    padding-left: 2em
}

@media screen and (min-width:641px) {
    .p-faq {
        padding-top: var(--space-lg);
        padding-bottom: var(--space-lg)
    }

    .p-faq__questionContent {
        padding-left: 2.5em
    }

    .p-faq__answerDesc {
        padding-left: 2.5em
    }
}

@media screen and (min-width:1024px) {
    .p-faq {
        padding-top: 85px;
        padding-bottom: 100px
    }

    .p-faq__heading {
        width: 100%
    }

    .p-faq__heading>img {
        margin-top: 25px
    }

    .p-faq__body {
        margin-top: 45px
    }

    .p-faq__item:not(:first-of-type) {
        margin-top: 20px
    }

    .p-faq__questionContent {
        padding-left: 3em
    }

    .p-faq__trigger {
        padding: 15px 36px
    }

    .p-faq__iconQuestion {
        width: 35px;
        height: 36px;
        left: 36px
    }

    .p-faq__answerContent {
        padding: 28px 36px
    }

    .p-faq__iconAnswer {
        width: 22px;
        height: 22px;
        top: 34px;
        left: 45px
    }

    .p-faq__answerDesc {
        max-width: 1040px;
        padding-left: 3em
    }
}

@media screen and (max-width:1023px) {
    .p-faq__questionTitle {
        font-size: 1rem
    }
}

.c-iconPlus {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: absolute;
    top: 50%;
    right: 1em;
    width: 12px;
    height: 12px;
    top: 50%;
    transform: translateY(-50%);
    transition: all 0.3s ease
}

.c-iconPlus.is-active {
    background-color: transparent
}

.c-iconPlus.is-active>*::before {
    transform: rotate(180deg)
}

.c-iconPlus.is-active>*::after {
    transform: rotate(180deg);
    opacity: 0
}

.c-iconPlus>*::before,
.c-iconPlus>*::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto 0;
    background-color: var(--black);
    width: 12px;
    height: 1px;
    transition: all 0.3s ease
}

.c-iconPlus>*::after {
    transform: rotate(90deg)
}

@media screen and (min-width:641px) {
    .c-iconPlus {
        width: 16px;
        height: 16px;
        right: 1.2em
    }

    .c-iconPlus>*::before,
    .c-iconPlus>*::after {
        width: 16px;
        height: 1.5px
    }
}

@media screen and (min-width:1024px) {
    .c-iconPlus {
        width: 22px;
        height: 22px;
        right: 1.5em
    }

    .c-iconPlus>*::before,
    .c-iconPlus>*::after {
        width: 22px;
        height: 2px
    }
}

.p-contact {
    padding-top: var(--space-md);
    padding-bottom: var(--space-sm);
    background-color: #FFF
}

.p-contact__inner.u-container {
    max-width: 800px
}

.p-contact__headingGroup {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.p-contact__heading {
    display: block;
    width: auto
}

.p-contact__subheading {
    color: var(--black);
    line-height: 1.6;
    font-family: var(--japanese-sans-serif);
    font-size: 15px;
    font-size: .9375rem;
    font-weight: 400;
    letter-spacing: 0;
    margin: 1em 0 0
}

.p-contact__subheading strong {
    color: #ff0001;
    display: inline-block
}

.p-contact__content {
    margin-top: var(--space-xs)
}

@media screen and (min-width:641px) {
    .p-contact {
        padding-top: var(--space-lg);
        padding-bottom: var(--space-md)
    }

    .p-contact__subheading {
        margin: 1.5em 0 0
    }

    .p-contact__content {
        margin-top: 35px
    }
}

@media screen and (min-width:1024px) {
    .p-contact {
        padding-top: 78px;
        padding-bottom: 66px
    }

    .p-contact__inner.u-container {
        max-width: 1300px
    }

    .p-contact__headingGroup {
        flex-direction: row;
        align-items: center
    }

    .p-contact__subheading {
        line-height: 1.4;
        margin: 0 0 0 2em
    }

    .p-contact__content {
        margin-top: 40px
    }
}

@media screen and (max-width:1023px) {
    .p-contact__subheading {
        font-size: clamp(13px, 0rem + 1.75vw, 15px)
    }
}

.c-formContact tbody tr th,
.c-formContact tbody tr td {
    display: block;
    width: 100%
}

.c-formContact tbody tr th {
    padding: 0
}

.c-formContact tbody tr td {
    padding: 10px 0 20px
}

.c-formContact tbody tr td input[type=text],
.c-formContact tbody tr td input[type=tel] {
    width: 100%;
    line-height: 1;
    font-family: var(--japanese-sans-serif);
    font-size: 14px;
    font-size: clamp(14px, 0.7045454545rem + 0.7272727273vw, 18px);
    font-weight: 400;
    letter-spacing: 0;
    padding: 1em 1em;
    border: 1px solid #D3D3D3;
    border-radius: 4px
}

.c-formContact tbody tr td input[type=text]::-moz-placeholder,
.c-formContact tbody tr td input[type=tel]::-moz-placeholder {
    color: #B7B7B7
}

.c-formContact tbody tr td input[type=text]::placeholder,
.c-formContact tbody tr td input[type=tel]::placeholder {
    color: #B7B7B7
}

.c-formContact__label {
    color: #FF4442;
    width: 100%;
    line-height: 1;
    font-family: var(--japanese-sans-serif);
    font-size: 16px;
    font-size: 1rem;
    font-size: clamp(1rem, 0.8863636364rem + 0.4848484848vw, 1.25rem);
    font-weight: 500;
    letter-spacing: 0;
    padding: .7em .7em;
    background-color: #EBEBEB
}

.wpcf7-form-control-wrap {
    position: relative
}

.wpcf7-form-control-wrap[data-name="your-address"] {
    display: inline-block
}

.wpcf7-form-control-wrap[data-name="your-address"]::before {
    content: "";
    background-image: url(../img/icon-form-arrow.png);
    width: 16px;
    height: 16px;
    background-repeat: no-repeat;
    background-size: contain;
    right: 10px;
    top: 30px;
    position: absolute
}

.wpcf7-form-control-wrap[data-name="your-address"] select {
    background-color: #FFF;
    border-radius: 4px
}

.c-formContact__listCheckbox {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px
}

.c-formContact__listCheckbox .wpcf7-list-item {
    margin: 0
}

@media screen and (min-width:641px) {
    .c-formContact tbody tr td {
        padding: 20px 0 40px
    }
}

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

    .c-formContact tbody tr th,
    .c-formContact tbody tr td {
        display: table-cell;
        border-bottom: 1px solid #DEDADA
    }

    .c-formContact tbody tr th {
        width: 220px;
        padding: 25px 0;
        vertical-align: top
    }

    .c-formContact tbody tr td {
        width: auto;
        padding: 20px 42px;
        vertical-align: top
    }

    .c-formContact tbody tr td input[type=text],
    .c-formContact tbody tr td input[type=tel] {
        max-width: 505px;
        padding: .7em 1em;
        font-size: 18px
    }

    .c-formContact tbody tr td input[type=text]#your-company,
    .c-formContact tbody tr td input[type=tel]#your-company {
        max-width: 605px
    }

    .c-formContact__label {
        padding: 1em 1em
    }

    .c-formContact__listCheckbox {
        flex-wrap: nowrap
    }

    .c-formContact__listCheckbox .wpcf7-list-item {
        display: block
    }

    .c-formContact__itemCheckbox .wpcf7-list-item:not(.last) {
        margin-left: 12px
    }
}

.c-formContact__listCheckbox label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 18px;
    font-size: clamp(16px, 0.5227272727rem + 1.1363636364vw, 18px);
    padding: 1em 1.5em 1em 1em;
    border: 1px solid #D3D3D3;
    border-radius: 4px;
    background-color: #fff
}

.c-formContact__listCheckbox input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.c-formContact__listCheckbox input {
    cursor: pointer;
    display: inline-block;
    line-height: 1;
    position: relative;
    width: auto
}

.c-formContact__listCheckbox input:checked::after {
    opacity: 1;
    transform: rotate(45deg) scale3d(1, 1, 1)
}

.c-formContact__listCheckbox input::before {
    background: #fff;
    border: 1px solid #707070;
    content: "";
    display: block;
    width: 20px;
    height: 20px
}

.c-formContact__listCheckbox input::after {
    opacity: 0;
    content: "";
    display: block;
    width: 8px;
    height: 13px;
    border-right: 3px solid #FF4442;
    border-bottom: 3px solid #FF4442;
    position: absolute;
    top: 2px;
    left: 6px;
    transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(.7, .7, 1);
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out
}

.c-formContact__listCheckbox label span {
    line-height: 1;
    font-size: inherit;
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap;
    padding: 0 0 0 .5em
}

@media screen and (min-width:641px) {
    .c-formContact__listCheckbox label {
        padding: 1.5rem 2.8rem 1.5rem 1.8rem
    }

    .c-formContact__listCheckbox label span {
        font-size: 18px;
        font-size: 1.125rem
    }
}

.c-formContact__menu {
    padding: 1.2rem 2.8rem 1.2rem 1.8rem;
    border: 1px solid #D3D3D3
}

.c-formContact__menu:invalid,
.c-formContact__menu option:first-child {
    color: #B7B7B7
}

.c-formContact__menu option {
    color: #000
}

.c-formContact__menu:focus,
.c-formContact__menu:hover {
    border: 1px solid #D3D3D3;
    outline: none
}

@media screen and (max-width:640px) {
    .c-formContact__menu {
        padding: 1rem 2.8rem 1rem 1.8rem
    }

    .c-formContact__listCheckbox input {
        margin-top: -.05rem
    }
}

.c-policy {
    padding: 1.5em 1em;
    border: 1px solid #D3D3D3;
    background-color: var(--white)
}

.c-policy__title {
    color: var(--black);
    line-height: 1;
    font-size: 18px;
    font-weight: 500
}

.c-policy__content {
    height: 140px;
    overflow: auto;
    margin: 1rem 0 0
}

.c-policy__content>p {
    color: var(--black);
    line-height: 2;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0;
    font-size: clamp(.75rem, 0.6931818182rem + 0.2424242424vw, .875rem)
}

.c-policy__content>p a {
    display: inline
}

@media screen and (min-width:641px) {
    .c-policy {
        padding: 1.8em 2em
    }
}

@media screen and (min-width:1024px) {
    .c-policy {
        padding: 1.7em 2em;
        margin-top: 45px
    }

    .c-policy__content {
        height: 55px;
        margin: .8em 0 0
    }
}

@media screen and (max-width:1023px) {
    .c-policy__title {
        font-size: clamp(14px, 0rem + 1.759vw, 18px)
    }
}

.c-consent {
    margin-top: var(--space-xs)
}

.c-consent label {
    display: table;
    cursor: pointer;
    margin: 0 auto;
    transition: all 0.35s ease
}

.c-consent label:hover {
    opacity: .5
}

.c-consent label input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.c-consent__check {
    display: flex;
    align-items: center;
    justify-content: center
}

.c-consent .wpcf7-list-item {
    display: inline;
    margin: 0
}

.c-consent .wpcf7-list-item-label {
    color: var(--black);
    display: inline-block;
    line-height: 1;
    font-size: 21px;
    font-size: clamp(15px, 0.7670454545rem + 0.7272727273vw, 21px);
    font-weight: 400;
    letter-spacing: 0;
    padding-left: .5em
}

.c-consent__box input {
    cursor: pointer;
    display: inline-block;
    line-height: 1;
    position: relative;
    width: auto;
    vertical-align: bottom
}

.c-consent__box input:checked::after {
    opacity: 1;
    transform: rotate(45deg) scale3d(1, 1, 1)
}

.c-consent__box input::before {
    background: #fff;
    border: 1px solid #707070;
    content: "";
    display: block;
    width: 15px;
    height: 15px
}

.c-consent__box input::after {
    opacity: 0;
    content: "";
    display: block;
    width: 5px;
    height: 9px;
    border-right: 2px solid #FF4442;
    border-bottom: 2px solid #FF4442;
    position: absolute;
    top: 2px;
    left: 5px;
    transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(.7, .7, 1);
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out
}

.c-consent label {
    line-height: 1;
    font-size: 20px;
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap;
    padding: 0 0 0 .5em
}

@media screen and (min-width:641px) {
    .c-consent {
        margin-top: 68px
    }

    .c-consent .wpcf7-list-item-label {
        font-size: 21px;
        font-size: 1.3125rem
    }

    .c-consent__box input::before {
        width: 23px;
        height: 23px
    }

    .c-consent__box input::after {
        width: 9px;
        height: 15px;
        border-right: 3px solid #FF4442;
        border-bottom: 3px solid #FF4442;
        top: 2px;
        left: 7px
    }
}

.c-submit {
    display: flex;
    margin: var(--space-xs) auto 0
}

.c-submit__button {
    cursor: pointer;
    position: relative;
    display: block;
    width: 86%;
    min-width: 240px;
    max-width: 426px;
    overflow: hidden;
    line-height: 1;
    font-size: 21px;
    font-size: clamp(16px, 0.8977272727rem + 0.9696969697vw, 21px);
    font-weight: 700;
    text-align: center;
    white-space: nowrap;
    letter-spacing: 0;
    margin: 0 auto
}

.c-submit__button input[type=submit] {
    color: var(--white);
    width: 100%;
    font-weight: 500;
    padding: 1.2em 0;
    border-radius: 50px;
    background-color: #FF4442;
    transition: all 0.35s ease
}

.c-submit__button input[type=submit]:disabled {
    pointer-events: none;
    background-color: #CCC
}

.c-submit__button:has(input[type=submit]:disabled) {
    cursor: not-allowed
}

.c-submit__button:has(input[type=submit]:disabled)::before {
    display: none
}

.c-submit__icon {
    width: 1.2em;
    pointer-events: none;
    position: absolute;
    top: 50%;
    right: 1em;
    transform: translateY(-50%)
}

.c-submit__icon>svg {
    width: 100%;
    height: auto
}

@media screen and (min-width:641px) {
    .c-submit {
        margin: 40px auto 0
    }
}

@media screen and (min-width:1024px) {
    .c-submit {
        display: table;
        width: 100%;
        margin: 28px auto 0
    }

    .c-submit__button {
        width: 100%;
        max-width: 448px
    }

    .c-submit__button input[type=submit] {
        padding: 1em 0
    }

    .c-submit__icon {
        width: 28px;
        right: 30px
    }
}

.c-secTtl__sub {
    color: #FF4442;
    line-height: 1;
    font-size: 13px;
    font-size: .8125rem;
    font-size: clamp(.8125rem, 0.25rem + 2.8125vw, 1.375rem);
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap
}

.c-secTtl {
    color: #FF4442;
    line-height: 1;
    font-size: 10vw;
    font-weight: 700;
    letter-spacing: .04em
}

.c-secTtl__sub+.c-secTtl {
    margin-top: 15px
}

@media screen and (min-width:641px) {
    .c-secTtl {
        font-size: 4rem
    }

    .c-secTtl__sub+.c-secTtl {
        margin-top: 25px
    }
}

@media screen and (max-width:640px) {
    .c-secTtl {
        font-size: 2.2rem
    }
}

.c-footerNavi__list {
    display: flex;
    align-items: center;
    justify-content: center
}

.c-footerNavi__item {
    line-height: 1;
    font-size: 10px;
    font-size: .625rem;
    font-size: clamp(.625rem, 0.5340909091rem + 0.4545454545vw, .875rem)
}

.c-footerNavi__item:not(:first-of-type) {
    margin: 0 0 0 1.5em
}

.c-footerNavi__item a {
    color: var(--black);
    position: relative;
    font-size: inherit;
    font-weight: 400;
    letter-spacing: 0;
    white-space: nowrap
}

.c-footerNavi__item a:hover::after {
    transform: scale(1, 1);
    transform-origin: top left
}

.c-footerNavi__item a::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--black);
    transform: scale(0, 1);
    transform-origin: top right;
    transition: transform 0.2s;
    position: absolute;
    bottom: -8px;
    left: 0
}

.c-buttonToTop {
    color: var(--black);
    position: relative;
    display: block;
    text-align: center;
    padding: 0;
    margin: 0 auto
}

.c-buttonToTop:hover .c-buttonToTop__circle {
    background-color: var(--accent)
}

.c-buttonToTop__circle {
    transition: all 0.45s cubic-bezier(.65, 0, .076, 1);
    position: relative;
    display: block;
    margin: 0;
    width: 3rem;
    height: 3rem;
    background-color: var(--black);
    border-radius: 1.625rem
}

.c-buttonToTop__circle::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    margin: auto;
    width: .625rem;
    height: .625rem;
    border-top: .125rem solid #fff;
    border-left: .125rem solid #fff;
    transform: rotate(45deg);
    transform-origin: left top
}

.c-buttonHeader {
    display: flex;
    align-items: center;
    transition: all 0.35s ease
}

.c-buttonHeader:hover {
    opacity: .5
}

.c-buttonHeader__icon {
    width: 31px;
    margin-right: 4px
}

.c-buttonHeader__text {
    display: flex;
    flex-direction: column;
    align-items: center
}

.c-buttonHeader__number {
    color: var(--black);
    line-height: 1;
    font-size: 14px;
    font-size: .875rem;
    font-size: clamp(.875rem, 0.5568181818rem + 1.5909090909vw, 1.75rem);
    font-weight: 600;
    letter-spacing: 0;
    white-space: nowrap
}

.c-buttonHeader__desc {
    color: var(--black);
    line-height: 1;
    font-size: 5px;
    font-size: .3125rem;
    font-size: clamp(.3125rem, 0.1534090909rem + 0.7954545455vw, .75rem);
    font-weight: 400;
    letter-spacing: 0;
    white-space: nowrap;
    margin: .2em 0 0
}

@media screen and (max-width:980px) {
    footer .c-buttonHeader__number {
        font-size: 24px
    }

    footer .c-buttonHeader__desc {
        font-size: 10px
    }
}

.c-flash:hover {
    opacity: .8;
    transition: 0.5s
}

.c-flash:hover::before {
    animation: none
}

.c-flash::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(130deg, rgba(255, 255, 255, 0) 20%, rgba(255, 255, 255, .5) 50%, rgba(255, 255, 255, 0) 80%);
    animation: flash 4s infinite
}

@keyframes flash {
    80% {
        left: -100%
    }

    100% {
        left: 100%
    }
}

.l-footer {
    position: relative;
    z-index: 101;
    border-top: 2px solid var(--white);
    background-color: #F8DE16
}

.l-footer__inner {
    padding: 28px 0 25px
}

.l-footer__content {
    display: flex;
    flex-direction: column
}

.l-footer__logo {
    width: 32%;
    max-width: 177px;
    margin: 0 auto
}

.l-footer__button {
    margin: 20px 0 10px
}

.l-footer__button .c-buttonHeader {
    justify-content: center;
    margin: .8em auto 0
}

.l-footer__navi {
    margin: 1.5em auto 0
}

.l-footer__copy {
    line-height: 1;
    margin: 1.5em auto 0
}

.l-footer__copy small {
    color: var(--black);
    font-size: 10px;
    font-size: .625rem;
    font-size: clamp(.625rem, 0.5113636364rem + 0.5681818182vw, .9375rem);
    font-weight: 400;
    letter-spacing: 0;
    white-space: nowrap
}

@media screen and (min-width:1024px) {
    .l-footer__inner {
        padding: 32px 0 45px
    }

    .l-footer__content {
        flex-direction: row;
        align-items: flex-end
    }

    .l-footer__logo {
        width: 15%;
        max-width: 177px;
        margin: 0
    }

    .l-footer__button {
        margin: auto 0 auto 3%
    }

    .l-footer__button .c-buttonHeader {
        margin-right: 0;
        margin: 0 auto 0
    }

    .l-footer__navi {
        margin: auto auto auto 3%
    }

    .l-footer__copy {
        margin: 0 0 0 auto
    }

    .l-footer__copy small {
        font-size: 13px;
        font-size: .8125rem
    }
}

.c-fixed_cta {
    display: none;
}

@media screen and (max-width:1023px) {
    .c-fixed_cta {
        transition: transform 0.5s ease;
        -webkit-transform: translateY(100%);
        transform: translateY(100%);
        position: fixed;
        bottom: 0;
        left: 0;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 5px;
        width: 100vw;
        box-sizing: border-box;
        padding: 10px;
        background: rgba(45, 45, 45, 20%);
        z-index: 200;
    }

    .c-fixed_cta.is-active {
        -webkit-transform: translateY(0%);
        transform: translateY(0%);
    }

    .c-fixed_cta .c-buttonUnit__button {
        height: 60px;
    }

    .c-fixed_cta .c-buttonUnit__text,
    .c-fixed_cta .c-buttonUnit__text {
        font-size: clamp(1.0625rem, 0.9204545455rem + 0.6060606061vw, 1.375rem);
    }

    .c-fixed_cta .c-buttonUnit__text>span {
        display: block;
        font-size: 8px;
        font-size: .5rem;
        font-size: clamp(.5rem, 0.3636363636rem + 0.6818181818vw, .875rem);
        font-weight: 400;
        margin-top: .4em
    }
}