@charset "UTF-8";
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

:where([hidden]:not([hidden="until-found"])) {
    display: none !important;
}

:where(html) {
    -webkit-text-size-adjust: none;
    color-scheme: dark light;
}

@supports not (min-block-size: 100dvb) {
    :where(html) {
        block-size: 100%;
    }
}
@media (prefers-reduced-motion: no-preference) {
    :where(html:focus-within) {
        scroll-behavior: smooth;
    }
}
:where(body) {
    block-size: 100%;
    block-size: 100dvb;
    line-height: 1.5;
    font-family: system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}

:where(input, button, textarea, select) {
    font: inherit;
    color: inherit;
}

:where(textarea) {
    resize: vertical;
    resize: block;
}

:where(button, label, select, summary, [role="button"], [role="option"]) {
    cursor: pointer;
}

:where(:disabled) {
    cursor: not-allowed;
}

:where(label:has(> input:disabled), label:has(+ input:disabled)) {
    cursor: not-allowed;
}

:where(button) {
    border-style: solid;
}

:where(a) {
    text-underline-offset: 0.2ex;
}

:where(ul, ol) {
    list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
    display: block;
}

:where(img, picture, svg) {
    max-inline-size: 100%;
    block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
    overflow-wrap: break-word;
}

:where(h1, h2, h3) {
    line-height: calc(1em + 0.5rem);
}

:where(hr) {
    border: none;
    -webkit-border-before: 1px solid;
    border-block-start: 1px solid;
    color: inherit;
    block-size: 0;
    overflow: visible;
}

:where(:focus-visible) {
    outline: 2px solid var(--focus-color, Highlight);
    outline-offset: 2px;
}

