@import"https://fonts.googleapis.com/css2?family=Oswald&display=swap";
@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap";

body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "游ゴシック", "Yu Gothic", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

header .img_top {
  width: auto;
  height: auto;
  margin: 0 auto;
}
@media screen and (min-width: 600px) {
  .pc_none {
    display: none;
  }
}
@media screen and (max-width: 599px) {
  .pc_none {
    display: none;
  }
}

footer {
  background-color: #e6e6e6
}

section {
  background-color: #fff;
  margin-bottom: calc((50/375)*100vw);
  padding: 0 5.3vw
}

@media screen and (min-width: 600px) {
  section {
    width: auto;
    margin: 0 3rem 3rem;
    padding: 0
  }
}

@media screen and (min-width: 1089px) {
  section {
    width: 860px;
    margin: 0 auto 3rem;
    padding: 0
  }
}

.summary {
  padding: 0
}

.attention {
  padding: 0
}

.contact {
  padding: 0
}

.float {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 1000;
  padding: 1rem;
  margin: 0;
  width: 100%;
  background-color: rgba(0, 0, 0, .5);
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: stretch;
  align-items: stretch
}

.float .float-inner {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: stretch;
  align-items: stretch
}

@media screen and (min-width: 600px) {
  .float {
    padding: 1rem 3rem
  }

  .float .float-inner {
    width: 860px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: stretch;
    align-items: stretch
  }
}

.float a {
  display: block;
  width: 100%
}

.float a:first-child {
  margin-right: .5rem
}

@media screen and (min-width: 600px) {
  .float a:first-child {
    margin-right: 28px
  }
}

.float a:hover {
  opacity: .85
}

.header__id-bar {
  background-color: #e0331b;
  color: #fff;
  padding: 1rem;
  text-align: center
}

.header__id-bar svg {
  display: block;
  margin: 0 auto
}

.kv {
  width: 100%;
  height: auto
}

@media screen and (min-width: 1089px) {
  .kv {
    background-color: #fff
  }
}

.kv__inner {
  background-color: #000;
  background: url("../img/kv_sp.jpg");
  margin: 0 auto;
  padding: 25px 0 40vw 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat
}

@media screen and (min-width: 600px) {
  .kv__inner {
    margin: 0 auto;
    padding: 75px 0 0 0;
    max-width: 1920px;
    height: 100vw;
    background: url("../img/kv.jpg");
    background-position: center;
    background-size: cover
  }
}

@media screen and (min-width: 1089px) {
  .kv__inner {
    margin: 0 auto;
    padding: 60px 0 0 0;
    max-width: 1530px;
    height: 822px;
    background: url("../img/kv.jpg");
    background-position: center;
    background-size: cover
  }
}

.kv__inner h1 {
  width: 90vw;
  margin: 0 auto 26px;
  padding: 0
}

@media screen and (min-width: 600px) {
  .kv__inner h1 {
    width: 90vw;
    margin: 0 auto 52px
  }
}

@media screen and (min-width: 1089px) {
  .kv__inner h1 {
    width: 860px;
    margin: 0 auto 41px
  }
}

.no-webp .kv__inner {
  background: url("../img/kv_sp.jpg")
}

@media screen and (min-width: 600px) {
  .no-webp .kv__inner {
    background: url("../img/kv.jpg")
  }
}

.pickup {
  list-style-type: none;
  margin: 0 auto;
  padding: 0;
  width: 90vw
}

@media screen and (min-width: 600px) {
  .pickup {
    width: 90vw;
    display: -ms-grid;
    display: grid;
    gap: .5rem;
    -ms-grid-rows: auto .5rem auto;
    -ms-grid-columns: 1fr .5rem 1fr;
    grid-template: "item1 item2"auto "item3 item4"auto/1fr 1fr
  }

  .pickup li:nth-child(1) {
    grid-area: item1
  }

  .pickup li:nth-child(2) {
    grid-area: item2
  }

  .pickup li:nth-child(3) {
    grid-area: item3
  }

  .pickup li:nth-child(4) {
    grid-area: item4
  }
}

@media screen and (min-width: 600px) {
  .pickup li:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1
  }

  .pickup li:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3
  }

  .pickup li:nth-child(3) {
    -ms-grid-row: 3;
    -ms-grid-column: 1
  }

  .pickup li:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 3
  }
}

