@charset "UTF-8";

html {
    scroll-behavior: smooth
}

*,
::after,
::before,
body {
    margin: 0;
    padding: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 500;
    color: #504043
}

a {
    text-decoration: none
}

li {
    list-style: none
}

img,
picture {
    width: 100%;
    vertical-align: bottom
}

picture {
    display: block
}

.allwrap {
    overflow: hidden
}

.content {
    max-width: 1200px;
    margin: 0 auto
}

h2 {
    font-size: 48px;
    font-family: "Zen Kaku Gothic New", sans-serif;
    text-align: center;
    line-height: 1.35;
    font-weight: 700
}

h3 {
    font-size: 40px;
    line-height: 1.35;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 500;
    text-align: center
}

span.sub-title {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: .13em;
    display: block;
    line-height: 1;
    text-align: center
}

.titleWrap {
    text-align: center
}

.blueText {
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block
}

.header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    background-color: #fff;
    -webkit-box-shadow: 0 4px 14px rgba(0, 55, 111, .05);
    box-shadow: 0 4px 14px rgba(0, 55, 111, .05);
    border-radius: 0 0 8px 8px;
    padding: 12px 2.5%;
    position: fixed;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 999
}

.header__logo {
    max-width: 329px;
    width: 27%
}

.header__content {
    display: -ms-grid;
    display: grid;
    grid-column-gap: 3%;
    -ms-grid-columns: 44% 29% 21%;
    grid-template-columns: 44% 29% 21%;
    max-width: 730px;
    /* width: 100%; */
    width: 73%;
    text-align: right
}

.header__content a {
    display: block;
    padding: 16px;
    border-radius: 4px;
    margin-top: 6px;
    font-weight: 700;
    position: relative
}

.header__content a::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 16px;
    width: 16px;
    height: 16px;
    font-family: 'Font Awesome 5 Free'
}