:where(
        .visually-hidden:not(
                :focus,
                :active,
                :focus-within,
                .not-visually-hidden
            )
    ) {
    clip-path: inset(50%) !important;
    height: 1px !important;
    width: 1px !important;
    overflow: hidden !important;
    position: absolute !important;
    white-space: nowrap !important;
    border: 0 !important;
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

*::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

*::-webkit-scrollbar-track {
    background-color: #efefef;
}

*::-webkit-scrollbar-thumb {
    background-color: #3d64cb;
}

html {
    font-size: 62.5%;
    -webkit-text-size-adjust: none;
    scroll-behavior: smooth;
    scroll-padding-top: 80px;
}

body {
    font-family: "Hiragino Sans", "ヒラギノ角ゴシック", "ヒラギノ角ゴ Pro W3",
        "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "Helvetica Neue",
        Helvetica, Arial, sans-serif;
    font-size: 1.6rem;
    color: #333;
    line-height: 1.4;
    background-color: #fbf9ef;
    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

p {
    line-height: 1.8;
}

a:link,
a:visited,
a:hover,
a:link {
    color: #3d64cb;
    text-decoration: none;
}

img {
    width: 100%;
    height: auto;
    vertical-align: text-bottom;
    display: block;
}

.l-container {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 1200px 1fr;
    grid-template-columns: 1fr 1200px 1fr;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
}
.l-container > * {
    -ms-grid-column: 2;
    grid-column: 2;
}
.l-container .is-full {
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    grid-column: 1/4;
}
@media screen and (max-width: 1200px) {
    .l-container {
        -ms-grid-columns: 0 1fr 0;
        grid-template-columns: 0 1fr 0;
    }
}
.l-container_inn {
    width: 95%;
    max-width: 1200px;
    margin: auto;
}

.mgt-0 {
    margin-top: 0px !important;
}

.pdt-0 {
    padding-top: 0px !important;
}

.mgb-0 {
    margin-bottom: 0px !important;
}

.pdb-0 {
    padding-bottom: 0px !important;
}

.mgl-0 {
    margin-left: 0px !important;
}

.pdl-0 {
    padding-left: 0px !important;
}

.mgr-0 {
    margin-right: 0px !important;
}

.pdr-0 {
    padding-right: 0px !important;
}

.mgt-10 {
    margin-top: 10px !important;
}

.pdt-10 {
    padding-top: 10px !important;
}

.mgb-10 {
    margin-bottom: 10px !important;
}

.pdb-10 {
    padding-bottom: 10px !important;
}

.mgl-10 {
    margin-left: 10px !important;
}

.pdl-10 {
    padding-left: 10px !important;
}

.mgr-10 {
    margin-right: 10px !important;
}

.pdr-10 {
    padding-right: 10px !important;
}

.mgt-20 {
    margin-top: 20px !important;
}

.pdt-20 {
    padding-top: 20px !important;
}

.mgb-20 {
    margin-bottom: 20px !important;
}

.pdb-20 {
    padding-bottom: 20px !important;
}

.mgl-20 {
    margin-left: 20px !important;
}

.pdl-20 {
    padding-left: 20px !important;
}

.mgr-20 {
    margin-right: 20px !important;
}

.pdr-20 {
    padding-right: 20px !important;
}

.mgt-30 {
    margin-top: 30px !important;
}

.pdt-30 {
    padding-top: 30px !important;
}

.mgb-30 {
    margin-bottom: 30px !important;
}

.pdb-30 {
    padding-bottom: 30px !important;
}

.mgl-30 {
    margin-left: 30px !important;
}

.pdl-30 {
    padding-left: 30px !important;
}

.mgr-30 {
    margin-right: 30px !important;
}

.pdr-30 {
    padding-right: 30px !important;
}

.mgt-40 {
    margin-top: 40px !important;
}

.pdt-40 {
    padding-top: 40px !important;
}

.mgb-40 {
    margin-bottom: 40px !important;
}

.pdb-40 {
    padding-bottom: 40px !important;
}

.mgl-40 {
    margin-left: 40px !important;
}

.pdl-40 {
    padding-left: 40px !important;
}

.mgr-40 {
    margin-right: 40px !important;
}

.pdr-40 {
    padding-right: 40px !important;
}

.mgt-50 {
    margin-top: 50px !important;
}

.pdt-50 {
    padding-top: 50px !important;
}

.mgb-50 {
    margin-bottom: 50px !important;
}

.pdb-50 {
    padding-bottom: 50px !important;
}

.mgl-50 {
    margin-left: 50px !important;
}

.pdl-50 {
    padding-left: 50px !important;
}

.mgr-50 {
    margin-right: 50px !important;
}

.pdr-50 {
    padding-right: 50px !important;
}

.mgt-60 {
    margin-top: 60px !important;
}

.pdt-60 {
    padding-top: 60px !important;
}

.mgb-60 {
    margin-bottom: 60px !important;
}

.pdb-60 {
    padding-bottom: 60px !important;
}

.mgl-60 {
    margin-left: 60px !important;
}

.pdl-60 {
    padding-left: 60px !important;
}

.mgr-60 {
    margin-right: 60px !important;
}

.pdr-60 {
    padding-right: 60px !important;
}

.mgt-70 {
    margin-top: 70px !important;
}

.pdt-70 {
    padding-top: 70px !important;
}

.mgb-70 {
    margin-bottom: 70px !important;
}

.pdb-70 {
    padding-bottom: 70px !important;
}

.mgl-70 {
    margin-left: 70px !important;
}

.pdl-70 {
    padding-left: 70px !important;
}

.mgr-70 {
    margin-right: 70px !important;
}

.pdr-70 {
    padding-right: 70px !important;
}

.mgt-80 {
    margin-top: 80px !important;
}

.pdt-80 {
    padding-top: 80px !important;
}

.mgb-80 {
    margin-bottom: 80px !important;
}

.pdb-80 {
    padding-bottom: 80px !important;
}

.mgl-80 {
    margin-left: 80px !important;
}

.pdl-80 {
    padding-left: 80px !important;
}

.mgr-80 {
    margin-right: 80px !important;
}

.pdr-80 {
    padding-right: 80px !important;
}

.mgt-90 {
    margin-top: 90px !important;
}

.pdt-90 {
    padding-top: 90px !important;
}

.mgb-90 {
    margin-bottom: 90px !important;
}

.pdb-90 {
    padding-bottom: 90px !important;
}

.mgl-90 {
    margin-left: 90px !important;
}

.pdl-90 {
    padding-left: 90px !important;
}

.mgr-90 {
    margin-right: 90px !important;
}

.pdr-90 {
    padding-right: 90px !important;
}

.mgt-100 {
    margin-top: 100px !important;
}

.pdt-100 {
    padding-top: 100px !important;
}

.mgb-100 {
    margin-bottom: 100px !important;
}

.pdb-100 {
    padding-bottom: 100px !important;
}

.mgl-100 {
    margin-left: 100px !important;
}

.pdl-100 {
    padding-left: 100px !important;
}

.mgr-100 {
    margin-right: 100px !important;
}

.pdr-100 {
    padding-right: 100px !important;
}

.mgt-110 {
    margin-top: 110px !important;
}

.pdt-110 {
    padding-top: 110px !important;
}

.mgb-110 {
    margin-bottom: 110px !important;
}

.pdb-110 {
    padding-bottom: 110px !important;
}

.mgl-110 {
    margin-left: 110px !important;
}

.pdl-110 {
    padding-left: 110px !important;
}

.mgr-110 {
    margin-right: 110px !important;
}

.pdr-110 {
    padding-right: 110px !important;
}

.mgt-120 {
    margin-top: 120px !important;
}

.pdt-120 {
    padding-top: 120px !important;
}

.mgb-120 {
    margin-bottom: 120px !important;
}

.pdb-120 {
    padding-bottom: 120px !important;
}

.mgl-120 {
    margin-left: 120px !important;
}

.pdl-120 {
    padding-left: 120px !important;
}

.mgr-120 {
    margin-right: 120px !important;
}

.pdr-120 {
    padding-right: 120px !important;
}

.mgt-130 {
    margin-top: 130px !important;
}

.pdt-130 {
    padding-top: 130px !important;
}

.mgb-130 {
    margin-bottom: 130px !important;
}

.pdb-130 {
    padding-bottom: 130px !important;
}

.mgl-130 {
    margin-left: 130px !important;
}

.pdl-130 {
    padding-left: 130px !important;
}

.mgr-130 {
    margin-right: 130px !important;
}

.pdr-130 {
    padding-right: 130px !important;
}

.mgt-140 {
    margin-top: 140px !important;
}

.pdt-140 {
    padding-top: 140px !important;
}

.mgb-140 {
    margin-bottom: 140px !important;
}

.pdb-140 {
    padding-bottom: 140px !important;
}

.mgl-140 {
    margin-left: 140px !important;
}

.pdl-140 {
    padding-left: 140px !important;
}

.mgr-140 {
    margin-right: 140px !important;
}

.pdr-140 {
    padding-right: 140px !important;
}

.mgt-150 {
    margin-top: 150px !important;
}

.pdt-150 {
    padding-top: 150px !important;
}

.mgb-150 {
    margin-bottom: 150px !important;
}

.pdb-150 {
    padding-bottom: 150px !important;
}

.mgl-150 {
    margin-left: 150px !important;
}

.pdl-150 {
    padding-left: 150px !important;
}

.mgr-150 {
    margin-right: 150px !important;
}

.pdr-150 {
    padding-right: 150px !important;
}

.mgt-160 {
    margin-top: 160px !important;
}

.pdt-160 {
    padding-top: 160px !important;
}

.mgb-160 {
    margin-bottom: 160px !important;
}

.pdb-160 {
    padding-bottom: 160px !important;
}

.mgl-160 {
    margin-left: 160px !important;
}

.pdl-160 {
    padding-left: 160px !important;
}

.mgr-160 {
    margin-right: 160px !important;
}

.pdr-160 {
    padding-right: 160px !important;
}

.mgt-170 {
    margin-top: 170px !important;
}

.pdt-170 {
    padding-top: 170px !important;
}

.mgb-170 {
    margin-bottom: 170px !important;
}

.pdb-170 {
    padding-bottom: 170px !important;
}

.mgl-170 {
    margin-left: 170px !important;
}

.pdl-170 {
    padding-left: 170px !important;
}

.mgr-170 {
    margin-right: 170px !important;
}

.pdr-170 {
    padding-right: 170px !important;
}

.mgt-180 {
    margin-top: 180px !important;
}

.pdt-180 {
    padding-top: 180px !important;
}

.mgb-180 {
    margin-bottom: 180px !important;
}

.pdb-180 {
    padding-bottom: 180px !important;
}

.mgl-180 {
    margin-left: 180px !important;
}

.pdl-180 {
    padding-left: 180px !important;
}

.mgr-180 {
    margin-right: 180px !important;
}

.pdr-180 {
    padding-right: 180px !important;
}

.mgt-190 {
    margin-top: 190px !important;
}

.pdt-190 {
    padding-top: 190px !important;
}

.mgb-190 {
    margin-bottom: 190px !important;
}

.pdb-190 {
    padding-bottom: 190px !important;
}

.mgl-190 {
    margin-left: 190px !important;
}

.pdl-190 {
    padding-left: 190px !important;
}

.mgr-190 {
    margin-right: 190px !important;
}

.pdr-190 {
    padding-right: 190px !important;
}

.mgt-200 {
    margin-top: 200px !important;
}

.pdt-200 {
    padding-top: 200px !important;
}

.mgb-200 {
    margin-bottom: 200px !important;
}

.pdb-200 {
    padding-bottom: 200px !important;
}

.mgl-200 {
    margin-left: 200px !important;
}

.pdl-200 {
    padding-left: 200px !important;
}

.mgr-200 {
    margin-right: 200px !important;
}

.pdr-200 {
    padding-right: 200px !important;
}

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

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

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

.bold {
    font-weight: bold;
}

.float-left {
    float: left;
}

.float-right {
    float: right;
}

br.smp {
    display: none;
}
@media screen and (max-width: 768px) {
    br.smp {
        display: inline;
    }
}

br.pc {
    display: inline;
}
@media screen and (max-width: 768px) {
    br.pc {
        display: none;
    }
}

a:hover {
    transition: opacity 0.5s;
    -moz-transition: opacity 0.5s;
    -webkit-transition: opacity 0.5s;
    -o-transition: opacity 0.5s;
    -ms-transition: opacity 0.5s;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
a:hover:hover {
    opacity: 0.5;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.header {
    z-index: 1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 240px 1fr;
    grid-template-columns: 240px 1fr;
    padding: 24px;
    border-bottom: 1px solid #e3e3e3;
    background: #fff;
    width: 100%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header_logo {
    display: block;
}
.header > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header_nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
}
.header_nav a {
    color: #202020;
    display: block;
    font-weight: bold;
}
.header_nav a:hover {
    color: #3d64cb;
    opacity: 1;
}
.header_cv {
    text-align: center;
    width: 300px;
    height: 48px;
    line-height: 48px;
    background-color: #ff6c2d;
    color: #fff !important;
    border-radius: 24px;
    font-weight: bold;
}
@media screen and (max-width: 1200px) {
    .header {
        -ms-grid-columns: 200px 1fr;
        grid-template-columns: 200px 1fr;
        font-size: 1.4rem;
    }
    .header > div {
        gap: 20px;
    }
    .header_nav {
        gap: 10px;
    }
    .header_cv {
        width: 260px;
    }
}
@media screen and (max-width: 1000px) {
    .header {
        padding: 10px;
    }
    .header_nav {
        display: none;
    }
}
@media screen and (max-width: 768px) {
    .header_cv {
        width: 90%;
        position: fixed;
        bottom: 10px;
        left: 5%;
        font-size: 1.6rem;
    }
}

.footer {
    text-align: center;
    background-color: #333;
    color: #fff;
    font-size: 1.4rem;
}
.footer > div {
    padding: 64px 0 40px;
}
.footer > div span {
    font-size: 2rem;
    display: block;
    margin-bottom: 10px;
}
.footer > div a {
    font-size: 3rem;
    color: #fff;
}
.footer > div p {
    margin-top: 10px;
}
.footer_link {
    font-size: 1.4rem;
    text-decoration: underline;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 26px;
    margin-bottom: 60px;
}
.footer_link a {
    color: #fff;
}
.footer .copyright {
    border-top: 1px solid #616161;
    padding: 16px;
    font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
    .footer_link {
        display: block;
    }
    .footer .copyright {
        padding-bottom: 80px;
    }
}

.main {
    background: url("img/main_bg.svg") no-repeat center 100% / cover;
    padding: 140px 0;
    font-weight: bold;
    position: relative;
    overflow: hidden;
}
.main:before {
    content: "";
    width: 824px;
    height: 555px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url("img/main.webp");
    position: absolute;
    right: 50%;
    -webkit-transform: translate(100%, 0);
    transform: translate(100%, 0);
    bottom: 50px;
}
.main:after {
    content: "";
    width: 200px;
    height: 200px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url("img/badge.webp");
    position: absolute;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    top: 150px;
}
.main_title {
    font-size: 5rem;
    margin-bottom: 20px;
}
.main_title span {
    display: inline-block;
    border-bottom: 5px solid #3d64cb;
    margin-bottom: 10px;
}
.main_text {
    font-size: 2.2rem;
    margin-bottom: 60px;
}
.main_btn {
    width: 491px;
    height: auto;
    display: block;
}
@media screen and (max-width: 1200px) {
    .main:before {
        width: 600px;
        height: 400px;
        bottom: 80px;
    }
    .main:after {
        width: 160px;
        height: 160px;
    }
    .main_title {
        font-size: 4rem;
    }
    .main_text {
        font-size: 2rem;
        margin-bottom: 40px;
    }
    .main_btn {
        width: 400px;
    }
}
@media screen and (max-width: 1000px) {
    .main {
        padding: 120px 0 60px;
    }
    .main:after {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
        top: 90px;
    }
    .main_btn {
        width: 360px;
    }
}
@media screen and (max-width: 768px) {
    .main {
        padding: 100px 20px 60px;
        display: -ms-grid;
        display: grid;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
    .main:before {
        width: 320px;
        height: 220px;
        bottom: auto;
        top: 250px;
        -webkit-transform: translate(50%, 0);
        transform: translate(50%, 0);
        background-image: url("img/main_sp.webp");
    }
    .main:after {
        width: 120px;
        height: 120px;
        top: 70px;
        -webkit-transform: translate(60px, 0);
        transform: translate(60px, 0);
    }
    .main_title {
        font-size: 2.4rem;
        margin-bottom: 260px;
    }
    .main_text {
        font-size: 1.6rem;
        margin-bottom: 40px;
    }
    .main_btn {
        width: 100%;
        max-width: 360px;
    }
}

.worries {
    font-weight: bold;
    padding: 64px 0;
}
.worries_title {
    text-align: center;
    font-size: 4rem;
    margin-bottom: 40px;
}
.worries_title strong {
    font-size: 4.8rem;
    color: #4e988f;
}
.worries_title span {
    display: block;
    width: 260px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    margin: 0 auto 20px;
    position: relative;
    border-radius: 30px;
    background-color: #4e988f;
    color: #fff;
    font-size: 1.8rem;
}
.worries_title span:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -20px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border: 10px solid rgba(0, 0, 0, 0);
    border-top: 10px solid #4e988f;
}
.worries_list {
    width: 90%;
    max-width: 1040px;
    margin: auto;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 40px 1fr 40px 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}
.worries_list_item {
    display: -ms-grid;
    display: grid;
    gap: 20px;
    justify-items: center;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
    -ms-flex-line-pack: start;
    align-content: start;
}
.worries_list_item .el_head {
    background-color: #fff;
    border-radius: 16px;
    text-align: center;
    line-height: 1.36;
    font-size: 2.2rem;
    width: 100%;
    height: 150px;
    display: -ms-grid;
    display: grid;
    place-items: center;
    position: relative;
}
.worries_list_item .el_head strong {
    color: #ff6c2d;
}
.worries_list_item .el_head:before {
    content: "";
    width: 36px;
    height: 66px;
    background: url("img/balloon.svg") no-repeat center/contain;
    position: absolute;
    bottom: -50px;
    left: 60px;
}
.worries_list_item .el_img {
    height: 160px;
    width: auto;
}
.worries_list_item .el_text {
    font-size: 1.6rem;
}
@media screen and (max-width: 1000px) {
    .worries_list {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    }
    .worries_list_item {
        -ms-grid-columns: 2fr 1fr 1fr;
        grid-template-columns: 2fr 1fr 1fr;
    }
}
@media screen and (max-width: 768px) {
    .worries_title {
        font-size: 2.2rem;
    }
    .worries_title strong {
        font-size: 3rem;
    }
    .worries_title span {
        width: 200px;
        height: 40px;
        line-height: 40px;
        border-radius: 20px;
        font-size: 1.6rem;
    }
    .worries_list_item {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    }
}

.feature {
    font-weight: bold;
    padding: 120px 0;
    background-color: #e0f3f1;
    position: relative;
}
.feature:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border: 100px solid rgba(0, 0, 0, 0);
    border-top: 60px solid #fbf9ef;
}
.feature_title {
    font-size: 3rem;
    text-align: center;
    margin-bottom: 80px;
}
.feature_title img {
    display: inline-block;
    width: 600px;
    height: auto;
    margin-bottom: 10px;
    margin-right: 10px;
}
.feature_title span {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    display: block;
    margin: auto;
    font-size: 4rem;
    border-bottom: 10px solid #ffe81c;
}
.feature_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 60px 1fr 60px 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 60px;
}
.feature_list_item {
    display: -ms-grid;
    display: grid;
    gap: 10px;
    justify-items: center;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
    -ms-flex-line-pack: start;
    align-content: start;
}
.feature_list_item .el_img {
    height: 340px;
    width: auto;
}
.feature_list_item .el_text {
    font-size: 1.6rem;
}
@media screen and (max-width: 1200px) {
    .feature_list {
        gap: 40px;
    }
    .feature_list_item .el_img {
        height: 260px;
        width: auto;
    }
}
@media screen and (max-width: 1000px) {
    .feature_list {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    }
    .feature_list_item {
        -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
}
@media screen and (max-width: 768px) {
    .feature {
        padding: 60px 0;
    }
    .feature:before {
        border: 50px solid rgba(0, 0, 0, 0);
        border-top: 30px solid #fbf9ef;
    }
    .feature_title {
        font-size: 2rem;
        margin-bottom: 40px;
    }
    .feature_title img {
        width: 80%;
        margin-right: 0;
        vertical-align: middle;
    }
    .feature_title span {
        font-size: 2.8rem;
        border-bottom: 6px solid #ffe81c;
    }
    .feature_list {
        padding: 0 20px;
    }
    .feature_list_item {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    }
}

.cv {
    position: relative;
    font-weight: bold;
    height: 260px;
    width: 100%;
    background-color: #3d64cb;
    text-align: center;
    color: #fff;
    font-size: 3rem;
    line-height: 1.2;
    display: -ms-grid;
    display: grid;
    place-items: center;
}
.cv:before,
.cv:after {
    content: "";
    width: 240px;
    height: 297px;
    display: block;
    position: absolute;
    background: no-repeat center/contain;
    bottom: 0;
}
.cv:before {
    background-image: url("img/cv01.webp");
    left: 50%;
    -webkit-transform: translate(-540px, 0);
    transform: translate(-540px, 0);
}
.cv:after {
    background-image: url("img/cv02.webp");
    right: 50%;
    -webkit-transform: translate(540px, 0);
    transform: translate(540px, 0);
}
.cv strong {
    font-size: 6rem;
    color: #ffe81c;
}
.cv span {
    font-size: 4.8rem;
}
.cv span strong {
    font-size: 4.8rem;
    color: #ffe81c;
}
.cv a {
    display: block;
    width: 500px;
    height: 60px;
    line-height: 60px;
    background-color: #ff6c2d;
    border: 2px solid #fff;
    border-radius: 6px;
    color: #fff;
    text-align: center;
    font-size: 2.2rem;
    margin: 20px auto 0;
}
@media screen and (max-width: 1200px) {
    .cv:before,
    .cv:after {
        width: 200px;
        height: 240px;
    }
    .cv:before {
        -webkit-transform: translate(-480px, 0);
        transform: translate(-480px, 0);
    }
    .cv:after {
        -webkit-transform: translate(480px, 0);
        transform: translate(480px, 0);
    }
}
@media screen and (max-width: 1000px) {
    .cv {
        font-size: 2rem;
        height: 200px;
    }
    .cv strong {
        font-size: 4rem;
    }
    .cv span {
        font-size: 3rem;
    }
    .cv span strong {
        font-size: 3rem;
    }
    .cv a {
        width: 400px;
        height: 45px;
        line-height: 45px;
        font-size: 1.8rem;
    }
    .cv:before {
        -webkit-transform: translate(-380px, 0);
        transform: translate(-380px, 0);
    }
    .cv:after {
        -webkit-transform: translate(380px, 0);
        transform: translate(380px, 0);
    }
}
@media screen and (max-width: 768px) {
    .cv:before,
    .cv:after {
        display: none;
    }
    .cv a {
        width: 100%;
    }
}

.point {
    font-weight: bold;
    padding: 80px 0;
}
.point_title {
    text-align: center;
    font-size: 4rem;
    margin-bottom: 40px;
}
.point_title strong {
    font-size: 5rem;
}
.point_title img {
    display: inline-block;
    width: 430px;
    height: auto;
    margin-right: 10px;
}
.point_title span {
    display: block;
    width: 260px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    margin: 0 auto 20px;
    position: relative;
    border-radius: 30px;
    background-color: #4e988f;
    color: #fff;
    font-size: 1.8rem;
}
.point_title span:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -20px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border: 10px solid rgba(0, 0, 0, 0);
    border-top: 10px solid #4e988f;
}
@media screen and (max-width: 1000px) {
    .point {
        padding: 80px 0 40px;
    }
    .point_title {
        margin-bottom: 60px;
    }
}
@media screen and (max-width: 768px) {
    .point_title {
        font-size: 2rem;
    }
    .point_title strong {
        font-size: 3.8rem;
    }
    .point_title img {
        width: 60%;
        margin-right: 0;
    }
    .point_title span {
        width: 200px;
        height: 40px;
        line-height: 40px;
        border-radius: 20px;
        font-size: 1.6rem;
    }
}

.point_cont {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 60px 1fr;
    grid-template-columns: 1fr 1fr;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 60px;
}
.point_cont_img {
    background-color: #e0f3f1;
    border-radius: 0 240px 240px 0;
    height: 480px;
    display: -ms-grid;
    display: grid;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    justify-items: end;
}
.point_cont_img > div {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    aspect-ratio: 530/360;
    width: 530px;
}
.point_cont_text {
    max-width: 440px;
    padding: 0 20px;
}
.point_cont_text h3 {
    font-size: 3rem;
    line-height: 1.5;
    margin-bottom: 20px;
}
.point_cont_text h3 span {
    display: block;
    color: #4e988f;
    font-size: 2rem;
}
.point_cont_text h3 span strong {
    font-size: 2.6rem;
}
.point_cont.is-odd {
    justify-items: end;
}
.point_cont.is-odd .point_cont_img {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    border-radius: 240px 0 0 240px;
    justify-items: start;
    -ms-grid-column-align: normal;
    justify-self: normal;
}
.point_cont.is-odd .point_cont_text {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
}
@media screen and (max-width: 1000px) {
    .point_cont {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    }
    .point_cont_img {
        justify-items: center;
        height: 300px;
        margin-bottom: 20px;
    }
    .point_cont_text {
        -ms-grid-column-align: center;
        justify-self: center;
        margin-bottom: 60px;
    }
    .point_cont.is-odd {
        justify-items: center;
    }
    .point_cont.is-odd .point_cont_img {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
        border-radius: 240px 0 0 240px;
        justify-items: center;
        -ms-grid-column-align: normal;
        justify-self: normal;
    }
    .point_cont.is-odd .point_cont_text {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }
}
@media screen and (max-width: 768px) {
    .point_cont {
        gap: 0;
    }
    .point_cont_img > div {
        width: 90%;
    }
}

.form {
    padding: 80px 0;
    background-color: #f5f6fb;
}
.form_title {
    text-align: center;
    font-size: 4rem;
    margin-bottom: 40px;
}
.form_title strong {
    font-size: 4.8rem;
    color: #3d64cb;
}
.form_title span {
    display: block;
    width: 260px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    margin: 0 auto 20px;
    position: relative;
    border-radius: 30px;
    background-color: #3d64cb;
    color: #fff;
    font-size: 1.8rem;
}
.form_title span:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -20px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border: 10px solid rgba(0, 0, 0, 0);
    border-top: 10px solid #3d64cb;
}
.form_item {
    width: 90%;
    max-width: 800px;
    margin: auto;
}
.form_item iframe {
    width: 100%;
    height: 600px;
    border: 1px solid #ccc;
    margin: 40px 0;
    background-color: #fff;
    border-radius: 16px;
}
@media screen and (max-width: 768px) {
    .form {
        padding: 60px 0;
    }
    .form_title {
        font-size: 2.6rem;
    }
    .form_title strong {
        font-size: 3rem;
    }
    .form_title span {
        width: 200px;
        height: 40px;
        line-height: 40px;
        border-radius: 20px;
        font-size: 1.4rem;
    }
    .form_item iframe {
        height: 400px;
    }
    .form p {
        font-size: 1.3rem;
    }
}

.column {
    padding: 140px 0;
}
@media screen and (max-width: 768px) {
    .column {
        padding: 100px 0;
    }
}
.column_title {
    text-align: center;
    font-size: 4rem;
    margin-bottom: 40px;
}
.column_title strong {
    font-size: 4.8rem;
    color: #4e988f;
}
.column_title span {
    display: block;
    width: 260px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    margin: 0 auto 20px;
    position: relative;
    border-radius: 30px;
    background-color: #4e988f;
    color: #fff;
    font-size: 1.8rem;
}
.column_title span:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -20px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border: 10px solid rgba(0, 0, 0, 0);
    border-top: 10px solid #4e988f;
}
@media screen and (max-width: 768px) {
    .column_title {
        font-size: 3rem;
    }
}
.column_List {
    width: 90%;
    max-width: 1040px;
    margin: auto;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: minmax(0, 1fr) 40px minmax(0, 1fr) 40px minmax(0, 1fr);
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 40px;
}
.column_List a {
    border: 6px solid #4e988f;
    background-color: #fff;
    padding: 20px 15px;
    padding-bottom: 30px;
    aspect-ratio: 12/6;
    display: -ms-grid;
    display: grid;
    place-items: center;
    position: relative;
    color: #333;
    font-size: 1.8rem;
    line-height: 1.6;
    border-radius: 6px;
    background: url("/LP/img/bg.png") repeat center/15px;
    padding-left: 100px;
}
.column_List a span {
    position: absolute;
    bottom: 10px;
    right: 10px;
    color: #888;
    font-size: 1.4rem;
}
.column_List a.makoto:before {
    background: url("/LP/img/makoto.png") no-repeat center/contain;
}
.column_List a.mio:before {
    background: url("/LP/img/mio.png") no-repeat center/contain;
}
.column_List a:before {
    content: "";
    position: absolute;
    width: 100px;
    height: 120px;
    bottom: 0;
    left: 0;
    font-weight: bold;
    color: #ff6c2e;
    font-size: 15px;
    padding-left: 10px;
    text-shadow: 2px 2px 0 #fff, -2px -2px 0 #fff, -2px 2px 0 #fff,
        2px -2px 0 #fff, 0px 2px 0 #fff, 0 -2px 0 #fff, -2px 0 0 #fff,
        2px 0 0 #fff;
}
.column_List a:after {
    top: 10px;
    right: 10px;
    content: "";
    width: 30px;
    height: 30px;
    position: absolute;
    display: block;
    background: url("img/apple-touch-icon.png") no-repeat center/contain;
}
.column_List a:first-child:before {
    content: "NEW!";
}
@media screen and (max-width: 1000px) {
    .column_List {
        -ms-grid-columns: minmax(0, 1fr) 20px minmax(0, 1fr);
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }
    .column_List a {
        font-size: 1.6rem;
    }
}
@media screen and (max-width: 768px) {
    .column_List {
        -ms-grid-columns: minmax(0, 1fr);
        grid-template-columns: repeat(1, minmax(0, 1fr));
        gap: 20px;
    }
}