@media screen and (min-width: 1089px) {
  .pickup {
    width: 860px;
    display: -ms-grid;
    display: grid;
    gap: .4rem;
    -ms-grid-rows: auto .4rem auto;
    -ms-grid-columns: 1fr .4rem 1fr;
    grid-template: "item1 item2"auto "item3 item4"auto/1fr 1fr
  }

  .pickup li:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1
  }

  .pickup li:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3
  }

  .pickup li:nth-child(3) {
    -ms-grid-row: 3;
    -ms-grid-column: 1
  }

  .pickup li:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 3
  }
}

.pickup li {
  margin-bottom: 4px
}

@media screen and (min-width: 600px) {
  .pickup li {
    margin: 0
  }
}

.usecase {
  padding-top: calc((25/375)*100vw)
}

@media screen and (min-width: 600px) {
  .usecase {
    padding: 44px 3rem 0;
    margin: 0 auto 4rem
  }
}

@media screen and (min-width: 1089px) {
  .usecase {
    padding: 44px 0 0
  }
}

.usecase p {
  margin: 0 auto 20px;
  padding: 0
}

@media screen and (min-width: 600px) {
  .usecase p {
    margin: 0 auto 36px
  }
}

.usecase p img {
  margin: 0 auto
}

@media screen and (min-width: 1089px) {
  .usecase p img {
    zoom: .8
  }
}

.usecase ul {
  list-style-type: none;
  margin: 0 auto;
  padding: 0;
  width: 90vw;
  display: -ms-grid;
  display: grid;
  gap: .5rem;
  -ms-grid-rows: 80px .5rem 80px .5rem 80px;
  -ms-grid-columns: 1fr .5rem 1fr;
  grid-template: "usecase1 usecase2"80px "usecase3 usecase4"80px "usecase5 usecase6"80px/1fr 1fr
}

.usecase ul li:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: usecase1
}

.usecase ul li:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: usecase2
}

.usecase ul li:nth-child(3) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: usecase3
}

.usecase ul li:nth-child(4) {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  grid-area: usecase4
}

.usecase ul li:nth-child(5) {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  grid-area: usecase5
}

.usecase ul li:nth-child(6) {
  -ms-grid-row: 5;
  -ms-grid-column: 3;
  grid-area: usecase6
}

@media screen and (min-width: 600px) {
  .usecase ul {
    width: auto;
    gap: .5rem;
    -ms-grid-rows: auto .5rem auto;
    -ms-grid-columns: 1fr .5rem 1fr .5rem 1fr;
    grid-template: "usecase1 usecase2 usecase3"auto "usecase4 usecase5 usecase6"auto/1fr 1fr 1fr
  }

  .usecase ul li:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1
  }

  .usecase ul li:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3
  }

  .usecase ul li:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5
  }

  .usecase ul li:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 1
  }

  .usecase ul li:nth-child(5) {
    -ms-grid-row: 3;
    -ms-grid-column: 3
  }

  .usecase ul li:nth-child(6) {
    -ms-grid-row: 3;
    -ms-grid-column: 5
  }
}

@media screen and (min-width: 1089px) {
  .usecase ul {
    width: 860px;
    gap: .5rem;
    -ms-grid-rows: auto .5rem auto;
    -ms-grid-columns: 1fr .5rem 1fr .5rem 1fr;
    grid-template: "usecase1 usecase2 usecase3"auto "usecase4 usecase5 usecase6"auto/1fr 1fr 1fr
  }

  .usecase ul li:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1
  }

  .usecase ul li:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3
  }

  .usecase ul li:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5
  }

  .usecase ul li:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 1
  }

  .usecase ul li:nth-child(5) {
    -ms-grid-row: 3;
    -ms-grid-column: 3
  }

  .usecase ul li:nth-child(6) {
    -ms-grid-row: 3;
    -ms-grid-column: 5
  }
}

.usecase li {
  margin-bottom: 4px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .usecase li {
    margin: 0
  }
}

