@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Mochiy+Pop+One&display=swap");
@import url("https://use.fontawesome.com/releases/v6.2.0/css/all.css");

:root {
    --font-00: "Noto Sans JP", YuGothic, "Yu Gothic", sans-serif;
    --font-01: "Noto Serif JP", "Yu Mincho Light", "YuMincho", "Yu Mincho", "游明朝体", serif;
    --color-00: #fff;
    --color-01: #222;
    --color-02: #e8e8e8;
    --color-03: #ec6941;
    --color-04: #dad7d2;
    --color-05: #ffe5dd;
    --color-06: #807f7f;
    --color-07: #dadada;
    --filter-for-03: invert(44%) sepia(95%) saturate(947%) hue-rotate(337deg) brightness(99%) contrast(86%);
}

:before,
:after {
    pointer-events: none;
}

.main>* {
    position: relative;
}

.up-ofi {
    height: 100%;
}

button {
    border: none;
}

[class*="section-m"],
[class*="section-p"] {
    --section-xlarge: 140px;
    --section-large: 100px;
    --section-medium: 80px;
    --section-small: 60px;
    --section-xsmall: 40px;
}

.section-my-xlarge {
    margin-top: var(--section-xlarge);
    margin-bottom: var(--section-xlarge);
}

.section-mt-xlarge {
    margin-top: var(--section-xlarge);
}

.section-mb-xlarge {
    margin-bottom: var(--section-xlarge);
}

.section-my-large {
    margin-top: var(--section-large);
    margin-bottom: var(--section-large);
}

.section-mt-large {
    margin-top: var(--section-large);
}

.section-mb-large {
    margin-bottom: var(--section-large);
}

.section-my-medium {
    margin-top: var(--section-medium);
    margin-bottom: var(--section-medium);
}

.section-mt-medium {
    margin-top: var(--section-medium);
}

.section-mb-medium {
    margin-bottom: var(--section-medium);
}

.section-my-small {
    margin-top: var(--section-small);
    margin-bottom: var(--section-small);
}

.section-mt-small {
    margin-top: var(--section-small);
}

.section-mb-small {
    margin-bottom: var(--section-small);
}

.section-my-xsmall {
    margin-top: var(--section-xsmall);
    margin-bottom: var(--section-xsmall);
}

.section-mt-xsmall {
    margin-top: var(--section-xsmall);
}

.section-mb-xsmall {
    margin-bottom: var(--section-xsmall);
}

@media (max-width: 1024px) {
    .section-my-xlarge {
        margin-top: calc(var(--section-xlarge) * 0.8);
        margin-bottom: calc(var(--section-xlarge) * 0.8);
    }

    .section-mt-xlarge {
        margin-top: calc(var(--section-xlarge) * 0.8);
    }

    .section-mb-xlarge {
        margin-bottom: calc(var(--section-xlarge) * 0.8);
    }

    .section-my-large {
        margin-top: calc(var(--section-large) * 0.8);
        margin-bottom: calc(var(--section-large) * 0.8);
    }

    .section-mt-large {
        margin-top: calc(var(--section-large) * 0.8);
    }

    .section-mb-large {
        margin-bottom: calc(var(--section-large) * 0.8);
    }

    .section-my-medium {
        margin-top: calc(var(--section-medium) * 0.8);
        margin-bottom: calc(var(--section-medium) * 0.8);
    }

    .section-mt-medium {
        margin-top: calc(var(--section-medium) * 0.8);
    }

    .section-mb-medium {
        margin-bottom: calc(var(--section-medium) * 0.8);
    }

    .section-my-small {
        margin-top: calc(var(--section-small) * 0.8);
        margin-bottom: calc(var(--section-small) * 0.8);
    }

    .section-mt-small {
        margin-top: calc(var(--section-small) * 0.8);
    }

    .section-mb-small {
        margin-bottom: calc(var(--section-small) * 0.8);
    }

    .section-my-xsmall {
        margin-top: calc(var(--section-xsmall) * 0.8);
        margin-bottom: calc(var(--section-xsmall) * 0.8);
    }

    .section-mt-xsmall {
        margin-top: calc(var(--section-xsmall) * 0.8);
    }

    .section-mb-xsmall {
        margin-bottom: calc(var(--section-xsmall) * 0.8);
    }
}

@media (max-width: 599px) {
    .section-my-xlarge {
        margin-top: calc(var(--section-xlarge) * 0.5);
        margin-bottom: calc(var(--section-xlarge) * 0.5);
    }

    .section-mt-xlarge {
        margin-top: calc(var(--section-xlarge) * 0.5);
    }

    .section-mb-xlarge {
        margin-bottom: calc(var(--section-xlarge) * 0.5);
    }

    .section-my-large {
        margin-top: calc(var(--section-large) * 0.5);
        margin-bottom: calc(var(--section-large) * 0.5);
    }

    .section-mt-large {
        margin-top: calc(var(--section-large) * 0.5);
    }

    .section-mb-large {
        margin-bottom: calc(var(--section-large) * 0.5);
    }

    .section-my-medium {
        margin-top: calc(var(--section-medium) * 0.5);
        margin-bottom: calc(var(--section-medium) * 0.5);
    }

    .section-mt-medium {
        margin-top: calc(var(--section-medium) * 0.5);
    }

    .section-mb-medium {
        margin-bottom: calc(var(--section-medium) * 0.5);
    }

    .section-my-small {
        margin-top: calc(var(--section-small) * 0.5);
        margin-bottom: calc(var(--section-small) * 0.5);
    }

    .section-mt-small {
        margin-top: calc(var(--section-small) * 0.5);
    }

    .section-mb-small {
        margin-bottom: calc(var(--section-small) * 0.5);
    }

    .section-my-xsmall {
        margin-top: calc(var(--section-xsmall) * 0.5);
        margin-bottom: calc(var(--section-xsmall) * 0.5);
    }

    .section-mt-xsmall {
        margin-top: calc(var(--section-xsmall) * 0.5);
    }

    .section-mb-xsmall {
        margin-bottom: calc(var(--section-xsmall) * 0.5);
    }
}

.section-py-xlarge {
    padding-top: var(--section-xlarge);
    padding-bottom: var(--section-xlarge);
}

.section-pt-xlarge {
    padding-top: var(--section-xlarge);
}

.section-pb-xlarge {
    padding-bottom: var(--section-xlarge);
}

.section-py-large {
    padding-top: var(--section-large);
    padding-bottom: var(--section-large);
}

.section-pt-large {
    padding-top: var(--section-large);
}

.section-pb-large {
    padding-bottom: var(--section-large);
}

.section-py-medium {
    padding-top: var(--section-medium);
    padding-bottom: var(--section-medium);
}

.section-pt-medium {
    padding-top: var(--section-medium);
}

.section-pb-medium {
    padding-bottom: var(--section-medium);
}

.section-py-small {
    padding-top: var(--section-small);
    padding-bottom: var(--section-small);
}

.section-pt-small {
    padding-top: var(--section-small);
}

.section-pb-small {
    padding-bottom: var(--section-small);
}

.section-py-xsmall {
    padding-top: var(--section-xsmall);
    padding-bottom: var(--section-xsmall);
}

.section-pt-xsmall {
    padding-top: var(--section-xsmall);
}

.section-pb-xsmall {
    padding-bottom: var(--section-xsmall);
}

@media (max-width: 1024px) {
    .section-py-xlarge {
        padding-top: calc(var(--section-xlarge) * 0.8);
        padding-bottom: calc(var(--section-xlarge) * 0.8);
    }

    .section-pt-xlarge {
        padding-top: calc(var(--section-xlarge) * 0.8);
    }

    .section-pb-xlarge {
        padding-bottom: calc(var(--section-xlarge) * 0.8);
    }

    .section-py-large {
        padding-top: calc(var(--section-large) * 0.8);
        padding-bottom: calc(var(--section-large) * 0.8);
    }

    .section-pt-large {
        padding-top: calc(var(--section-large) * 0.8);
    }

    .section-pb-large {
        padding-bottom: calc(var(--section-large) * 0.8);
    }

    .section-py-medium {
        padding-top: calc(var(--section-medium) * 0.8);
        padding-bottom: calc(var(--section-medium) * 0.8);
    }

    .section-pt-medium {
        padding-top: calc(var(--section-medium) * 0.8);
    }

    .section-pb-medium {
        padding-bottom: calc(var(--section-medium) * 0.8);
    }

    .section-py-small {
        padding-top: calc(var(--section-small) * 0.8);
        padding-bottom: calc(var(--section-small) * 0.8);
    }

    .section-pt-small {
        padding-top: calc(var(--section-small) * 0.8);
    }

    .section-pb-small {
        padding-bottom: calc(var(--section-small) * 0.8);
    }

    .section-py-xsmall {
        padding-top: calc(var(--section-xsmall) * 0.8);
        padding-bottom: calc(var(--section-xsmall) * 0.8);
    }

    .section-pt-xsmall {
        padding-top: calc(var(--section-xsmall) * 0.8);
    }

    .section-pb-xsmall {
        padding-bottom: calc(var(--section-xsmall) * 0.8);
    }
}

@media (max-width: 599px) {
    .section-py-xlarge {
        padding-top: calc(var(--section-xlarge) * 0.5);
        padding-bottom: calc(var(--section-xlarge) * 0.5);
    }

    .section-pt-xlarge {
        padding-top: calc(var(--section-xlarge) * 0.5);
    }

    .section-pb-xlarge {
        padding-bottom: calc(var(--section-xlarge) * 0.5);
    }

    .section-py-large {
        padding-top: calc(var(--section-large) * 0.5);
        padding-bottom: calc(var(--section-large) * 0.5);
    }

    .section-pt-large {
        padding-top: calc(var(--section-large) * 0.5);
    }

    .section-pb-large {
        padding-bottom: calc(var(--section-large) * 0.5);
    }

    .section-py-medium {
        padding-top: calc(var(--section-medium) * 0.5);
        padding-bottom: calc(var(--section-medium) * 0.5);
    }

    .section-pt-medium {
        padding-top: calc(var(--section-medium) * 0.5);
    }

    .section-pb-medium {
        padding-bottom: calc(var(--section-medium) * 0.5);
    }

    .section-py-small {
        padding-top: calc(var(--section-small) * 0.5);
        padding-bottom: calc(var(--section-small) * 0.5);
    }

    .section-pt-small {
        padding-top: calc(var(--section-small) * 0.5);
    }

    .section-pb-small {
        padding-bottom: calc(var(--section-small) * 0.5);
    }

    .section-py-xsmall {
        padding-top: calc(var(--section-xsmall) * 0.5);
        padding-bottom: calc(var(--section-xsmall) * 0.5);
    }

    .section-pt-xsmall {
        padding-top: calc(var(--section-xsmall) * 0.5);
    }

    .section-pb-xsmall {
        padding-bottom: calc(var(--section-xsmall) * 0.5);
    }
}