.column_cont {
    width: 100%;
    max-width: 800px;
    margin: auto;
    background-color: #fff;
    border-radius: 10px;
    padding: 40px;
}
@media screen and (max-width: 768px) {
    .column_cont {
        padding: 20px;
    }
}
.column_cont > * + * {
    margin-top: 30px;
}
.column_cont .column_head {
    border: 6px solid #4e988f;
    background-color: #fff;
    padding: 20px;
    padding-bottom: 30px;
    aspect-ratio: 12/6;
    display: -ms-grid;
    display: grid;
    place-items: center;
    position: relative;
    color: #333;
    font-size: 3.8rem;
    line-height: 1.6;
    border-radius: 6px;
    background: url("/LP/img/bg.png") repeat center/15px;
    padding-left: 100px;
}
.column_cont .column_head.makoto:before {
    background: url("/LP/img/makoto_2x.png") no-repeat center/contain;
}
.column_cont .column_head.mio:before {
    background: url("/LP/img/mio_2x.png") no-repeat center/contain;
}
.column_cont .column_head:before {
    content: "";
    position: absolute;
    width: 170px;
    height: 188px;
    bottom: 0;
    left: 0;
    font-weight: bold;
    color: #ff6c2e;
    font-size: 15px;
    padding-left: 10px;
    text-shadow: 2px 2px 0 #fff, -2px -2px 0 #fff, -2px 2px 0 #fff,
        2px -2px 0 #fff, 0px 2px 0 #fff, 0 -2px 0 #fff, -2px 0 0 #fff,
        2px 0 0 #fff;
}
.column_cont .column_head:after {
    top: 10px;
    right: 10px;
    content: "";
    width: 50px;
    height: 50px;
    position: absolute;
    display: block;
    background: url("/LP/img/apple-touch-icon.png") no-repeat center/contain;
}
.column_cont h1 {
    padding: 0.25em 0.5em; /*上下 左右の余白*/
    color: #494949; /*文字色*/
    background: transparent; /*背景透明に*/
    font-size: 6rem;
    line-height: 8rem;
}
@media screen and (max-width: 768px) {
    .column_cont h1 {
        font-size: 2rem;
    }
}
.column_cont h2 {
    color: #364e96; /*文字色*/
    padding: 0.5em 0; /*上下の余白*/
    border-top: solid 3px #364e96; /*上線*/
    border-bottom: solid 3px #364e96; /*下線*/
    font-size: 2rem;
}
.column_cont h2.point:before {
    content: "";
    background: url("/LP/img/ponta.png") no-repeat center/contain;
    width: 60px;
    height: 60px;
    display: inline-block;
    padding: 0.5em 1em;
    margin-right: 1em;
    color: #fff;
    border-radius: 0.5em;
}
.column_cont h2.point {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 60px 2rem 1fr;
    grid-template-columns: 60px 1fr;
    gap: 2rem;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
@media screen and (max-width: 768px) {
    .column_cont h2 {
        font-size: 1.8rem;
    }
}
.column_cont img {
    border-radius: 6px;
}
.column_cont ul {
    list-style: disc;
    padding-left: 20px;
}
.column_cont ul li + li {
    margin-top: 10px;
}
.column_cont .el_date {
    text-align: right;
}
.column_cont .el_character01 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 160px 10px 1fr;
    grid-template-columns: 160px 1fr;
    gap: 10px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
@media screen and (max-width: 768px) {
    .column_cont .el_character01 {
        -ms-grid-columns: 100px 1fr;
        grid-template-columns: 100px 1fr;
    }
}
.column_cont .el_character01 img {
    display: block;
    width: auto;
}
.column_cont .el_character01 p {
    background-color: #f3d5d4;
    padding: 20px;
    border-radius: 10px;
    position: relative;
    font-weight: bold;
}
@media screen and (max-width: 768px) {
    .column_cont .el_character01 p {
        padding: 10px;
        line-height: 1.6;
        font-size: 1.4rem;
    }
}
.column_cont .el_character01 p:before {
    content: "";
    border: 20px solid transparent;
    border-right-color: #f3d5d4;
    position: absolute;
    left: -40px;
}
.column_cont .el_character02 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 10px 160px;
    grid-template-columns: 1fr 160px;
    gap: 10px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
@media screen and (max-width: 768px) {
    .column_cont .el_character02 {
        -ms-grid-columns: 1fr 100px;
        grid-template-columns: 1fr 100px;
    }
}
.column_cont .el_character02 img {
    display: block;
    width: auto;
    margin-left: auto;
}
.column_cont .el_character02 p {
    background-color: #cbe9e1;
    padding: 20px;
    border-radius: 10px;
    position: relative;
    font-weight: bold;
}
@media screen and (max-width: 768px) {
    .column_cont .el_character02 p {
        padding: 10px;
        line-height: 1.6;
        font-size: 1.4rem;
    }
}
.column_cont .el_character02 p:before {
    content: "";
    border: 20px solid transparent;
    border-left-color: #cbe9e1;
    position: absolute;
    right: -40px;
}
/*# sourceMappingURL=common.css.map */