.usecase li picture {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

.usecase li img {
  width: 100%;
  height: auto
}

.apply-tel, .apply-shop {
  background-color: #f8d5c1;
  margin-bottom: .5rem;
  border-radius: .5rem;
  padding: 1rem;
  display: -webkit-flex;
  display: flex
}

.apply-tel>*:nth-child(1), .apply-shop>*:nth-child(1) {
  -webkit-flex: 1;
  flex: 1;
  color: red
}

.apply-tel>*:nth-child(2), .apply-shop>*:nth-child(2) {
  -webkit-flex: 1.5;
  flex: 1.5
}

.attention h2 {
  background-color: #5d1a08;
  color: #fff;
  padding: .5rem;
  font-size: .7rem;
  text-align: center
}

.contact h2 {
  border: 1px solid #5d1a08;
  color: #5d1a08;
  padding: .5rem;
  font-size: .8rem;
  font-weight: normal;
  text-align: center
}

.loantype__tab {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: stretch;
  align-items: stretch
}

.loantype__tab .tab {
  cursor: pointer;
  width: 43.7vw;
  height: 18vw;
  padding: .5rem 0 0;
  background-color: #e7380d;
  color: #fff;
  border-radius: .5rem .5rem 0 0;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .loantype__tab .tab {
    width: 49.5%;
    height: auto;
    padding: 1.2rem 0 .6rem
  }
}

@media screen and (min-width: 1089px) {
  .loantype__tab .tab {
    height: auto;
    padding: 1rem 0 .6rem
  }
}

.loantype__tab .tab__web {
  background-color: #f08300
}

.loantype__tab .tab__web:hover {
  background-color: #ff900b
}

.loantype__tab .tab__shop {
  background-color: #e7380d
}

.loantype__tab .tab__shop:hover {
  background-color: #f2461b
}

@media screen and (min-width: 600px) {
  .loantype__tab .tab picture img {
    height: 2rem
  }
}

@media screen and (min-width: 1089px) {
  .loantype__tab .tab picture img {
    height: 3rem
  }
}

.loantype-web, .loantype-shop {
  padding: 0;
  margin-bottom: 3rem;
  display: none
}

.loantype-web.active, .loantype-shop.active {
  display: block
}

.loantype-inner__shop, .loantype-inner__web {
  background-color: #fffbda;
  border: calc((5/375)*100vw) solid #000;
  border-radius: 0 0 calc((7.5/375)*100vw) calc((7.5/375)*100vw);
  overflow: hidden
}

@media screen and (min-width: 600px) {
  .loantype-inner__shop, .loantype-inner__web {
    border: 6px solid #000
  }
}

.loantype-inner__shop {
  border-color: #e7380d
}

.loantype-inner__web {
  border-color: #f08300
}

.loantype__innercontent {
  display: -webkit-flex;
  display: flex
}

.loantype__innercontent>div {
  -webkit-flex: 1;
  flex: 1
}

.loantype__innercontent>div:first-child {
  border-right: 3px solid #e7380d
}

.loantype__innerhead {
  text-align: center;
  position: relative;
  font-size: calc((14/375)*100vw);
  font-weight: bold
}

@media screen and (min-width: 600px) {
  .loantype__innerhead {
    font-size: 1.2rem;
    font-weight: 600
  }
}

@media screen and (min-width: 1089px) {
  .loantype__innerhead {
    font-size: 1.5rem;
    font-weight: 600
  }
}

.loantype__innerhead p {
  padding: 1em
}

@media screen and (min-width: 600px) {
  .loantype__innerhead br {
    display: none
  }
}

.loantype__innerhead .fukidashiline img {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%
}

.loantype__innerhead .appdl {
  margin: 0;
  padding: 1rem 0 2rem
}

.loantype__innerhead .appdl a {
  display: block;
  width: 90%;
  margin: 0 auto
}

@media screen and (min-width: 600px) {
  .loantype__innerhead .appdl a {
    width: 60%;
    margin: 0 auto
  }
}

.loantype__innerhead .appdl a:hover {
  opacity: .85
}

.loantype__innerhead .appdl img {
  display: block;
  margin: 0 auto;
  padding: 0
}

@media screen and (min-width: 600px) {
  .loantype__innerhead .appdl img {
    width: 100%
  }
}

.loantype__innerhead .btn {
  background-color: #e95504;
  margin: calc((18/375)*100vw) auto calc((37/375)*100vw);
  width: 300px;
  height: 65px;
  border-radius: calc((7.5/375)*100vw);
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

.loantype__innersubhead {
  padding: .5rem;
  text-align: center;
  background-color: #ffd800
}

.loantype__innersubhead p {
  font-size: calc((22/375)*100vw);
  color: #e60012;
  font-weight: bold;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .loantype__innersubhead p {
    font-size: 36px;
    font-weight: 600
  }
}

.loantype__innersubhead p span {
  display: block;
  line-height: 1
}

.loantype__innersubhead p span.wrap {
  background-color: #fff;
  font-size: .9em;
  padding: .1em .5em;
  margin: 0 0 0 .2em;
  border-radius: 2em
}

.loantype-shop .loantype__innersubhead {
  padding: .8rem 0
}

.loantype-shop .loantype__innersubhead p {
  font-size: 1.6rem;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

.loantype-shop .loantype__innersubhead p span.wrap {
  margin-top: .5rem;
  font-size: .7em
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innersubhead p {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center
  }

  .loantype-shop .loantype__innersubhead p span.wrap {
    margin: 0 0 0 .5rem;
    font-size: .8em
  }
}

.loantype__inneroutline {
  margin: 0 0 3rem 0;
  text-align: center
}

@media screen and (min-width: 600px) {
  .loantype__inneroutline {
    margin: 0 0 6rem 0
  }
}

@media screen and (min-width: 1089px) {
  .loantype__inneroutline {
    margin: 0 0 6rem 0
  }
}

.loantype__inneroutline picture {
  padding: 1rem 2.5rem .1rem
}

@media screen and (min-width: 600px) {
  .loantype__inneroutline picture {
    padding: 1.3rem 1.3rem .7rem
  }
}

.loantype__inneroutline img {
  height: auto;
  margin: 0 auto
}

.loantype__inneroutline p {
  font-size: calc((12/375)*100vw);
  font-weight: 400
}

@media screen and (min-width: 600px) {
  .loantype__inneroutline p {
    font-size: 1rem;
    font-weight: 400
  }

  .loantype__inneroutline p br {
    display: none
  }
}

.loantype-shop .loantype__inneroutline {
  margin: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  padding-bottom: 1rem
}

.loantype-shop .loantype__inneroutline picture {
  padding: 0;
  height: 5rem;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__inneroutline picture {
    padding: 1.3rem 1.3rem .7rem
  }
}

.loantype-shop .loantype__inneroutline img {
  width: 6.8rem;
  height: auto;
  margin: 0 auto
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__inneroutline img {
    max-height: 100%;
    max-width: 100%;
    height: auto;
    width: auto
  }
}

.loantype-shop .loantype__inneroutline p {
  font-size: calc((16/375)*100vw);
  font-weight: 600;
  letter-spacing: .15em
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__inneroutline p {
    font-size: 1.6rem;
    letter-spacing: .2em
  }
}

.loantype-shop .loantype__innerdetail {
  background-color: #fff000;
  font-size: calc((11/375)*100vw);
  border-bottom: 3px solid #e7380d;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  height: 6rem
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innerdetail {
    padding: 0 0 1em 0;
    height: auto
  }
}

.loantype-shop .loantype__innerdetail picture {
  padding: 0;
  height: 5rem;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innerdetail picture {
    padding: 1.3rem 1.3rem .7rem
  }
}

.loantype-shop .loantype__innerdetail img {
  width: 6.8rem;
  height: auto;
  margin: 0 auto
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innerdetail img {
    max-height: 100%;
    max-width: 100%;
    height: auto;
    width: auto
  }
}

.loantype-shop .loantype__innerdetail p {
  font-size: calc((16/375)*100vw);
  font-weight: 600;
  letter-spacing: .15em
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innerdetail p {
    font-size: 1.6rem;
    letter-spacing: .2em
  }
}

.loantype-shop .loantype__innerdetail .note {
  max-width: 75%;
  margin: 0 auto;
  text-indent: -1em;
  padding: 0 0 0 1em;
  font-size: .5rem
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__innerdetail .note {
    font-size: .8rem;
    font-weight: normal
  }
}

.loantype__process {
  position: relative;
  background-color: #fff;
  border: 2px solid #f08300;
  border-radius: calc((7.5/375)*100vw);
  margin: 1rem;
  padding: 20px 0 0
}

@media screen and (min-width: 600px) {
  .loantype__process {
    border-radius: .8rem
  }
}

.loantype__process .fukidashiline img {
  display: block;
  margin: .2rem 0 .5rem 0;
  padding: 0;
  width: 100%
}

.loantype__process h3 {
  background-color: #f08300;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  color: #fff;
  font-size: 13px;
  width: 175px;
  height: 30px;
  position: absolute;
  top: -15px;
  left: 50%;
  margin: 0 0 0 -87.5px;
  border-radius: calc((7.5/375)*100vw)
}

@media screen and (min-width: 600px) {
  .loantype__process h3 {
    font-size: 1.3rem;
    line-height: 1;
    padding: .9rem 3.5em;
    height: auto;
    width: auto;
    border-radius: .7rem;
    top: -1.55rem;
    margin: 0 0 0 -6em
  }
}

.loantype-inner__shop .loantype__process {
  border: 2px solid #e7380d
}

.loantype-inner__shop .loantype__process h3 {
  background-color: #e7380d
}

.step {
  display: -ms-grid;
  display: grid;
  gap: .3rem;
  -ms-grid-rows: auto .3rem auto .3rem auto;
  -ms-grid-columns: 1fr;
  grid-template: "title"auto "img"auto "desc"auto/1fr
}

.step .step-title, .step .step-img, .step .step-description {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

.step .step-title {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: title;
  margin: 0 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5
}

.step .step-img {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: img;
  margin: 0 0
}

.step .step-description {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  grid-area: desc;
  margin: 0 1rem .5rem;
  font-size: .8rem;
  font-weight: 400;
  line-height: 1.5
}

.step .mid {
  font-size: 1.2rem
}

.step .large {
  font-size: 1.5rem
}

.step .bold {
  font-weight: 600
}

.step .red {
  color: #e60012
}

@media screen and (min-width: 600px) {
  .step {
    padding: 1.5rem 1.5rem;
    gap: 0rem;
    -ms-grid-rows: auto 0rem auto;
    -ms-grid-columns: 1fr 0rem 4fr;
    grid-template: "img title"auto "img desc"auto/1fr 4fr
  }

  .step .step-title, .step .step-description {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    padding: 0;
    margin: 0
  }

  .step .step-title {
    font-size: 2rem
  }

  .step .step-img {
    padding: 0 1.5rem 0 0
  }

  .step .step-title {
    -ms-grid-row: 1;
    -ms-grid-column: 3
  }

  .step .step-img {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1
  }

  .step .step-description {
    -ms-grid-row: 3;
    -ms-grid-column: 3
  }
}

.loantype-shop .loantype__goodrate .arrowhead {
  margin-top: -3px;
  background-color: #fff000
}

.loantype-shop .loantype__goodrate .arrowhead svg {
  display: block;
  max-width: 100%;
  height: auto
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__goodrate .arrowhead svg {
    width: 100%;
    height: 3rem
  }
}

.loantype-shop .loantype__goodrate .arrowbody {
  position: relative;
  z-index: 10;
  background-color: #e50012;
  color: #fff;
  text-align: center;
  padding: .5rem .5rem 0;
  margin: 0 auto;
  max-width: 300px;
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__goodrate .arrowbody {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: flex-end;
    align-items: flex-end;
    padding: .5rem 1rem
  }
}

.loantype-shop .loantype__goodrate p {
  font-size: calc((16/375)*100vw);
  font-weight: 600;
  letter-spacing: .15em;
  line-height: 1
}

.loantype-shop .loantype__goodrate p:nth-child(2) {
  font-size: calc((18/375)*100vw);
  letter-spacing: .1em
}

.loantype-shop .loantype__goodrate p:nth-child(2) .mid {
  font-size: calc((23/375)*100vw)
}

.loantype-shop .loantype__goodrate p:nth-child(2) .large {
  font-size: calc((42/375)*100vw);
  font-family: "Oswald", sans-serif
}

@media screen and (min-width: 600px) {
  .loantype-shop .loantype__goodrate p {
    font-size: 1.5rem;
    letter-spacing: .25em
  }

  .loantype-shop .loantype__goodrate p:nth-child(2) {
    font-size: 1.5rem;
    letter-spacing: .25em
  }

  .loantype-shop .loantype__goodrate p:nth-child(2) .mid {
    font-size: 2rem
  }

  .loantype-shop .loantype__goodrate p:nth-child(2) .large {
    font-size: 2.6rem;
    font-family: "Oswald", sans-serif
  }
}

.loantype__mtrx picture {
  padding: 1rem 0 0
}

.loantype__mtrx picture img {
  margin: 0 auto
}

@media screen and (min-width: 600px) {
  .loantype__mtrx picture {
    padding: 1rem 1rem 0
  }
}

.loantype__terms {
  border: 2px solid #000;
  width: 95%;
  margin: 1rem auto 0;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto auto auto;
  -ms-grid-columns: 2fr 1fr;
  grid-template: "tex tex"auto "ter1 ter2"auto "ter3 ter4"auto/2fr 1fr
}

.loantype__terms div {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  padding: .1em .5rem
}

.loantype__terms div>p {
  font-size: .7rem
}

.loantype__terms div ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-size: .7rem
}

.loantype__terms div ul li:before {
  content: "●";
  font-size: 1rem;
  line-height: .7rem;
  color: #e7380d;
  margin-right: .1rem
}

.loantype__terms div:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: tex;
  text-align: center;
  background-color: #e7380d;
  color: #fff
}

.loantype__terms div:nth-child(1)>p {
  font-size: .8rem;
  font-weight: 600
}

.loantype__terms div:nth-child(2) {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: ter1;
  border-bottom: 2px dashed #000;
  background-color: #fff
}

.loantype__terms div:nth-child(3) {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
  grid-area: ter2;
  border-bottom: 2px dashed #000;
  background-color: #ffd800;
  -webkit-align-items: center;
  align-items: center
}

.loantype__terms div:nth-child(4) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: ter3;
  background-color: #fff
}

.loantype__terms div:nth-child(5) {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
  grid-area: ter4;
  background-color: #ffd800;
  -webkit-align-items: center;
  align-items: center
}

.loantype__note {
  width: 95%;
  margin: 0 auto 2.5rem;
  font-size: .7rem;
  padding: .5rem 0
}

.compare {
  margin: 1rem auto 1rem;
  padding: 0;
  width: 90vw;
  border-radius: calc((7/375)*100vw);
  overflow: hidden;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto auto auto auto auto auto auto;
  -ms-grid-columns: 1fr 1fr;
  grid-template: "comtitle comtitle"auto "feat-a1 feat-b1"auto "feat-a2 feat-b2"auto "feat-a3 feat-b3"auto "mtrx mtrx"auto "mtrx-abt mtrx-bbt"auto "feat-a4 feat-b4"auto/1fr 1fr
}

@media screen and (min-width: 600px) {
  .compare {
    width: auto;
    margin: 0 3rem 75px;
    padding: 0;
    border-radius: .7rem
  }
}

@media screen and (min-width: 1089px) {
  .compare {
    width: 860px;
    margin: 0 auto 75px;
    padding: 0;
    border-radius: .7rem
  }
}

.compare .section-title {
  height: 3.5em;
  margin-bottom: .65rem;
  text-align: center;
  font-size: calc((23/375)*100vw);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: .05em;
  color: #fff;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .compare .section-title {
    font-size: 2rem;
    height: auto;
    padding: 1rem 0
  }

  .compare .section-title br {
    display: none
  }
}

