@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap";
@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;700&display=swap";
@import"https://fonts.googleapis.com/css2?family=Anton&display=swap";
@import"https://fonts.googleapis.com/css2?family=Inter:wght@700&display=swap";
@import"https://fonts.googleapis.com/icon?family=Material+Icons";

html {
    font-size: 62.5%
}

body {
    font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 1.6em;
    line-height: 1.6;
    letter-spacing: .05em
}

a {
    text-decoration: none;
    outline: none
}

.wrapper {
    display: block;
    /* margin: 0px auto; */
    padding: 0px;
    min-height: 100vh
}

*, *::before, *::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
    margin: 0
}

ul[role=list], ol[role=list] {
    list-style: none
}

html {
    scroll-behavior: auto
}

body {
    min-height: 100vh;
    text-rendering: optimizeSpeed;
    line-height: 1.5
}

a:not([class]) {
    -webkit-text-decoration-skip: ink;
    text-decoration-skip-ink: auto
}

img, picture {
    max-width: 100%;
    display: block
}

input, button, textarea, select {
    font: inherit
}

@media(prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        -webkit-animation-duration: .01ms !important;
        animation-duration: .01ms !important;
        -webkit-animation-iteration-count: 1 !important;
        animation-iteration-count: 1 !important;
        -webkit-transition-duration: .01ms !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important
    }
}

@-webkit-keyframes menu-container-appeared {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes menu-container-appeared {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%)
    }

    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@-webkit-keyframes menu-container-leaved {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%)
    }
}

@keyframes menu-container-leaved {
    0% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }

    100% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%)
    }
}

@-webkit-keyframes menu-overlay-appeared {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes menu-overlay-appeared {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes menu-overlay-leaved {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

@keyframes menu-overlay-leaved {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

@-webkit-keyframes modal-photo-open {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes modal-photo-open {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes modal-photo-close {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

@keyframes modal-photo-close {
    0% {
        opacity: 1
    }

    100% {
        opacity: 0
    }
}

html {
    font-size: 4.2666666667vw;
    width: 100%
}

@media(min-width: 768px) {
    html {
        font-size: 2.0833333333vw
    }
}

@media(min-width: 1240px) {
    html {
        font-size: 1.4516129032vw
    }
}

@media(min-width: 1440px) {
    html {
        font-size: 1.3888888889vw
    }
}

body {
    font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 1.6em;
    line-height: 1.6;
    letter-spacing: .05em;
    width: 100%;
    height: 100%
}

a {
    text-decoration: none;
    outline: none
}

html[lang=ja] *:is([lang]):not([lang=ja]), html[lang=en] *:is([lang]):not([lang=en]) {
    display: none !important
}

.wrapper {
    padding: 0px;
    min-height: 100vh;
    width: 100%;
    overflow-x: hidden;
}

.font10 {
    font-size: min(.7575757576vw, 10px)
}

.font11 {
    font-size: min(.8333333333vw, 11px) !important
}

.font12 {
    font-size: min(.9090909091vw, 12px)
}

.font13 {
    font-size: min(.9848484848vw, 13px)
}

.font14 {
    font-size: min(1.0606060606vw, 14px)
}

.font16 {
    font-size: min(1.2121212121vw, 16px)
}

.font20 {
    font-size: min(1.5151515152vw, 20px)
}

.font26 {
    font-size: min(1.9696969697vw, 26px)
}

.font40 {
    font-size: min(3.0303030303vw, 40px)
}

.font42 {
    font-size: min(3.1818181818vw, 42px)
}

.font50 {
    font-size: min(3.7878787879vw, 50px)
}

.font60 {
    font-size: min(4.5454545455vw, 60px)
}

.font80 {
    font-size: min(6.0606060606vw, 80px)
}

.font90 {
    font-size: min(6.8181818182vw, 90px)
}

.font100 {
    font-size: min(7.5757575758vw, 100px)
}

.font143 {
    font-size: min(10.8333333333vw, 143px)
}

.-gold {
    color: #a49162
}

.-black {
    color: #222
}

.-grey {
    color: #676767
}

.-white {
    color: #fff
}

.-light-gray {
    color: #D0D0D0
}


.language-change {
    font-size: 10px;
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 10px;
    margin: 10px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer
}

.language-change label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 5px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline
}

.language-change label .radio {
    accent-color: #222
}

.language-change.sp {
    color: #222;
    justify-content: center;
    margin-top: 40px;
    gap: 20px;
    font-size: 18px;
}

.language-change.sp label {
    align-items: center;
}

.nav-header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1000;
    width: 100%;
    background: rgba(255, 255, 255, .95);
    -webkit-box-shadow: 0 0 1.6rem 0 rgba(0, 0, 0, .1);
    box-shadow: 0 0 1.6rem 0 rgba(0, 0, 0, .1)
}

.nav-header__container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    justify-content: center;
    align-items: center;
    max-width: 1320px;
    padding: 0 5px;
    height: 5rem;
    margin: 0 auto;
    padding: 0 0 0 15px;
    -webkit-transition: all .2s;
    transition: all .2s
}

@media screen and (max-width: 767px) {
    .nav-header__container {
        padding: 0 15px
    }
}

.nav-header__logo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-right: auto;
    color: #222;
    font-weight: 700;
    font-size: 2rem
}

.nav-header__logo-image {
    display: block;
    height: 3rem
}

.nav-header__menu {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0
}

@media(min-width: 992px) {
    .nav-header__menu {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.nav-header__menu-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    width: 100%;
    height: 100%
}

.nav-header__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    color: #222;
    text-align: center;
    font-family: "Poppins", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    padding: 0 16px;
    min-width: 100px
}

.nav-header__link:after {
    display: block;
    opacity: 0;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 4px;
    background: #191919;
    content: "";
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -webkit-transition: all .2s;
    transition: all .2s
}

.nav-header__link:hover:after {
    opacity: 1;
    width: 100%
}

.nav-header__contact {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    border: none;
    line-height: 1;
    text-decoration: none;
    text-align: center;
    outline: none;
    cursor: pointer;
    -webkit-transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    background-color: #191919;
    color: #fff;
    margin-left: 1.6rem;
    padding: 1.2rem 3.2rem;
    border-radius: 100px
}

.nav-header__contact:hover {
    background-color: #0c0c0c
}

.nav-header__toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 6rem;
    height: 6rem;
    background: #191919;
    cursor: pointer;
    -webkit-transition: all .2s;
    transition: all .2s
}

@media(min-width: 992px) {
    .nav-header__toggle {
        display: none
    }
}

.nav-header__toggle:hover {
    background: #0c0c0c
}

.nav-header__toggle-line {
    display: block;
    width: 35%;
    border-bottom: 2px solid #fff
}

.nav-header__toggle-line:nth-child(2) {
    margin: 10% 0px
}

.nav-drawer {
    display: none;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    z-index: 1002
}

.nav-drawer__container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: absolute;
    right: 0;
    top: 0;
    width: 80%;
    height: 100%;
    max-width: 350px;
    min-width: 200px;
    background: #fff;
    border-left: #e2e2e2 1px solid;
    -webkit-box-shadow: 0 0 5px rgba(0, 0, 0, .1);
    box-shadow: 0 0 5px rgba(0, 0, 0, .1);
    overflow: hidden;
    -webkit-animation-duration: var(--nav-drawer-duration);
    animation-duration: var(--nav-drawer-duration);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.nav-drawer[data-open=true] .nav-drawer__container {
    -webkit-animation-name: menu-container-appeared;
    animation-name: menu-container-appeared
}

.nav-drawer[data-open=false] .nav-drawer__container {
    -webkit-animation-name: menu-container-leaved;
    animation-name: menu-container-leaved
}

.nav-drawer__menu {
    display: block;
    margin: 0;
    padding: 0;
    list-style: none;
    overflow-y: auto
}

.nav-drawer__menu-item {
    border-bottom: #e2e2e2 1px dashed
}

.nav-drawer__menu-item:hover {
    background: #efefef
}

.nav-drawer__link {
    position: relative;
    display: block;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    color: inherit;
    letter-spacing: .01em;
    padding: 0.5em 2.5em 0.5em 2em;
    text-decoration: none
}

.nav-drawer__link-main {
    display: block;
    font-weight: 500
}

.nav-drawer__link-sub {
    color: #aaa;
    display: block
}

.nav-drawer__menu-button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0px;
    padding: 0px
}

.nav-drawer__button-close {
    position: relative;
    background-color: #191919;
    margin: 0px 0px 0px auto;
    padding: 0px;
    width: 6rem;
    height: 6rem;
    border: none;
    -webkit-box-shadow: 0 0 12px rgba(0, 0, 0, .15);
    box-shadow: 0 0 12px rgba(0, 0, 0, .15);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer
}

.nav-drawer__button-close:hover, .nav-drawer__button-close:focus {
    outline: none;
    background: #262626
}

.nav-drawer__button-close-line {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 40%;
    height: 2px;
    margin: auto;
    background: #fff
}

.nav-drawer__button-close-line:nth-child(1) {
    -webkit-transform: translateY(0) rotate(45deg);
    transform: translateY(0) rotate(45deg)
}

.nav-drawer__button-close-line:nth-child(2) {
    -webkit-transform: translateY(0) rotate(-45deg);
    transform: translateY(0) rotate(-45deg)
}

.nav-drawer__overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: rgba(0, 0, 0, .08);
    -webkit-animation-duration: var(--nav-drawer-duration);
    animation-duration: var(--nav-drawer-duration);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.nav-drawer[data-open=true] .nav-drawer__overlay {
    -webkit-animation-name: menu-overlay-appeared;
    animation-name: menu-overlay-appeared
}

.nav-drawer[data-open=false] .nav-drawer__overlay {
    -webkit-animation-name: menu-overlay-leaved;
    animation-name: menu-overlay-leaved
}

.nav-pagetop {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: fixed;
    bottom: 60px;
    right: 15px;
    z-index: -1000;
    width: 70px;
    height: 70px;
    font-size: 10px;
    font-weight: 400;
    line-height: 1.6;
    color: #fff;
    background: #191919;
    border-radius: 50%;
    opacity: 0;
    cursor: pointer;
    -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .15);
    box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .15);
    -webkit-transition: all .2s;
    transition: all .2s
}