[class*="space-m"],
[class*="space-p"] {
    --space-xlarge: 100px;
    --space-large: 80px;
    --space-medium: 60px;
    --space-small: 40px;
    --space-xsmall: 20px;
}

.space-mt-small>*+* {
    margin-top: var(--space-small);
}

@media (max-width: 1024px) {
    .space-mt-xlarge>*+* {
        margin-top: calc(var(--space-xlarge) * 0.8);
    }

    .space-mt-large>*+* {
        margin-top: calc(var(--space-large) * 0.8);
    }

    .space-mt-medium>*+* {
        margin-top: calc(var(--space-medium) * 0.8);
    }

    .space-mt-small>*+* {
        margin-top: calc(var(--space-small) * 0.8);
    }

    .space-mt-xsmall>*+* {
        margin-top: calc(var(--space-xsmall) * 0.8);
    }

    .space-mt-none\@tb>*+* {
        margin-top: 0;
    }

    .space-mt-15\@tb>*+* {
        margin-top: 15px;
    }

    .space-mt-10\@tb>*+* {
        margin-top: 10px;
    }

    .space-mt-5\@tb>*+* {
        margin-top: 5px;
    }
}

@media (max-width: 599px) {
    .space-mt-xlarge>*+* {
        margin-top: calc(var(--space-xlarge) * 0.5);
    }

    .space-mt-large>*+* {
        margin-top: calc(var(--space-large) * 0.5);
    }

    .space-mt-medium>*+* {
        margin-top: calc(var(--space-medium) * 0.5);
    }

    .space-mt-small>*+* {
        margin-top: calc(var(--space-small) * 0.5);
    }

    .space-mt-xsmall>*+* {
        margin-top: calc(var(--space-xsmall) * 0.5);
    }

    .space-mt-none\@sp>*+* {
        margin-top: 0;
    }

    .space-mt-15\@sp>*+* {
        margin-top: 15px;
    }

    .space-mt-10\@sp>*+* {
        margin-top: 10px;
    }

    .space-mt-5\@sp>*+* {
        margin-top: 5px;
    }
}

@media (max-width: 1024px) {
    .space-pt-xlarge>*+* {
        padding-top: calc(var(--space-xlarge) * 0.8);
    }

    .space-pt-large>*+* {
        padding-top: calc(var(--space-large) * 0.8);
    }

    .space-pt-medium>*+* {
        padding-top: calc(var(--space-medium) * 0.8);
    }

    .space-pt-small>*+* {
        padding-top: calc(var(--space-small) * 0.8);
    }

    .space-pt-xsmall>*+* {
        padding-top: calc(var(--space-xsmall) * 0.8);
    }
}

@media (max-width: 599px) {
    .space-pt-xlarge>*+* {
        padding-top: calc(var(--space-xlarge) * 0.5);
    }

    .space-pt-large>*+* {
        padding-top: calc(var(--space-large) * 0.5);
    }

    .space-pt-medium>*+* {
        padding-top: calc(var(--space-medium) * 0.5);
    }

    .space-pt-small>*+* {
        padding-top: calc(var(--space-small) * 0.5);
    }

    .space-pt-xsmall>*+* {
        padding-top: calc(var(--space-xsmall) * 0.5);
    }
}

[class*="-ttl-"] {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-bottom: 65px;
    text-align: center;
}

.ttl-left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    text-align: left;
}

.ttl-right {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    text-align: right;
}

.ttl-center {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
}

@media (max-width: 1024px) {
    .ttl-left\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        text-align: left;
    }

    .ttl-right\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        text-align: right;
    }

    .ttl-center\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        text-align: center;
    }
}

@media (max-width: 599px) {
    .ttl-left\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        text-align: left;
    }

    .ttl-right\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        text-align: right;
    }

    .ttl-center\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        text-align: center;
    }

    [class*="-ttl-"] {
        margin-bottom: 30px;
    }
}

[class*="-btn-"] {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.btn-left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.btn-right {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.btn-center {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

@media (max-width: 1024px) {
    .btn-left\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .btn-right\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }

    .btn-center\@tb {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
}

@media (max-width: 599px) {
    .btn-left\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .btn-right\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }

    .btn-center\@sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
}

html {
    font-family: var(--font-00);
    font-size: 16px;
    color: var(--color-01);
}

.wrapper {
    overflow: hidden;
}

.list-inner {
    height: 100%;
}

.txt-font-00 {
    font-family: var(--font-00);
}

.txt-font-01 {
    font-family: var(--font-01);
}

.txt-font-02 {
    font-family: var(--txt-font-02);
}

.text-lh {
    line-height: 2;
}

.text-lead {
    line-height: 2;
    text-align: center;
}

.marker {
    font-weight: bold;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, var(--color-05)));
    background: linear-gradient(transparent 60%, var(--color-05) 60%);
}

.marker.-ver2 {
    color: black;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(128, 57, 57, 0.3)));
    background: linear-gradient(transparent 60%, rgba(128, 57, 57, 0.3) 60%);
}

.list-inner {
    width: 100%;
    height: 100%;
}

.fz-95 {
    font-size: 95%;
}

.radius20 {
    overflow: hidden;
    border-radius: 20px;
}

@media(max-width:599px) {

    .radius20 {
        border-radius: 15px;
    }
}

.radius10 {
    overflow: hidden;
    border-radius: 10px;
}

@media (max-width: 1024px) {
    .text-lh {
        line-height: 1.8;
    }

    .text-lead {
        line-height: 1.8;
    }



    .fz-95\@tb {
        font-size: 95%;
    }

}

@media (max-width: 599px) {
    .text-lead {
        text-align: left;
    }

    .fz-95\@sp {
        font-size: 95%;
    }
}

.box-white {
    padding: 50px;
    border-radius: 30px;
    background-color: white;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
}

.box-white.-large {
    padding: 50px;
}

@media (max-width: 1024px) {
    .box-white {
        padding: 30px 20px;
        border-radius: 20px;
    }

    .box-white.-large {
        padding: 30px 10px;
    }
}

[class*=icon] {
    display: inline-block;
    font-size: 1em;
    line-height: 1;
}

[class*=icon] img {
    width: 100%;
    height: auto;
}

[class*=icon].-large {
    font-size: 1.25em;
}

[class*=icon-fa]::before {
    line-height: 1;
}

[class*=icon-fa-brands]::before {
    font-family: "Font Awesome 5 Brands";
}

[class*=icon-fa-free]::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}

.card-01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 1em;
    margin-left: 1em;
    margin-right: 1em;
    padding: 1em;
    border-radius: 1em;
    background-color: var(--color-02);
    position: relative;
}

.card-01 .num {
    width: 2em;
    height: 2em;
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 2em;
    font-weight: bold;
    color: white;
    line-height: 1;
    text-align: center;
    border-radius: 100%;
    background-color: var(--color-03);
    -webkit-transform: translate(-25%, -25%);
    transform: translate(-25%, -25%);
    position: absolute;
    top: 0;
    padding-bottom: .1em;
    left: 0;
    z-index: 1;
}

.card-01 .card-img {
    width: 25%;
}

.card-01 .card-content {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-left: 1em;
}

@media (max-width: 1024px) {
    .card-01 .card-img {
        width: 35%;
    }
}

@media (max-width: 599px) {
    .card-01 .card-img {
        width: 100%;
    }

    .card-01 .card-content {
        width: 100%;
        margin-top: 0.5em;
        margin-left: 0;
    }
}

.txt-color-00,
.hovertxt-color-00:hover {
    color: var(--color-00);
}

.txt-color-01,
.hovertxt-color-01:hover {
    color: var(--color-01);
}

.txt-color-02,
.hovertxt-color-02:hover {
    color: var(--color-02);
}

.txt-color-03,
.hovertxt-color-03:hover {
    color: var(--color-03);
}

.txt-color-04,
.hovertxt-color-04:hover {
    color: var(--color-04);
}

.txt-color-05,
.hovertxt-color-05:hover {
    color: var(--color-05);
}

.txt-color-06,
.hovertxt-color-06:hover {
    color: var(--color-06);
}

.txt-color-07,
.hovertxt-color-07:hover {
    color: var(--color-07);
}

.txt-color-08,
.hovertxt-color-08:hover {
    color: var(--txt-color-08);
}

.txt-color-09,
.hovertxt-color-09:hover {
    color: var(--txt-color-09);
}

.txt-color-10,
.hovertxt-color-10:hover {
    color: var(--txt-color-10);
}

.back-color-00 {
    background: var(--color-00);
}

.back-color-01 {
    background: var(--color-01);
}

.back-color-02 {
    background: var(--color-02);
}

.back-color-03 {
    background: var(--color-03);
}

.back-color-04 {
    background: var(--color-04);
}

.back-color-05 {
    background: var(--color-05);
}

.back-color-06 {
    background: var(--color-06);
}

.back-color-07 {
    background: var(--color-07);
}

.back-color-08 {
    background: var(--back-color-08);
}

.back-color-09 {
    background: var(--back-color-09);
}

.back-color-10 {
    background: var(--back-color-10);
}

.ttl-color-00 {
    color: var(--color-00);
}

.ttl-color-01 {
    color: var(--color-01);
}

.ttl-color-02 {
    color: var(--color-02);
}

.ttl-color-03 {
    color: var(--color-03);
}

.ttl-color-04 {
    color: var(--color-04);
}

.ttl-color-05 {
    color: var(--color-05);
}

.ttl-color-06 {
    color: var(--color-06);
}

.ttl-color-07 {
    color: var(--color-07);
}

.ttl-color-08 {
    color: var(--color-08);
}

.ttl-color-09 {
    color: var(--color-09);
}

.ttl-color-10 {
    color: var(--ttl-color-10);
}