.compare .loan-summary .header {
  height: 3em
}

.compare .feature-a, .compare .feature-b {
  margin-bottom: .5em
}

.compare .feature-a {
  background-color: rgba(240, 131, 0, .2);
  margin-right: .5em
}

.compare .feature-b {
  background-color: rgba(0, 113, 188, .2);
  margin-left: .5em
}

.compare .header {
  height: 3.5em;
  text-align: center;
  font-size: calc((14/375)*100vw);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: .1em;
  color: #fff;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center
}

@media screen and (min-width: 600px) {
  .compare .header {
    font-size: 1.2rem;
    height: auto;
    padding: 1rem 0
  }

  .compare .header br {
    display: none
  }
}

.compare .header-a {
  background-color: #f08300
}

.compare .header-b {
  background-color: #0071bc
}

.compare .section-title {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: comtitle;
  background-color: #f08300
}

.compare .feat-a1 {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: feat-a1
}

.compare .feat-a2 {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: feat-a2
}

.compare .feat-a3 {
  -ms-grid-row: 4;
  -ms-grid-column: 1;
  grid-area: feat-a3;
  margin-bottom: 0
}

.compare .feat-a4 {
  -ms-grid-row: 7;
  -ms-grid-column: 1;
  grid-area: feat-a4;
  margin-bottom: 0
}