.nav-pagetop.active {
    opacity: 1;
    z-index: 1000
}

.nav-pagetop:before {
    display: block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    -webkit-transition: all .2s;
    transition: all .2s
}

.nav-pagetop:after {
    content: "PAGETOP";
    display: block;
    padding: 4px 0px
}

.nav-pagetop:hover {
    background: #0c0c0c;
    -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .15);
    box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .15)
}

.nav-pagetop:hover:before {
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px)
}

.mainvisual {
    position: relative;
    background-image: url("../img/mainvisual.jpg");
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat
}

.mainvisual::before {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0;
    background-color: rgba(255, 255, 255, .3);
    content: ""
}

.mainvisual__container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1320px;
    height: 80vh;
    padding-top: 6rem;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1
}

.mainvisual__text-main {
    font-weight: 700;
    font-size: 4rem;
    line-height: 1
}

@media screen and (min-width: 768px) {
    .mainvisual__text-main {
        font-size: 5.6rem
    }
}

.mainvisual__text-sub {
    padding-top: 1.6rem;
    color: #222;
    font-size: 1.6rem
}

.page-heading__content {
    margin: 0;
    padding: 0
}

.page-heading__content--left {
    text-align: left
}

.page-heading__content--center {
    text-align: center
}

.page-heading__content--right {
    text-align: right
}

.page-heading__text-main {
    font-size: 4rem
}

.page-heading__text-main:after {
    display: block;
    max-width: 240px;
    padding-top: 2.4rem;
    border-bottom: 3px solid #222;
    content: ""
}

.page-heading__content--left .page-heading__text-main::after {
    margin-left: 0;
    margin-right: auto
}

.page-heading__content--center .page-heading__text-main::after {
    margin-left: auto;
    margin-right: auto
}

.page-heading__content--right .page-heading__text-main::after {
    margin-left: auto;
    margin-right: 0
}

.page-heading__text-sub {
    font-weight: 400;
    font-size: 1.6rem;
    color: #222;
    padding-top: 2.4rem
}

.page-heading__message {
    max-width: 800px;
    margin: 0 auto;
    padding-top: 6.4rem;
    color: #676767;
    font-weight: 400;
    font-size: 1.6rem;
    text-align: center
}

.page-heading-sub__content {
    margin: 0;
    padding: 0
}

.page-heading-sub__content--left {
    text-align: left
}

.page-heading-sub__content--center {
    text-align: center
}

.page-heading-sub__content--right {
    text-align: right
}

.page-heading-sub__text {
    position: relative;
    font-size: 2.4rem
}

.page-heading-sub__text:before {
    display: inline-block;
    vertical-align: middle;
    width: 6px;
    height: 1.6em;
    margin-right: .8rem;
    border-radius: 3px;
    background: #191919;
    content: ""
}

.page-heading-sub__message {
    margin: 0 auto;
    padding-top: 1.6rem;
    color: #676767;
    font-weight: 400;
    font-size: 1.6rem
}

.footer {
    background: #222
}

.footer__menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    list-style: none;
    margin: 0;
}

.footer__menu-item:not(:first-child) {
    margin-left: 1.6rem
}

.footer__menu-item-link {
    color: #fafafa;
    -webkit-transition: all .2s;
    transition: all .2s
}

.footer__menu-item-link:hover, .footer__menu-item-link:focus {
    text-decoration: underline
}

.footer__copy {
    padding: 1.6rem 0;
    color: #676767;
    font-size: 1.2rem;
    text-align: center
}

.photo-modal {
    display: none;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1002;
    width: 100%;
    height: 100%;
    overflow: hidden;
    -webkit-animation-duration: var(--photo-modal-duration);
    animation-duration: var(--photo-modal-duration);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.photo-modal[data-open=true] {
    -webkit-animation-name: modal-photo-open;
    animation-name: modal-photo-open
}

.photo-modal[data-open=false] {
    -webkit-animation-name: modal-photo-close;
    animation-name: modal-photo-close
}

.photo-modal__container {
    max-width: 800px;
    max-height: 80%;
    margin: auto;
    overflow: auto
}

.photo-modal__image img {
    display: block;
    max-width: 100%;
    margin: 0 auto
}

.photo-modal .button-detail__button--next, .photo-modal .button-detail__button--prev, .photo-modal .button-detail__button--back, .photo-modal .button-detail__button, .photo-modal .photo-modal__button--next, .photo-modal .photo-modal__button--prev, .photo-modal .photo-modal__button--close, .photo-modal .photo-modal__button {
    position: absolute;
    width: 4rem;
    height: 4rem;
    margin: 0;
    padding: 0;
    border: none;
    background-color: rgba(0, 0, 0, 0);
    color: #fff;
    cursor: pointer;
    -webkit-transition: color .4s;
    transition: color .4s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.photo-modal .button-detail__button--next:hover, .photo-modal .button-detail__button--prev:hover, .photo-modal .button-detail__button--back:hover, .photo-modal .button-detail__button:hover, .photo-modal .photo-modal__button--next:hover, .photo-modal .photo-modal__button--prev:hover, .photo-modal .photo-modal__button--close:hover, .photo-modal .photo-modal__button:hover, .photo-modal .button-detail__button--next:focus, .photo-modal .button-detail__button--prev:focus, .photo-modal .button-detail__button--back:focus, .photo-modal .button-detail__button:focus, .photo-modal .photo-modal__button--next:focus, .photo-modal .photo-modal__button--prev:focus, .photo-modal .photo-modal__button--close:focus, .photo-modal .photo-modal__button:focus {
    color: #f2f2f2;
    outline: none
}

.photo-modal .button-detail__button--next::before, .photo-modal .button-detail__button--prev::before, .photo-modal .button-detail__button--back::before, .photo-modal .button-detail__button::before, .photo-modal .photo-modal__button--next::before, .photo-modal .photo-modal__button--prev::before, .photo-modal .photo-modal__button--close::before, .photo-modal .photo-modal__button::before {
    font-size: 2.5rem
}

.photo-modal__button--close {
    top: 0;
    right: 0
}

.photo-modal__button--close::before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: ""
}

.photo-modal__button--prev {
    top: 50%;
    left: 0
}

.photo-modal__button--prev::before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: ""
}

.photo-modal__button--next {
    top: 50%;
    right: 0
}

.photo-modal__button--next::before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: ""
}

.photo-modal__overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: rgba(0, 0, 0, .85)
}

.button-guide {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    border: none;
    line-height: 1;
    text-decoration: none;
    text-align: center;
    outline: none;
    cursor: pointer;
    -webkit-transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    display: flex;
    width: 100%;
    max-width: 60rem;
    margin: 0 auto;
    padding: 1.6rem;
    border: none;
    border-radius: 8px;
    background: #eee;
    color: #222;
    font-weight: 400;
    font-size: 1.6rem
}

.button-guide:hover, .button-guide:focus {
    background: #191919;
    color: #fff
}

.button-detail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 60rem;
    margin: 0 auto
}

.button-detail .button-detail__button--next, .button-detail .button-detail__button--prev, .button-detail .button-detail__button--back, .button-detail .button-detail__button, .button-detail .photo-modal__button, .button-detail .photo-modal__button--close, .button-detail .photo-modal__button--prev, .button-detail .photo-modal__button--next {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    border: none;
    line-height: 1;
    text-decoration: none;
    text-align: center;
    outline: none;
    cursor: pointer;
    -webkit-transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s;
    transition: box-shadow .2s, text-shadow .2s, background-color .2s, border-color .2s, opacity .2s, -webkit-box-shadow .2s;
    margin-bottom: 2.4rem;
    padding: 1.6rem 2.4rem;
    border-radius: .4rem;
    background: #eee;
    color: #222
}

