@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100&family=Noto+Sans+TC:wght@100;900&family=Noto+Serif+TC:wght@900&display=swap");
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

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

.container-outer {
  margin: 0 40px;
}

@media screen and (max-width: 540px) {
  .container-outer {
    margin: 0 10px;
  }
}

.container-inner {
  max-width: 1000px;
  margin: auto;
}

.d-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

body {
  background-color: #fb93a9;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-image: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.12'%3E%3Cpath d='M50 50c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10s-10-4.477-10-10 4.477-10 10-10zM10 10c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10S0 25.523 0 20s4.477-10 10-10zm10 8c4.418 0 8-3.582 8-8s-3.582-8-8-8-8 3.582-8 8 3.582 8 8 8zm40 40c4.418 0 8-3.582 8-8s-3.582-8-8-8-8 3.582-8 8 3.582 8 8 8z' /%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

nav {
  background-color: #ef3054;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 50;
}

nav .header-block {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 6px 0;
  position: relative;
}

nav .header-block .nav-logo {
  width: 180px;
}

@media screen and (max-width: 540px) {
  nav .header-block .nav-logo {
    width: 150px;
  }
}

nav .header-block .nav-logo img {
  width: 100%;
}

nav .header-block .nav-company {
  width: 30px;
  position: relative;
  cursor: pointer;
}

nav .header-block .nav-company img {
  width: 100%;
}

nav .header-block .cart-main {
  position: absolute;
  top: 3rem;
  right: -22px;
  display: none;
}

@media screen and (max-width: 540px) {
  nav .header-block .cart-main {
    right: -4px;
  }
}

nav .header-block .cart-main .cart-block {
  width: 250px;
  height: auto;
  background-color: #fff;
  border: 4px #313131 solid;
  border-radius: 12px;
  padding: 1rem;
}

@media screen and (max-width: 300px) {
  nav .header-block .cart-main .cart-block {
    width: 220px;
  }
}

nav .header-block .cart-main .cart-block table {
  display: table;
  border-collapse: separate;
  border-spacing: 8px;
}

nav .header-block .cart-main .cart-block table .title-top {
  color: #ef3054;
  font-weight: bold;
}

nav .header-block .cart-main .cart-block table tr .name {
  width: 60%;
}

nav .header-block .cart-main .cart-block table tr:first-child td:nth-child(n+2) {
  text-align: right;
}

nav .header-block .cart-main .cart-block table tr:nth-child(n+2) {
  color: #565656;
  font-size: 15px;
}

nav .header-block .cart-main .cart-block table tr:nth-child(n+2) a {
  color: #565656;
  text-decoration: none;
  line-height: 1.2;
  width: 50%;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

nav .header-block .cart-main .cart-block table tr:nth-child(n+2) a:active {
  color: #ff3f3f;
}

nav .header-block .cart-main .cart-block table tr:nth-child(n+2) td:nth-child(n+2) {
  text-align: right;
}

nav .header-block .cart-main .cart-block .go-cart-btn {
  width: 100%;
  background-color: #ff3f3f;
  border-radius: 5px;
  border: 0;
}

nav .header-block .cart-main .cart-block .go-cart-btn a {
  color: #fff;
  text-decoration: none;
  display: block;
  padding: 7px 10px;
}

nav .header-block .cart-main::after {
  content: "";
  position: absolute;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 20px;
  height: 20px;
  top: -11px;
  right: 24px;
  border: 4px solid #313131;
  background-color: #ffdf7b;
  z-index: -1;
}

@media screen and (max-width: 540px) {
  nav .header-block .cart-main::after {
    right: 14px;
  }
}

.bgfix {
  background: url(../img/main-bottom.png) no-repeat center bottom;
  background-size: contain;
  z-index: -1;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-width: 100%;
  height: 100%;
}

@media screen and (max-width: 1024px) {
  .bgfix {
    display: none;
  }
}

.transparent-bg {
  background: url(../img/main-bg.png) no-repeat center top;
  z-index: -3;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  height: 1715px;
}

@media screen and (max-width: 768px) {
  .transparent-bg {
    height: 85%;
    background-size: cover;
  }
}

header {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 1024px) {
  header {
    height: 100%;
    padding-bottom: 2.2rem;
  }
}

@media screen and (max-width: 320px) {
  header {
    height: 100%;
    padding-bottom: 1.3rem;
  }
}

header .header-outer {
  padding-top: 6rem;
}

@media screen and (max-width: 540px) {
  header .header-outer {
    padding-top: 4rem;
  }
}

header .header-title {
  width: 600px;
  margin: 0 auto;
}

@media screen and (max-width: 1024px) {
  header .header-title {
    width: 60%;
  }
}

@media screen and (max-width: 1024px) {
  header .header-title {
    width: 65%;
  }
}

@media screen and (max-width: 540px) {
  header .header-title {
    width: 75%;
  }
}

header .header-title img {
  width: 100%;
  height: auto;
}

header .header-award {
  width: 530px;
  margin: 0 auto;
  margin-top: 4rem;
}

@media screen and (max-width: 1024px) {
  header .header-award {
    width: 50%;
  }
}

@media screen and (max-width: 768px) {
  header .header-award {
    width: 56%;
    margin-top: 3rem;
  }
}

@media screen and (max-width: 540px) {
  header .header-award {
    width: 68%;
    margin-top: 2.5rem;
  }
}

header .header-award img {
  width: 100%;
}

header .title-banner {
  background: url(../img/title-banner.png) no-repeat center;
  position: absolute;
  width: 900px;
  height: 40vh;
  background-size: contain;
  margin: 0 auto;
  padding-top: 9.5rem;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
}

@media screen and (max-width: 1024px) {
  header .title-banner {
    height: 28vh;
    width: 80%;
  }
}

@media screen and (max-width: 768px) {
  header .title-banner {
    height: 28vh;
    width: 85%;
  }
}

@media screen and (max-width: 540px) {
  header .title-banner {
    width: 100%;
    height: 20vh;
    padding-top: 7.9rem;
  }
}

header .bg-ribbon {
  background: url(../img/ribbon.png) no-repeat center;
  position: absolute;
  width: 100vw;
  height: 40vh;
  background-size: contain;
  margin: 0 auto;
  padding-top: 9.5rem;
  z-index: -2;
  top: 3rem;
  left: 0;
  right: 0;
}

@media screen and (max-width: 1024px) {
  header .bg-ribbon {
    padding-top: 0;
    top: 0;
  }
}

header .woman-L {
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: -1;
  left: 0;
}

@media screen and (min-width: 1025px) {
  header .woman-L {
    display: none;
  }
}

header .woman-L .m-woman {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  width: 27%;
}

@media screen and (max-width: 540px) {
  header .woman-L .m-woman {
    bottom: 2rem;
    left: 0;
    width: 33%;
  }
}

header .woman-L .m-woman img {
  width: 100%;
}

header .woman-R {
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: -1;
  right: 0;
}

@media screen and (min-width: 1025px) {
  header .woman-R {
    display: none;
  }
}

header .woman-R .m-woman-R {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  width: 27%;
}

@media screen and (max-width: 540px) {
  header .woman-R .m-woman-R {
    bottom: 2rem;
    right: 0;
    width: 33%;
  }
}

header .woman-R .m-woman-R img {
  width: 100%;
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}

header .fire-block {
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: -2;
}

header .fire-L {
  left: 0;
}

header .fire-L .top-L-fire {
  position: absolute;
  top: 4rem;
  left: 4rem;
  width: 300px;
}

@media screen and (max-width: 1024px) {
  header .fire-L .top-L-fire {
    width: auto;
  }
}

@media screen and (max-width: 540px) {
  header .fire-L .top-L-fire {
    width: 50%;
    left: 0;
  }
}

header .fire-L .top-L-fire img {
  width: 100%;
}

header .fire-L .bottom-L-fire {
  position: absolute;
  bottom: 12rem;
  right: 20rem;
  width: 250px;
}

@media screen and (max-width: 1024px) {
  header .fire-L .bottom-L-fire {
    right: 16rem;
    width: auto;
  }
}

@media screen and (max-width: 540px) {
  header .fire-L .bottom-L-fire {
    width: 40%;
    bottom: 12rem;
    right: 5.5rem;
  }
}

header .fire-L .bottom-L-fire img {
  width: 100%;
}

header .fire-R {
  right: 0;
}

header .fire-R .top-R-fire {
  position: absolute;
  top: 9rem;
  right: 4rem;
  width: 350px;
}

@media screen and (max-width: 1024px) {
  header .fire-R .top-R-fire {
    width: 300px;
    right: 0rem;
  }
}

@media screen and (max-width: 768px) {
  header .fire-R .top-R-fire {
    width: 200px;
    right: 0rem;
  }
}

@media screen and (max-width: 540px) {
  header .fire-R .top-R-fire {
    width: 50%;
    top: 10.5rem;
    right: 0rem;
  }
}

header .fire-R .top-R-fire img {
  width: 80%;
}

header .fire-R .bottom-R-fire {
  position: absolute;
  bottom: 6rem;
  left: 19rem;
  width: 300px;
}

@media screen and (max-width: 540px) {
  header .fire-R .bottom-R-fire {
    width: 40%;
    bottom: 6rem;
    left: 7rem;
  }
}

header .fire-R .bottom-R-fire img {
  width: 80%;
}

main .container-inner {
  max-width: 900px;
}

main .container-outer {
  margin: 0 40px;
}

@media screen and (max-width: 768px) {
  main .container-outer {
    margin: 0 20px;
  }
}

main .container-outer-bottom {
  margin: 0 40px;
}

@media screen and (max-width: 768px) {
  main .container-outer-bottom {
    margin: 0 10px;
  }
}

main .container-inner-bottom {
  max-width: 960px;
  margin: 0 auto;
}

main .content_style {
  background-color: #f5ebbb;
  border-radius: 2.5rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 15px solid #ff3f3f;
  padding: 5rem;
  -webkit-box-shadow: 0px 0px 1px 6px #313131;
          box-shadow: 0px 0px 1px 6px #313131;
  position: relative;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  main .content_style {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2rem 1rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 3rem;
  }
}

@media screen and (max-width: 540px) {
  main .content_style {
    border: 6px solid #ff3f3f;
    -webkit-box-shadow: 0px 0px 1px 4px #313131;
            box-shadow: 0px 0px 1px 4px #313131;
    margin-top: 3rem;
  }
}

main .content_style .rank-top {
  position: absolute;
  top: -3rem;
  left: 2rem;
  width: 90px;
}

@media screen and (max-width: 540px) {
  main .content_style .rank-top {
    width: 20%;
    left: 1rem;
  }
}

@media screen and (max-width: 320px) {
  main .content_style .rank-top {
    top: -2rem;
  }
}

main .content_style .rank-top img {
  width: 100%;
}

main .content_style .content-top-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-right: 3rem;
  height: 280px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media screen and (max-width: 540px) {
  main .content_style .content-top-img {
    width: 50%;
    height: auto;
  }
}

main .content_style .content-top-img img {
  width: auto;
  height: 100%;
}

@media screen and (max-width: 540px) {
  main .content_style .content-top-img img {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  main .content_style .content-top-img {
    margin: auto;
  }
}

main .content_style .content-text-block {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  letter-spacing: 1px;
  width: 60%;
}

@media screen and (max-width: 768px) {
  main .content_style .content-text-block {
    width: 100%;
    text-align: center;
    margin-top: 2rem;
  }
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block {
    text-align: start;
  }
}

main .content_style .content-text-block h2 {
  font-size: 25px;
  font-weight: bold;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block h2 {
    font-size: 20px;
  }
}

main .content_style .content-text-block h2 a {
  color: #131313;
  text-decoration: none;
}

main .content_style .content-text-block p {
  line-height: 2;
  margin-bottom: 3rem;
  letter-spacing: 2px;
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block p {
    font-size: 14px;
  }
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block .text-pc {
    display: none;
  }
}

@media screen and (min-width: 541px) {
  main .content_style .content-text-block .text-m {
    display: none;
  }
}

main .content_style .content-text-block .bottom-text-block {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media screen and (max-width: 768px) {
  main .content_style .content-text-block .bottom-text-block {
    padding: 0 6rem;
  }
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block .bottom-text-block {
    padding: 0;
  }
}

@media screen and (max-width: 320px) {
  main .content_style .content-text-block .bottom-text-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

main .content_style .content-text-block .bottom-text-block .price-block {
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block .bottom-text-block .price-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

@media screen and (max-width: 320px) {
  main .content_style .content-text-block .bottom-text-block .price-block {
    margin-bottom: 10px;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

main .content_style .content-text-block .bottom-text-block b {
  color: #ff3f3f;
  font-size: 23px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: 25px;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}

@media screen and (max-width: 768px) {
  main .content_style .content-text-block .bottom-text-block b {
    margin-left: 20px;
    font-size: 27px;
  }
}

@media screen and (max-width: 540px) {
  main .content_style .content-text-block .bottom-text-block b {
    margin-left: 0;
    margin-top: 10px;
  }
}

@media screen and (max-width: 320px) {
  main .content_style .content-text-block .bottom-text-block b {
    margin-left: 15px;
  }
}

main .content_style .content-text-block .bottom-text-block b small {
  font-size: 16px;
}

main .content_style .content-text-block .bottom-text-block .btn-block {
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin-left: auto;
}

@media screen and (max-width: 320px) {
  main .content_style .content-text-block .bottom-text-block .btn-block {
    margin-left: 0;
  }
}

main .content_style .content-text-block .bottom-text-block .btn-block .more {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

main .content_style .content-text-block .bottom-text-block .btn-block .more a {
  background-color: #ff3f3f;
  color: #fff;
  padding: 8px 6px 8px 11px;
  border-radius: 10rem 0px 0px 10rem;
  border-top: 3px solid #313131;
  border-left: 3px solid #313131;
  border-bottom: 3px solid #313131;
  text-decoration: none;
  font-size: 13px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

@media screen and (max-width: 768px) {
  main .content_style .content-text-block .bottom-text-block .btn-block .more a {
    font-size: 16px;
  }
}

main .content_style .content-text-block .bottom-text-block .btn-block .more:hover a {
  background-color: #fbad32;
  color: #313131;
}

main .content_style .content-text-block .bottom-text-block .btn-block .company-btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

main .content_style .content-text-block .bottom-text-block .btn-block .company-btn a {
  background-color: #fff;
  width: 23px;
  border-radius: 0px 10rem 10rem 0px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 8px 11px 8px 6px;
  border: 3px solid #313131;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

main .content_style .content-text-block .bottom-text-block .btn-block .company-btn a img {
  width: 100%;
}

main .content_style .content-text-block .bottom-text-block .btn-block .company-btn a:hover {
  background-color: #fff1a2;
}

main .content_style:nth-child(2) {
  border: 15px solid #ff9900;
}

@media screen and (max-width: 540px) {
  main .content_style:nth-child(2) {
    border: 6px solid #ff9900;
  }
}

main .content_style:nth-child(2) .content-text-block .btn-block .more a {
  background-color: #ff9900;
}

main .content_style:nth-child(2) .content-text-block .btn-block .more a:hover {
  background-color: #ff3f3f;
  color: #fff;
}

@media screen and (max-width: 540px) {
  main .content_style:nth-child(2) .content-top-img {
    width: 25%;
  }
}

main .content_style:nth-child(3) {
  border: 15px solid #409dba;
}

@media screen and (max-width: 540px) {
  main .content_style:nth-child(3) {
    border: 6px solid #409dba;
  }
}

main .content_style:nth-child(3) .content-text-block .btn-block .more a {
  background-color: #409dba;
}

main .content-top-mt {
  margin-top: 8rem;
}

@media screen and (max-width: 540px) {
  main .content-top-mt {
    margin-top: 6.5rem;
  }
}

main .content_style::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 1.5rem;
  left: 1.5rem;
  background-color: #f5ebbb;
  border-radius: 2.5rem;
  border: 6px #313131 solid;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  main .content_style::after {
    top: 13px;
    left: 13px;
    border: 4px #313131 solid;
  }
}

main .award-bottom {
  margin-top: 5rem;
}

main .award-bottom .item-main {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

main .award-bottom .item-main .item-block {
  width: 25%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 768px) {
  main .award-bottom .item-main .item-block {
    width: 50%;
  }
}

@media screen and (max-width: 320px) {
  main .award-bottom .item-main .item-block {
    width: 100%;
  }
}

main .award-bottom .item-main .item-block-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 35px 15px;
  background: #fff;
  border-radius: 10px;
  border: 3px solid #313131;
  position: relative;
}

@media screen and (max-width: 768px) {
  main .award-bottom .item-main .item-block-inner {
    margin: 21px 8px;
  }
}

main .award-bottom .item-main .item-block-inner::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 5px;
  left: 5px;
  background-color: #ffe6bf;
  border-radius: 10px;
  border: 3px #313131 solid;
  z-index: -1;
}

main .award-bottom .item-main .rank-bottom {
  position: absolute;
  top: -16px;
  left: 12px;
  background: url(../img/rank.png);
  background-size: contain;
  width: 45px;
  height: 39px;
  background-repeat: no-repeat;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

main .award-bottom .item-main .rank-bottom p {
  font-size: 23px;
}

main .award-bottom .item-main .item-link {
  display: block;
  color: #313131;
  text-decoration: none;
  padding: 0 10px;
}

main .award-bottom .item-main .item-link .item_img {
  margin-top: 1rem;
}

main .award-bottom .item-main .item-link .item_img img {
  width: 100%;
}

main .award-bottom .item-main .item-link .item_title {
  margin-top: 0.5rem;
  font-weight: bold;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-height: 1.2;
}

main .award-bottom .item-main .item-bottom-block {
  margin-top: 1rem;
  padding: 15px 10px;
}

main .award-bottom .item-main .item-bottom-block del {
  font-size: 14px;
}

main .award-bottom .item-main .item-bottom-block .price {
  font-size: 24px;
  font-weight: bold;
  color: #ff3f3f;
}

main .award-bottom .item-main .item-bottom-block .price small {
  font-size: 13px;
}

main .award-bottom .item-main .item-bottom-block .cart-btn {
  position: absolute;
  right: 0;
  bottom: 2rem;
  background-color: #ffb94b;
  padding: 5px;
  border-radius: 10rem 0 0 10rem;
  border-top: 2px solid #313131;
  border-left: 2px solid #313131;
  border-bottom: 2px solid #313131;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

main .award-bottom .item-main .item-bottom-block .cart-btn a {
  text-decoration: none;
  color: #313131;
  font-weight: bold;
}

@media screen and (max-width: 540px) {
  main .award-bottom .item-main .item-bottom-block .cart-btn a {
    font-size: 14px;
  }
}

main .award-bottom .item-main .item-bottom-block .cart-btn:hover {
  background-color: #ff4c72;
}

main .award-bottom .item-main .item-bottom-block .cart-btn:hover a {
  color: #fff;
}

main .block-list {
  background-image: url(../img/decoline.png);
  height: 2rem;
  background-size: 100% auto;
  margin: 0 auto;
  background-repeat: no-repeat;
  margin-top: 3rem;
  margin-bottom: 3rem;
}

@media screen and (max-width: 540px) {
  main .block-list {
    margin-bottom: 2rem;
  }
}

main .class-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-bottom: 5rem;
}

main .class-main a {
  width: 25%;
  color: #313131;
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  main .class-main a {
    width: 50%;
  }
}

@media screen and (max-width: 320px) {
  main .class-main a {
    width: 100%;
  }
}

main .class-main .sort-block {
  background-color: #ffb94b;
  padding: 29px 20px;
  border-radius: 10px;
  border: 3px solid #313131;
  margin: 20px 30px;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}

@media screen and (max-width: 920px) {
  main .class-main .sort-block {
    margin: 20px 20px;
  }
}

@media screen and (max-width: 375px) {
  main .class-main .sort-block {
    margin: 15px 15px;
  }
}

main .class-main .sort-block span {
  width: 50px;
  margin-bottom: 10px;
}

main .class-main .sort-block span img {
  width: 100%;
}

main .class-main .sort-block p {
  font-size: 20px;
}

@media screen and (max-width: 540px) {
  main .class-main .sort-block p {
    font-size: 18px;
  }
}

main .class-main .sort-block .go-btn {
  text-align: center;
  background-color: #fff;
  border-radius: 50px;
  margin-top: 13px;
  padding: 5px 10px;
  width: 60%;
  border: 3px solid #313131;
  color: #313131;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

main .class-main .sort-block .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 0 10px 15px;
  border-color: transparent transparent transparent #313131;
}

@media screen and (max-width: 375px) {
  main .class-main .sort-block .triangle {
    display: none;
  }
}

@media screen and (max-width: 320px) {
  main .class-main .sort-block .triangle {
    display: block;
  }
}

main .class-main .sort-block::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 5px;
  left: 5px;
  background-color: #ffffff;
  border-radius: 10px;
  border: 3px #313131 solid;
  z-index: -1;
}

main .class-main .sort-block:hover .go-btn {
  background-color: #ffe77a;
}

footer {
  background-color: #313131;
  text-align: center;
  color: #fff;
  padding: 0.5rem;
  font-size: 14px;
}

.top {
  position: fixed;
  right: 2rem;
  bottom: 38vh;
  font-size: 12px;
  color: #2b2b2b;
  background-color: #ffffff;
  width: 4.5em;
  height: 4.5em;
  display: none;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  line-height: 1.25;
  font-weight: bold;
  border-radius: 10px;
  -webkit-box-shadow: 3px 3px 0px #1d1d1d;
          box-shadow: 3px 3px 0px #1d1d1d;
  border: 2px solid #313131;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

@media screen and (max-width: 1024px) {
  .top {
    width: 4em;
    height: 4em;
    bottom: 3vh;
    right: 1rem;
    background-color: #ffffffad;
  }
}

.top:hover {
  background-color: #ffb94b;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.top .arrow {
  display: block;
  width: 1px;
  border-width: 8px;
  border-style: solid;
  border-color: transparent transparent #131313 transparent;
  margin-top: 8px;
  margin-bottom: -8px;
  margin-left: auto;
  margin-right: auto;
}

.animal-trans-L {
  -webkit-animation: animal 15s infinite linear;
  -webkit-transform-origin: center center;
  transform-origin: center center;
  -webkit-animation-delay: 1s;
}

@-webkit-keyframes animal {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
  }
  100% {
    transform: rotate(-360deg);
    -ms-transform: rotate(-360deg);
    -webkit-transform: rotate(-360deg);
  }
}

.animal-trans-R {
  -webkit-animation: animal 15s infinite linear;
  -webkit-transform-origin: center center;
  transform-origin: center center;
  -webkit-animation-delay: 1s;
}

@-webkit-keyframes animal {
  0% {
    transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
  }
}

.slideUp {
  animation-name: slideUp;
  -webkit-animation-name: slideUp;
  animation-duration: 1s;
  -webkit-animation-duration: 1s;
  animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  visibility: visible !important;
}

@keyframes slideUp {
  0% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  50% {
    -webkit-transform: translateY(-8%);
            transform: translateY(-8%);
  }
  65% {
    -webkit-transform: translateY(4%);
            transform: translateY(4%);
  }
  80% {
    -webkit-transform: translateY(-4%);
            transform: translateY(-4%);
  }
  95% {
    -webkit-transform: translateY(2%);
            transform: translateY(2%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}

@-webkit-keyframes slideUp {
  0% {
    -webkit-transform: translateY(100%);
  }
  50% {
    -webkit-transform: translateY(-8%);
  }
  65% {
    -webkit-transform: translateY(4%);
  }
  80% {
    -webkit-transform: translateY(-4%);
  }
  95% {
    -webkit-transform: translateY(2%);
  }
  100% {
    -webkit-transform: translateY(0%);
  }
}

.slideDown {
  animation-name: slideDown;
  -webkit-animation-name: slideDown;
  animation-duration: 1s;
  -webkit-animation-duration: 1s;
  animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  visibility: visible !important;
}

@keyframes slideDown {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  50% {
    -webkit-transform: translateY(8%);
            transform: translateY(8%);
  }
  65% {
    -webkit-transform: translateY(-4%);
            transform: translateY(-4%);
  }
  80% {
    -webkit-transform: translateY(4%);
            transform: translateY(4%);
  }
  95% {
    -webkit-transform: translateY(-2%);
            transform: translateY(-2%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}

@-webkit-keyframes slideDown {
  0% {
    -webkit-transform: translateY(-100%);
  }
  50% {
    -webkit-transform: translateY(8%);
  }
  65% {
    -webkit-transform: translateY(-4%);
  }
  80% {
    -webkit-transform: translateY(4%);
  }
  95% {
    -webkit-transform: translateY(-2%);
  }
  100% {
    -webkit-transform: translateY(0%);
  }
}

.floating {
  animation-name: floating;
  -webkit-animation-name: floating;
  animation-duration: 2s;
  -webkit-animation-duration: 2s;
  animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
}

@keyframes floating {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  50% {
    -webkit-transform: translateY(10px);
            transform: translateY(10px);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}

@-webkit-keyframes floating {
  0% {
    -webkit-transform: translateY(0%);
  }
  50% {
    -webkit-transform: translateY(10px);
  }
  100% {
    -webkit-transform: translateY(0%);
  }
}

/* Bounce In */
.hvr-bounce-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}

.hvr-bounce-in:hover,
.hvr-bounce-in:focus,
.hvr-bounce-in:active {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
  -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
  transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

@media screen and (max-width: 768px) {
  .hvr-bounce-in:hover,
  .hvr-bounce-in:focus,
  .hvr-bounce-in:active {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

/* Bounce Out */
.hvr-bounce-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}

.hvr-bounce-out:hover,
.hvr-bounce-out:focus,
.hvr-bounce-out:active {
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
  -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
  transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}
/*# sourceMappingURL=style.css.map */