.compare .feat-b1 {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
  grid-area: feat-b1
}

.compare .feat-b2 {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
  grid-area: feat-b2
}

.compare .feat-b3 {
  -ms-grid-row: 4;
  -ms-grid-column: 2;
  grid-area: feat-b3;
  margin-bottom: 0
}

.compare .feat-b4 {
  -ms-grid-row: 7;
  -ms-grid-column: 2;
  grid-area: feat-b4;
  margin-bottom: 0
}

.compare .mtrx {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: mtrx
}

.compare .mtrx-abt {
  -ms-grid-row: 6;
  -ms-grid-column: 1;
  grid-area: mtrx-abt;
  height: .8em;
  margin: 0 .5em .5em 0;
  background-color: rgba(240, 131, 0, .2)
}

.compare .mtrx-bbt {
  -ms-grid-row: 6;
  -ms-grid-column: 2;
  grid-area: mtrx-bbt;
  height: .8em;
  margin: 0 0 .5em .5em;
  background-color: rgba(0, 113, 188, .2)
}

.compare .title {
  font-size: calc((14/375)*100vw);
  padding: 1em 1em .3em;
  text-align: center;
  line-height: 1.2;
  font-weight: 600
}

@media screen and (min-width: 600px) {
  .compare .title {
    font-size: 1.6rem
  }
}