.btn-color-00 .btn-inner>* {
    background: var(--color-00);
}

.btn-color-01 .btn-inner>* {
    background: var(--color-01);
}

.btn-color-02 .btn-inner>* {
    background: var(--color-02);
}

.btn-color-03 .btn-inner>* {
    background: var(--color-03);
}

.btn-color-04 .btn-inner>* {
    background: var(--color-04);
}

.btn-color-05 .btn-inner>* {
    background: var(--color-05);
}

.btn-color-06 .btn-inner>* {
    background: var(--color-06);
}

.btn-color-07 .btn-inner>* {
    background: var(--color-07);
}

.btn-color-08 .btn-inner>* {
    background: var(--color-08);
}

.btn-color-09 .btn-inner>* {
    background: var(--color-09);
}

.btn-color-10 .btn-inner>* {
    background: var(--btn-color-10);
}

.hoverbtn-color-00 .btn-inner>*:after {
    background: -webkit-gradient(linear, left top, right top, from(var(--color-00)), color-stop(var(--color-00)), to(transparent));
    background: linear-gradient(90deg, var(--color-00), var(--color-00), transparent);
}

.hoverbtn-color-01 .btn-inner>*:after {
    background: -webkit-gradient(linear, left top, right top, from(var(--color-01)), color-stop(var(--color-01)), to(transparent));
    background: linear-gradient(90deg, var(--color-01), var(--color-01), transparent);
}

.btn-color-02 .btn-inner>* {
    background: var(--color-02);
}

.btn-color-03 .btn-inner>* {
    background: var(--color-03);
}

.btn-color-04 .btn-inner>* {
    background: var(--color-04);
}

.btn-color-05 .btn-inner>* {
    background: var(--color-05);
}

.btn-color-06 .btn-inner>* {
    background: var(--color-06);
}

.btn-color-07 .btn-inner>* {
    background: var(--color-07);
}

.btn-color-08 .btn-inner>* {
    background: var(--color-08);
}

.btn-color-09 .btn-inner>* {
    background: var(--color-09);
}

.btn-color-10 .btn-inner>* {
    background: var(--btn-color-10);
}

.ele-cate-01 .box {
    padding: 20px;
    border-radius: 20px;
}

.ele-cate-01 .tit {
    margin-bottom: 1em;
    font-weight: bold;


    font-size: clamp(1.25rem, 1.193rem + 0.24vw, 1.375rem);
    letter-spacing: 0.1em;
}

.ele-ttl-01 {
    font-size: 45px;
    line-height: 1;
}

.ele-ttl-01 .ttl-main {
    letter-spacing: 6px;
    font-weight: 500;
}

.ele-ttl-01 .ttl-sub {
    margin-top: 20px;
    font-weight: 500;
    font-size: 25%;
    letter-spacing: 3px;
}

.ele-ttl-01 .ttl-sub .em {
    font-size: 120%;
}

@media (max-width: 1024px) {
    .ele-ttl-01 {
        font-size: 50px;
    }
}

@media (max-width: 599px) {
    .ele-ttl-01 {
        font-size: 40px;
    }

    .ele-ttl-01 .ttl-sub {
        margin-top: 10px;
        font-size: 16px;
    }
}

.ele-ttl-02 .border {
    width: 100%;
    border-bottom: 4px solid;
    position: absolute;
    bottom: 0;
    left: 0;
}

.ele-ttl-02 .ttl-main {
    padding-bottom: 10px;
    font-size: 26px;
    letter-spacing: 2px;
}

@media (max-width: 599px) {
    .ele-ttl-02 .ttl-main {
        font-size: 20px;
    }
}

.ele-ttl-03 .ttl-main {
    font-size: 30px;
    letter-spacing: 3px;
    position: relative;
    z-index: 0;
}

.ele-ttl-03 .ttl-main .border {
    width: 50px;
    margin: 15px auto 0px;
    border-bottom: 3px solid;
}

[class*=title].-mb-exlarge {
    margin-bottom: 1.5em;
}

.title-01 {
    font-weight: bold;

    font-size: clamp(1.25rem, 1.136rem + 0.48vw, 1.5rem);
    color: var(--color-03);
}

.title-01.-ver2 {
    color: var(--color-06);
}

.title-02 {
    margin: 1em 0;
    font-weight: bold;


    font-size: clamp(2rem, 1.659rem + 1.45vw, 2.75rem);
    color: var(--color-03);
}

.title-03 {
    padding-left: 0.5em;
    font-weight: bold;


    font-size: 26px;
    color: var(--color-03);
    position: relative;
}

.title-inner {
    position: relative;
    z-index: 1;
}

