blockquote,
body,
dd,
div,
dl,
dt,
fieldset,
figure,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
li,
ol,
p,
pre,
td,
textarea,
th,
ul {
    margin: 0;
    padding: 0
}

address,
caption,
cite,
code,
dfn,
em,
i,
th,
var {
    font-style: normal;
    font-weight: 400
}

fieldset,
img,
object {
    border: 0;
    vertical-align: bottom
}

img {
    -ms-interpolation-mode: bicubic;
    font-size: 0;
    line-height: 0
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

caption,
th {
    text-align: left
}

ul {
    list-style-type: none
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 100%;
    font-weight: 400
}

q:after,
q:before {
    content: ""
}

abbr,
acronym {
    border: 0;
    font-variant: normal
}

input,
select,
textarea {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit
}

legend {
    color: #000
}

article,
aside,
audio,
canvas,
details,
figcaption,
figure,
footer,
header,
mark,
menu,
nav,
section,
summary,
time,
video {
    background: #0000;
    border: 0;
    font-size: 100%;
    margin: 0;
    outline: 0;
    padding: 0;
    vertical-align: initial
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section {
    display: block
}

body {
    color: #000;
    font-family: Noto Sans JP, sans-serif
}

html {
    font-size: 62.5%
}

body {
    font-size: 1rem
}

body * {
    line-height: 1.5
}

* {
    -moz-font-feature-settings: "liga", "kern";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility
}

@font-face {
    font-family: Optima Italic;
    font-style: normal;
    font-weight: 400;
    src: local("Optima Italic"), url(Optima_Italic.woff) format("woff")
}

body {
    background-color: #0262af;
    box-sizing: border-box;
    font-style: normal
}

div:has(>iframe[src^="https://app.netlify.com"]) {
    display: none
}

button {
    -webkit-appearance: none;
    appearance: none;
    background: #0000;
    border: 0;
    border-radius: 0;
    font-family: inherit;
    outline: none;
    padding: 0
}

img {
    height: auto;
    width: 100%
}

sub {
    bottom: -5px;
    position: relative
}

.container {
    margin-left: auto;
    margin-right: auto
}

.pagetop {
    align-items: center;
    background-color: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    opacity: 0;
    position: fixed;
    transition: opacity .24s ease-out, visibility .24s ease-out;
    visibility: hidden;
    will-change: opacity, visibility;
    z-index: 2
}

.pagetop.show {
    opacity: 1;
    visibility: visible
}

.top .pagetop {
    background-color: #fff
}

@media(any-hover:hover) {
    .pagetop {
        cursor: pointer
    }

    .pagetop .arw {
        transition: transform .24s ease-out;
        will-change: transform
    }

    .pagetop:hover .arw {
        transform: translateY(-10%);
        transition-duration: .32s
    }
}

.btn {
    align-items: center;
    background-color: #181d61;
    display: block;
    display: flex;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    text-decoration: none;
    transition: all .3s
}

.btn:hover {
    opacity: .7
}

.btn span {
    align-items: center;
    background-color: #181d61;
    color: #fff;
    display: flex;
    text-decoration: none
}

.btn span:after {
    background: url(/lacalut/assets/img/icon_link.svg) no-repeat 0 0;
    background-size: 100%;
    content: "";
    display: block;
    height: 16px;
    margin-left: 14px;
    transition: transform .2s ease-in-out;
    width: 16px
}

@media only screen and (max-width:767px) {
    sub {
        bottom: -.5333333333vw;
        position: relative
    }

    .only--mobile {
        display: block
    }

    .only--desktop {
        display: none
    }

    .btn {
        font-size: 4.2666666667vw;
        height: 17.6vw;
        margin-top: 16vw;
        width: 89.6vw
    }

    .btn span:after {
        height: 4.2666666667vw;
        margin-left: 3.7333333333vw;
        width: 4.2666666667vw
    }
}

@media screen and (min-width:768px) {
    body {
        font-size: min(1.3333333333vw, 16px);
        overflow-x: hidden
    }

    sub {
        bottom: min(-.25vw, -3px);
        position: relative
    }

    .only--mobile {
        display: none
    }

    .only--desktop {
        display: block
    }

    .container {
        margin-left: auto;
        margin-right: auto;
        padding-left: min(4.1666666667vw, 50px);
        padding-right: min(4.1666666667vw, 50px);
        width: min(98.3333333333vw, 1180px)
    }

    .pagetop {
        bottom: min(.8333333333vw, 10px);
        filter: drop-shadow(0 0 min(.5vw, 6px) rgba(0, 0, 0, .16));
        height: min(6.3333333333vw, 76px);
        margin-bottom: min(.4166666667vw, 5px);
        margin-left: auto;
        position: -webkit-sticky;
        position: sticky;
        right: min(.8333333333vw, 10px);
        width: min(6.3333333333vw, 76px)
    }

    .pagetop .arw {
        height: min(2vw, 24px);
        width: min(2.3333333333vw, 28px)
    }

    .btn {
        font-size: min(1.5vw, 18px);
        height: min(5.5vw, 66px);
        margin-top: min(3.1666666667vw, 38px);
        width: min(40vw, 480px)
    }

    .btn span:after {
        height: min(1.3333333333vw, 16px);
        margin-left: min(1.1666666667vw, 14px);
        width: min(1.3333333333vw, 16px)
    }
}

@keyframes fadeInBottom {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: 0
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.kv__content {
    opacity: 0
}

body.--loaded .kv__content {
    animation-duration: 1s;
    animation-fill-mode: both;
    animation-name: fadeIn
}

.js-inview {
    opacity: 0
}

.is-inview {
    animation-duration: .7s;
    animation-fill-mode: both;
    animation-name: fadeInBottom
}

.header .header__logo {
    position: fixed;
    z-index: 3
}

@media only screen and (max-width:767px) {
    .header__logo {
        height: 5.8666666667vw;
        left: 5.3333333333vw;
        top: 5.3333333333vw;
        width: 40.2666666667vw
    }

    .header__logo a {
        height: 100%;
        width: 100%
    }
}

@media screen and (min-width:768px) {
    .header__logo {
        height: min(2.0833333333vw, 25px);
        left: min(3.0833333333vw, 37px);
        top: min(2.25vw, 27px);
        width: min(14.3333333333vw, 172px)
    }

    .header__logo a {
        height: 100%;
        width: 100%
    }
}

.menu__btn {
    cursor: pointer;
    position: fixed;
    transition: transform .3s linear;
    z-index: 30
}

.menu__btn span {
    background-color: #fff;
    display: block;
    position: absolute;
    top: 50%
}

.menu__item {
    transition: .3s
}

.menu__item:hover {
    opacity: .7
}

.menu__item a,
.menu__item span {
    color: #fff;
    cursor: pointer;
    text-decoration: none
}

.menu__content {
    background-color: #0262af;
    display: block;
    height: 100%;
    left: 0;
    opacity: 0;
    position: fixed;
    top: 0;
    transition: opacity .12s linear, visibility .16s ease-out;
    visibility: hidden;
    width: 100%;
    will-change: opacity, visibility;
    z-index: 20
}

.menu__content.is-active {
    opacity: 1;
    transition-duration: .32s, .4s;
    visibility: visible
}

.menu__logo {
    position: absolute
}

.menu__sns-list .item {
    transition: transform .32s ease-out
}

.menu__sns-list .item:hover {
    transform: scale(1.1)
}

@media only screen and (max-width:767px) {
    .menu__btn {
        height: 2.6666666667vw;
        right: 5.3333333333vw;
        top: 6.9333333333vw;
        width: 10.6666666667vw
    }

    .menu__btn span {
        height: .2666666667vw;
        position: absolute;
        transition: transform .3s linear;
        width: 10.6666666667vw
    }

    .menu__btn .top {
        top: 0
    }

    .menu__btn .bottom {
        top: 2.1333333333vw
    }

    .menu__btn.is-active .top {
        top: min(.3333333333vw, 4px);
        transform: rotate(25deg)
    }

    .menu__btn.is-active .bottom {
        top: min(.3333333333vw, 4px);
        transform: rotate(-25deg)
    }

    .menu__inner {
        left: 50%;
        position: absolute;
        text-align: center;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 83.2vw
    }

    .menu__list {
        color: #fff;
        display: flex;
        flex-direction: column;
        height: 36.8vw;
        justify-content: space-between;
        margin-top: 16vw
    }

    .menu__item a,
    .menu__item span,
    .menu__list {
        font-size: 4.8vw
    }

    .menu__sns-list {
        display: flex;
        justify-content: space-between;
        margin-left: auto;
        margin-right: auto;
        margin-top: 13.3333333333vw;
        width: 42.6666666667vw
    }

    .menu__sns-list .item a {
        display: block;
        font-size: 0;
        height: 10.6666666667vw;
        outline: none;
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap;
        width: 10.6666666667vw
    }

    .menu__sns-list .x {
        background: url(../img/icon_x.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__sns-list .facebook {
        background: url(../img/icon_facebook.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__sns-list .line {
        background: url(../img/icon_line.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__logo {
        bottom: 8vw;
        left: 50%;
        transform: translateX(-50%);
        width: 69.3333333333vw
    }
}

@media screen and (min-width:768px) {
    .menu__btn {
        height: min(5vw, 60px);
        right: min(3.3333333333vw, 40px);
        top: min(2.6666666667vw, 32px);
        width: min(5vw, 60px)
    }

    .menu__btn span {
        height: min(.1666666667vw, 2px);
        position: absolute;
        transition: transform .3s linear;
        width: min(5vw, 60px)
    }

    .menu__btn .top {
        top: 0
    }

    .menu__btn .bottom {
        top: min(1.3333333333vw, 16px)
    }

    .menu__btn.is-active .top {
        top: min(.6666666667vw, 8px);
        transform: rotate(25deg)
    }

    .menu__btn.is-active .bottom {
        top: min(.6666666667vw, 8px);
        transform: rotate(-25deg)
    }

    .menu__inner {
        left: 50%;
        position: absolute;
        text-align: center;
        top: 50%;
        transform: translate(-50%, -50%);
        width: min(33.3333333333vw, 400px)
    }

    .menu__list {
        color: #fff;
        display: flex;
        flex-direction: column;
        height: min(13.75vw, 165px);
        justify-content: space-between;
        margin-top: min(4.1666666667vw, 50px)
    }

    .menu__item a,
    .menu__item span,
    .menu__list {
        font-size: min(2vw, 24px)
    }

    .menu__sns-list {
        display: flex;
        justify-content: space-between;
        margin-left: auto;
        margin-right: auto;
        margin-top: min(5vw, 60px);
        width: min(13.3333333333vw, 160px)
    }

    .menu__sns-list .item a {
        display: block;
        font-size: 0;
        height: min(3.3333333333vw, 40px);
        outline: none;
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap;
        width: min(3.3333333333vw, 40px)
    }

    .menu__sns-list .x {
        background: url(../img/icon_x.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__sns-list .facebook {
        background: url(../img/icon_facebook.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__sns-list .line {
        background: url(../img/icon_line.webp) no-repeat 0 0;
        background-size: 100%
    }

    .menu__logo {
        bottom: min(3.3333333333vw, 40px);
        left: min(3.3333333333vw, 40px);
        width: min(21.6666666667vw, 260px)
    }
}

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

    .kv,
    .kv .kv__content {
        position: relative
    }

    .kv .kv__content {
        background: url(/lacalut/assets/img/kv-image-sp.webp) no-repeat 0 0;
        background-position: 50%;
        background-size: 100%;
        height: 154.6666666667vw;
        margin-left: auto;
        margin-right: auto;
        width: 100vw
    }

    .kv .kv__name {
        background: url(/lacalut/assets/img/kv_name-sp.webp) no-repeat 0 0;
        background-size: 100%;
        height: 20.8vw;
        top: 24vw;
        width: 85.3333333333vw
    }

    .kv .kv__catch,
    .kv .kv__name {
        left: 50%;
        position: absolute;
        transform: translateX(-50%);
        z-index: 2
    }

    .kv .kv__catch {
        top: 128vw;
        width: 87.2vw
    }

    .kv .kv__pkg {
        height: 73.6vw;
        position: absolute;
        right: 3.7333333333vw;
        top: 52.2666666667vw;
        width: 44vw;
        z-index: 2
    }

    .kv .kv__pkg img {
        height: auto
    }

    .kv .kv__arrow {
        animation: bounce 1.5s infinite;
        bottom: 10.6666666667vw;
        height: 3.7333333333vw;
        position: absolute;
        right: 0;
        transform: rotate(90deg);
        width: 10.6666666667vw
    }
}

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

    .kv,
    .kv .kv__content {
        position: relative
    }

    .kv .kv__content {
        background: url(/lacalut/assets/img/kv-image.webp) no-repeat 0 0;
        background-position: 50%;
        background-size: 100%;
        height: min(64vw, 768px);
        margin-left: auto;
        margin-right: auto;
        width: min(113.8333333333vw, 1366px)
    }

    .kv .kv__name {
        background: url(/lacalut/assets/img/kv_name.webp) no-repeat 0 0;
        background-size: 100%;
        height: min(9.5833333333vw, 115px);
        left: 50%;
        top: min(7.4166666667vw, 89px);
        transform: translateX(-50%);
        width: min(64.1666666667vw, 770px)
    }

    .kv .kv__name,
    .kv .kv__pkg {
        position: absolute;
        z-index: 2
    }

    .kv .kv__pkg {
        right: min(26.75vw, 321px);
        top: min(19.5vw, 234px);
        width: min(20.8333333333vw, 250px)
    }

    .kv .kv__catch {
        left: 50%;
        position: absolute;
        top: min(52.1666666667vw, 626px);
        transform: translateX(-50%);
        width: min(41.6666666667vw, 500px);
        z-index: 2
    }

    .kv .kv__arrow {
        animation: bounce 1.5s infinite;
        bottom: min(3.3333333333vw, 40px);
        height: min(1.1666666667vw, 14px);
        position: absolute;
        right: 0;
        transform: rotate(90deg);
        width: min(3.3333333333vw, 40px)
    }
}

@keyframes bounce {
    0% {
        opacity: 1;
        transform: translateY(0) rotate(90deg)
    }

    45% {
        opacity: 1
    }

    80% {
        opacity: 0;
        transform: translateY(20px) rotate(90deg)
    }

    to {
        opacity: 0;
        transform: translateY(20px) rotate(90deg)
    }
}

@media screen and (width >=768px)and (width <=1000px) {
    .kv .kv__content {
        height: 55vw;
        width: 100%
    }

    .kv .kv__pkg {
        right: 24.2vw;
        top: 16.8vw;
        width: 13vw
    }

    .kv .kv__catch {
        left: 50%;
        top: 43.4vw;
        width: 48vw
    }
}

.product .btn {
    align-items: center;
    background-color: #181d61;
    display: flex;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    text-decoration: none;
    transition: opacity .3s
}

.product .btn:hover {
    opacity: .7
}

.product .btn span {
    align-items: center;
    background-color: #181d61;
    color: #fff;
    display: flex;
    text-decoration: none
}

.product .btn span:after {
    background: url(/lacalut/assets/img/icon_link.svg) no-repeat 0 0;
    background-size: 100%;
    content: "";
    display: block;
    height: 16px;
    margin-left: 14px;
    transition: transform .2s ease-in-out;
    width: 16px
}

.product .product__title {
    align-items: center;
    border: 1px solid #fff;
    display: flex;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    position: relative
}

@media only screen and (max-width:767px) {
    .product {
        color: #fff;
        padding-top: 11.7333333333vw
    }

    .product .product__title {
        font-size: 4vw;
        width: 24vw
    }

    .product .product__catch {
        border-bottom: 1px solid #fff;
        font-size: 5.8666666667vw;
        line-height: 1.2727272727;
        margin-left: auto;
        margin-right: auto;
        margin-top: 6.4vw;
        padding-bottom: 2.6666666667vw;
        text-align: center;
        width: 89.3333333333vw
    }

    .product .product__container {
        margin-left: auto;
        margin-right: auto;
        margin-top: 5.3333333333vw
    }

    .product .product__image {
        margin-left: auto;
        margin-right: auto;
        width: 45.8666666667vw
    }

    .product .product__content {
        margin-left: auto;
        margin-right: auto;
        margin-top: 2.6666666667vw;
        width: 89.3333333333vw
    }

    .product .product__copy {
        font-size: 5.3333333333vw;
        margin-top: 6.6666666667vw;
        width: 72.5333333333vw
    }

    .product .product__text {
        font-size: 4.2666666667vw;
        line-height: 1.8;
        margin-left: auto;
        margin-right: auto;
        margin-top: 0
    }

    .product .product__text li {
        margin-left: 5.3333333333vw;
        margin-top: 6.9333333333vw;
        text-indent: -1em
    }

    .product .btn {
        height: 17.6vw;
        margin-top: 8vw;
        width: 89.3333333333vw
    }

    .product .btn span {
        font-size: 4.2666666667vw
    }

    .product .btn span:after {
        height: 4.2666666667vw;
        margin-left: 3.7333333333vw;
        width: 4.2666666667vw
    }
}

@media screen and (min-width:768px) {
    .product {
        color: #fff;
        margin-left: auto;
        margin-right: auto;
        padding-top: min(6.9166666667vw, 83px);
        width: 100%
    }

    .product .product__title {
        align-items: center;
        display: flex;
        font-size: min(2vw, 24px);
        width: min(12vw, 144px)
    }

    .product .product__title span {
        display: block;
        margin-bottom: min(.1666666667vw, 2px)
    }

    .product .product__catch {
        border-bottom: 1px solid #fff;
        font-size: min(3vw, 36px);
        text-align: center;
        width: min(64.1666666667vw, 770px)
    }

    .product .product__catch,
    .product .product__container {
        margin-left: auto;
        margin-right: auto;
        margin-top: min(3.3333333333vw, 40px)
    }

    .product .product__container {
        display: flex;
        justify-content: space-between;
        width: min(73.9166666667vw, 887px)
    }

    .product .product__image {
        width: min(28.3333333333vw, 340px)
    }

    .product .product__name {
        margin-left: min(1.5vw, 18px);
        width: min(43.5vw, 522px)
    }

    .product .product__content {
        display: flex;
        flex-direction: column;
        justify-content: center;
        margin-top: min(2.5vw, 30px);
        width: min(45vw, 540px)
    }

    .product .product__copy {
        font-size: min(3vw, 36px);
        margin-top: min(2.5vw, 30px)
    }

    .product .product__text {
        font-size: min(1.6666666667vw, 20px);
        line-height: 2;
        margin-left: min(2.5vw, 30px);
        margin-top: min(.4166666667vw, 5px);
        width: min(39.6666666667vw, 476px)
    }

    .product .product__text li {
        margin-left: min(1.6666666667vw, 20px);
        margin-top: min(2.5vw, 30px);
        text-indent: -1em
    }
}

@media only screen and (max-width:767px) {
    .structure {
        color: #fff
    }

    .structure .structure__catch {
        border-bottom: 1px solid #fff;
        font-size: 5.3333333333vw;
        margin-left: auto;
        margin-right: auto;
        margin-top: 21.3333333333vw;
        padding-bottom: 2.6666666667vw;
        text-align: center;
        width: 72.2666666667vw
    }

    .structure .structure__name {
        margin-left: auto;
        margin-right: auto;
        margin-top: 8vw;
        width: 69.3333333333vw
    }

    .structure .structure__box {
        border: 2px solid #fff;
        box-sizing: border-box;
        margin-left: auto;
        margin-right: auto;
        margin-top: 13.6vw;
        padding-bottom: 8vw;
        padding-left: 8vw;
        padding-top: 2.6666666667vw;
        position: relative;
        width: 89.3333333333vw
    }

    .structure .structure__list-title {
        background-color: #0262af;
        font-size: 6.9333333333vw;
        font-weight: 700;
        left: 50%;
        padding-left: 3.7333333333vw;
        padding-right: 3.7333333333vw;
        position: absolute;
        top: -4.5333333333vw;
        transform: translateX(-50%)
    }

    .structure .structure__list {
        display: flex;
        flex-wrap: wrap;
        font-size: 4.8vw;
        margin-top: 8vw
    }

    .structure .structure__list .item {
        display: flex;
        width: 37.6vw
    }

    .structure .structure__list .item:before {
        display: block;
        font-size: 8.8vw;
        height: 10.9333333333vw;
        margin-right: 4vw;
        width: 4.8vw
    }

    .structure .structure__list .item.--1 {
        align-items: center;
        line-height: 1.1;
        margin-right: 5.6vw
    }

    .structure .structure__list .item.--1:before {
        content: "1."
    }

    .structure .structure__list .item.--2 {
        align-items: center;
        line-height: 1.1;
        width: 32.8vw
    }

    .structure .structure__list .item.--2:before {
        content: "2."
    }

    .structure .structure__list .item.--3 {
        align-items: end;
        margin-right: 5.6vw
    }

    .structure .structure__list .item.--3:before {
        content: "3."
    }

    .structure .structure__list .item.--4 {
        align-items: end;
        width: 32.8vw
    }

    .structure .structure__list .item.--4:before {
        content: "4."
    }

    .structure .structure__list .item.--5 {
        align-items: end;
        margin-right: 5.6vw
    }

    .structure .structure__list .item.--5:before {
        content: "5."
    }

    .structure .structure__container {
        margin-left: auto;
        margin-right: auto;
        margin-top: 5.3333333333vw;
        padding-bottom: 53.3333333333vw;
        padding-top: 42.6666666667vw;
        position: relative;
        width: 89.3333333333vw
    }

    .structure .structure__image {
        margin-left: auto;
        margin-right: auto;
        position: relative;
        width: 48.5333333333vw;
        z-index: 2
    }

    .structure .structure__intro-list {
        box-sizing: border-box
    }

    .structure .structure__intro-list .item {
        background-color: #fff;
        border-radius: 3.2vw;
        box-sizing: border-box;
        color: #181d61;
        font-size: 3.2vw;
        padding: 4.2666666667vw 4.2666666667vw 4.2666666667vw 5.8666666667vw;
        position: absolute
    }

    .structure .structure__intro-list .item.--1 {
        left: 50%;
        top: 0;
        transform: translateX(-50%);
        width: 66.6666666667vw
    }

    .structure .structure__intro-list .item.--2 {
        bottom: 0;
        padding-bottom: 0;
        right: 0;
        width: 40vw
    }

    .structure .structure__intro-list .item.--3 {
        bottom: 0;
        left: 0;
        width: 40vw
    }

    .structure .structure__intro-list .head {
        color: #e1001f;
        font-size: 4.2666666667vw;
        font-weight: 700;
        text-align: center
    }

    .structure .structure__intro-list .head span {
        display: block;
        font-size: 3.2vw
    }

    .structure .structure__intro-list .component {
        font-size: 4.2666666667vw;
        font-weight: 500;
        text-align: center
    }

    .structure .structure__intro-list .text {
        font-size: 3.7333333333vw;
        line-height: 1.5714285714;
        margin-top: min(1.25vw, 15px)
    }

    .structure .btn {
        align-items: center;
        background-color: #181d61;
        display: flex;
        height: min(5.5vw, 66px);
        justify-content: center;
        margin-top: min(4.1666666667vw, 50px);
        text-decoration: none;
        width: min(38.3333333333vw, 460px)
    }
}

@media screen and (min-width:768px) {
    .structure {
        color: #fff
    }

    .structure .structure__catch {
        border-bottom: 1px solid #fff;
        font-size: min(3vw, 36px);
        margin-left: auto;
        margin-right: auto;
        margin-top: min(8.9166666667vw, 107px);
        text-align: center;
        width: min(53.8333333333vw, 646px)
    }

    .structure .structure__name {
        margin-left: auto;
        margin-right: auto;
        margin-top: min(4.1666666667vw, 50px);
        width: min(43.3333333333vw, 520px)
    }

    .structure .structure__box {
        border: 2px solid #fff;
        margin-left: auto;
        margin-right: auto;
        margin-top: min(5.8333333333vw, 70px);
        padding-bottom: min(2.75vw, 33px);
        padding-top: min(2.5833333333vw, 31px);
        position: relative;
        width: min(70vw, 840px)
    }

    .structure .structure__list-title {
        background-color: #0262af;
        font-size: min(3.3333333333vw, 40px);
        font-weight: 700;
        left: 50%;
        padding-left: min(2.0833333333vw, 25px);
        padding-right: min(2.0833333333vw, 25px);
        position: absolute;
        top: max(-2.9166666667vw, -35px);
        transform: translateX(-50%)
    }

    .structure .structure__list {
        display: block;
        display: flex;
        flex-wrap: wrap;
        font-size: min(2.3333333333vw, 28px);
        margin-left: auto;
        margin-right: auto;
        width: min(61.5vw, 738px)
    }

    .structure .structure__list .item span {
        font-size: min(4.1666666667vw, 50px);
        margin-right: min(.8333333333vw, 10px)
    }

    .structure .structure__list .item.--1 {
        margin-left: min(1.6666666667vw, 20px)
    }

    .structure .structure__list .item.--1,
    .structure .structure__list .item.--3,
    .structure .structure__list .item.--4 {
        margin-right: min(4.1666666667vw, 50px)
    }

    .structure .structure__list .item.--3,
    .structure .structure__list .item.--4,
    .structure .structure__list .item.--5 {
        margin-top: max(-.8333333333vw, -10px)
    }

    .structure .structure__container {
        margin-left: auto;
        margin-right: auto;
        position: relative;
        width: min(76.5vw, 918px)
    }

    .structure .structure__image {
        margin-left: auto;
        margin-right: auto;
        margin-top: min(4.6666666667vw, 56px);
        position: relative;
        width: min(31.5vw, 378px);
        z-index: 2
    }

    .structure .structure__intro-list .item {
        background-color: #fff;
        border-radius: min(1.5vw, 18px);
        box-sizing: border-box;
        color: #181d61;
        font-size: min(1.3333333333vw, 16px);
        padding: min(2.1666666667vw, 26px) min(2vw, 24px) min(3vw, 36px);
        position: absolute;
        width: min(25vw, 300px)
    }

    .structure .structure__intro-list .item.--1 {
        left: min(.5vw, 6px);
        top: 0
    }

    .structure .structure__intro-list .item.--2 {
        left: 50%;
        top: min(21.8333333333vw, 262px);
        transform: translateX(-50%)
    }

    .structure .structure__intro-list .item.--3 {
        right: 0;
        top: 0
    }

    .structure .structure__intro-list .head {
        color: #e1001f;
        font-size: min(1.8333333333vw, 22px);
        font-weight: 700;
        text-align: center
    }

    .structure .structure__intro-list .head span {
        font-size: min(1.3333333333vw, 16px)
    }

    .structure .structure__intro-list .component {
        font-size: min(1.6666666667vw, 20px);
        font-weight: 500;
        line-height: 1.2;
        margin-top: min(.8333333333vw, 10px);
        text-align: center
    }

    .structure .structure__intro-list .text {
        font-size: min(1.5vw, 18px);
        line-height: 1.5555555556;
        margin-left: auto;
        margin-right: auto;
        margin-top: min(1.25vw, 15px);
        width: min(19.0833333333vw, 229px)
    }

    .structure .btn {
        align-items: center;
        background-color: #181d61;
        display: flex;
        height: min(5.5vw, 66px);
        justify-content: center;
        margin-top: min(4.1666666667vw, 50px);
        text-decoration: none;
        width: min(38.3333333333vw, 460px)
    }
}

.question .question__title {
    color: #fff
}

.question .btn {
    align-items: center;
    background-color: #181d61;
    display: flex;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    text-decoration: none;
    transition: opacity .3s
}

.question .btn:hover {
    opacity: .7
}

.question .btn span {
    align-items: center;
    background-color: #181d61;
    color: #fff;
    display: flex;
    text-decoration: none
}

.question .btn span:after {
    background: url(../img/icon_arrow.png) no-repeat 0 0;
    background-size: 100%;
    content: "";
    display: block;
    height: 10px;
    margin-left: 14px;
    width: 38px
}

.question .btn:hover span:after {
    transform: translateX(2px)
}

@media only screen and (max-width:767px) {
    .question {
        font-size: 4.2666666667vw;
        padding-bottom: 22.6666666667vw;
        padding-top: 15.2vw;
        text-align: center
    }

    .question .question__title {
        color: #fff
    }

    .question .btn {
        align-items: center;
        background-color: #181d61;
        display: flex;
        height: 17.6vw;
        justify-content: center;
        margin-left: auto;
        margin-right: auto;
        margin-top: 6.1333333333vw;
        text-decoration: none;
        width: 89.3333333333vw
    }

    .question .btn span {
        color: #fff
    }

    .question .btn span:after {
        height: 2.6666666667vw;
        margin-left: min(1.1666666667vw, 14px);
        width: 10.1333333333vw
    }
}

@media screen and (min-width:768px) {
    .question {
        padding-bottom: min(3.3333333333vw, 40px);
        padding-top: min(21.8333333333vw, 262px);
        text-align: center
    }

    .question .question__title {
        font-size: min(2vw, 24px)
    }

    .question .btn {
        margin-top: min(2.5vw, 30px)
    }

    .question .btn span {
        color: #fff
    }

    .question .btn span:after {
        height: min(.8333333333vw, 10px);
        margin-left: min(1.1666666667vw, 14px);
        width: min(3.1666666667vw, 38px)
    }
}

.footer {
    background-color: #fff;
    color: #181d61
}

.footer a {
    color: #181d61;
    display: inline-block;
    position: relative;
    text-decoration: none
}

.footer a:before {
    background-color: #181d61;
    bottom: 0;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform .32s ease-out;
    width: 100%;
    will-change: transform
}

.footer a:hover:before {
    transform: scaleX(1);
    transform-origin: left
}

.footer .footer__logo a:before {
    display: none
}

.footer .footer__list,
.footer .footer__list-contact {
    border-left: 1px solid #1577e5
}

.footer .footer__contact p {
    font-weight: 600
}

.footer .footer__copy {
    color: #a7a7a7;
    text-align: center
}

@media only screen and (max-width:767px) {
    .footer {
        padding-bottom: 13.3333333333vw;
        padding-top: 16vw
    }

    .footer .footer__inner {
        margin-left: auto;
        margin-right: auto;
        width: 89.3333333333vw
    }

    .footer .footer__container {
        margin-bottom: 10.6666666667vw
    }

    .footer .footer__logo {
        margin-left: auto;
        margin-right: auto;
        width: 40.2666666667vw
    }

    .footer .footer__list {
        font-size: 3.2vw;
        margin-top: 10.6666666667vw;
        width: 100%
    }

    .footer .footer__list .item {
        margin-left: 5.3333333333vw
    }

    .footer .footer__contact p {
        font-size: 3.7333333333vw;
        margin-top: 10.6666666667vw
    }

    .footer .footer__list-contact {
        font-size: 3.2vw;
        margin-top: 3.7333333333vw
    }

    .footer .footer__list-contact .item {
        margin-left: 5.3333333333vw
    }

    .footer .footer__list,
    .footer .footer__list-contact {
        display: flex;
        flex-direction: column;
        height: 23.7333333333vw;
        justify-content: space-between
    }

    .footer .footer__copy {
        font-size: 2.6666666667vw;
        text-align: center
    }
}

@media screen and (min-width:768px) {
    .footer {
        padding-bottom: min(4.5833333333vw, 55px);
        padding-top: min(6.6666666667vw, 80px)
    }

    .footer .footer__inner {
        margin-left: auto;
        margin-right: auto;
        width: min(81.6666666667vw, 980px)
    }

    .footer .footer__container {
        display: flex;
        margin-bottom: min(5vw, 60px)
    }

    .footer .footer__logo {
        margin-right: min(8.3333333333vw, 100px);
        width: min(18.3333333333vw, 220px)
    }

    .footer .footer__list {
        font-size: min(1.1666666667vw, 14px);
        margin-top: min(2.5vw, 30px);
        width: min(20.6666666667vw, 248px)
    }

    .footer .footer__list .item {
        margin-left: min(1.6666666667vw, 20px)
    }

    .footer .footer__contact p {
        font-size: min(1.25vw, 15px)
    }

    .footer .footer__list-contact {
        font-size: min(1.1666666667vw, 14px);
        margin-left: min(.25vw, 3px);
        margin-top: min(.8333333333vw, 10px)
    }

    .footer .footer__list-contact .item {
        margin-left: min(1.1666666667vw, 14px)
    }

    .footer .footer__list,
    .footer .footer__list-contact {
        display: flex;
        flex-direction: column;
        height: min(8vw, 96px);
        justify-content: space-between
    }

    .footer .footer__copy {
        font-size: min(.9166666667vw, 11px);
        margin-right: min(1.6666666667vw, 20px)
    }
}