.compare .feature-a .title span {
  color: #e60012
}

.compare .feature-b .title span {
  color: #0071bc
}

.compare .text {
  font-size: calc((12/375)*100vw);
  padding: 0 1.5em 1.5em;
  line-height: 1.3
}

@media screen and (min-width: 600px) {
  .compare .text {
    font-size: 1rem
  }
}

.simulation {
  width: 90vw;
  margin: calc((50/375)*100vw) auto;
  padding: 0
}

.simulation a {
  display: block;
  height: auto
}

.simulation a:hover {
  opacity: .85
}

.simulation img {
  width: 100%;
  height: auto;
  margin: calc((18/375)*100vw) auto calc((37/375)*100vw)
}

@media screen and (min-width: 600px) {
  .simulation img {
    margin: 0
  }
}

@media screen and (min-width: 600px) {
  .simulation {
    width: 65%;
    margin: 0 auto 75px;
    padding: 0 3rem 0
  }
}

@media screen and (min-width: 1089px) {
  .simulation {
    width: 480px;
    margin: 0 auto 75px;
    padding: 0
  }
}

.summary {
  width: 90vw;
  margin: 1rem auto;
  color: #5d1a08;
  font-size: .8rem
}

@media screen and (min-width: 600px) {
  .summary {
    width: auto;
    margin: 0 auto 0;
    padding: 0 3rem 1rem
  }
}