.title-03::before {
    content: "";
    width: 2em;
    height: 2em;
    display: block;
    border-radius: 100%;
    background-color: var(--color-05);

    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.title-03.-center {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

.title-04 {
    margin-bottom: 3em;
    font-size: clamp(1.05rem, 0.73rem + 1.36vw, 1.75rem);
    line-height: 1;
    position: relative;
}

.title-04 .main {
    font-weight: bold;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1;
}

.title-04 .sub {
    margin: auto;
    font-weight: bold;
    font-size: 380%;
    color: var(--color-04);
}

[class*="title"] .num {
    width: 2.2em;
    height: 2.2em;
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: white;
    line-height: 1;
    text-align: center;
    border-radius: 100%;
    background-color: var(--color-03);
    position: absolute;
    top: -5px;
    left: 0;
    font-size: 90%;
    padding-bottom: 2px;
}

[class*="ttl-mb-"] {
    --ttl-mb-xlarge: 80px;
    --ttl-mb-large: 60px;
    --ttl-mb-medium: 40px;
    --ttl-mb-small: 20px;
    --ttl-mb-xsmall: 10px;
}

.ttl-mb-xlarge {
    margin-bottom: var(--ttl-mb-xlarge);
}

.ttl-mb-large {
    margin-bottom: var(--ttl-mb-large);
}

.ttl-mb-medium {
    margin-bottom: var(--ttl-mb-medium);
}

.ttl-my-medium {
    margin-bottom: 40px;
    margin-top: 40px;
}

.ttl-mb-small {
    margin-bottom: var(--ttl-mb-small);
}

.ttl-mb-xsmall {
    margin-bottom: var(--ttl-mb-xsmall);
}

.ttl-mb-none {
    margin-bottom: 0;
}

@media (max-width: 1024px) {
    .ttl-mb-xlarge {
        margin-bottom: calc(var(--ttl-mb-xlarge) * 0.8);
    }

    .ttl-mb-large {
        margin-bottom: calc(var(--ttl-mb-large) * 0.8);
    }

    .ttl-mb-medium {
        margin-bottom: calc(var(--ttl-mb-medium) * 0.8);
    }

    .ttl-my-medium {
        margin-bottom: 32px;
        margin-top: 32px;
    }

    .ttl-mb-small {
        margin-bottom: calc(var(--ttl-mb-small) * 0.8);
    }

    .ttl-mb-xsmall {
        margin-bottom: calc(var(--ttl-mb-xsmall) * 0.8);
    }
}

@media (max-width: 599px) {
    .ttl-mb-xlarge {
        margin-bottom: calc(var(--ttl-mb-xlarge) * 0.5);
    }

    .ttl-mb-large {
        margin-bottom: calc(var(--ttl-mb-large) * 0.5);
    }

    .ttl-mb-medium {
        margin-bottom: calc(var(--ttl-mb-medium) * 0.5);
    }

    .ttl-my-medium {
        margin-bottom: 24px;
        margin-top: 0;
    }

    .ttl-mb-small {
        margin-bottom: calc(var(--ttl-mb-small) * 0.5);
    }

    .ttl-mb-xsmall {
        margin-bottom: calc(var(--ttl-mb-xsmall) * 0.5);
    }
}

.ele-btn-01 .btn-inner>* {
    width: 272px;
    display: block;
    overflow: hidden;
    padding: 20px 30px;
    font-size: 14px;
    letter-spacing: 4px;
    text-align: center;
    border-radius: 10px;
    position: relative;
    z-index: 0;
    background-color: rgba(255, 255, 255, 0.5);
}

.ele-btn-01 .btn-inner>* .border {
    width: 100%;
    height: 100%;
    border: 1px solid;
    border-radius: 10px;
    position: absolute;
    top: 0;
    left: 0;
}

.ele-btn-01 .btn-inner>*:after {
    content: "";
    width: 200%;
    height: 110%;
    -webkit-transition: -webkit-transform 450ms;
    transition: -webkit-transform 450ms;
    transition: transform 450ms;
    transition: transform 450ms, -webkit-transform 450ms;
    -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    position: absolute;
    top: 0;
    left: 0;
}

.ele-btn-01 .btn-inner>*:hover:after {
    -webkit-transform: translate3d(0%, 0, 0);
    transform: translate3d(0%, 0, 0);
    ;
}

.ele-btn-01.pattern-01 .btn-inner>* {
    padding: 15px 30px;
    font-size: 20px;
}

.ele-btn-01 .btn-inner>*:before {
    content: "→";
    font-family: var(--font-00);
    font-weight: bold;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 20px;
    z-index: 1;
}

.ele-btn-01.-btn-arrow-left .btn-inner>*:before {
    content: "←";
    left: 20px;
    right: auto;
}

.ele-btn-01 .btn-inner .btntxt {
    position: relative;
    z-index: 1;
}

.ele-btn-01.-arrow-none .btn-inner>*:before {
    display: none;
}

.ele-btn-01 i {
    margin-right: 10px;
    font-size: 24px;
}

.ele-btn-01.sns-btn-01 a {
    border: 1px solid var(--color-06);
}

@media(max-width:1024px) {
    .ele-btn-01 .btn-inner>* {
        width: 240px;
        padding: 16px 30px;
        letter-spacing: 3px;
        max-width: 100%;
    }
}

.ele-btn-02 .btn-inner {
    width: 272px;
    display: block;
    overflow: hidden;
    font-size: 14px;
    color: var(--color-00);
    letter-spacing: 4px;
    text-align: center;
    border: 1px solid var(--color-03);
    border-radius: 10px;
    position: relative;
    z-index: 0;
}

.ele-btn-02 .btn-inner>* {
    width: 100%;
    height: 100%;
    display: block;
    padding: 20px 30px;
    background: var(--color-03);
    position: relative;
    z-index: 1;
    border: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.ele-btn-02 .btn-inner:after {
    content: "";
    width: 200%;
    height: 110%;
    -webkit-transition: -webkit-transform 450ms;
    transition: -webkit-transform 450ms;
    transition: transform 450ms;
    transition: transform 450ms, -webkit-transform 450ms;
    -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    position: absolute;
    top: 0;
    left: 0;
}

.ele-btn-02 .btn-inner:hover:after {
    -webkit-transform: translate3d(0%, 0, 0);
    transform: translate3d(0%, 0, 0);
}

.btn-huge {
    width: 500px;
    max-width: 90%;
    margin-top: 3em;
    margin-left: auto;
    margin-right: auto;
}

.btn-huge a {
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 1em;


    font-size: clamp(1.25rem, 1.193rem + 0.24vw, 1.375rem);
    color: white;
    text-align: center;
    border: 2px solid var(--color-03);
    border-radius: 1em;
    background-color: var(--color-03);
}

.btn-huge a:hover {
    color: var(--color-03);
    background-color: white;
    opacity: 1;
}

.btn-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.btn-wrap>[class*="btn"] {
    max-width: calc(50% - 1em);
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin: 0 0.5em;
    margin-top: 0;
}

.btn-wrap [class*="btn"] .btn-inner {
    max-width: 100%;
}

[class*="btn-mt-"] {
    --btn-mt-xlarge: 80px;
    --btn-mt-large: 60px;
    --btn-mt-medium: 40px;
    --btn-mt-small: 20px;
    --btn-mt-xsmall: 10px;
}

.btn-mt-xlarge {
    margin-top: var(--btn-mt-xlarge);
}

.btn-mt-large {
    margin-top: var(--btn-mt-large);
}

.btn-mt-medium {
    margin-top: var(--btn-mt-medium);
}

.btn-mt-small {
    margin-top: var(--btn-mt-small);
}

.btn-mt-xsmall {
    margin-top: var(--btn-mt-xsmall);
}

.btn-mt-none {
    margin-top: 0;
}

@media (max-width: 1024px) {
    .btn-mt-xlarge {
        margin-top: calc(var(--btn-mt-xlarge) * 0.8);
    }

    .btn-mt-large {
        margin-top: calc(var(--btn-mt-large) * 0.8);
    }

    .btn-mt-medium {
        margin-top: calc(var(--btn-mt-medium) * 0.8);
    }

    .btn-mt-small {
        margin-top: calc(var(--btn-mt-small) * 0.8);
    }

    .btn-mt-xsmall {
        margin-top: calc(var(--btn-mt-xsmall) * 0.8);
    }
}

@media (max-width: 599px) {
    .btn-mt-xlarge {
        margin-top: calc(var(--btn-mt-xlarge) * 0.5);
    }

    .btn-mt-large {
        margin-top: calc(var(--btn-mt-large) * 0.5);
    }

    .btn-mt-medium {
        margin-top: calc(var(--btn-mt-medium) * 0.5);
    }

    .btn-mt-small {
        margin-top: calc(var(--btn-mt-small) * 0.5);
    }

    .btn-mt-xsmall {
        margin-top: calc(var(--btn-mt-xsmall) * 0.5);
    }
}

.ele-h1-01 {
    padding: 5px;
    font-size: 12px;
}

@media(max-width:1024px) {
    .ele-h1-01 {
        color: #000;
    }
}

.header {
    width: 100%;
    padding: 10px 30px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 30;
    background-color: rgba(255, 255, 255, 0.6);
    -webkit-box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
}

.header-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.header-left {
    width: 300px;
}

.logo {
    width: 100%;
}

.header-right {
    width: 330px;
    white-space: nowrap;
}

.header-tel {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.header-tel-01 {
    font-size: 14px;
    font-weight: bold;
    color: #fff;
    padding: 3px 15px;
    background-color: var(--color-03);
    border-radius: 15px;
}

.header-tel-02 {
    font-size: 18px;
    font-weight: bold;
    color: var(--color-03);
}

.header-tel-03 {
    width: 100%;

}

.header-tel-03 a {
    width: 100%;
    display: block;
    font-size: 45px;
    letter-spacing: -.05em;
    font-weight: bold;
    position: relative;
    padding-left: 50px;
    line-height: 1em;
}

.freedial-icon {
    width: 45px;
    height: 45px;
    background-image: url(../images/regist_new/freedial.webp);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-40%);
    transform: translateY(-40%);
    -webkit-filter: var(--filter-for-03);
    filter: var(--filter-for-03);
}

#footer {
    position: relative;
    z-index: 2;
}

footer .logo a img {
    -webkit-filter: brightness(1) invert(0);
    filter: brightness(1) invert(0);
}

.ele-footer-01 {
    border-radius: 10vw 0 0 0;
    position: relative;
    z-index: 0;
}

.ele-footer-01 .infobox .tel>a {
    padding-left: 50px;
    font-size: 32px;
    letter-spacing: 2px;
    position: relative;
    z-index: 0;
}

.ele-footer-01 .infobox .tel>a:before {
    content: "";
    width: 40px;
    height: 40px;
    display: inline-block;
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0.1em;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 75%;
    color: white;
    line-height: 1;
    border-radius: 100%;
    background-color: var(--color-03);
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 16px;
    letter-spacing: 0;
}

.ele-fnav-01 .tit {
    margin-bottom: 20px;
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 3px;
}

.ele-fnav-01 .tit .border {
    margin-top: 20px;
    border-bottom: 2px solid;
}

@media (max-width: 1024px) {

    footer .infobox {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    footer .infobox .box {
        margin-left: 3em;
    }

    footer .infobox .ele-btn-01 {
        width: 100%;
    }

    .ele-fnav-01 .tit {
        letter-spacing: 3px;
    }
}

@media (max-width: 599px) {
    .ele-footer-01 {
        padding-left: 1em;
        padding-right: 1em;
    }

    footer .infobox .box {
        margin-left: 0;
    }

    .ele-copy-01 {
        padding-bottom: 7em;
    }
}

.ele-return-01 {
    width: 200px;
    opacity: 0;
    -webkit-transition: opacity 0.3s linear;
    transition: opacity 0.3s linear;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -10;
    border-radius: 0.5em;
}

.ele-return-01 a {
    width: 100%;
    padding: 10px 0;
    font-size: 14px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;

}

.ele-return-01 a::before {
    content: "";
    font-family: "Font Awesome 6 Free";
    font-weight: 600;
    font-size: 22px;
    margin-right: 5px;
}

.ele-return-01 a:hover {
    cursor: pointer;
}

.scrolled .ele-return-01 {
    opacity: 1;
    z-index: 10;
}

.fix-content {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    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: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding-right: 4em;
    position: fixed;
    bottom: 2em;
    right: 1em;
    z-index: 10;
}

.fix-box .phone .square-inner .tel {
    margin: 0.25em 0;
    font-size: 180%;
}

.btn-contact a {
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 1em;


    font-size: clamp(0.875rem, 0.761rem + 0.48vw, 1.125rem);
    color: var(--color-03);
    text-align: center;
    border-radius: 100%;
    background-color: white;
    position: relative;
}

.btn-contact a::before {
    content: "";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 200%;
    line-height: 1;
}

.fix-content .btn-contact {
    display: none;
}

.fix-box .btn-contact a {
    height: 100%;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
}

.fix-content>div:nth-child(2) {
    display: none;
}

@media (max-width: 1024px) {
    .fix-content {
        bottom: 1em;
    }



    .fix-box .phone .square-inner {
        margin: 5px;
        font-size: 10px;
    }

    .fix-content .btn-contact {
        display: block;
    }
}

@media (max-width: 599px) {
    .fix-content {
        width: 220px;
        padding: 0;
    }

    .fix-content>div:nth-child(2) {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        background-color: #fff;
        padding: 10px;
        width: 100%;
        border-radius: 20px;
        -webkit-box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
        box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
        position: relative;
        z-index: 90;

    }

    .fix-box .phone .square-inner .tel {
        font-size: 130%;
    }

    .fix-box .phone .square-inner .text {
        -webkit-transform: scale(0.8);
        transform: scale(0.8);
    }

    .fix-content .header-tel-01 {
        display: none;
    }

    .fix-content .header-tel-02 {
        font-size: 12px;
    }

    .fix-content .header-tel-03 a {
        font-size: 20px;
        letter-spacing: 0;
    }

    .fix-content .freedial-icon {
        height: 18px;
    }

    .fix-content>div:nth-child(2) {
        padding: 5px 10px;
        border-radius: 5px;
    }

    .fix-content .ele-return-01 {
        width: 220px;
        bottom: 55px;
    }

    .fix-content .ele-return-01 a {
        padding: 0;
    }
}

.ele-mainimg-01 {
    position: relative;
}

.ele-mainimg-01 .pic {
    overflow: hidden;
    position: relative;
    overflow: hidden;
    border-radius: 0 0 10vw 0;
    opacity: 0.5
}

.ele-mainimg-01 .pic:after {
    content: "";
    display: block;
    padding-top: 870px;
}

.ele-mainimg-01 .ken-box {
    width: 100%;
    height: 100% !important;
    padding-top: 150px;
    position: absolute;
    top: 0;
    z-index: 1;
    overflow: hidden;
    opacity: 1;
}

.ken-box>ul {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.ken-box>ul li {
    width: 25%;
    height: 50%;
}

.ken-box>ul li img {
    width: 100%;
    height: 100%;
    -o-object-position: center;
    object-position: center;
    -o-object-fit: cover;
    object-fit: cover;
}

.ele-mainimg-01 .catch-main {
    font-size: clamp(20px, 3vw, 34px);
    letter-spacing: 0px;
    text-shadow: 2px 2px 0 var(--color-03), -2px -2px 0 var(--color-03), -2px 2px 0 var(--color-03), 2px -2px 0 var(--color-03), 0px 2px 0 var(--color-03), 0 -2px 0 var(--color-03), -2px 0 0 var(--color-03), 2px 0 0 var(--color-03);
    font-weight: bold;
    -webkit-filter: drop-shadow(5px 4px 0 var(--color-03));
    filter: drop-shadow(5px 4px 0 var(--color-03));
    line-height: 1.2em;
}

.ele-mainimg-01 .catch-sub {
    font-size: 30px;
    line-height: 1.2;
    color: var(--color-00);

    font-weight: bold;
    margin-right: .1em;
    letter-spacing: .1em;
}

.ele-mainimg-01 .catch-sub .big01 {
    font-size: 1.5em;
    color: var(--color-06);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(50%, rgb(255, 238, 0)));
    background: linear-gradient(transparent 60%, rgb(255, 238, 0) 50%);
    text-shadow: 1px 1px 0 #FFF,
        -1px -1px 0 #FFF,
        -1px 1px 0 #FFF,
        1px -1px 0 #FFF,
        0px 1px 0 #FFF,
        0 -1px 0 #FFF,
        -1px 0 0 #FFF,
        1px 0 0 #FFF;
}

.mini-form {
    width: 100%;
    background-color: #fff;
    padding: 10px;
    border-radius: 30px;
    z-index: 2;
    border: 3px solid var(--color-03);
    -webkit-box-shadow: 5px 5px 0 var(--color-03);
    box-shadow: 5px 5px 0 var(--color-03);
}

.block-text {
    width: 100%;
    margin-bottom: 20px;
}

.block-text ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.block-text ul li {
    display: block;
    width: 10%;
    background-color: #fff;
    border-radius: 10px;
    position: relative;
    border: 3px solid var(--color-03);
    -webkit-box-shadow: 5px 5px 0 var(--color-03);
    box-shadow: 5px 5px 0 var(--color-03);
}

.block-text ul li.y {
    background-color: rgb(255, 238, 0);
}

.block-text ul li::after {
    content: "";
    display: block;
    position: relative;
    width: 100%;
    padding-top: 100%;
}

.block-text ul li span {
    position: absolute;
    top: 46%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    color: var(--color-03);
    font-size: clamp(30px, 5.5vw, 77px);
    font-weight: bold;
    line-height: 1;
}

@media(max-width:1024px) {
    .ele-mainimg-01 .pic::after {
        padding-top: 600px;
    }

    .block-text {
        width: 100%;
        margin-bottom: 20px;
    }

    .block-text ul li {
        width: 11%;
    }

    .ele-mainimg-01 .catch {
        width: 96%;
        text-align: center;
        padding: 10px;
    }

    .ele-mainimg-01 .catch-sub {
        font-size: 24px;
    }


    .ball-count {
        max-width: 410px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media(max-width:599px) {
    .ele-mainimg-01 .pic::after {
        padding-top: 470px;
    }

    .ele-mainimg-01 .ken-box {
        padding-top: 120px;
    }

    .ele-mainimg-01 .catch {
        top: 60%;
    }

    .block-text ul li {
        border-radius: 5px;
        border: 2px solid var(--color-03);
        -webkit-box-shadow: 2px 2px 0 var(--color-03);
        box-shadow: 2px 2px 0 var(--color-03);
    }

    .ball-count ul li div span {
        font-size: 20px;
        margin-top: 2px;
    }

    .ken-box>ul li {
        width: 50%;
        height: 25%;
    }

    .ball-count ul li div {
        font-size: 14px;
    }

}

.ele-lowerimg-01 .pic {
    width: 100%;
    display: block;
    position: relative;
}

.ele-lowerimg-01 .pic img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    border-radius: 0 0 0 210px;
    -webkit-filter: brightness(0.8);
    filter: brightness(0.8);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.ele-lowerimg-01 .pic:after {
    content: "";
    display: block;
    padding-top: 25%;
}

.ele-lowerimg-01 .catch {
    font-size: 70px;
    line-height: 1;
    position: absolute;
    bottom: 8%;
    right: calc(50% - 500px);
    z-index: 1;
}

.ele-lowerimg-01 .catch .catch-main {
    margin-top: 20px;
    font-weight: 500;
    font-size: 25%;
    letter-spacing: 3px;
}

.ele-lowerimg-01 .catch .catch-sub {
    letter-spacing: 6px;
}

@media (max-width: 1024px) {
    .ele-lowerimg-01 .catch {
        font-size: 50px;
        right: 2%;
    }
}

@media (max-width: 599px) {
    .ele-lowerimg-01 .pic:after {
        padding-top: 60%;
    }

    .ele-lowerimg-01 .pic img {
        border-radius: 0 0 0 50px;
    }

    .ele-lowerimg-01 .catch {
        font-size: 36px;
    }

    .ele-lowerimg-01 .catch .catch-main {
        margin-top: 10px;
    }
}

@media (max-width: 599px) {
    .ele-pankuzu-01.breadcrumbs li {
        font-size: 13px;
    }
}

.ele-reason-01 .txt {
    line-height: 2;
}

.ele-reason-01 .slick-arrow.btn-back {
    right: 60px;
}

.ele-reason-01 .slick-arrow.btn-back:after {
    content: "←";
    font-family: var(--font-00);
    font-weight: bold;
}

.ele-reason-01 .slick-arrow.btn-next:after {
    content: "→";
    font-family: var(--font-00);
    font-weight: bold;
}

.ele-reason-01 .pic img {
    border-radius: 30px;
}

@media(max-width:599px) {
    .ele-reason-01 .pic img {
        border-radius: 20px;
    }

    .ele-reason-01 .slick-dots li {
        height: 6px;
    }
}

.ele-message-01 .pic [class*="up-ofi"] img {
    border-radius: 0 100px 0 0;
}

.ele-message-01.pattern-01 .pic [class*="up-ofi"] img {
    border-radius: 100px 0 0 0;
}

@media(max-width:599px) {
    .ele-message-01 .pic [class*="up-ofi"] img {
        border-radius: 0 50px 0 0;
    }

    .ele-message-01.pattern-01 .pic [class*="up-ofi"] img {
        border-radius: 50px 0 0 0;
    }
}

.ele-trouble-01 li>* {
    padding: 20px;
    border-radius: 30px;
    height: 100%;
}

.ele-trouble-01 li img {
    border-radius: 10px;
}

.ele-trouble-01 li .txt {
    font-size: 18px;
    line-height: 2;
}

@media(max-width:1024px) {
    .ele-trouble-01 li>* {
        padding: 20px 10px;
        border-radius: 20px;
    }
}

@media(max-width:599px) {
    .ele-trouble-01 li .txt {
        font-size: 14px;
    }
}

.ele-service-01 .back {
    width: 200%;
    height: 100%;
    border-radius: 10vw 0 0 0;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.ele-service-01 li .tit {

    font-size: clamp(1.125rem, 0.898rem + 0.97vw, 1.5rem);
    letter-spacing: 2px;
}

@media (max-width: 1024px) {
    .ele-service-01 .deco {
        left: 10vw;
    }

    .ele-service-01 li>*>* {
        padding: 20px;
    }
}

@media(max-width:599px) {
    .ele-service-01 li>*>* {
        padding: 15px;
        border-radius: 15px;
    }
}

.ele-works-02 li {
    margin: 0 10px;
}

.ele-works-01 li .box {
    border-radius: 30px;
}

.ele-works-01 li .box>* {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: start;
    align-items: flex-start;
    -ms-flex-align: start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 30px;
}

.ele-works-01 li .txtbox {
    margin: 0 auto;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    -webkit-text-orientation: upright;
    text-orientation: upright;
}

.ele-works-01 li .tit {
    font-size: 18px;
}

.slick-dots-01 .slick-dots {
    width: 100%;
    max-width: 600px;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    position: absolute;
    top: -50px;
    right: calc(50% - 500px);
}

.slick-dots-01 .slick-dots li {
    height: 10px;
    display: inline-block;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin: 0;
    font-size: 0;
    background: var(--color-00);
}

.slick-dots-01 .slick-dots li.slick-active {
    background: var(--color-03);
}

.slick-dots-01 .slick-dots li+li {
    margin-left: 10px;
}

.ele-works-02 .box {
    height: 100%;
    padding: 20px;
    border-radius: 20px;
}

.ele-works-02 li .cate {
    line-height: 1;
}

.ele-works-02 li .cate .tag01 {
    min-width: 75px;
    display: inline-block;
    margin: 1px;
    padding: 0.25em .3em .4em .3em;
    font-size: 14px;
    line-height: 1;
    text-align: center;
    border: 2px solid var(--color-03);
    color: var(--color-03);
    border-radius: 0.25em;
    font-weight: bold;
}

.ele-works-02 li .cate .tag02 {
    min-width: 75px;
    display: inline-block;
    margin: 1px;
    padding: 0.25em .3em .4em .3em;
    font-size: 14px;
    line-height: 1;
    text-align: center;
    border: 2px solid var(--color-03);
    color: #fff;
    background-color: var(--color-03);
    border-radius: 0.25em;
    font-weight: bold;
}

.ele-works-02 li .day {
    font-size: 14px;
}

@media (max-width: 1024px) {
    .slick-dots-01 .slick-dots {
        max-width: 360px;
        right: 1em;
    }
}

@media (max-width: 599px) {
    .slick-dots-01 .slick-dots {
        max-width: calc(100% - 2em);
    }
}

.ele-blog-01 .box {
    height: 100%;
    padding: 10px 30px 50px;
    border-radius: 30px;
}

.ele-blog-01 .ttl {
    margin-top: -50px;
}

.ele-blog-01 li .tit {
    width: calc(100% - 100px);
    font-size: 14px;
}

.ele-blog-02 li .box {
    padding: 30px;
    border-radius: 20px;
}

.ele-blog-02 li .cate {
    line-height: 1;
}

.ele-blog-02 li .cate>* {
    min-width: 100px;
    display: inline-block;
    margin: 1px;
    font-weight: bold;
    padding: 3px 10px;
    font-size: 12px;
    line-height: 1;
    text-align: center;
    border: 1px solid;
    border-radius: 0.25em;
}

@media(max-width:599px) {
    .ele-blog-01 .box {
        border-radius: 20px;
    }
}

.ele-faq-01 .box {
    padding: 23px 25px 23px;
}

.ele-faq-01 .box>* {
    padding-left: 55px;
    position: relative;
    z-index: 0;
}

.ele-faq-01 .box .faq-q {
    padding-right: 25px;
}

.ele-faq-01 .box .mark {
    width: 55px;
    padding-right: 5px;
    font-size: 30px;
    line-height: 1;
    letter-spacing: 5px;
    position: absolute;
    top: -4px;
    left: 0;
}

.ele-faq-01 .box .txt {
    font-size: 18px;
}

.ele-faq-01 .box .faq-q .icon {
    width: 20px;
    font-weight: 800;
    font-size: 30px;
    text-align: center;
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    line-height: 1;
    font-size: 16px;

}

.ele-faq-01 .box .faq-q .icon:after {
    content: "";
    font-family: "font awesome 5 free";
    font-weight: bold;
}

.ele-faq-01 .box .faq-q.is-parent .icon:after {
    content: "";
    font-family: "font awesome 5 free";
    font-weight: bold;
}

.ele-faq-01 .box .faq-a {
    margin-top: 30px;
}

.ele-faq-02 .box>* {
    padding-left: 55px;
    position: relative;
    z-index: 0;
}

.ele-faq-02 .box .faq-q {
    padding-right: 25px;
}

.ele-faq-02 .box .mark {
    width: 55px;
    padding-right: 5px;
    font-size: 30px;
    line-height: 1;
    letter-spacing: 5px;
    position: absolute;
    top: -4px;
    left: 0;
}

.ele-faq-02 .box .txt {
    font-size: 18px;
}

.ele-faq-02 .box .faq-q .icon {
    width: 20px;
    font-weight: 800;
    font-size: 30px;
    text-align: center;
    position: absolute;
    top: -10px;
    right: 0;
}

.ele-faq-02 .box .faq-q .icon:after {
    content: "+";
}

.ele-faq-02 .box .faq-q.is-parent .icon:after {
    content: "-";
}

.ele-faq-02 .box .faq-a {
    margin-top: 30px;
}

@media (max-width: 599px) {
    .ele-faq-02 .box>* {
        padding-left: 45px;
    }

    .ele-faq-02 .box .mark {
        width: 45px;
        font-size: 26px;
        top: -1px;
    }

    .ele-faq-02 .box .txt {
        font-size: 16px;
    }
}

.ele-faq-03 .box {
    padding: 40px 50px;
    border-radius: 30px;
}

@media (max-width: 599px) {
    .ele-faq-03 .box {
        padding: 30px 20px;
    }

    .list-rec>* dt {
        width: 100%;
        margin-bottom: 5px;
    }

    .list-rec>* dd {
        width: 100%;
    }
}

.ele-contact-01 {
    position: relative;
    z-index: 0;
}

.ele-contact-01 .back {
    width: 100%;
    height: 150%;
    position: absolute;
    top: 0;
    left: 0;
}

.mk2.ele-contact-01 .back {
    width: 100%;
    height: 100%;
}

.ele-contact-01 .back img {
    opacity: 0.3;
}

.ele-contact-02 .tel {
    line-height: 1;
}

.ele-contact-02 .tel>* {
    padding-left: 50px;
    font-size: 44px;
    letter-spacing: 4px;
    position: relative;
    z-index: 0;
}

.ele-contact-02 .tel>*:before {
    content: "";
    width: 40px;
    height: 40px;
    display: inline-block;
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0.1em;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 16px;
    color: white;
    line-height: 1;
    border-radius: 100%;
    background-color: var(--color-03);
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    letter-spacing: 0;
}

.ele-contact-03 .box {
    padding: 2em 3em;
    border-radius: 2em;
}

.ele-contact-03 dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.ele-contact-03 dt {
    width: 130px;
}

.ele-contact-03 dt .tit {
    width: 100%;
}

.ele-contact-03 dd {
    width: calc(100% - 130px);
}

.ele-contact-03 .form dt .label {
    display: inline-block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 2px 10px;
    font-size: 12px;
    color: #fff;
    border-radius: 5px;
    background: var(--color-03);
}

.ele-contact-03 .form .form_shape li {
    display: inline-block;
    margin-bottom: 10px;
    margin-right: 20px;
}

.ele-contact-03 .form .form_shape input {
    display: none;
}

.ele-contact-03 .form .form_shape label {
    padding-left: 25px;
    line-height: 28px;
    position: relative;
    z-index: 0;
}

.ele-contact-03 .form .form_shape label:before {
    content: "";
    width: 18px;
    height: 18px;
    display: inline-block;
    border: 2px solid;
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 0;
}

.ele-contact-03 .form .form_shape label:after {
    content: "";
    width: 12px;
    height: 12px;
    display: block;
    display: none;
    border-radius: 50%;
    background: var(--color-03);
    position: absolute;
    top: 3px;
    left: 3px;
}

.ele-contact-03 .form .form_shape input:checked+label:after {
    display: block;
}

.ele-contact-03 .form dd input,
.ele-contact-03 .form dd textarea,
.ele-contact-03 .form dd select {
    width: 100%;
    height: 100%;
    padding: 10px 10px;
    border: none;
    border-radius: 5px;
    background: var(--color-02);
}

.ele-contact-03 .form dd select {
    max-width: 20em;
    padding: 10px 30px 10px 10px;
    min-height: 44px;
}

.ele-contact-03 .form .address-code dd input {
    width: 50%;
}

.ele-contact-03 .form .address {
    margin-bottom: 20px;
}

.ele-contact-03 .form .address .txt {
    display: inline-block;
    padding-left: 30px;
    position: relative;
}

.ele-contact-03 .form .address .txt input {
    width: 100px;
    position: relative;
    z-index: 0;
}

.ele-contact-03 .form dd.radiobtn {
    padding: 0.5em;
}

.ele-contact-03 .form dd.radiobtn label {
    display: inline-block;
    margin: 0.5em 0;
    padding: 0 10px 0 30px;
    position: relative;
}

.ele-contact-03 .form dd.radiobtn label::before {
    content: "";
    width: 20px;
    height: 20px;
    display: block;
    border: 2px solid #dcdcdc;
    border-radius: 3px;
    background-color: white;
    position: absolute;
    top: 0.2em;
    left: 0;
}

.ele-contact-03 .form dd.radiobtn label:hover {
    text-decoration: underline;
    cursor: pointer;
}

.ele-contact-03 .form dd.radiobtn input {
    display: none;
}

.ele-contact-03 .form dd.radiobtn input:checked+label {
    text-decoration: underline;
}

.ele-contact-03 .form dd.radiobtn input:checked+label::after {
    content: "";
    width: 0;
    height: 0;
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 20px;
    color: var(--color-03);
    line-height: 1;
    background-color: transparent;
    position: absolute;
    top: 0;
    left: 2px;
}

.ele-contact-03 .form dd.radiobtn input+label {
    margin-left: 15px;
}

@media (max-width: 1024px) {

    .ele-contact-02 .tel>* {
        font-size: 30px;
    }

    .ele-contact-03 .box {
        padding: 2em;
    }
}

@media (max-width: 599px) {

    .ele-contact-03 .box {
        padding: 2em 1em;
    }

    .ele-contact-03 dt {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
    }

    .ele-contact-03 dt .tit {
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
    }

    .ele-contact-03 .form dt .label {
        margin-left: 1em;
    }

    .ele-contact-03 dt,
    .ele-contact-03 dd {
        width: 100%;
    }

    .ele-contact-03 dd {
        margin-top: 0.5em;
    }

    .ele-contact-03 .form dd.radiobtn {
        padding: 0.5em 0;
    }
}

.ele-news-01 li .tit {
    width: calc(100% - 100px);
    font-size: 14px;
}

.ele-news-01 li .tit.mk2 {
    font-size: 18px;
    font-weight: bold;
}

@media (max-width: 599px) {
    .ele-news-01 li .day {
        width: 100%;
        padding-bottom: 5px;
        padding-right: 0;
    }

    .ele-news-01 li .tit {
        width: 100%;
    }

    .ele-news-01 li .tit.mk2 {
        font-size: 16px;
    }
}

.ele-news-02 .box {
    padding: 40px 50px;
    border-radius: 30px;
}

.ele-news-02 .cate>*,
.split-category span {
    min-width: 100px;
    display: inline-block;
    margin: 1px;
    padding: 0.25em 1em;
    font-size: 12px;
    line-height: 1;
    text-align: center;
    border: 1px solid;
    border-radius: 0.25em;
}

@media (max-width:599px) {
    .ele-news-02 .box {
        padding: 30px 20px;
    }
}

.list-flow li .list-inner {
    width: calc(100% - .5em);
    height: calc(100% - .5em);
    margin-top: .5em;
    margin-left: .5em;
    padding: 20px;
    border-radius: 30px;
    background-color: white;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
    position: relative;
}

.list-flow li .list-inner .num {
    width: 2.5em;
    height: 2.5em;
    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-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 1.5em;
    color: white;
    line-height: 1;
    text-align: center;
    border-radius: 100%;
    background-color: var(--color-03);
    -webkit-transform: translate(-25%, -25%);
    transform: translate(-25%, -25%);
    position: absolute;
    padding-left: .2em;
    padding-bottom: .1em;
    top: 0;
    left: 0;
    z-index: 1;
    font-weight: bold;
}

.list-flow li .list-inner .num.-ver2 {
    background-color: var(--color-06);
}

.list-const-flow li+li {
    margin-top: 3em;
}

.list-check.-large li {
    font-size: 110%;
}

.list-risk li .list-inner {
    padding: 2em 1em;
    border-radius: 1em;
    background-color: var(--color-04);
}

.list-01.-ver2 dt {
    color: var(--color-06);
}

@media (max-width: 1024px) {
    .list-table>dt {
        width: 35%;
    }

    .list-table-03 {
        margin-top: 8em;
    }
}

@media (max-width: 599px) {
    .list-table-wrap {
        border-radius: 1em;
    }

    .list-table>dt,
    .list-table>dd {
        padding: 1em;
    }

    .list-table>dt {
        width: 100%;
    }

    .list-flow li .list-inner {
        border-radius: 20px;
    }
}

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

.table-paint.-ver2 tr th:last-child {
    width: 15%;
}

.table-paint.-ver2 tr td:last-child {
    text-align: center;
}

@media (max-width: 768px) {

    .table-paint tr th,
    .table-paint tr td {
        padding: 1em 0.5em;
        font-size: 14px;
    }
}

@media (max-width: 1024px) {
    .pager-list.-left\@tb {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .pager-list.-right\@tb {
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }

    .pager-list li {
        margin: 0 0.25em;
    }
}

@media (max-width: 599px) {
    .pager-list.-left\@sp {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .pager-list.-right\@sp {
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }
}

.card-img,
.card-content {
    width: 100%;
}

.card-img .img {
    height: 100%;
}

.card-content {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.card-content .tit {
    margin: 0.25em 0;
    padding: 0.5em;
    font-weight: bold;
    font-size: 120%;
    color: var(--color-03);
}

.card-content .more-btn {
    padding: 1em 0.5em;
    font-size: 90%;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: var(--color-05);
}

.inner-rec-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0.5em;
}

.inner-rec-list dt,
.inner-rec-list dd {
    margin: 0;
    padding: 0;
}

.inner-rec-list dt {
    width: 30%;
    padding-right: 1em;
    font-weight: bold;
    position: relative;
}

.inner-rec-list dt::after {
    content: "：";
    display: inline-block;
    position: absolute;
    top: 0;
    right: 0;
}

.inner-rec-list dd {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

@media (max-width: 1024px) {
    .card-content .tit {
        font-size: 100%;
    }

    .inner-rec-list dt {
        width: 35%;
    }
}

@media (max-width: 599px) {
    .card {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
    }

    .card-img {
        width: 35%;
    }

    .card-content {
        width: 10%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-flex: 1;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-positive: 1;
        flex-grow: 1;
    }

    .card-content .tit {
        margin: 0;
    }

    .inner-rec-list dt,
    .inner-rec-list dd {
        width: 100%;
    }

    .inner-rec-list dt::after {
        display: none;
    }

    .inner-rec-list dd {
        margin-top: 0.5em;
        padding-left: 1em;
        font-size: 90%;
    }
}

.for-sp .ele-ttl-01 {
    font-size: 40px;
}

.for-sp .title-04 {
    font-size: 16.8px;
}

.for-sp .title-01 {
    font-size: 20px;
}

.tags>span {
    min-width: 100px;
    display: inline-block;
    margin: 1px;
    font-weight: bold;
    padding: 3px 10px;
    font-size: 12px;
    line-height: 1;
    text-align: center;
    border: 1px solid;
    border-radius: 0.25em;
}

@media(max-width:599px) {
    .tel>a {
        text-wrap: nowrap;
        letter-spacing: 0 !important;
    }
}

.tel3-num.pc-only {
    font-size: 28px;
    padding: 5px 0;
}

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

@media(max-width:1024px) {
    .tel3-num.pc-only {
        display: none;
    }

    .telnum.sp-only {
        display: block;
        font-size: 140%;
        line-height: 1.8;
        white-space: nowrap;
    }
}

.og-text {
    font-size: 20px;
    font-weight: bold;
}

.og-num {
    font-size: 40px;
    letter-spacing: -.05em;
}

@media(max-width:1024px) {
    .header {
        padding: 10px;
    }

    .header-right {
        width: 250px;
    }

    .header-tel-01 {
        font-size: 12px;
        padding: 1px 10px;
        border-radius: 10px;
    }

    .header-tel-02 {
        font-size: 14px;
    }

    .header-tel-03 a {
        font-size: 34px;
        padding-left: 35px;
    }

    .freedial-icon {
        width: 32px;
        height: 32px;
        -webkit-transform: translateY(-40%);
        transform: translateY(-40%);
    }

    .logo {
        max-width: 250px;
    }

    .cs-item-title {
        padding: 8px 10px 12px 10px;
        font-size: 22px;
        border-radius: 20px;
    }

    .cs-arrow {
        padding: 0 10px;
    }

    .cs-arrow-left span {
        padding: 5px 0;
    }

    .cs-arrow-right span {
        padding: 5px 0;
    }

    .cs-arrow-inner>*>span {
        font-size: 16px;
    }

    .cs-arrow-left::before {
        border-top: 25px solid transparent;
        border-bottom: 25px solid transparent;
        border-right: 20px solid #555555;
    }

    .cs-arrow-right::after {
        border-top: 25px solid transparent;
        border-bottom: 25px solid transparent;
        border-left: 20px solid #555555;
    }

    .cs-arrow.lefty .cs-arrow-inner .cs-arrow-right span,
    .cs-arrow.righty .cs-arrow-inner .cs-arrow-right span {
        height: 25px;
    }

    .cs-mini-list {
        bottom: 0%;
    }

    .lefty .cs-mini-list {
        left: 0%;
    }

    .righty .cs-mini-list {
        right: 0%;
    }

    .cs-mini-list li {
        padding-left: 1.5em;
        font-size: 16px;
    }

    .cs-mini-list li::before {
        top: 0.2em;
        font-size: 20px;
    }

    .list-flow li .list-inner {
        padding: 15px 10px;
    }

    .title-03 {
        font-size: 24px;
    }

    .odr01 {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .odr02 {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    .odr03 {
        -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
        order: 3;
    }

}

.color-bg {
    background-color: var(--color-03);
    width: 120vw;
    position: absolute;
    top: -150px;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(-7deg);
    transform: translateX(-50%) rotate(-7deg);
    z-index: 1;
    padding: 300px 0 50px 0;
}

.color-bg>* {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.row1 {
    display: block;
    position: relative;
    z-index: 1;
    -webkit-transform: skew(-10deg, 0);
    transform: skew(-10deg, 0);
}

.row1>span {
    display: inline-block;
    padding: 0 .2em .1em .2em;
    position: relative;
    background-color: #fff;
    font-size: clamp(38px, 6vw, 90px);
    font-family: "Mochiy Pop One",
        sans-serif;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0vw;
    color: var(--color-03);
    line-height: 1.2em;
}

.row1>span::after {
    content: "";
    width: 100%;
    height: 100%;
    display: inline-block;
    border: 1px solid #fff;
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: -1;
}

@media(max-width:599px) {
    .row1 {
        margin-left: -.2em;
    }

    .row1>span {
        letter-spacing: -.05em;
    }
}

.row2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-top: 10px;
    padding-left: 5vw;
    white-space: nowrap;
}

@media(max-width:1200px) {
    .color-bg>* {
        max-width: 1000px;
    }

    .row2 {
        padding-left: 3vw;
    }
}

.no-bg-set {
    position: absolute;
    bottom: 30px;
    left: 0;
    width: 100%;
    z-index: 3;
}

.mini-form .ele-btn-02 .btn-inner>* {
    padding: 10px 30px;
}

@media(max-width:599px) {
    .header-right {
        display: none;
    }

    .header-tel-03 a {
        font-size: 30px;
    }

    .header-tel-01 {
        padding: 1px 5px;
        border-radius: 7px;
    }

    .ele-return-01 {
        bottom: 80px;
    }

    .slick-dots-01 .slick-dots {
        top: -20px;
    }

    .ele-ttl-03 .ttl-main {
        font-size: 24px;
    }

    .mini-form {
        position: relative;
        bottom: 0;
        right: 0;
        width: 96%;
        margin: 40px auto 0 auto;
    }

    .ele-works-02 li .cate .tag01,
    .ele-works-02 li .cate .tag02 {
        font-size: 12px;
    }

}

.ftr-flex-item {
    width: 33%;
}

.ftr-logo {
    width: 100%;
}

.ftr-logo>a {
    display: block;
    max-width: 250px;
}

.ftr-logo.sunlife>a {
    max-width: 150px;
    margin: 10px auto;
    font-weight: bold;
    font-size: 14px;
    -webkit-filter: var(--filter-for-03);
    filter: var(--filter-for-03);
}

.ftr-logo>a>img {
    display: block;
    width: 100%;
}

.ftr-flex .header-tel {
    max-width: 300px;
}

.ftr-flex .header-tel-01 {
    padding: 2px 10px;
}

.ftr-flex .header-tel-03 a {
    font-size: 40px;
}

.ftr-bnr {
    width: 100%;
    max-width: 300px;
    margin-left: auto;
}

.ftr-bnr>a {
    display: block;
    width: 100%;
    padding: 20px 0;
    background-color: var(--color-05);
    border-radius: 20px;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2);
}

.bnr-txt01 {
    font-size: 24px;
    text-align: center;
}

.bnr-txt02 {
    text-align: center;
    font-weight: bold;
}

.thanks-section {
    margin-top: 150px;
}

@media(max-width:1024px) {
    .ftr-flex-item {
        width: 48%;
    }

    .ftr-flex .header-tel {
        max-width: 250px;
    }

    .ftr-flex .header-tel-03 a {
        font-size: 34px;
    }

    .ftr-txt.mk03 {
        font-size: 14px;
    }

    .ftr-logo.sunlife>a {
        margin: 5px auto;
    }

    .ftr-bnr {
        max-width: 100%;
        margin-left: 0;
    }

    .trans-block::after {
        padding-top: 73%;
    }
}

@media(max-width:599px) {
    .ftr-flex-item {
        width: 100%;
    }

    .ftr-logo>a {
        margin-left: auto;
        margin-right: auto;
    }

    .ftr-flex .header-tel-03 a {
        font-size: 30px;
    }

    .ftr-flex .header-tel {
        margin-left: auto;
        margin-right: auto;
    }

    .thanks-section {
        margin-top: 120px;
    }
}

.float-parent {
    display: block;
}

.float-parent:before,
.float-parent:after {
    content: "";
    display: block;
    clear: both;
}

.float-wrap .float-parent+.float-parent {
    margin-top: 40px;
}

.float-wrap .float-parent .float-title {
    float: right;
}

.float-wrap .float-parent .float-img {
    float: left;
}

.float-wrap .float-parent .float-content {
    float: right;
}

.float-wrap .float-parent:nth-of-type(even) .float-title {
    float: left;
}

.float-wrap .float-parent:nth-of-type(even) .float-img {
    float: right;
}

.float-wrap .float-parent:nth-of-type(even) .float-content {
    float: left;
}

.float-wrap .float-parent02+.float-parent02 {
    margin-top: 40px;
}

.float-wrap.float-wrap2 .float-parent:nth-of-type(even) .float-title,
.float-wrap.float-wrap2 .float-parent:nth-of-type(even) .float-content {
    float: right;
}

.float-wrap.float-wrap2 .float-parent:nth-of-type(even) .float-img {
    float: left;
}

.float-wrap.-space-mini .float-parent+.float-parent {
    margin-top: 30px;
}

.float-img .notreverse {
    float: left;
}

.radius-img {
    position: relative;
}

.radius-img::before {
    content: "";
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: var(--color-03);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.radius-img img {
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 50% 50% 40% 60% / 50% 60% 40% 50%;
}

.box-text-left {
    font-size: 24px;
    line-height: 1.2em;
    margin-right: 1em;
    color: var(--color-03);
    font-weight: bold;
    letter-spacing: 0px;
    text-shadow: 0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff;
    white-space: nowrap;
}

.box-text-right {
    color: var(--color-03);
    font-size: clamp(30px, 5vw, 77px);
    letter-spacing: 0px;
    text-shadow: 0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff,
        0px 0px 3px #fff;
    font-weight: bold;
    line-height: 1.2em;
    white-space: nowrap;
}

.c001 {
    color: #807f7f;
}

.no-bg-set-left {
    width: calc(100% - 510px);
}

.no-bg-set-right {
    width: 500px;
}

.box-text-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

@media(max-width:1300px) {
    .box-text-box {
        -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;
    }

    .box-text-left {
        margin-right: 0em;
        text-align: center;
    }

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

.mv-person {
    width: 400px;
    height: 510px;
    position: absolute;
    bottom: 0;
    right: clamp(600px, 55vw, 900px);
    z-index: 2;
}

.mv-person>img {
    position: relative;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center top;
    object-position: center top;
    width: 100%;
    height: 100%;
}

@media(max-width:1024px) {
    .box-text-left {
        line-height: 1.4;
        font-size: 22px;
    }

    .row2 {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        padding-top: 10px;
        padding-left: 5vw;
    }

    .color-bg {
        padding: 260px 11vw 30px;
    }

    .no-bg-set-left {
        width: 100%;
    }

    .title-03.tight {
        font-size: 22px;
        letter-spacing: -.05em;
    }

    .mv-person {
        right: -65px;
    }

    .mv-person>img {
        position: relative;
        -o-object-fit: contain;
        object-fit: contain;
        -o-object-position: center bottom;
        object-position: center bottom;
        width: 100%;
        height: 100%;
    }



}

@media(max-width:599px) {

    .float-wrap .float-parent .float-title,
    .float-wrap .float-parent .float-img,
    .float-wrap .float-parent .float-content,
    .float-wrap .float-parent:nth-of-type(even) .float-title,
    .float-wrap .float-parent:nth-of-type(even) .float-img,
    .float-wrap .float-parent:nth-of-type(even) .float-content {
        float: none;
    }

    .float-wrap .float-parent:nth-of-type(even) .float-img,
    .float-wrap .float-parent .float-img {
        margin-left: auto;
        margin-right: auto;
    }

    .box-white.-large .title-03 {
        font-size: 22px;
    }


    .box-text-left {
        line-height: 1.4;
        font-size: 16px;
    }

    .block-text {
        margin-bottom: 10px;
    }

    .row2 {
        padding-left: 0vw;
        margin-left: -10px;
    }

    .box-text-right {
        margin-top: 0px;
        font-size: 42px;
    }

    .no-bg-set {
        bottom: 15px;
    }

    .color-bg {
        padding: 260px 11vw 10px;
    }

    .ele-mainimg-01 .catch-main {
        letter-spacing: -.05em;
    }

    .ele-mainimg-01 .catch-sub {
        margin-bottom: 0;
    }

    .ele-mainimg-01 .catch-sub .big01 {
        font-size: 1em;
    }

    .mv-person {
        width: 70%;
        min-width: 250px;
        height: calc(100vw - 130px);
        min-height: 350px;
        position: absolute;
        bottom: -90px;
        right: -60px;
        z-index: 2;
    }

    .ball-count {
        width: 270px;
        margin-left: 0;
        margin-right: auto;
        margin-bottom: 20px;
    }

    .ball-count ul li {
        width: 33%;
    }

    .box-text-box {
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .ball-count ul li::before {
        width: calc(100% - 6px);
        height: calc(100% - 6px);
    }

    .int {
        overflow: hidden;
    }

}

.c-area {
    padding-top: .5em;
    margin-top: .5em;
    border-top: 2px solid var(--color-05);
}

.tag {
    display: inline-block;
    margin-left: 10px;
    padding: 0.25em .3em .4em .3em;
    font-size: 14px;
    line-height: 1;
    text-align: center;
    border: 2px solid var(--color-03);
    color: #fff;
    background-color: var(--color-03);
    border-radius: 0.25em;
    font-weight: bold;
}

.tag2 {
    display: inline-block;
    margin-top: 10px;
    padding: 0.25em .3em .4em .3em;
    font-size: 14px;
    line-height: 1;
    text-align: center;
    border: 2px solid var(--color-03);
    color: #fff;
    background-color: var(--color-03);
    border-radius: 0.25em;
    font-weight: bold;
}

.limited-banner {
    width: 100%;
    display: block;
    position: relative;
    background: linear-gradient(45deg, #B67B03 0%, #DAAF08 45%, #e9cd66 70%, #DAAF08 85%, #B67B03 90% 100%);
    padding: 6px;
    border-radius: 10px;
    margin-bottom: 15px;
}

.limited-banner-inner {
    width: 100%;
    background: repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px, #ffeece 3px, #ffeece 8px);
    border-radius: 6px;
    position: relative;
    padding: 0 20px 10px;
    z-index: 1;
}

.lr01 {
    position: relative;
    margin: 30px;
    text-align: center;
    max-width: 150px;
    margin: 0 auto;
    -webkit-transform: translateY(-30px);
    transform: translateY(-30px);
}

.lr01:before,
.lr01:after {
    position: absolute;
    z-index: 0;
    bottom: -10px;
    display: block;
    content: "";
    border: 1em solid #d90606;
}

.lr01:before {
    left: -20px;
    border-left-width: 15px;
    border-left-color: transparent;
}

.lr01:after {
    right: -20px;
    border-right-width: 15px;
    border-right-color: transparent;
}

.lr01 span {
    position: relative;
    z-index: 1;
    display: block;
    padding: 3px 30px;
    color: #fff;
    background: #fa4141;
    font-size: 20px;
    font-weight: bold;
    text-shadow: 1px 1px 0 #000,
        -1px -1px 0 #000,
        -1px 1px 0 #000,
        1px -1px 0 #000,
        0px 1px 0 #000,
        0 -1px 0 #000,
        -1px 0 0 #000,
        1px 0 0 #000;
}

.lr01 span:before,
.lr01 span:after {
    position: absolute;
    bottom: -10px;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    border-style: solid;
    border-color: #b70505 transparent transparent transparent;
}

.lr01 span:before {
    left: 0;
    border-width: 10px 0 0 10px;
}

.lr01 span:after {
    right: 0;
    border-width: 10px 10px 0 0;
}

.lr02 {
    font-size: 20px;
    line-height: 1.2;
    color: var(--color-03);
    font-weight: bold;
    text-align: center;
    margin-top: -15px;
}

.lr03 {
    color: #000;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    letter-spacing: -.08em;
}

.lmsp02 {
    font-size: 30px;
    font-weight: bold;
    background-image: -webkit-gradient(linear, right top, left top, from(#B67B03), color-stop(25%, #DAAF08), color-stop(50%, #e9cd66), color-stop(75%, #DAAF08), to(#B67B03));
    background-image: linear-gradient(-90deg, #B67B03 0%, #DAAF08 25%, #e9cd66 50%, #DAAF08 75%, #B67B03 100%);
    background-size: 250% 100%;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-animation: shine 1.5s infinite;
    animation: shine 1.5s infinite;
}

@-webkit-keyframes shine {
    0% {
        background-position: 100% 50%;
    }

    50% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 100% 50%;
    }
}

@keyframes shine {
    0% {
        background-position: 100% 50%;
    }

    50% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 100% 50%;
    }
}

.lmsp01 {
    color: rgb(255, 238, 0);
    font-size: 55px;
    text-shadow: 2px 2px 0 var(--color-03), -2px -2px 0 var(--color-03), -2px 2px 0 var(--color-03), 2px -2px 0 var(--color-03), 0px 2px 0 var(--color-03), 0 -2px 0 var(--color-03), -2px 0 0 var(--color-03), 2px 0 0 var(--color-03);
    font-weight: bold;
    -webkit-filter: drop-shadow(5px 4px 0 var(--color-03));
    filter: drop-shadow(5px 4px 0 var(--color-03));
    line-height: 1em;
    display: inline-block;
    margin-right: .05em;
}

.lmtd-text {
    position: relative;
    padding: 10px 0;
    background: -webkit-repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px, #ffeece 3px, #ffeece 8px);
    background: repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px, #ffeece 3px, #ffeece 8px);
    border-radius: 7px;
    margin-bottom: 20px;
    color: rgb(255, 238, 0);
    text-shadow: 1.5px 1.5px 0 var(--color-03),
        -1.5px -1.5px 0 var(--color-03),
        -1.5px 1.5px 0 var(--color-03),
        1.5px -1.5px 0 var(--color-03),
        0px 1.5px 0 var(--color-03),
        0 -1.5px 0 var(--color-03),
        -1.5px 0 0 var(--color-03),
        1.5px 0 0 var(--color-03);
    font-weight: bold;
    -webkit-filter: drop-shadow(5px 4px 0 var(--color-03));
    filter: drop-shadow(5px 4px 0 var(--color-03));
    line-height: 1em;
    font-size: 34px;
    letter-spacing: -.05em;
    max-width: 500px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.lmtd-text::after {
    position: absolute;
    content: "";
    top: 100%;
    left: 30px;
    border: 15px solid transparent;
    border-top: 15px solid #ffeece;
    width: 0;
    height: 0;

}

@media(max-width:1024px) {


    .lmsp01 {
        font-size: 40px;
    }

    .lmsp02 {
        font-size: 24px;
    }

    .lmtd-text {
        font-size: 28px;
    }

    .limited-banner {
        max-width: 550px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media(max-width:599px) {
    .ele-mainimg-01 .pic::after {
        padding-top: 500px;
    }

    .limited-banner {
        max-width: 270px;
        margin-left: 0;
        margin-right: auto;
    }

    .lr02 {
        font-size: 18px;
    }

    .limited-banner-inner {
        padding: 0 10px 10px;
    }

    .lr03 {
        font-size: 16px;
    }

    .lmsp01 {
        font-size: 30px;
        -webkit-filter: drop-shadow(2px 1px 0 var(--color-03));
        filter: drop-shadow(2px 1px 0 var(--color-03));
    }
}