.header__content span {
    padding: 2px 6px;
    display: block;
    width: -moz-fit-content;
    width: -webkit-fit-content;
    width: fit-content;
    margin: 0 auto;
    background: linear-gradient(91.02deg, #3e6e8f -.17%, #375d78 102.74%);
    border-radius: 3px;
    color: #fff;
    font-size: 12px;
    line-height: 1;
    position: relative
}

.header__content span::before {
    content: "";
    position: absolute;
    bottom: -10px;
    left: 50%;
    border: 5px solid transparent;
    border-top: 6px solid #3e6e8f;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
}

.header__content--form a {
    background-color: #eef8ff;
    color: #0f5484
}

.header__content--form a::before {
/*    content: "";*/
    content: "";
    color: #1490e7;
    font-weight: 900
}

.header__content--line a {
    color: #fff;
    background: linear-gradient(93.14deg, #15d363 -.1%, #18bf5c 100%)
}

.header__content--line a::before {
    background: url(../img/header_line.svg) no-repeat center center/contain
}

.header__content--tel a {
    font-weight: 900;
    color: #fff;
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%)
}

.header__content--tel a::before {
    content: "";
    color: #fff;
    font-weight: 900
}

.fv {
    background: url(../img/fv_bg.png) no-repeat center center/cover;
    background-blend-mode: screen;
    background-color: #a9d6f9;
    position: relative
}

.fv .content {
    padding-top: 104px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.fv .content__item:first-of-type {
    max-width: 627px;
    width: 52%
}

.fv .content__item:last-of-type {
    max-width: 611px;
    width: 51%
}

.fv .content__item:last-of-type picture {
    -webkit-transform: translateX(10%);
    transform: translateX(10%)
}

.fv__aside {
    color: #fff;
    position: absolute;
    max-width: 1200px;
    background: linear-gradient(90.4deg, #605355 .23%, #45383a 99.71%);
    -webkit-box-shadow: 0 4px 0 #3d3133;
    box-shadow: 0 4px 0 #3d3133;
    border-radius: 4px;
    width: 100%;
    left: 50%;
    bottom: -7%;
    -webkit-transform: translateX(-50%) skew(-5deg) rotate(-5deg);
    transform: translateX(-50%) skew(-5deg) rotate(-5deg);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 10px 24px
}

.fv__aside::before {
    position: absolute;
    content: '';
    background: url(../img/emblem.png) no-repeat center center/contain;
    height: 191px;
    width: 100%;
    top: -58%;
    left: -42%;
    z-index: 100;
    -webkit-transform: skew(5deg) rotate(5deg);
    transform: skew(5deg) rotate(5deg)
}

.fv__aside::after {
    position: absolute;
    content: '';
    background-image: repeating-linear-gradient(-45deg, #534649, #534649 7px, transparent 0, transparent 14px);
    width: 100%;
    height: 100%;
    top: 0;
    z-index: -1;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
}

.fv__aside--title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-transform: skewX(5deg);
    transform: skewX(5deg);
    margin-right: 16px
}

.fv__aside--title h4 {
    line-height: 1;
    margin-top: 24px;
    color: #fff;
    font-weight: 900;
    font-size: 32px;
    position: relative;
    letter-spacing: .02em
}

.fv__aside--title h4::before {
    display: inline-block;
    position: absolute;
    content: 'SUPPORT\00A AREA';
    top: -24px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%;
    font-size: 16px;
    color: #feda63;
    font-family: Oswald, sans-serif;
    letter-spacing: .18em
}

.fv__aside--content {
    max-width: 635px;
    -webkit-transform: skewX(5deg);
    transform: skewX(5deg)
}

.fv__aside--content span {
    padding: 10px 12px;
    font-size: 14px;
    color: #fff;
    font-weight: 700;
    border-radius: 3px;
    background-color: rgba(0, 0, 0, .2);
    display: inline-block;
    margin-bottom: 4px
}

.fv__aside--content span:last-of-type {
    background: 0 0;
    font-family: Oswald, sans-serif;
    font-weight: 300;
    color: rgba(255, 255, 255, .5)
}

.fv__aside--content small {
    color: #fff;
    font-size: 13px;
    font-weight: 300;
    display: block
}

.online {
    background-color: #eef8ff;
    padding: 124px 0 20px
}
.online.present02 {
    max-width: 1200px;
    margin: 0 auto;
    padding: 76px 0 22px;
    position: relative;
    z-index: 2;
}

.online .title {
    max-width: 686px;
    margin: 0 auto;
    text-align: center
}

.online .title span {
    font-weight: 500;
    font-family: Oswald, sans-serif;
    letter-spacing: .18em;
    color: #543b00;
    opacity: .2;
    display: block
}

.online .title h3 {
    font-weight: 900;
    margin: 12px 0 0;
    position: relative;
    display: inline-block;
    color: #e18700;
    background: -webkit-linear-gradient(288deg, #efbc06, #e18700);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.online .title h3::after,
.online .title h3::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 55px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 65px;
    height: 1.5px;
    background: #504043
}

.online .title h3::before {
    left: -62px;
    -webkit-transform: translateY(-50%) rotate(60deg);
    transform: translateY(-50%) rotate(60deg)
}

.online .title h3::after {
    right: -62px;
    -webkit-transform: translateY(-50%) rotate(-60deg);
    transform: translateY(-50%) rotate(-60deg)
}

.online .title p {
    font-size: 18px;
    font-weight: 500;
    text-align: center;
    color: rgba(80, 64, 67, .8)
}

.worries {
    padding: 100px 0 80px;
    background-color: #373b3e;
    background-image: repeating-linear-gradient(-45deg, #494d4f, #494d4f 7px, transparent 0, transparent 14px)
}

.worries h3 {
    color: #fff;
    margin-bottom: 56px;
    position: relative;
    font-weight: 900
}

.worries h3::after {
    content: 'YOUR\00a0WORRIES';
    color: #fff;
    opacity: .1;
    font-size: 100px;
    font-weight: 900;
    letter-spacing: .13em;
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    line-height: 1
}

.worries ul {
    background-color: #474b4d;
    max-width: 842px;
    padding: 62px 0;
    margin: 0 auto
}

.worries ul li {
    font-size: 20px;
    font-weight: 500;
    color: #fff;
    max-width: 602px;
    margin: 0 auto 36px;
    position: relative;
    padding-left: 60px
}

.worries ul li span {
    color: #ffc700
}

.worries ul li:last-of-type {
    margin-bottom: 0
}

.worries ul li::before {
    content: '';
    background: rgba(255, 255, 255, .15);
    border-radius: 2px;
    width: 28px;
    height: 28px;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 0
}

.worries ul li::after {
    content: '';
    background: url(../img/check_blue.png) no-repeat center/contain;
    width: 24px;
    height: 24px;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 6px;
    display: inline-block
}

.about {
    background-color: #eef8ff;
    padding: 120px 0
}

.about .titleWrap {
    text-align: center;
    position: relative
}

.about .titleWrap::before {
    display: inline-block;
    position: absolute;
    content: 'ABOUT\00AUS';
    top: -.4em;
    line-height: 1;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%;
    font-size: 100px;
    color: #0096ff;
    opacity: .07;
    letter-spacing: .13em;
    font-weight: 900
}

.about .content {
    margin-top: 56px
}

.about .content__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    padding-top: 52px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.about .content__item dl {
    max-width: 480px;
    margin-top: 102px
}

.about .content__item dl dt {
    font-weight: 400;
    font-size: 40px;
    line-height: 1.5;
    color: #084b99;
    margin-bottom: 48px
}

.about .content__item dl dd {
    font-size: 18px;
    line-height: 2;
    color: #084b99
}

.about .content__item picture {
    max-width: 376px;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content
}

.about .content__item::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 0;
    left: 0;
    font-size: 283px;
    font-weight: 300;
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    line-height: 1
}

.about .content__item:first-of-type {
    max-width: 928px;
    width: 77%;
    margin-left: auto
}

.about .content__item:first-of-type::before {
    content: '01';
    left: -33%
}

.about .content__item:nth-of-type(2) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    margin: 40px 0;
    max-width: 915px;
    width: 76%
}

.about .content__item:nth-of-type(2)::before {
    content: '02';
    left: initial;
    right: -32%
}

.about .content__item:nth-of-type(2) picture {
    max-width: 339px
}

.about .content__item:last-of-type {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 885px;
    width: 73%;
    margin-left: auto
}

.about .content__item:last-of-type::before {
    content: '03';
    left: -36%
}

.about .content__item:last-of-type picture {
    max-width: 340px
}

.nigata {
    background: -webkit-gradient(linear, left top, left bottom, from(#bfe5ff), to(#fff));
    background: linear-gradient(180deg, #bfe5ff 0, #fff 100%);
    padding: 24px 0 120px;
    position: relative
}

.nigata::after {
    position: absolute;
    content: '';
    background-image: repeating-linear-gradient(-45deg, rgba(38, 38, 38, .1), rgba(38, 38, 38, .1) 7px, transparent 0, transparent 14px);
    opacity: .1;
    width: 100%;
    top: 0;
    left: 0;
    height: 100%
}

.nigata .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1200px;
    margin: 0 auto;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    position: relative;
    z-index: 100
}

.nigata .content p {
    line-height: 2;
    font-size: 18px;
    color: #032641;
    max-width: 480px;
    margin: 27px auto 0
}

.nigata .content::after,
.nigata .content::before {
    display: inline-block;
    position: absolute;
    content: '';
    /* top: 50%; */
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%
}

.nigata .content::before {
    content: 'NIIGATA AKIYA';
    font-size: 181px;
   /* -webkit-text-fill-color: transparent;
    color: transparent;*/
     -webkit-text-fill-color:#ffffff;
    color:#ffffff;
    -webkit-text-stroke: 1px #fff;
    font-weight: 900;
    top: 28%;
    -webkit-transform: translate(-50%, -28%);
    transform: translate(-50%, -28%);
    z-index: 5;
    white-space: pre
}

.nigata .content::after {
    background: url(../img/nigata_bg.jpg) no-repeat center center/cover;
    bottom: 0;
    width: 100%;
    height: 245px;
    bottom: 0;
}

.nigata .content h2 {
    max-width: 584px
}

.nigata .content__img {
    max-width: 502px;
    position: relative;
    z-index: 10
}

.nigata .content__item {
    position: relative;
    z-index: 10;
    margin-bottom: 65px;
    margin-right: 5.8%
}

.ctas {
    padding: 0px 0 56px;
    max-width: 1200px;
    margin: 0 auto;
    background-color: #eef8ff;
    position: relative;
    z-index: 100
}

.ctas .ctaWrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    /* max-width: 960px; */
    max-width: 1084px;
    margin: 0 auto
}

.ctas .ctaWrap hr {
    height: 104px;
    width: 1px;
    border: none;
    border-right: 1px solid rgba(80, 64, 67, .1)
}

.ctas .ctaWrap__item {
    line-height: 1;
    max-height: 104px;
    position: relative;
    max-width: 468px;
    width: 49%;
    text-align: center;
    padding: 30px 0;
    border-radius: 4px;
    overflow: hidden;
    display: block;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.ctas .ctaWrap__item span {
    font-size: 13px;
    font-weight: 900;
    position: relative;
    z-index: 99
}

.ctas .ctaWrap__item p {
    font-size: 22px;
    font-weight: 900;
    color: #fff;
    margin-top: 8px
}

.ctas .ctaWrap__item::after,
.ctas .ctaWrap__item::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-family: 'Font Awesome 5 Free';
    font-size: 18px;
    font-weight: 900;
    color: #fff
}

.ctas .ctaWrap__item::before {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    left: 21px
}

.ctas .ctaWrap__item.form {
    background: linear-gradient(94.02deg, #EFBC06 -.11%, #E18700 99.89%);
    -webkit-box-shadow: 0 6px 0 0 #AF7900;
    box-shadow: 0 6px 0 0 #AF7900;
    width: 100%;
    max-width: 100%;
    margin: 24px 0 30px;
    margin-top: 0px;
}

.ctas .ctaWrap__item.form span {
    color: #745000;
}

.ctas .ctaWrap__item.form::before {
    content: '';
    background: #AF7900;
    padding: 16px 14px 0 14px;
    right:35px;
    left:initial;
}

.ctas .ctaWrap__item.form::after {
    background: url(../img/form-bg02.png) no-repeat center center/contain;
    width: 132px;
    height: 132px;
    left: 2px
}

.ctas .ctaWrap__item.line {
    background: linear-gradient(93.14deg, #15d363 -.1%, #18bf5c 100%);
    -webkit-box-shadow: 0 6px 0 0 #008c39;
    box-shadow: 0 6px 0 0 #008c39;
    width: 45%;
    max-width: 560px;
}

.ctas .ctaWrap__item.line span {
    color: #005f27
}

.ctas .ctaWrap__item.line::before {
    background: url(../img/line.svg) center center/cover
}

.ctas .ctaWrap__item.line::after {
    background: url(../img/line_bg.svg) no-repeat center center/contain;
    width: 127px;
    height: 104px;
    right: 6px
}

.ctas .ctaWrap__item.tel {
    background: #55484a;
    -webkit-box-shadow: 0 6px 0 0 #241a1c;
    box-shadow: 0 6px 0 0 #241a1c;
    width: 50%;
    max-width: 560px;
    padding: 27px 0 30px;
}

.ctas .ctaWrap__item.tel span {
    color: #fff;
    font-weight: 400;
    font-size: 14px
}

.ctas .ctaWrap__item.tel p {
    font-size: 36px;
    letter-spacing: .02em;
    margin-top: 4px
}

.ctas .ctaWrap__item.tel::before {
    content: '\f2a0';
    background: #75696b;
    padding: 14px 14px 0 16px
}

.ctas .ctaWrap__item.caution {
    /*background-color: #fff;*/
    max-width: 100%;
    width: 100%;
    padding: 22px 18px 22px 46px;
}

.ctas .ctaWrap__item.caution p {
    line-height: 1.7;
    font-weight: 500;
    font-size: 12px;
    color: #504043;
    text-align: left;
    margin-top: 0;
    opacity: .7
}

.ctas .ctaWrap__item.caution::before {
    background: url(../img/caution.svg) no-repeat center center/contain;
    width: 20px;
    height: 20px;
    left: 18px
}

.ctas .ctaWrap__item:hover {
    -webkit-box-shadow: 0 0;
    box-shadow: 0 0
}

.ctas .ctaWrap .ctaWrap__item-content:first-of-type {
    width:46%;
}
.ctas .ctaWrap .ctaWrap__item-content:first-of-type img {
    position: relative;
    top: -7px;
    left: -10px
}
.ctas .ctaWrap .ctaWrap__item-content:last-of-type {
    width:52%;
    padding-top: 25px;
}

.ctas .ctaWrap:first-of-type {
    padding-bottom: 18px
}
.ctas .attention-txt {
    text-align: center;
}


.ctas .ctaWrap:last-of-type {
    padding-top: 24px;
    border-top: 1px solid rgba(80, 64, 67, .1)
}

.danger {
    padding: 72px 0 120px;
    background-color: #faf2e6;
    background-image: repeating-linear-gradient(-45deg, #f5ede1, #f5ede1 7px, transparent 0, transparent 14px)
}

.danger .titleWrap {
    position: relative
}

.danger .titleWrap::before {
    display: inline-block;
    position: absolute;
    content: 'DEMERIT & RISK';
    top: -20px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%;
    font-size: 100px;
    color: rgba(0, 0, 0, .05);
    font-weight: 900;
    line-height: 1;
    white-space: pre
}

.danger .titleWrap h2 {
    display: inline-block;
    line-height: 1.35;
    position: relative;
    padding: 12px 0;
    padding: 28px 0
}

.danger .titleWrap h2 span {
    background: linear-gradient(114.05deg, #c44600 2.67%, #e15f00 98.22%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent
}

.danger .titleWrap h2:before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    background: repeating-linear-gradient(-45deg, #504043, #504043 7px, #ffc700 0, #ffc700 14px);
    height: 12px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%
}

.danger .titleWrap h2:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    height: 12px;
    background: repeating-linear-gradient(-45deg, #504043, #504043 7px, #ffc700 0, #ffc700 14px);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%
}

.danger .titleWrap p {
    max-width: 640px;
    margin: 47px auto 48px;
    font-size: 18px;
    line-height: 1.7;
    text-align: left
}

.danger .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 1152px;
    width: 80%
}

.danger .content dl {
    width: 48%;
    max-width: 560px;
    background-color: #fff;
    font-size: 18px;
    border-radius: 4px;
    padding: 36px 0;
    -webkit-box-shadow: 0 6px 0 0 #dadad5;
    box-shadow: 0 6px 0 0 #dadad5
}

.danger .content dl dt {
    font-size: 22px;
    color: #fff;
    background-color: #504043;
    padding: 10px 16px;
    width: 86%;
    margin: 0 auto 18px;
    max-width: 480px;
    border-radius: 4px;
    line-height: 1.7;
    font-weight: 700
}

.danger .content dl dt span {
    color: #ff620a
}

.danger .content dl dd {
    border-top: 1px solid rgba(80, 64, 67, .2);
    max-width: 480px;
    width: 86%;
    margin: 0 auto;
    line-height: 1.8;
    padding: 18px 0 0
}

.danger .content dl dd:nth-of-type(2) {
    border-top: none;
    line-height: 1.5;
    background-color: #f9f9f9;
    border-radius: 8px;
    padding: 16px;
    margin-top: 16px
}

.danger .content dl dd:nth-of-type(2) span {
    display: block;
    font-size: 14px;
    opacity: .7;
    margin-top: 8px
}

.danger .content dl dd:nth-of-type(2) ul {
    margin-top: 12px;
    font-size: 16px;
    line-height: 1.7
}

.danger .content dl dd:nth-of-type(2) ul a {
    font-size: 14px;
    opacity: .8;
    background-color: #fff;
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, .12);
    padding: 5px 8px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    width: 59px;
    display: inline-block;
    text-align: right;
    margin-left: 14px;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.danger .content dl dd:nth-of-type(2) ul a::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 9px;
    width: 20px;
    height: 1px;
    background: url(../img/url_brown.svg);
    width: 10px;
    height: 10px
}

.danger .content dl dd:nth-of-type(2) ul a:hover {
    text-decoration: underline
}

.danger .content dl dd ul span {
    font-size: 13px
}

.danger .content dl dd ul li {
    padding-left: 1em;
    text-indent: -1em
}

.danger .content dl dd ul li ul {
    margin-left: 1rem
}

.danger .content dl dd ul li p {
    margin-left: 1rem
}

.danger .content dl:nth-of-type(n+3) {
    margin-top: 32px
}

.house {
    padding: 80px 0 120px;
    background: #eef8ff
}

.house p.sub-title {
    margin: 24px 0 48px;
    color: #504043;
    font-size: 18px;
    line-height: 1.7
}

.house .content {
    color: #504043;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.house .content__item {
    max-width: 378px;
    border-radius: 8px;
    background-color: #fff;
    padding-bottom: 40px;
    -webkit-box-shadow: 0 6px 0 0 #d0dee9;
    box-shadow: 0 6px 0 0 #d0dee9
}

.house .content__item--title {
    background-color: #504043;
    height: 58px;
    padding: 8px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-top-right-radius: 8px;
    border-top-left-radius: 8px
}

.house .content__item--title span.content__item--sale {
    border-radius: 2px;
    position: relative;
    width: 88px;
    height: 42px;
    background: linear-gradient(315deg, #fbcd22 0, #ffe396 100%)
}

.house .content__item--title span.content__item--sale::before {
    display: inline-block;
    position: absolute;
    content: '売却金額';
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    left: 50%;
    background: linear-gradient(315deg, #fbcd22 0, #ffe396 100%);
    background: linear-gradient(114.05deg, #c44600 2.67%, #e15f00 98.22%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    font-size: 18px;
    font-weight: 900;
    width: 88px;
    text-align: center;
    height: 18px;
    line-height: 1
}

.house .content__item--title p {
    letter-spacing: .03em;
    background: #504043;
    display: inline-block;
    background: linear-gradient(315deg, #faae1c 0, #ffe396 52.6%, #fbcd22 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    font-size: 38px;
    font-weight: 900;
    line-height: 1.2;
    margin: 8px
}

.house .content__item--title p span.content__item--yen {
    font-size: 24px
}

.house .content__item dl {
    margin: 24px auto 0;
    max-width: 299px
}

.house .content__item dl dt {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 12px
}

.house .content__item dl dd {
    font-size: 18px;
    line-height: 1.5
}

.consult {
    background-color: #f7efe4;
    padding-top: 80px
}

.consult h2 {
    color: #946116
}

.consult .sub-title {
    font-size: 18px;
    line-height: 1.8;
    margin-top: 24px;
    text-align: center;
    color: #504043
}

.consult .content {
    max-width: 1200px;
    margin: 88px auto 0
}

.consult .content__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.consult .content__item picture {
    max-width: 472px;
    width: 39%
}

.consult .content__item .texts {
    max-width: 670px;
    width: 56%
}

.consult .content__item .texts span {
    color: #f29305;
    line-height: 1.5;
    font-weight: 700;
    letter-spacing: .05em;
    position: relative
}

.consult .content__item .texts span::after {
    display: inline-block;
    position: absolute;
    content: '';
    bottom: -12px;
    left: 0;
    width: 32px;
    height: 2px;
    background: #f29305
}

.consult .content__item .texts h3 {
    margin: 28px 0 24px;
    text-align: left;
    line-height: 1.4
}

.consult .content__item .texts p {
    font-size: 18px;
    line-height: 2
}

.consult .content__item:last-of-type {
    margin-top: 72px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.staff {
    background-color: #f7efe4;
    padding: 88px 0 120px
}

.staff h2 {
    color: #946116;
    margin-bottom: 48px
}

.staff .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1200px;
    margin: 0 auto;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.staff .content__item {
    max-width: 396px;
    background-color: #fff;
    border-radius: 8px;
    padding: 28px 0;
    width: 100%;
    color: #504043;
    -webkit-box-shadow: 0 6px 0 0 #e4d3bb;
    box-shadow: 0 6px 0 0 #e4d3bb
}

.staff .content__item picture {
    max-width: 340px;
    max-height: 320px;
    border-radius: 4px;
    display: block;
    margin: 0 auto
}

.staff .content__item .name {
    color: #504043;
    font-size: 20px;
    line-height: 1.5;
    letter-spacing: .4em;
    margin: 16px auto;
    font-weight: 700;
    text-align: center;
    height: auto
}

.staff .content__item dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 340px;
    margin: 0 auto;
    border-top: 1px solid #504043;
    -o-border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image: -webkit-gradient(linear, left top, right top, from(#504043), color-stop(14%, #504043), color-stop(15%, rgba(80, 64, 67, .1)), to(rgba(80, 64, 67, .1)));
    border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image-slice: 1
}

.staff .content__item dl dt {
    color: #504043;
    padding: 16px 0;
    max-width: 104px;
    width: 30%
}

.staff .content__item dl dd {
    padding: 16px 0;
    color: #504043;
    font-weight: 300
}

.staff .content__item dl:last-of-type {
    border-bottom: 1px solid #504043;
    -o-border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image: -webkit-gradient(linear, left top, right top, from(#504043), color-stop(14%, #504043), color-stop(15%, rgba(80, 64, 67, .1)), to(rgba(80, 64, 67, .1)));
    border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image-slice: 1
}

.staff .content__item p {
    max-width: 340px;
    margin: 0 auto;
    color: #504043;
    line-height: 2;
    padding: 16px 0;
    height: 288px
}

.staff .content__item p:last-of-type {
    height: auto;
    border-top: 1px solid #504043;
    -o-border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image: -webkit-gradient(linear, left top, right top, from(#504043), color-stop(14%, #504043), color-stop(15%, rgba(80, 64, 67, .1)), to(rgba(80, 64, 67, .1)));
    border-image: linear-gradient(90deg, #504043 0, #504043 14%, rgba(80, 64, 67, .1) 15%, rgba(80, 64, 67, .1) 100%);
    border-image-slice: 1
}

.faq {
    padding: 104px 0;
    background-color: #f7efe4
}

.faq h2 {
    color: #946116
}

.faq .content {
    margin-top: 48px;
    max-width: 920px
}

.faq .content dl {
    background: #fff;
    -webkit-box-shadow: 0 6px 12px rgba(90, 122, 145, .1);
    box-shadow: 0 6px 12px rgba(90, 122, 145, .1);
    border-radius: 8px;
    padding: 32px 40px
}

.faq .content dl dt {
    font-size: 20px;
    line-height: 1.5;
    margin-bottom: 16px;
    position: relative;
    padding-left: 63px
}

.faq .content dl dt::before {
    display: inline-block;
    position: absolute;
    content: '';
    background: url(../img/faq.png) no-repeat center center/contain;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 0;
    width: 46px;
    height: 46px;
    font-weight: 400;
    color: #f29305
}

.faq .content dl dd {
    font-size: 18px;
    font-weight: 400;
    padding-top: 24px;
    border-top: 1px solid rgba(80, 64, 67, .1);
    line-height: 1.8
}

.faq .content dl:nth-of-type(n+2) {
    margin-top: 24px
}

.contact {
    padding: 200px 0;
    background: #eef8ff
}

.contact .content {
    max-width: 1200px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.contact .content .titleWrap {
    text-align: left
}

.contact .content .titleWrap span {
    color: #0060a3;
    text-align: left
}

.contact .content .titleWrap h2 {
    margin: 8px 0 24px;
    line-height: 1.35;
    text-align: left;
}

.contact .content .titleWrap p {
    line-height: 2;
    color: #3f6f90;
    max-width: 384px;
    margin-bottom: 32px
}

.contact .content .titleWrap div {
    -webkit-box-shadow: 0 6px 12px rgba(90, 122, 145, .1);
    box-shadow: 0 6px 12px rgba(90, 122, 145, .1);
    border-radius: 4px;
    background: #fff;
    max-width: 368px;
    text-align: center;
    line-height: 1;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.contact .content .titleWrap div a {
    font-weight: 700;
    position: relative
}

.contact .content .titleWrap div a::before {
    display: inline-block;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 0
}

.contact .content .titleWrap div:hover {
    -webkit-box-shadow: 0 0 0;
    box-shadow: 0 0 0
}

.contact .content .titleWrap .form--line a {
    padding: 20px 0;
    display: block;
    background: linear-gradient(93.14deg, #15d363 -.1%, #18bf5c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent
}

.contact .content .titleWrap .form--line a::before {
    padding-top: 6px;
    content: url(../img/header_line.svg);
    width: 32px;
    height: 32px;
    background: linear-gradient(93.14deg, #15d363 -.1%, #18bf5c 100%);
    border-radius: 4px;
    left: 16px
}

.contact .content .titleWrap .form--tel {
    margin-top: 16px
}

.contact .content .titleWrap .form--tel a {
    padding: 16px 0;
    font-size: 24px;
    display: block
}

.contact .content .titleWrap .form--tel a::before {
    content: "";
    width: 18px;
    height: 24px;
    font-family: 'Font Awesome 5 Free';
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    font-weight: 900;
    left: 25px
}

.contact .content .form-box {
    width: 60%;
}

.contact .content .form {
    max-width: 720px;
    /*width: 60%;*/
    background-color: #fff;
    padding: 51px 0;
    border-radius: 8px;
    -webkit-box-shadow: 0 6px 0 rgba(90, 122, 145, .2);
    box-shadow: 0 6px 0 rgba(90, 122, 145, .2);
    height: 100%;
}

.contact .content .form__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 606px;
    margin: 0 auto 32px;
    width: 84%;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.contact .content .form__item label {
    font-size: 18px;
    line-height: 1.7;
    color: #032641
}

.contact .content .form__item input,
.contact .content .form__item select,
.contact .content .form__item textarea {
    width: 73%;
    max-width: 446px;
    border: 1px solid #c1d3df;
    border-radius: 6px;
    color: #032641;
    background-color: #f8fbfe;
    height: 48px;
    padding: 9px 14px 9px 20px;
    line-height: 2
}

.contact .content .form__item input:hover,
.contact .content .form__item select:hover,
.contact .content .form__item textarea:hover {
    cursor: pointer
}

.contact .content .form__item select {
    background: #eef3f6;
    border: none;
    color: #6a7f8e
}

.contact .content .form__item textarea {
    height: 88px
}

.contact .content .form__item:last-of-type {
    margin-bottom: 53px
}

.contact .content .form__item:nth-last-of-type(n+2) label {
    position: relative
}

.contact .content .form__item:nth-last-of-type(n+3) label::before {
    display: inline-block;
    position: absolute;
    content: '*';
    top: -18px;
    left: -9px;
    font-size: 18px;
    font-weight: 500;
    color: #c34600
}

.contact .content .form__item:nth-last-of-type(n+2) label::before {
    display: inline-block;
    position: absolute;
    content: '*';
    top: -18px;
    left: -9px;
    font-size: 18px;
    font-weight: 500;
    color: #c34600
}

.contact .content .form button {
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    border-radius: 4px;
    border: none;
    display: block;
    color: #fff;
    width: 100%;
    max-width: 606px;
    margin: 0 auto;
    font-size: 20px;
    padding: 27px 0;
    width: 84%;
    position: relative;
    padding-left: 32px;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.contact .content .form button::before {
    display: inline-block;
    position: absolute;
    content: "";
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 33%;
    width: 20px;
    height: 20px;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    color: #fff;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.contact .content .form button:hover {
    cursor: pointer;
    color: #4eb0f4;
    background: #fff;
    border: 2px solid #4eb0f4;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s
}

.contact .content .form button:hover::before {
    color: #4eb0f4
}

.contact .content .form p.error {
    font-size: 14px;
    margin-top: 8px;
    color: #c34600;
    display: block;
    width: 100%
}

.company {
    padding: 120px 0 168px
}

.company h2 {
    margin-bottom: 72px
}

.company span.sub-title {
    color: #0060a3
}

.company .content {
    max-width: 1040px;
    margin: 0 auto
}

.company .content dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    line-height: 1.5;
    color: #464646;
    font-size: 18px
}

.company .content dl dt {
    width: 22%;
    max-width: 228px;
    text-align: center;
    padding: 32px 0;
    border-top: 1px solid #4eb0f4;
    font-weight: 500
}

.company .content dl dd {
    padding: 32px 0;
    font-weight: 400;
    border-top: 1px solid rgba(78, 176, 244, .1);
    width: 78%;
    padding-left: 8.4%
}

.company .content dl dd a {
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
    position: relative;
    margin-left: 7.4%;
    font-weight: 400
}

.company .content dl dd a::before {
    display: inline-block;
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: -21px;
    width: 13px;
    height: 13px;
    background: url(../img/googleMap.svg);
    fill: #464646
}

.company .content dl dd a:hover {
    border-bottom: .5px solid #464646
}

.footer {
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    font-size: 16px;
    height: 120px;
    text-align: center;
    line-height: 24px;
    padding-top: 48px
}

.footer small {
    font-size: 16px;
    color: #fff
}

.complete {
    background: #eef8ff;
    height: 100vh
}

.complete .content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 120px 0 0;
    text-align: center
}

.complete .content h2 {
    font-size: 24px;
    margin-bottom: 80px
}

.complete .content p {
    color: #084b99;
    line-height: 2
}
.download-btn {
    margin:30px auto;
}
.download {
    background: linear-gradient(94.02deg, #4eb0f4 -.11%, #4e9bf4 99.89%);
    border-radius: 4px;
    border: none;
    display: block;
    color: #fff;
    width: 100%;
    max-width: 606px;
    margin: 0 auto;
    font-size: 20px;
    padding: 27px 0;
    width: 84%;
    position: relative;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
}
/* .download::before {
    display: inline-block;
    position: absolute;
    content: "";
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 33%;
    width: 20px;
    height: 20px;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    color: #fff;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
}
.download:hover::before {
    color: #4eb0f4;
} */
.download:hover {
    cursor: pointer;
    color: #4eb0f4;
    background: #fff;
    border: 2px solid #4eb0f4;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
}

.sp {
    display: none
}

.pc {
    display: block
}

.w320 {
    display: none
}

@media screen and (max-width:1200px) {
    .fv__aside--title h4 {
        font-size: 20px
    }

    .fv__aside--title h4::before {
        font-size: 13px
    }

    .about .content__item::before {
        font-size: 234px
    }

    .about .content__item:first-of-type {
        width: 80%
    }

    .about .content__item:first-of-type::before {
        left: -26%
    }

    .about .content__item:nth-of-type(2) {
        width: 80%
    }

    .about .content__item:nth-of-type(2)::before {
        right: -24%
    }

    .about .content__item:nth-of-type(2) dl {
        margin-left: 12px
    }

    .about .content__item:last-of-type {
        width: 80%
    }

    .about .content__item:last-of-type::before {
        left: -27%
    }

    .nigata .content {
        padding: 0 12px
    }

    .house .content__item {
        width: 33%
    }

    .consult {
        padding: 80px 12px 0
    }

    .staff .content__item {
        width: 33%;
        padding: 28px 6px
    }

    .contact {
        padding: 200px 12px
    }

    .company {
        padding: 120px 12px 168px
    }
}

@media screen and (max-width:1000px) {
    h2 {
        font-size: 24px;
        line-height: 1.35
    }

    span.sub-title {
        font-size: 12px;
        margin-bottom: 8px
    }

    .titleWrap p {
        font-size: 14px
    }

    .ctas {
        max-width: 386px;
        background-color: initial;
        padding: 0
    }

    .ctas .ctaWrap {
        display: block
    }

    .ctas .ctaWrap:first-of-type {
        padding: 0
    }

    .ctas .ctaWrap:last-of-type {
        padding: 0;
        border-top: none
    }

    .ctas .ctaWrap__item {
        padding: 28px 0;
        width: 100%
    }

    .ctas .ctaWrap__item::before {
        display: none
    }

    .ctas .ctaWrap__item span {
        font-size: 12px
    }

    .ctas .ctaWrap__item p {
        font-size: 18px
    }

    .ctas .ctaWrap__item:not(:first-of-type) {
        margin-top: 16px
    }

    .ctas .ctaWrap__item.form::after {
        right: 22px
    }

    .ctas .ctaWrap__item.line::after {
        top: 51%
    }

    .ctas .ctaWrap__item.tel {
        width: 100%;
        margin-top: 16px
    }

    .ctas .ctaWrap__item.tel::before {
        display: block;
        left: 16px;
        width: 40px;
        height: 40px;
        padding: 11px 14px 0
    }
    .ctas .ctaWrap .ctaWrap__item-content:first-of-type {
        width: 108%;
        
    }
    .ctas .ctaWrap .ctaWrap__item-content:last-of-type {
        width: 100%;
    }
    .ctas .ctaWrap__item.line {
        width: 100%;
    }
    .online.present02 {
        background: initial;
        padding: 4px 0 22px;
    }

    .ctas .ctaWrap__item.tel span {
        font-size: 12px
    }

    .ctas .ctaWrap__item.tel p {
        font-size: 28px
    }

    .ctas .ctaWrap__item.caution {
        margin-top: 24px;
        background-color: initial;
        padding: 0;
        max-width: initial;
        font-size: 12px;
        opacity: .7
    }

    .header {
        width: 95%;
        padding: 12px 8px
    }

    .header__logo {
        width: 58%
    }

    .header__content {
        display: none
    }

    .fv {
        position: relative
    }

    .fv .content {
        display: block;
        padding-top: 96px
    }

    .fv .content__item:first-of-type {
        max-width: 288px;
        width: 100%;
        margin: 0 auto
    }

    .fv .content__item:last-of-type {
        max-width: 440px;
        width: 120%;
        margin: -6% auto -2%
    }

    .fv .content__item:last-of-type picture {
        -webkit-transform: translate(0);
        transform: translate(0)
    }

    .fv__aside {
        display: block;
        position: relative;
        left: 0;
        z-index: 90;
        width: 100vw;
        -webkit-transform: skew(-5deg) rotate(-5deg);
        transform: skew(-5deg) rotate(-5deg);
        padding: 24px 0;
        border-radius: 0
    }

    .fv__aside::before {
        left: -7.5em;
        top: -52%;
        height: 200px
    }

    .fv__aside--title {
        margin-right: 0;
        text-align: center;
        display: block
    }

    .fv__aside--title h4 {
        font-size: 24px;
        margin-bottom: 24px
    }

    .fv__aside--title h4::before {
        font-size: 14px
    }

    .fv__aside--content {
        max-width: 280px;
        margin: 0 auto
    }

    .fv__aside--content span {
        font-size: 12px;
        padding: 8px
    }

    .fv__aside--content small {
        margin-top: 8px
    }

    .fv::after {
        position: absolute;
        bottom: 0;
        right: 0;
        content: '';
        background-color: #eef8ff;
        width: 100vw;
        height: 200px
    }

    .online {
        padding: 54px 16px 48px
    }

    .online .title {
        margin: 0 auto 32px;
        max-width: 386px
    }

    .online .title span {
        font-size: 13px
    }

    .online .title h3 {
        font-size: 24px;
        margin: 8px auto 16px
    }

    .online .title p {
        font-size: 14px
    }

    .worries {
        padding: 24px 5px 40px
    }

    .worries h3 {
        padding-top: 32px;
        font-size: 24px;
        margin-bottom: 24px
    }

    .worries h3::after {
        font-size: 40px;
        content: 'YOUR\AWORRIES';
        top: 0
    }

    .worries .content {
        max-width: 386px
    }

    .worries ul {
        padding: 40px 16px
    }

    .worries ul li {
        padding-left: 36px;
        font-size: 14px
    }

    .worries ul li::before {
        width: 20px;
        height: 20px;
        top: 10px
    }

    .worries ul li::after {
        width: 18px;
        height: 14px;
        left: 4px;
        top: 10px
    }

    .about {
        padding: 56px 16px 40px
    }

    .about .titleWrap::before {
        content: 'ABOUTUS';
        font-size: 40px
    }

    .about .content {
        margin-top: 16px;
        max-width: 386px
    }

    .about .content__item {
        display: block;
        width: 100%
    }

    .about .content__item::before {
        font-size: 220px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        background: linear-gradient(176.48deg, #4eb0f4 5.8%, rgba(78, 155, 244, 0) 94.2%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        text-fill-color: transparent;
        width: 220px
    }

    .about .content__item:first-of-type,
    .about .content__item:last-of-type {
        width: 100%
    }

    .about .content__item:first-of-type::before,
    .about .content__item:last-of-type::before {
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%)
    }

    .about .content__item:nth-of-type(2) {
        margin: 0;
        width: 100%
    }

    .about .content__item:nth-of-type(2)::before {
        left: 50%;
        right: initial
    }

    .about .content__item dl dt {
        font-size: 24px;
        margin-bottom: 0;
        padding: 0 12px;
        position: relative;
        z-index: 10;
        text-align: center
    }

    .about .content__item dl dd {
        font-size: 16px
    }

    .about .content__item dl picture {
        margin: 32px auto
    }

    .nigata {
        padding: 55px 16px 48px;
    }
    .online .title h3::before {
        left: -80px;
        top: 38px;
    }
    .online .title h3::after {
        right: -80px;
        top: 38px;
    }
    

    .nigata .content {
        display: block
    }

    .nigata .content h2 {
        margin: 0 auto
    }

    .nigata .content p {
        font-size: 14px;
        margin: 24px auto
    }

    .nigata .content__img {
        display: none
    }

    .nigata .content__item {
        padding-top: 20px;
        margin: 0 auto;
        max-width: 386px
    }

    .nigata .content::before {
        font-size: 48px;
        opacity: .5;
        top: 0
    }

    .nigata .content::after {
        content: '';
        background: 0 0
    }

    .danger {
        padding: 40px 16px
    }

    .danger .titleWrap {
        max-width: 386px;
        margin: 0 auto
    }

    .danger .titleWrap::before {
        font-size: 40px;
        content: 'DEMERIT\ARISK';
        top: 8px;
        letter-spacing: .13em
    }

    .danger .titleWrap h2 {
        display: block;
        padding: 24px 0 16px
    }

    .danger .titleWrap h2::after,
    .danger .titleWrap h2::before {
        height: 8px
    }

    .danger .titleWrap h2 span {
        font-weight: 700
    }

    .danger .titleWrap p {
        margin: 24px 0;
        font-size: 14px
    }

    .danger .content {
        width: 100%;
        display: block;
        max-width: 386px
    }

    .danger .content dl {
        padding: 24px 16px;
        width: 100%;
        margin-top: 24px
    }

    .danger .content dl dt {
        font-size: 16px;
        width: 100%;
        margin-bottom: 12px
    }

    .danger .content dl dd {
        padding-top: 12px;
        width: 100%;
        font-size: 14px
    }

    .danger .content dl dd ul li {
        line-height: 1.7
    }

    .danger .content dl dd ul span {
        font-size: 12px
    }

    .danger .content dl dd:nth-of-type(2) ul {
        font-size: 12px
    }

    .danger .content dl dd:nth-of-type(2) ul li {
        color: rgba(80, 64, 67, .7)
    }

    .danger .content dl dd:nth-of-type(2) ul a {
        font-size: 12px;
        color: rgba(80, 64, 67, .7);
        margin: 0;
        padding: 0;
        border: none;
        background: 0 0;
        width: 45px;
        border-bottom: .5px solid rgba(80, 64, 67, .7);
        border-radius: 0
    }

    .danger .content dl dd:nth-of-type(2) span {
        font-size: 12px
    }

    .danger .content dl:nth-of-type(3) dd ul li {
        font-size: 12px
    }

    .danger .content dl:last-of-type dd ul li ul li {
        padding: 0
    }

    .danger .content dl:nth-of-type(n+2) {
        margin-top: 24px
    }

    .house {
        padding: 48px 16px
    }

    .house p.sub-title {
        font-size: 16px;
        margin: 16px 0 32px
    }

    .house .content {
        display: block
    }

    .house .content__item {
        margin: 0 auto;
        width: 100%
    }

    .house .content__item dl {
        padding: 0 16px
    }

    .house .content__item dl dt {
        font-size: 12px
    }

    .house .content__item dl dd {
        font-size: 18px
    }

    .house .content__item:not(:first-of-type) {
        margin-top: 32px
    }

    .house .content__item--title p {
        font-size: 32px
    }

    .consult {
        padding: 48px 16px 0
    }

    .consult .sub-title {
        font-size: 16px;
        line-height: 1.7
    }

    .consult .content {
        margin-top: 32px;
        max-width: 386px
    }

    .consult .content__item {
        display: block
    }

    .consult .content__item picture {
        width: 100%
    }

    .consult .content__item .texts {
        width: 100%;
        margin-top: 32px
    }

    .consult .content__item .texts span {
        font-size: 14px
    }

    .consult .content__item .texts h3 {
        font-size: 32px
    }

    .consult .content__item .texts p {
        font-size: 16px
    }

    .consult .content__item:last-of-type {
        margin-top: 32px
    }

    .staff {
        padding: 32px 16px 48px
    }

    .staff .content {
        display: block
    }

    .staff .content__item {
        padding: 28px 16px;
        margin: 0 auto 6px;
        width: 100%
    }

    .staff .content__item picture {
        max-height: initial
    }

    .staff .content__item .name {
        font-size: 16px;
        padding: 0;
        margin: 16px 0 12px
    }

    .staff .content__item dl dt {
        font-size: 14px
    }

    .staff .content__item dl dd {
        font-size: 14px
    }

    .staff .content__item p {
        font-size: 14px;
        height: auto
    }

    .faq {
        padding: 48px 16px
    }

    .faq .content {
        margin-top: 24px;
        max-width: 386px
    }

    .faq .content dl {
        padding: 32px 16px
    }

    .faq .content dl dt {
        font-size: 16px;
        padding-left: 50px
    }

    .faq .content dl dt::before {
        width: 32px;
        height: 32px
    }

    .faq .content dl dd {
        font-size: 14px;
        padding-top: 24px
    }

    .contact {
        padding: 48px 16px
    }

    .contact .content {
        max-width: 384px;
        margin: 0 auto;
        display: block
    }

    .contact .content .titleWrap {
        text-align: center
    }

    .contact .content .titleWrap span {
        text-align: center;
        margin-bottom: 4px
    }

    .contact .content .titleWrap h2 {
        margin: 0 0 16px;
        text-align: center;
    }

    .contact .content .titleWrap p {
        text-align-last: left;
        margin-bottom: 24px
    }

    .contact .content .titleWrap .form--line a {
        padding: 20px 0 22px;
        font-size: 14px
    }

    .contact .content .titleWrap .form--tel a {
        padding: 16px 0 22px;
        font-size: 18px
    }

    .contact .content .titleWrap div {
        max-width: initial
    }

    .add-coupon {
        margin-top: 20px;
        margin-top: 12px;
        width: 100% !important;
    }

    .contact .content .form-box {
        width: 100%;
    }

    .contact .content .form {
        margin: 24px 0;
        width: 100%;
        padding: 32px 12px
    }

    .contact .content .form__item {
        max-width: initial;
        width: 100%;
        margin-bottom: 16px
    }

    .contact .content .form__item label {
        width: 100%;
        margin-bottom: 8px;
        font-size: 16px
    }

    .contact .content .form__item input,
    .contact .content .form__item select,
    .contact .content .form__item textarea {
        width: 100%;
        font-size: 14px
    }

    .contact .content .form__item:last-of-type {
        margin-bottom: 32px
    }

    .contact .content .form__item:nth-last-of-type(n+3) label::before {
        top: -14px;
        left: -3px
    }

    .contact .content .form button {
        font-size: 14px;
        width: 100%;
        padding-left: 22px
    }

    .contact .content .form button::before {
        height: 14px;
        left: 28%;
    }

    .company {
        padding: 48px 16px
    }

    .company .titleWrap h2 {
        margin-bottom: 32px
    }

    .company .content {
        max-width: 386px;
        margin: 0 auto
    }

    .company .content dl {
        display: block;
        padding: 16px 0;
        border-top: 1px solid #4eb0f4;
        -o-border-image: linear-gradient(90deg, #4eb0f4 0, #4eb0f4 21%, rgba(78, 176, 244, .1) 22%, rgba(78, 176, 244, .1) 100%);
        border-image: -webkit-gradient(linear, left top, right top, from(#4eb0f4), color-stop(21%, #4eb0f4), color-stop(22%, rgba(78, 176, 244, .1)), to(rgba(78, 176, 244, .1)));
        border-image: linear-gradient(90deg, #4eb0f4 0, #4eb0f4 21%, rgba(78, 176, 244, .1) 22%, rgba(78, 176, 244, .1) 100%);
        border-image-slice: 1
    }

    .company .content dl dt {
        font-size: 13px;
        margin-bottom: 8px;
        padding: 0;
        border: none;
        text-align: left;
        width: 100%;
        max-width: initial
    }

    .company .content dl dd {
        width: 100%;
        font-size: 14px;
        padding: 0;
        border: none
    }

    .company .content dl dd a {
        font-size: 12px;
        margin-left: 23px;
        border-bottom: .5px solid #504043
    }

    .footer {
        height: 138px;
        padding: 48px 24px;
        line-height: 1.5;
        text-align: center
    }

    .footer small {
        font-size: 14px
    }

    .sp {
        display: block
    }

    .pc {
        display: none
    }

    .w320 {
        display: none
    }
}

@media screen and (max-width:500px) {
    .fv .content__item:last-of-type {
        margin: -16% auto -4%
    }

    .fv__aside::before {
        left: -26%
    }
    .online .title h3 {
        font-size: 24px;
        margin: 8px auto 8px;
    }
    .ctas .ctaWrap__item {
        padding: 30px 0;
    }
    .online .title h3::before {
        /* left: -82px;
        top: 33px; */
        display:none;
    }
    .online .title h3::after {
        /* right: -82px;
        top: 33px; */
        display:none;
    }
    .ctas .ctaWrap__item.line::after {
        right: 30px;
    }
    .ctas .ctaWrap .ctaWrap__item-content:first-of-type img {
        position: relative;
        top: -39px;
        right: 0;
        left: -8px;
    }
    .ctas .ctaWrap .ctaWrap__item-content:first-of-type {
        width: 107%;
        height: 247px;
    }
    .ctas .attention-txt {
        display:none;
    }
    .ctas .ctaWrap .ctaWrap__item-content:last-of-type {
        width: 100%;
        padding-top: 0;
    }
    .ctas .ctaWrap__item.line {
        width: 100%;
    }
    .online .title p {
        text-align: center;
    }
    .ctas .ctaWrap:last-of-type {
        display: flex;
        flex-direction: column;
    }

    .ctas .ctaWrap__item.line {
        order: 1;
        margin-top: 20px;
    }

    .ctas .ctaWrap__item.tel {
        text-align: left;
        padding-left: 28%;
        order: 2;
        margin-top: 25px;
    }
    .ctas .ctaWrap__item.tel::before {
        display: block;
        left: 22px;
        width: 50px;
        font-size: 22px;
        height: 50px;
        padding: 14px 14px 0 19px;
    }
    .ctas .ctaWrap:last-of-type {
        padding: 0px;
        border-top: 1px solid rgba(80, 64, 67, .1)!important;
    }
    .ctas .ctaWrap__item.caution p {
        padding-bottom: 20px;
    }

    .about .content__item dl dt {
        text-align: left
    }
    .nigata {
        background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#bfe5ff));
        background: linear-gradient(0deg, #bfe5ff 0, #fff 100%);
        padding: 48px 16px;
    }
    .nigata .content {
        display:none;
    }
    .online {
        padding: 75px 16px 40px;
    }
    .online.present02 {
        background-color: transparent;
        padding: 0px;
    }
    .ctas .ctaWrap__item.form {
        /*margin: 24px 0;*/
    }
    .ctas .ctaWrap__item.form::after {
        right: 14px;
        left: initial;
    }
    .contact .content .titleWrap h2 {
        text-align: center;
    }
    .contact .content .form button::before {
        left: 26%;
    }
}


@media screen and (max-width:486px) {
    .sp {
        display: block
    }

    .pc {
        display: none
    }

    .w320 {
        display: block
    }

    .footer {
        text-align: left
    }
}
@media screen and (max-width:395px) {
.ctas .ctaWrap .ctaWrap__item-content:first-of-type img {
    position: relative;
    top: -28px;
    right: 0;
    left: -8px;
}
}
@media screen and (max-width:376px) {
.ctas .ctaWrap .ctaWrap__item-content:first-of-type img {
    top: -20px;
}
}