@media screen and (min-width: 1089px) {
  .summary {
    width: 860px;
    margin: 0 auto 1rem;
    padding: 0
  }
}

.summary h2 {
  background-color: #5d1a08;
  color: #fff;
  padding: 1.2rem 1rem .3rem;
  font-size: calc((15/375)*100vw);
  font-weight: 600;
  line-height: 1;
  text-align: center;
  border-radius: calc((7/375)*100vw);
  cursor: pointer
}

.summary h2:hover {
  opacity: .8
}

.summary h2 span {
  display: block;
  font-size: .8rem;
  line-height: 1;
  padding: .5rem 0
}

.summary h2 span.open {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg)
}

.summary h2 span picture {
  padding: 0 0 0
}

.summary h2 span picture img {
  margin: 0 auto
}

.summary h2+div {
  display: none
}

.summary h2+div.active {
  display: block
}

@media screen and (min-width: 600px) {
  .summary h2 {
    font-size: 1.6rem;
    border-radius: .8rem
  }

  .summary h2 br {
    display: none
  }
}

.summary h3 {
  background-color: #daccc7;
  color: #5d1a08;
  margin: 1rem 0;
  padding: .2rem 1rem;
  text-align: center;
  font-weight: normal;
  font-size: calc((13.5/375)*100vw);
  font-weight: 600
}

@media screen and (min-width: 600px) {
  .summary h3 {
    font-size: 1.2rem
  }
}