.button-detail .button-detail__button--next:hover, .button-detail .button-detail__button--prev:hover, .button-detail .button-detail__button--back:hover, .button-detail .button-detail__button:hover, .button-detail .photo-modal__button:hover, .button-detail .photo-modal__button--close:hover, .button-detail .photo-modal__button--prev:hover, .button-detail .photo-modal__button--next:hover, .button-detail .button-detail__button--next:focus, .button-detail .button-detail__button--prev:focus, .button-detail .button-detail__button--back:focus, .button-detail .button-detail__button:focus, .button-detail .photo-modal__button:focus, .button-detail .photo-modal__button--close:focus, .button-detail .photo-modal__button--prev:focus, .button-detail .photo-modal__button--next:focus {
    background: #191919;
    color: #fff
}

.button-detail__button--back {
    width: 100%
}

.button-detail__button--back:before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    margin-right: .8rem
}

.button-detail__button--prev {
    width: 100%
}

@media screen and (min-width: 768px) {
    .button-detail__button--prev {
        width: calc(50% - 15px);
        margin-right: 15px
    }
}

.button-detail__button--prev:before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    margin-right: .8rem
}

.button-detail__button--next {
    width: 100%
}

@media screen and (min-width: 768px) {
    .button-detail__button--next {
        width: calc(50% - 15px);
        margin-left: 15px
    }
}

.button-detail__button--next:after {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    margin-left: .8rem
}

.pagination__list, .pagination .page-numbers {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    list-style-type: none;
    margin: 0;
    padding: 0
}

.pagination__list-item, .pagination .page-numbers>li {
    margin: .3rem
}

.pagination .pagination__link--next, .pagination .pagination__link.next, .pagination .page-numbers>li>a--next, .pagination .pagination__link--prev, .pagination .pagination__link.prev, .pagination .page-numbers>li>a--prev, .pagination .pagination__link, .pagination .page-numbers>li>a {
    -webkit-transition: background-color .2s;
    transition: background-color .2s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 1.2rem 1.6rem;
    border-radius: 6px;
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1;
    text-align: center;
    cursor: pointer
}

.pagination__link, .pagination .page-numbers>li>a {
    background-color: #eee;
    color: #222
}

.pagination__link:hover, .pagination__link:focus, .pagination .page-numbers>li>a:hover, .pagination .page-numbers>li>a:focus {
    background-color: #191919;
    color: #fff
}

.pagination__link--prev, .pagination__link.prev, .pagination .page-numbers>li>a--prev, .pagination .page-numbers>li>a.prev {
    min-width: 12rem;
    background-color: #eee;
    color: #222
}

.pagination__link--prev:before, .pagination__link.prev:before, .pagination .page-numbers>li>a--prev:before, .pagination .page-numbers>li>a.prev:before {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    display: inline-block;
    margin-right: .6rem;
    -webkit-transition: -webkit-transform .2s;
    transition: -webkit-transform .2s;
    transition: transform .2s;
    transition: transform .2s, -webkit-transform .2s
}

.pagination__link--prev:hover, .pagination__link--prev:focus, .pagination__link.prev:hover, .pagination__link.prev:focus, .pagination .page-numbers>li>a--prev:hover, .pagination .page-numbers>li>a--prev:focus, .pagination .page-numbers>li>a.prev:hover, .pagination .page-numbers>li>a.prev:focus {
    background-color: #191919;
    color: #fff
}

.pagination__link--prev:hover:before, .pagination__link--prev:focus:before, .pagination__link.prev:hover:before, .pagination__link.prev:focus:before, .pagination .page-numbers>li>a--prev:hover:before, .pagination .page-numbers>li>a--prev:focus:before, .pagination .page-numbers>li>a.prev:hover:before, .pagination .page-numbers>li>a.prev:focus:before {
    -webkit-transform: translateX(-4px);
    transform: translateX(-4px)
}

.pagination__link--next, .pagination__link.next, .pagination .page-numbers>li>a--next, .pagination .page-numbers>li>a.next {
    min-width: 12rem;
    background-color: #eee;
    color: #222
}

.pagination__link--next:after, .pagination__link.next:after, .pagination .page-numbers>li>a--next:after, .pagination .page-numbers>li>a.next:after {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
    content: "";
    display: inline-block;
    margin-left: .6rem;
    -webkit-transition: -webkit-transform .2s;
    transition: -webkit-transform .2s;
    transition: transform .2s;
    transition: transform .2s, -webkit-transform .2s
}

.pagination__link--next:hover, .pagination__link--next:focus, .pagination__link.next:hover, .pagination__link.next:focus, .pagination .page-numbers>li>a--next:hover, .pagination .page-numbers>li>a--next:focus, .pagination .page-numbers>li>a.next:hover, .pagination .page-numbers>li>a.next:focus {
    background-color: #191919;
    color: #fff
}

.pagination__link--next:hover:after, .pagination__link--next:focus:after, .pagination__link.next:hover:after, .pagination__link.next:focus:after, .pagination .page-numbers>li>a--next:hover:after, .pagination .page-numbers>li>a--next:focus:after, .pagination .page-numbers>li>a.next:hover:after, .pagination .page-numbers>li>a.next:focus:after {
    -webkit-transform: translateX(4px);
    transform: translateX(4px)
}

.pagination .pagination__text--dots, .pagination .pagination__text.dots, .pagination .page-numbers>li>span--dots, .pagination .pagination__text--current, .pagination .pagination__text.current, .pagination .page-numbers>li>span--current, .pagination .pagination__text, .pagination .page-numbers>li>span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 1.2rem 1.6rem;
    border-radius: 6px;
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1;
    text-align: center
}

.pagination__text, .pagination .page-numbers>li>span {
    background-color: #eee;
    color: #222
}

.pagination__text--current, .pagination__text.current, .pagination .page-numbers>li>span--current, .pagination .page-numbers>li>span.current {
    background-color: #191919;
    color: #fff
}

.pagination__text--dots, .pagination__text.dots, .pagination .page-numbers>li>span--dots, .pagination .page-numbers>li>span.dots {
    background-color: #eee;
    color: #222
}