.summary p {
  line-height: 1.3
}

@media screen and (min-width: 600px) {
  .summary p {
    font-size: 1rem
  }
}

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

@media screen and (min-width: 600px) {
  .summary table {
    width: 60%;
    margin: 0 auto
  }
}

.summary tr, .summary th, .summary td {
  border: 1px solid #5d1a08;
  padding: .2rem
}

.summary tr.center, .summary th.center, .summary td.center {
  text-align: center
}

.summary tr {
  font-size: calc((14.5/375)*100vw)
}

@media screen and (min-width: 600px) {
  .summary tr {
    font-size: .9rem
  }
}

.summary th {
  background-color: #5d1a08;
  color: #fff;
  font-size: calc((10/375)*100vw);
  font-weight: 400
}

@media screen and (min-width: 600px) {
  .summary th {
    font-size: .9rem
  }
}

.summary td {
  font-size: calc((14.5/375)*100vw)
}

@media screen and (min-width: 600px) {
  .summary td {
    font-size: .9rem
  }
}

.summary .small tr {
  font-size: calc((9/375)*100vw)
}

@media screen and (min-width: 600px) {
  .summary .small tr {
    font-size: .9rem
  }
}

.summary .small th {
  background-color: #5d1a08;
  color: #fff;
  font-size: calc((10/375)*100vw);
  font-weight: 400
}

@media screen and (min-width: 600px) {
  .summary .small th {
    font-size: .9rem
  }
}

.summary .small td {
  font-size: calc((9/375)*100vw)
}

@media screen and (min-width: 600px) {
  .summary .small td {
    font-size: .9rem
  }
}

.summary ul, .summary ol {
  list-style-type: none;
  margin: 0 0 .5rem 0;
  padding: 0;
  line-height: 1.5
}

@media screen and (min-width: 600px) {
  .summary ul, .summary ol {
    font-size: .9rem
  }
}

@media screen and (min-width: 600px) {
  .summary .caption {
    width: 60%;
    font-size: .8rem;
    margin: 0 auto
  }
}

.summary .col2 {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  align-items: flex-start
}

.summary .nowrap {
  margin: 0 0 0 1rem;
  display: inline-block;
  white-space: nowrap
}

.summary .disc>li {
  margin: 0 0 0 1.2rem;
  text-indent: -1.2rem
}

.summary .disc>li::before {
  content: "●";
  display: inline;
  font-size: .8rem;
  line-height: .8rem;
  vertical-align: middle;
  margin-right: .2rem
}

@media screen and (min-width: 600px) {
  .summary .disc>li::before {
    font-size: 1rem
  }
}

.summary .num {
  margin: 0 0 0 1.2rem;
  text-indent: -1.2rem
}

.summary .note {
  font-size: .7rem
}

@media screen and (min-width: 600px) {
  .summary .note {
    font-size: 1rem
  }
}

.summary .note>li {
  margin: 0 0 0 1rem;
  text-indent: -0.8rem
}

.summary .note>li::before {
  content: "※";
  display: inline;
  font-size: .9rem;
  line-height: .8rem;
  vertical-align: 0;
  margin-right: .2rem
}

.summary .note-nostyle {
  font-size: .7rem
}

@media screen and (min-width: 600px) {
  .summary .note-nostyle {
    font-size: 1rem
  }
}

.summary .cell__header {
  background-color: #e3d9d4
}

footer {
  padding: 1rem 1rem 8rem;
  margin: 3rem 0 0 0
}

footer .contact {
  background-color: transparent
}

@media screen and (min-width: 600px) {
  footer .contact {
    width: 540px;
    margin: 0 auto
  }
}

footer .contact h2 {
  margin-bottom: 1rem;
  font-size: calc((14.5/375)*100vw);
  color: #000;
  padding: .3rem
}

@media screen and (min-width: 600px) {
  footer .contact h2 {
    font-size: 1rem
  }
}

footer .contact .call {
  margin-bottom: 1.5rem
}

footer .footer__id {
  background-color: transparent
}

footer .footer__id svg {
  display: block;
  margin: 0 auto;
  max-width: calc((157/375)*100vw);
  height: auto
}

@media screen and (min-width: 600px) {
  footer .footer__id svg {
    max-width: 250px
  }
}