@media screen and (min-width: 768px) {
    .form__form-group {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.form__form-group-title {
    padding: 1rem
}

@media screen and (min-width: 768px) {
    .form__form-group-title {
        width: 260px;
        padding: 1.6rem
    }
}

.form__form-group-content {
    padding: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media screen and (min-width: 768px) {
    .form__form-group-content {
        width: calc(100% - 260px);
        padding: 1.6rem
    }
}

.form .form__label--required, .form .form__label--itemname, .form .form__label {
    display: inline-block;
    font-weight: 400;
    line-height: 1;
    letter-spacing: .08em
}

.form__label--itemname {
    color: #222
}

.form__label--required {
    margin-left: .4rem;
    padding: .4em .6em;
    border-radius: 3px;
    background: #fafafa;
    color: #676767;
    font-size: 1.4rem
}

.form__list {
    list-style: none;
    margin: 0;
    padding: 0
}

.form__list-item {
    margin-bottom: .6rem
}

.form .form__input--check, .form .form__input--radio, .form .form__input--select, .form .form__input--textarea-half, .form .form__input--textarea, .form .form__input--text-half, .form .form__input--text, .form .form__input {
    position: relative;
    width: 100%;
    padding: .4rem
}

.form .form__input--select select, .form__input--select .form select, .form .form__input--textarea-half textarea, .form__input--textarea-half .form textarea, .form .form__input--textarea textarea, .form__input--textarea .form textarea, .form .form__input--text-half input, .form__input--text-half .form input, .form .form__input--text input, .form__input--text .form input {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    width: 100%;
    margin: 0;
    border: 2px solid #efefef;
    background: #fff;
    font-weight: 400;
    font-size: 1.6rem;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.form .form__input--select select::-ms-expand, .form__input--select .form select::-ms-expand, .form .form__input--textarea-half textarea::-ms-expand, .form__input--textarea-half .form textarea::-ms-expand, .form .form__input--textarea textarea::-ms-expand, .form__input--textarea .form textarea::-ms-expand, .form .form__input--text-half input::-ms-expand, .form__input--text-half .form input::-ms-expand, .form .form__input--text input::-ms-expand, .form__input--text .form input::-ms-expand {
    display: none
}

.form .form__input--select select::-webkit-input-placeholder, .form__input--select .form select::-webkit-input-placeholder, .form .form__input--textarea-half textarea::-webkit-input-placeholder, .form__input--textarea-half .form textarea::-webkit-input-placeholder, .form .form__input--textarea textarea::-webkit-input-placeholder, .form__input--textarea .form textarea::-webkit-input-placeholder, .form .form__input--text-half input::-webkit-input-placeholder, .form__input--text-half .form input::-webkit-input-placeholder, .form .form__input--text input::-webkit-input-placeholder, .form__input--text .form input::-webkit-input-placeholder {
    color: #ccc
}

.form .form__input--select select::-moz-placeholder, .form__input--select .form select::-moz-placeholder, .form .form__input--textarea-half textarea::-moz-placeholder, .form__input--textarea-half .form textarea::-moz-placeholder, .form .form__input--textarea textarea::-moz-placeholder, .form__input--textarea .form textarea::-moz-placeholder, .form .form__input--text-half input::-moz-placeholder, .form__input--text-half .form input::-moz-placeholder, .form .form__input--text input::-moz-placeholder, .form__input--text .form input::-moz-placeholder {
    color: #ccc
}

.form .form__input--select select:-ms-input-placeholder, .form__input--select .form select:-ms-input-placeholder, .form .form__input--textarea-half textarea:-ms-input-placeholder, .form__input--textarea-half .form textarea:-ms-input-placeholder, .form .form__input--textarea textarea:-ms-input-placeholder, .form__input--textarea .form textarea:-ms-input-placeholder, .form .form__input--text-half input:-ms-input-placeholder, .form__input--text-half .form input:-ms-input-placeholder, .form .form__input--text input:-ms-input-placeholder, .form__input--text .form input:-ms-input-placeholder {
    color: #ccc
}

.form .form__input--select select::-ms-input-placeholder, .form__input--select .form select::-ms-input-placeholder, .form .form__input--textarea-half textarea::-ms-input-placeholder, .form__input--textarea-half .form textarea::-ms-input-placeholder, .form .form__input--textarea textarea::-ms-input-placeholder, .form__input--textarea .form textarea::-ms-input-placeholder, .form .form__input--text-half input::-ms-input-placeholder, .form__input--text-half .form input::-ms-input-placeholder, .form .form__input--text input::-ms-input-placeholder, .form__input--text .form input::-ms-input-placeholder {
    color: #ccc
}

.form .form__input--select select::placeholder, .form__input--select .form select::placeholder, .form .form__input--textarea-half textarea::placeholder, .form__input--textarea-half .form textarea::placeholder, .form .form__input--textarea textarea::placeholder, .form__input--textarea .form textarea::placeholder, .form .form__input--text-half input::placeholder, .form__input--text-half .form input::placeholder, .form .form__input--text input::placeholder, .form__input--text .form input::placeholder {
    color: #ccc
}

.form .form__input--select select::-ms-input-placeholder, .form__input--select .form select::-ms-input-placeholder, .form .form__input--textarea-half textarea::-ms-input-placeholder, .form__input--textarea-half .form textarea::-ms-input-placeholder, .form .form__input--textarea textarea::-ms-input-placeholder, .form__input--textarea .form textarea::-ms-input-placeholder, .form .form__input--text-half input::-ms-input-placeholder, .form__input--text-half .form input::-ms-input-placeholder, .form .form__input--text input::-ms-input-placeholder, .form__input--text .form input::-ms-input-placeholder {
    color: #ccc
}

.form .form__input--select select:-ms-input-placeholder, .form__input--select .form select:-ms-input-placeholder, .form .form__input--textarea-half textarea:-ms-input-placeholder, .form__input--textarea-half .form textarea:-ms-input-placeholder, .form .form__input--textarea textarea:-ms-input-placeholder, .form__input--textarea .form textarea:-ms-input-placeholder, .form .form__input--text-half input:-ms-input-placeholder, .form__input--text-half .form input:-ms-input-placeholder, .form .form__input--text input:-ms-input-placeholder, .form__input--text .form input:-ms-input-placeholder {
    color: #ccc
}

.form .form__input--text-half input, .form__input--text-half .form input, .form .form__input--text input, .form__input--text .form input {
    padding: .8rem 1.6rem;
    -webkit-transition: border-color .4s;
    transition: border-color .4s
}

.form .form__input--text-half input:focus, .form__input--text-half .form input:focus, .form .form__input--text input:focus, .form__input--text .form input:focus {
    border: 2px solid #191919
}

.form .form__input--textarea-half textarea, .form__input--textarea-half .form textarea, .form .form__input--textarea textarea, .form__input--textarea .form textarea {
    padding: 1.6rem;
    -webkit-transition: border-color .4s;
    transition: border-color .4s
}

.form .form__input--textarea-half textarea:focus, .form__input--textarea-half .form textarea:focus, .form .form__input--textarea textarea:focus, .form__input--textarea .form textarea:focus {
    border: 2px solid #191919
}

.form__input--text-half {
    max-width: 50%
}

.form__input--textarea-half {
    max-width: 50%
}

.form__input--select {
    max-width: 300px
}

.form__input--select select {
    padding: .8rem 2.4rem .8rem 1.6rem;
    cursor: pointer
}

.form__input--select::after {
    display: inline-block;
    position: absolute;
    top: 0;
    right: 12px;
    bottom: 0;
    z-index: 1;
    width: 0;
    height: 0;
    margin: auto 0;
    border-width: 6px 4px 0;
    border-style: solid;
    border-color: #ccc rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0);
    content: "";
    pointer-events: none
}

.form__input--radio {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer
}

.form__input--radio .radio-input {
    display: block !important;
    visibility: visible !important;
    opacity: 0 !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 4px !important;
    height: 4px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border: none !important
}

.form__input--radio .radio-icon {
    display: inline-block;
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    margin-right: .8rem;
    border: 1px solid #ccc;
    border-radius: 50%
}

.form__input--radio .radio-icon:before {
    opacity: 0;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 1.5rem;
    height: 1.5rem;
    margin: auto;
    border-radius: 50%;
    background: #191919;
    content: "";
    -webkit-transition: opacity .4s;
    transition: opacity .4s
}

.form__input--radio .radio-text {
    color: #ccc;
    -webkit-transition: color .4s;
    transition: color .4s
}

.form__input--radio .radio-input:checked+.radio-icon {
    border-color: #191919
}

.form__input--radio .radio-input:checked+.radio-icon:before {
    opacity: 1
}

.form__input--radio .radio-input:checked~.radio-text {
    color: #191919
}

.form__input--check {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer
}

.form__input--check .check-input {
    display: block !important;
    visibility: visible !important;
    opacity: 0 !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 4px !important;
    height: 4px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border: none !important
}

.form__input--check .check-icon {
    display: inline-block;
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    margin-right: .8rem;
    border: 2px solid #ccc
}

.form__input--check .check-icon:after {
    opacity: 0;
    position: absolute;
    top: .5rem;
    left: .3rem;
    width: 1.6rem;
    height: .8rem;
    border-bottom: 2px solid rgba(0, 0, 0, 0);
    border-left: 2px solid rgba(0, 0, 0, 0);
    content: "";
    -webkit-transition: opacity .4s;
    transition: opacity .4s
}

.form__input--check .check-text {
    color: #ccc;
    -webkit-transition: color .4s;
    transition: color .4s
}

.form__input--check .check-input:checked+.check-icon {
    border-color: #191919
}

.form__input--check .check-input:checked+.check-icon:after {
    opacity: 1;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    border-bottom: 2px solid #191919;
    border-left: 2px solid #191919
}

.form__input--check .check-input:checked~.check-text {
    color: #191919
}

.table-overview {
    width: 100%;
    line-height: 1.8;
    text-align: left
}

.table-overview tr th {
    width: 16rem;
    padding: .8rem;
    vertical-align: top
}

.table-overview tr td {
    width: calc(100% - 16rem);
    padding: .8rem 1.6rem;
    vertical-align: top
}

.service-feature-item__thumbnail {
    overflow: hidden
}

.service-feature-item__thumbnail-image {
    display: block;
    margin: 0 auto;
    max-width: 200px;
    border-radius: 100%
}

.service-feature-item__content {
    padding: 1.6rem
}

.service-feature-item__content-title {
    margin-bottom: 1.6rem;
    font-weight: 700;
    font-size: 2rem;
    text-align: center
}

.service-feature-item__content-text {
    color: #676767
}

@media screen and (min-width: 768px) {
    .service-content-item {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 768px) {
    .service-content-item__thumbnail {
        width: 30rem
    }
}

.service-content-item__thumbnail-image {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    border-radius: .8rem
}

.service-content-item__content {
    padding: 1.6rem
}

@media screen and (min-width: 768px) {
    .service-content-item__content {
        width: calc(100% - 30rem);
        padding: 3.2rem
    }
}

.service-content-item__content-title {
    margin-bottom: 1.6rem;
    font-weight: 700;
    font-size: 2rem;
    text-align: center
}

@media screen and (min-width: 768px) {
    .service-content-item__content-title {
        font-size: 2.4rem;
        text-align: left
    }
}

.service-content-item__content-text {
    color: #676767
}

.works-item {
    -webkit-box-shadow: 0 0 1.6rem 0 rgba(0, 0, 0, .15);
    box-shadow: 0 0 1.6rem 0 rgba(0, 0, 0, .15);
    -webkit-transition: all .2s;
    transition: all .2s;
    display: block;
    max-width: 600px;
    margin: 0 auto;
    padding: 0;
    overflow: hidden;
    border-radius: .8rem;
    background: #fff;
    color: #222;
    cursor: pointer
}

.works-item__thumbnail {
    overflow: hidden
}

.works-item__thumbnail-image {
    -webkit-transition: all .2s;
    transition: all .2s;
    display: block;
    max-width: 100%;
    margin: 0 auto
}

.works-item__content {
    padding: .8rem
}

@media(min-width: 992px) {
    .works-item__content {
        padding: 1.6rem
    }
}

.works-item__content-title {
    color: #222;
    font-weight: 400;
    font-size: 1.6rem;
    text-align: center
}

.works-item:hover {
    -webkit-box-shadow: 0 0 2.4rem 0 rgba(0, 0, 0, .3);
    box-shadow: 0 0 2.4rem 0 rgba(0, 0, 0, .3)
}

.works-item:hover .works-item__thumbnail-image {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
}

.works-item:hover .works-item__button-more {
    background: #222;
    color: #fff
}

.works-item:hover .works-item__button-more:after {
    -webkit-transform: translateX(4px);
    transform: translateX(4px)
}

@media screen and (min-width: 768px) {
    .sp {
        display: none !important
    }
}

@media screen and (max-width: 767px) {
    .pc {
        display: none !important
    }
}

@media screen and (max-width: 767px) {
    .sfont10 {
        font-size: 10px !important
    }

    .sfont11 {
        font-size: 11px !important
    }

    .sfont12 {
        font-size: 12px !important
    }

    .sfont13 {
        font-size: 13px !important
    }

    .sfont14 {
        font-size: 14px !important
    }

    .sfont16 {
        font-size: 16px !important
    }

    .sfont18 {
        font-size: 18px !important
    }

    .sfont20 {
        font-size: 20px !important
    }

    .sfont30 {
        font-size: 30px !important
    }

    .sfont40 {
        font-size: 40px !important
    }

    .sfont47 {
        font-size: 46px !important
    }

    .sfont60 {
        font-size: 60px !important
    }

    .sfont80 {
        font-size: 80px !important
    }

    .sfont100 {
        font-size: 100px !important
    }
}

.fadein {
    opacity: .1;
    -webkit-transform: translate(0, 50px);
    transform: translate(0, 50px);
    -webkit-transition: all 500ms;
    transition: all 500ms
}

.fadein.scrollin {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
}

.nav-header {
    background: #191919;
}

@media screen and (max-width: 767px) {
    .nav-header {
        width: 100vw
    }
}

.nav-header__logo-image {
    max-width: 200px;
    height: auto !important
}

.nav-header__menu {
    display: grid;
    grid-auto-flow: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    grid-template-columns: 1fr
}

.nav-header__link {
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    color: #fff;
    font-size: 14px
}

.nav-header__toggle {
    height: 4rem
}

.mv {
    position: relative;
    background-color: #191919;
    font-size: 20px;
    padding: 18px 26px 0px 26px;
    display: flex;
    justify-content: center;
    overflow: hidden;
}

@media screen and (max-width: 767px) {
    .mv {
        padding: 2rem 15px 5rem
    }
}

.mv__container {
    background: #191919 url("../../assets/img/bg_top01.webp") no-repeat;
    background-position: left 27%;
    background-size: 55%;
    width: 1320px;
    max-width: 1320px;
    display: grid;
    grid-template-columns: 27% 30% 1fr;
    grid-template-rows: 10% 40%;
    padding: 6rem 5px 200px;
    gap: 0px 0px;
    position: relative;
    grid-template-areas: "mv__txt1 mv__txt1 mv__logo""mv__txt3 mv__txt3 mv__logo""mv__vision mv__txt4 mv__txt4 ";
    font-family: "Anton", sans-serif;
    font-weight: 400
}

@media screen and (max-width: 767px) {
    .mv__container {
        background-image: url("bg.webp");
        grid-template-columns: 100%;
        grid-template-rows: 8% 12% 23% 12% 45%;
        grid-template-areas: "mv__txt1""mv__txt3""mv__logo""mv__vision""mv__txt4";
        padding-bottom: 5rem;
        padding-top: 2rem
    }
}

.mv__txt1 {
    grid-area: mv__txt1;
    max-width: 366px;
    width: 100%;
    line-height: 113px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
    margin-left: 2rem
}

@media screen and (max-width: 767px) {
    .mv__txt1 {
        margin: 0
    }
}

.mv__txt2 {
    max-width: 45px;
    width: 100%;
    margin-left: 1rem
}

.mv__txt3 {
    grid-area: mv__txt3;
    max-width: 669px;
    width: 100%;
    line-height: 165.88px;
    letter-spacing: -0.01em;
    text-align: left;
    margin-left: 2rem
}

@media screen and (max-width: 767px) {
    .mv__txt3 {
        line-height: 96px;
        margin: 0
    }
}

.mv__logo {
    position: relative;
    grid-area: mv__logo;
    background: #191919 url("../../assets/img/bg_top03.webp") no-repeat;
    background-position: right 48%;
    background-size: 11%;
    display: grid;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 1.5rem
}

@media screen and (max-width: 767px) {
    .mv__logo {
        background: #191919 url("../../assets/img/bg_top02.webp") no-repeat;
        background-position: left;
        background-size: 180%
    }
}

.mv__logo img {
    max-width: 430px
}

@media screen and (max-width: 767px) {
    .mv__logo img {
        max-width: 190px
    }
}

.mv__logo .mv__button {
    position: absolute;
    bottom: 45px;
    right: 60px;
    white-space: nowrap;
    font-weight: 500;
    border: 1px solid #fff;
    border-radius: 40px;
    padding: 0.25rem 1rem;
    line-height: 2;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media screen and (max-width: 767px) {
    .mv__logo .mv__button {
        bottom: 40px;
        right: 20px;
    }
}

.mv__vision {
    position: relative;
    grid-area: mv__vision;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    justify-items: center;
    display: grid;
    height: 85%;
    line-height: 80px;
}


@media screen and (max-width: 767px) {
    .mv__vision {
        padding-top: 25px;
    }
}


@media screen and (max-width: 767px) {
    .mv__vision::before {
        content: '';
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        width: 35px;
        height: 4px;
        background-color: #fff;
        border-radius: 20px;
    }
}

.mv__txt4 {
    grid-area: mv__txt4;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    /* line-height: 3.1818181818vw; */
    line-height: 42px;
    height: 82%
}

@media screen and (max-width: 767px) {
    .mv__txt4 {
        line-height: 32px
    }
}

.mv__modal {
    color: #222;
}

.mv__modal .modal__content {
    border-radius: 0;
}

@media screen and (min-width: 576px) {
    .mv__modal .modal__content {
        width: 90%;
        max-width: 920px;
    }
}

.mv__modal .modal__title {
    font-family: "Anton", sans-serif;
    font-weight: 400;
    text-align: center;
}

.mv__modal .modal__description {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    margin-top: 2rem;
    line-height: 180%;
    padding: 0px 60px;
    text-align: left;
}

@media screen and (max-width: 767px) {
    .mv__modal .modal__description {
        padding: 40px 0px 0px 0px;
        margin-top: 20px;
    }
}

.mv__modal .modal__writer {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    margin-top: 40px;
    line-height: 180%;
    padding: 0px 60px;
    text-align: left;
}

@media screen and (max-width: 767px) {
    .mv__modal .modal__writer {
        margin-top: 0px;
        padding: 0px 0px 40px;
    }
}

.mv__modal--img {
    margin-top: 40px;
    padding-inline: 60px;
    text-align: center;
}

@media screen and (max-width: 767px) {
    .mv__modal--img  {
        margin-top: 20px;
        padding-inline: 0;
    }
}

.mv__modal--img img {
    margin-inline: auto;
    max-width: 80%;
}

@media screen and (max-width: 767px) {
    .mv__modal--img img  {
        max-width: 100%;
    }
}

.footer {
    background: #191919;
    height: 100%;
    overflow: hidden;
}

.footer__wrap {
    width: 100%;
    padding: 40px 0px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items: center;
    border-top: 1px solid #676767;
    border-bottom: 1px solid #676767
}

.footer__menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    list-style: none;
    margin: 0;
    margin-right: 1rem
}

.footer__menu-item {
    font-size: min(1.2121212121vw, 16px)
}

.footer__menu-item:not(:first-child) {
    margin-left: 1.6rem
}

.footer__menu-item-link {
    color: #fafafa;
    -webkit-transition: all .2s;
    transition: all .2s
}

.footer__menu-item-link:hover, .footer__menu-item-link:focus {
    text-decoration: underline
}

.footer__container {
    max-width: 1320px;
    margin: 0 auto;
    width: 95%;
    display: grid;
    grid-template-columns: 10% auto auto 1fr;
    grid-template-rows: 150px 1fr;
    grid-auto-flow: row;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    grid-template-areas: "logo logo-border title company""copyright copyright copyright copyright";
    padding: 20px 5px 20px;
    gap: 30px 27px;
}

@media screen and (max-width: 767px) {
    .footer__container {
        grid-template-columns: 35% 55%;
        grid-template-rows: 1fr;
        margin: 0;
        padding: 1rem 15px;
        padding-top: 3rem;
        width: 100%;
        grid-template-areas: "company company""footer__border footer__border""logo title""copyright copyright";
        border-top: 1px solid #444;
    }
}

.footer__container .logo {
    grid-area: logo;
}

.footer__container .logo-border {
    grid-area: logo-border;
    border-right: 1px solid #444444;
    height: 70%;
    width: 1px;
}

.footer__container .footer__border {
    grid-area: footer__border;
    border-top: 1px solid #444444;
    width: 100%;
}

@media screen and (max-width: 767px) {
    .footer__container .logo {
        padding-top: 2rem;
        position: relative
    }

    .footer__container .logo::after {
        margin: 0 1rem;
        content: "";
        width: 2px;
        height: 100%;
        background-color: #444;
        position: absolute;
        left: 100%;
        bottom: -15px
    }
}

.footer__container .logo img {
    width: 146px
}

.footer__container .title {
    display: grid;
    grid-template-columns: -webkit-max-content;
    grid-template-columns: max-content;
    grid-template-rows: 1fr 1fr;
    gap: 0 0;
    grid-auto-flow: row;
    font-family: "Anton", sans-serif;
    font-weight: 400;
    grid-template-areas: "innovation""something";
    grid-area: title
}

.footer__container .something {
    grid-area: something
}

.footer__container .innovation {
    grid-area: innovation;
    align-self: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.footer__container .for {
    margin-left: .5rem;
    -ms-flex-item-align: end;
    align-self: flex-end
}

.footer__container .company {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: 25px;
    gap: 51px 39px;
    grid-auto-flow: row;
    grid-template-areas: "name honsya office""bottom-txt bottom-txt bottom-txt";
    grid-area: company;
    font-weight: 400;
    color: #fff !important;
}

.text-white {
    color: #fff !important;
}

*[x-apple-data-detectors] {
    color: inherit !important;
}

@media screen and (max-width: 767px) {
    .footer__container .company {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
        gap: 20px 0px;
        grid-template-areas: "name""honsya""office""bottom-txt";
        padding: 0px 0px 20px;
    }
}

.footer__container .company p {
    font-weight: 700
}

.footer__container hr {
    border: 1px solid #444;
}

.footer__container .bottom-txt {
    grid-area: bottom-txt
}

.footer__container .name {
    grid-area: name
}

.footer__container .honsya {
    grid-area: honsya
}

.footer__container .office {
    grid-area: office
}

.footer__container .copyright {
    grid-area: copyright;
    justify-self: center;
}

.about {
    background: #fafafa url("../../assets/img/bg_top02.webp") no-repeat;
    background-position: left 29%;
    background-size: 100%;
    padding: 0px 60px;
}

@media screen and (max-width: 767px) {
    .about {
        padding: 0px 20px
    }
}

.about__container {
    position: relative;
    max-width: 1320px;
    margin: 0 auto;
    background-size: 60%;
    padding: 3rem 5px
}

@media screen and (max-width: 767px) {
    .about__container {
        padding: 4rem 5px;
    }
}

.about__heading {
    margin-bottom: 2rem;
    font-family: "Anton", sans-serif;
    font-weight: 400
}

.about__heading .page-heading__content {
    display: grid;
    grid-template-columns: 100px 1fr;
    grid-template-rows: 45px 1fr;
    gap: 0px 0px;
    grid-template-areas: "page-heading__text ."". page-heading__text2";
    font-family: "Anton", sans-serif;
}

@media screen and (max-width: 767px) {
    .about__heading .page-heading__content {
        grid-template-columns: 25px auto;
        grid-template-rows: 75px auto
    }
}

.about__heading .page-heading__text {
    grid-area: page-heading__text
}

.about__heading .page-heading__text2 {
    grid-area: page-heading__text2
}

.page-heading__content--center .page-heading__text {
    font-family: "Anton", sans-serif;
}
.page-heading__text {
    font-family: "Anton", sans-serif;
}

.page-heading__text2 {
    white-space: nowrap;
}

@media screen and (max-width: 767px) {
    .page-heading__text2.sfont47 {
        font-size: clamp(42px, 1vw, 46px) !important;
    }
}

.about__content {
    overflow-x: auto !important;
    margin: 0 auto;
    text-align: center;
    display: grid;
    grid-template-columns: repeat(3, 30%);
    grid-template-rows: 1fr;
    gap: 0px 2%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    grid-template-areas: "about__content-wrap1 about__content-wrap2 about__content-wrap3"
}

@media screen and (max-width: 767px) {
    .about__content {
        display: -webkit-box
    }
}

.about__content-wrap1, .about__content-wrap2, .about__content-wrap3 {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: -webkit-max-content -webkit-max-content;
    grid-template-rows: max-content max-content;
    gap: 1rem 0px;
    grid-template-areas: "about__content-img""about__content-txt"
}

@media screen and (max-width: 767px) {
    .about__content-wrap1, .about__content-wrap2, .about__content-wrap3 {
        width: 80%;
        margin-right: 30px;
    }
}

.about__content-img {
    grid-area: about__content-img
}

.about__content-img img {
    width: 100%
}

.about__content-txt {
    display: grid;
    text-align: left;
    font-family: "Poppins", sans-serif;
    font-weight: 400
}

.about__content .about__content-txt_title {
    line-height: 28px;
    font-weight: 700;
}

@media screen and (max-width: 767px) {
    .about__content .about__content-txt_title {
        font-family: "Inter";
        max-width: 225px;
        margin-bottom: 10px;
    }
}

.about__content .about__content-txt_sub {
    font-family: "Poppins", sans-serif;
    font-weight: 500;
    letter-spacing: 0px;
    color: #A4A4A4;
    margin-bottom: 15px;
}

.about__content .about__content-txt_detail {
font-family: "Poppins", sans-serif;
    line-height: 19.5px
}

.message {
    background: #191919 url("../../assets/img/bg_top02.webp") no-repeat;
    background-position: left 35%;
    background-size: 100%;
}

@media screen and (min-width: 576px) {
    .message {
    overflow: hidden;
    padding: 4rem 5px
    }
}

.message__container {
    position: relative;
    max-width: 1320px;
    margin: 0 auto;
    padding: 12.4rem 15px;
    display: grid;
    grid-template-columns: 60% 1fr;
    grid-template-rows: 90px -webkit-max-content;
    grid-template-rows: 90px max-content;
    gap: 6rem 0px;
    padding: 4rem 5px 6rem
}

@media screen and (max-width: 767px) {
    .message__container {
        padding: 4rem 5px
    }
}

@media screen and (max-width: 767px) {
    .message__container {
        grid-template-columns: 1fr;
        grid-template-rows: auto max-content auto;
        gap: 0px 0px;
        padding: 4rem 15px 3.6rem;
        overflow: hidden;
        grid-template-areas: "message__heading""message__content""message__img"
    }
}

.message__img {
    grid-area: 2/2/3/3;
    position: relative
}

@media screen and (max-width: 767px) {
    .message__img {
        grid-area: message__img;
        display: grid;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        position: relative;
        margin-top: 8rem;
        padding-bottom: 5rem;
    }
}

.message__img::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: -webkit-gradient(linear, left bottom, left top, from(#191919), to(transparent));
    background: linear-gradient(0deg, #191919, transparent)
}

.message__img img {
    max-width: 33.8636363636vw
}

@media screen and (max-width: 767px) {
    .message__img img {
        max-width: 246px;
        width: 100%
    }
}

.message__heading {
    grid-area: 1/1/2/3
}

@media screen and (max-width: 767px) {
    .message__heading {
        grid-area: message__heading;
        font-family: "Anton", sans-serif;
        font-weight: 400
    }
}

.message__content {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    /* max-width: 56.7575757576vw; */
    max-width: 46.757576vw;
    width: 100%;
    text-align: left;
    line-height: 1.8181818182vw;
    grid-area: 2/1/3/3;
    z-index: 100
}

@media screen and (max-width: 767px) {
    .message__content {
        line-height: 19.5px;
        grid-area: message__content;
        max-width: 100%;
        margin: 30px 0 0;
    }
}

@media screen and (max-width: 767px) {
    .message__content__img {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        display: grid
    }

    .message__content__img img {
        width: 246px
    }
}

.message__content .message__btn {
    font-weight: 500;
    border: 1px solid #fff;
    border-radius: 40px;
    padding: 0 3rem;
    line-height: 2.4242424242vw;
    width: 7.5757575758vw;
    margin-top: 3rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

@media screen and (max-width: 767px) {
    .message__content .message__btn {
        width: 100px;
        position: absolute;
        bottom: 5%
    }
}

.message__content .modal {
    -webkit-box-pack: left;
    -ms-flex-pack: left;
    justify-content: left;
    margin-left: 0
}

@media screen and (max-width: 767px) {
    .message__content .modal {
        margin-top: -6rem
    }
}

.message__content .modal .modal__content {
    width: 90%;
    max-width: 920px;
    border-radius: 0;
    text-align: center
}

@media screen and (max-width: 767px) {
    .message__content .modal .modal__content {
        width: 100%
    }
}

.message__content .modal .modal__title {
    font-family: "Anton", sans-serif;
    font-weight: 400;
    text-align: center
}

.message__content .modal .modal__description {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    margin-top: 4rem;
    line-height: 180%;
    padding: 0px 60px;
    text-align: left;
}

@media screen and (max-width: 767px) {
    .message__content .modal .modal__description {
        padding: 40px 0px 0px 0px;
        margin-top: 20px;
    }

}

.message__content .modal .modal__writer {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    margin-top: 40px;
    line-height: 180%;
    padding: 0px 60px;
    text-align: left;
}

@media screen and (max-width: 767px) {
    .message__content .modal .modal__writer {
        margin-top: 0px;
        padding: 0px 0px 40px;
    }
}

@media screen and (max-width: 767px) {
    .message__content .modal .message__btn {
        padding: 0px 18px 0px 18px;
        line-height: 32px;
        height: 32px;
        width: 90px
    }
}

.project {
    background: #fafafa url("../../assets/img/bg_top02.webp") no-repeat;
    background-position: left 60%;
    background-size: 100%
}

@media screen and (max-width: 767px) {
    .project {
        background-image: url("bg.webp")
    }
}

.project__container {
    position: relative;
    max-width: 1320px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 500px 1fr;
    grid-template-rows: 215px 400px max-content;
    gap: 0px 0px;
    grid-auto-flow: row;
    padding: 4rem 5px 6rem;
    grid-template-areas: "project__heading  sub""exproject exproject""seminer-wrap seminer-wrap"
}

@media screen and (max-width: 767px) {
    .project__container {
        padding: 4rem 20px
    }
}

@media screen and (max-width: 767px) {
    .project__container {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
        grid-template-areas: "project__heading""sub""exproject""seminer-wrap";
        row-gap: 12px;
    }
}

.project__heading {
    grid-area: project__heading;
    max-width: 445px;
    width: 100%;
    display: grid;
    grid-template-columns: 65px 1fr;
    grid-template-rows: 25px 1fr;
    gap: 0px 0px;
    grid-template-areas: "our ."". project-txt";
    font-family: "Anton", sans-serif;
    font-weight: 400
}

@media screen and (max-width: 767px) {
    .project__heading {
        grid-template-columns: 33px 1fr;
        grid-template-rows: 23px 120px
    }
}

.project__heading .our {
    grid-area: our
}

.project__heading .project-txt {
    grid-area: project-txt
}

.project__sub {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    color: #191919;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 85px 50px;
    gap: 0px 0px;
    grid-auto-flow: row;
    grid-template-areas: "subtitle""subcontents";
    grid-area: sub;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: center
}

@media screen and (max-width: 767px) {
    .project__sub {
        grid-template-rows: 60px 90px
    }
}

.project__sub .subtitle {
    grid-area: subtitle;
    line-height: 24px
}

.project__sub .subcontents {
    width: 83%;
    grid-area: subcontents;
    line-height: 1.5;
}

@media screen and (max-width: 767px) {
    .project__sub .subcontents {
        width: 100%
    }
}


.project__exproject {
    display: grid;
    grid-template-columns: 35% 35%;
    grid-template-rows: 45% 40%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 0px 2rem;
    grid-auto-flow: row;
    grid-area: exproject
}

@media screen and (max-width: 767px) {
    .project__exproject {
        grid-template-columns: 1fr;
        grid-template-rows: 20rem;
        gap: 0px
    }
}

.project__exproject .project1, .project__exproject .project2 {
    display: grid;
    grid-template-rows: 1fr 1fr;
    grid-auto-flow: row;
    grid-template-areas: "project-img""project-txt";
    gap: 23px;
}

@media screen and (max-width: 767px) {
    .project__exproject .project1, .project__exproject .project2 {
        grid-template-rows: max-content 80px;
        gap: 10px;
    }
}

.project__exproject .project1 .project1, .project__exproject .project2 .project1 {
    grid-area: project1
}

.project__exproject .project1 .project2, .project__exproject .project2 .project2 {
    grid-area: project2
}

.project__exproject .project1 .project-img, .project__exproject .project2 .project-img {
    grid-area: project-img;
    box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.20);
}

.project__exproject .project1 .project-txt, .project__exproject .project2 .project-txt {
    grid-area: project-txt;
    font-family: "Poppins", sans-serif;
    font-weight: 700;
    color: #000;
}

.project__exproject .project1 .project-txt span, .project__exproject .project2 .project-txt span {
    background-color: #222;
    padding: 2px 8px
}

.project__seminer-wrap {
    display: grid;
    grid-template-columns: 80%;
    grid-template-rows: auto 1fr;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    padding: 0px 100px;
    gap: 0px 0px;
    grid-auto-flow: row;
    grid-template-areas: "seminer-title""seminer-subtitle""seminer-detail";
    grid-area: seminer-wrap;
    margin-top: 80px;
    color: #000;
}

@media screen and (max-width: 767px) {
    .project__seminer-wrap {
        grid-template-columns: 100%;
        grid-template-rows: 78px 24px max-content;
        padding: 0px 0px;
        margin-top: 40px;
    }
}

.project__seminer-wrap .seminer-title {
    grid-area: seminer-title;
    font-family: "Poppins", sans-serif;
    font-weight: 700
}

@media screen and (max-width: 767px) {
    .project__seminer-wrap .seminer-title {
        line-height: 32px;
    }
}

.project__seminer-wrap .seminer-detail {
    grid-area: seminer-detail;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    line-height: 2.2;
    margin-top: 30px;
}

.project__seminer-wrap .seminer-detail span {
    color: #D0D0D0;
}


.project__partner-wrap {
    display: grid;
    grid-template-columns: 80%;
    grid-template-rows: auto 1fr;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    padding: 0px 100px;
    gap: 0px 0px;
    grid-auto-flow: row;
    grid-template-areas: "partner-title""partner-subtitle""partner-detail";
/*    grid-area: partner-wrap; */
    margin-top: 80px;
    color: #000;
}

@media screen and (max-width: 767px) {
    .project__partner-wrap {
        grid-template-columns: 100%;
        grid-template-rows: 30px 24px max-content;
        padding: 0px 0px;
        margin-top: 40px;
    }
}

.project__partner-wrap .partner-title {
    grid-area: partner-title;
    font-family: "Poppins", sans-serif;
    font-weight: 700
}

@media screen and (max-width: 767px) {
    .project__partner-wrap .partner-title {
        line-height: 32px;
    }
}

.project__partner-wrap .partner-detail {
    grid-area: partner-detail;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    line-height: 2.2;
/*    margin-top: 30px; */
}

.project__partner-wrap .partner-detail span {
    color: #D0D0D0;
}

.media {
    background: #222 url("../../assets/img/bg_top02.webp") no-repeat;
    background-position: left 20%;
    background-size: 100%
}

.media__container {
    position: relative;
    max-width: 1320px;
    margin: 0 auto;
    padding: 12.4rem 15px;
    padding: 6rem 5px 2rem;
    display: grid;
    grid-template-columns: 9% 1fr 17.4242424242vw 8%;
    grid-template-rows: 40px 250px -webkit-max-content 200px 1fr;
    gap: 0px 0px;
    grid-auto-flow: row;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    grid-template-areas: "media__btitle media__btitle media__btitle . "". media__title media__img . "". media__txt media__txt . "". media__button media__button . "". media__list media__list . "
}

@media screen and (max-width: 767px) {
    .media__container {
        padding: 4rem 5px
    }
}

@media screen and (max-width: 767px) {
    .media__container {
        background-image: url("bg.webp");
        grid-template-columns: 1fr;
        grid-template-rows: 2% auto auto auto auto max-content;
        padding: 80px 15px 80px;
        grid-template-areas: "media__btitle""media__img""media__title""media__txt""media__button""media__list"
    }
}

.media__btitle {
    grid-area: media__btitle;
    font-family: "Anton", sans-serif;
    font-weight: 400;
    line-height: 36px;
    color: #444;
}

.media__title {
    grid-area: media__title;
    line-height: 24px
}

@media screen and (max-width: 767px) {
    .media__title {
        display: grid;
        justify-items: center;
        margin-top: 30px;
    }
}

.media__title .font30 {
    margin-bottom: 10px;
    font-size: 30px;
}

.media__title .font30,
.media__title .font20 {
    line-height: 1.2;
}

.media__title .font16 {
    line-height: 2;
}

@media screen and (max-width: 767px) {
    .media__title .font30 {
        line-height: 36px;
        letter-spacing: 0;
        margin-bottom: 2px;
    }
}

.media__title .font20 {
    line-height: 2.7272727273vw;
    margin-bottom: 1.8rem;
}

@media screen and (max-width: 767px) {
    .media__title .font20 {
        line-height: 24px
    }
}

.media__img {
    grid-area: media__img;
    display: grid;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.media__img img {
    height: 247px
}

@media screen and (max-width: 767px) {
    .media__img img {
        height: 305px
    }
}

.media__txt {
    grid-area: media__txt;
    border: 1px solid #444;
    background-color: rgba(34, 34, 34, .6);
    width: 95%;
    padding: 1.5151515152vw;
    line-height: 1.85;
    margin-top: 3rem;
}

@media screen and (max-width: 767px) {
    .media__txt {
        line-height: 24px;
        width: 100%
    }
}

.media__button {
    display: grid;
    grid-template-columns: 30% 30%;
    grid-template-rows: 57px 1fr;
    gap: 0px 3em;
    grid-auto-flow: row;
    grid-template-areas: ". .";
    grid-area: media__button;
    width: 95%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-line-pack: center;
    align-content: center;
    margin: 4.5454545455vw 0
}

@media screen and (max-width: 767px) {
    .media__button {
        grid-template-columns: 1fr;
        grid-template-areas: "."".";
        width: 80%;
        margin: 30px auto 0;
        gap: 30px;
        grid-template-rows: 1fr 1fr;
    }
}

.media__button .media__button--item {
    background-color: #fff;
    border-radius: 2px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    min-height: 57px;
}

.media__button .media__button--item span {
    position: relative;
    display: inline-block;
    color: #191919;
    margin-left: 12px;
    padding-left: 13px;
}

.media__button .media__button--item span::before {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    content: "";
    width: 2px;
    height: 1.5rem;
    background-color: #cacaca
}

.media__list {
    grid-area: media__list;
    padding: 60px 0 60px 0;
    display: grid;
    grid-auto-columns: 1fr;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 1fr 1fr;
    gap: 60px 23px;
    grid-auto-flow: row;
    width: 95%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    grid-template-areas: "media__list-item . ."". . .";
    border-top: 1px solid #444;
}

@media screen and (max-width: 767px) {
    .media__list {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr;
        gap: 0;
        width: 100%;
        grid-template-areas: "media__list-item"".""."".""."".";
        border-top: unset;
        padding-bottom: 0;
    }
}

.media__list-item {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    gap: 0px 0px;
    grid-auto-flow: row;
    grid-template-areas: "media-item"
}

@media screen and (max-width: 767px) {
    .media__list-item {
        padding: 1rem 0;
        border-top: 1px solid #444;
    }
}

.media__list-item .media-item {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 220px -webkit-max-content;
    grid-template-rows: 220px max-content;
    gap: 0px 0px;
    grid-auto-flow: row;
    grid-template-areas: "media-item__thumbnail""media-item__content";
    grid-area: media-item
}

@media screen and (max-width: 767px) {
    .media__list-item .media-item {
        grid-template-columns: 120px 1fr;
        grid-template-rows: 1fr;
        grid-template-areas: "media-item__thumbnail media-item__content"
    }
}

.media__list-item .media-item__thumbnail {
    grid-area: media-item__thumbnail
}

.media__list-item .media-item__thumbnail img {
    height: auto;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.media__list-item .media-item__content {
    grid-area: media-item__content;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    font-weight: 700;
    color: #676767;
    font-size: min(.8333333333vw, 11px)
}

@media screen and (max-width: 767px) {
    .media__list-item .media-item__content {
        font-size: 11px;
        margin-left: 0.8rem;
    }
}

.media__list-item .media-item__content-title {
    color: #fff;
    font-size: min(.9848484848vw, 13px);
    margin-bottom: 12px;
}

@media screen and (max-width: 767px) {
    .media__list-item .media-item__content-title {
        font-size: 13px
    }
}

.contact {
    background-color: #191919 !important;
    padding-block: 100px;
}

@media screen and (max-width: 767px) {
    .contact {
        padding-block: 60px;
    }
}

.contact .required {
    color: #eb00ff
}

.contact__container {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0px 5px;
    background: #fafafa;
    background-color: #191919 !important;
    display: grid;
    justify-items: center;
}

@media screen and (max-width: 767px) {
    .contact__container {
        padding: 0 15px;
        width: 100%
    }
}

.contact__heading {
    text-align: center
}

.contact__heading-main {
    font-family: "Anton", sans-serif;
    font-weight: 400
}

.contact__message {
    font-weight: 700;
    line-height: 1.8181818182vw;
    text-align: center;
    gap: 30px;
}

@media screen and (max-width: 767px) {
    .contact__message {
        line-height: 19.5px;
        text-align: left
    }
}

.contact__message p {
    font-size: 1.5909090909vw;
    margin-bottom: 1.8rem;
}

@media screen and (max-width: 767px) {
    .contact__message p {
        font-size: 16px;
        text-align: center
    }
}

@media screen and (max-width: 767px) {
    .contact__message p.font11 {
        text-align: right
    }
}

.contact__list-item {
    margin: 0 0 2.4rem 0;
    text-align: center
}

.contact__form {
    display: grid;
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    align-items:start;
    grid-template-columns: 30% 35%;
    grid-template-rows: -webkit-max-content 100px;
    grid-template-rows: max-content 100px;
    grid-auto-flow: row;
    grid-template-areas: "left right""button button";
}

.contact__form .left {
    display: flex;
    flex-direction: column;
    gap: 37px;
}

@media screen and (max-width: 767px) {
    .contact__form .left {
        gap: 23px;
        padding: 0px 0px 23px;
    }

}

.input__label {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

@media screen and (max-width: 767px) {
    .contact__form {
        width: 100%;
        grid-template-columns: 95%;
        grid-template-rows: 1fr;
        grid-template-areas: "left""right""button"
    }
}

.contact__form label {
    font-size: min(.9848484848vw, 13px);
    color: #fff;
    display: grid
}

@media screen and (max-width: 767px) {
    .contact__form label {
        font-size: 13px
    }
}

.contact .left {
    grid-area: left;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.contact .left label {
    display: grid
}

.contact .left label input {
    height: 40px;
    background-color: #222;
    color: #fff;
    border: 1px solid #444;
    width: 95%;
    padding: 4px 8px;
}

.contact .contact__from--conf {
    font-size: 15px;
    font-weight: 700;
}

.contact .right {
    grid-area: right
}

.contact .right textarea {
    background-color: #222;
    color: #fff;
    border: 1px solid #444;
    width: 95%;
    height: 18.2575757576vw;
    padding: 4px 8px;
}

@media screen and (max-width: 767px) {
    .contact .right textarea {
        height: 160px
    }
}

.contact .button {
    grid-area: button;
    width: 11.8181818182;
    display: grid;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.contact .button .submit__btn {
    background-color: #191919;
    border: 1px solid #fff;
    border-radius: 50px;
    height: 42px;
    line-height: 24px;
    text-transform: uppercase;
    font-size: 16px;
    font-weight: 700;
    padding: 8px 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 60px;
}

/* css start */
.start {
  background: #000;
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 9000;
}

.start-container {
  position: fixed;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
  text-align: center;
  transition: all 0.3s ease-in-out;
}

.start-video {
  position: relative;
  top: 0;
  left: 0;
  visibility: hidden;
  opacity: 0;
  z-index: 9999;
  width: 100%;
  height: 100%;
  transition: all 0.3s ease-in-out, opacity 0.5s ease-in-out;
  transform: scale(0.9);
}

.start-video.is-show {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
}

.start-video video {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 767px) {
    .start-video video {
      width: 100%;
      min-width: 320px;
      height: 100%;
      min-height: 400px;
    }
}

.link-blank {
    color: #000;
    display: inline-flex;
    align-items: center;
}

.link-blank::after {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    background:  url('/assets/img/icon-links.svg') no-repeat center center;
    background-size: contain;
    margin-left: 6px;
}