@charset "utf-8";
/*=========================================================================================================
    base
===========================================================================================================*/

#footer_shop a span:last-of-type {
  background: url(../images/common/icon_ecsite.svg) bottom left/contain no-repeat;
  display: inline-block;
  height: 1.25em;
  margin-right: 0.5em;
  vertical-align: middle;
  width: 1.25em;
}

/*=========================================================================================================
    Mobile
===========================================================================================================*/
@media only screen and (max-width: 767px) {

  @font-face {
    font-family: 'Ftr-Bk';
    src: url(../fonts/Ftr-Bk.woff) format('woff');
  }

  .pc-layout {
    display: none;
  }

  body {
    position: relative;
  }

  img {
    max-width: 90vw;
  }

/*--------------------
    header
----------------------*/
  header {
    color: #000;
  }

  header .header_logo h1 {
    padding: 6vw 0 6vw 3vw;
    position: relative;
    width: 65vw;
  }

  header .header_logo h1 img {

  }

/*--------------------
    navigation
----------------------*/
  header nav {
    background: #fff;
    color: #000;
    height: 100%;
    right: 0;
    position: fixed !important;
    top: 0;
    transform: translateX(100%);
    transition: .3s;
    width: 60vw !important;
    z-index: 3;
  }

  .nav_active {
    transform: translateX(0);
  }

  header nav ul {
    flex-direction: column;
    padding: 10vw 0 0 5vw !important;
  }

  header nav ul li a {
    color: #000;
    display: block;
    font-size: 1.4rem;
    padding:1.5em 0;
  }

/******* hamburger *******/
  #nav_button {
    background: rgba(255, 255, 255, .7);
    display: block;
    height: 50px;
    position: fixed;
    right: 4vw;
    text-align: center;
    top: 4vw;
    width: 50px;
    z-index: 4;
  }

  #nav_button span {
    border-bottom: 3px solid #000;
    display: block;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    transition: .35s ease-in-out;
    width: 30px;
  }

  #nav_button span:nth-of-type(1) {
    top: 9px;
  }

  #nav_button span:nth-of-type(2) {
    top: 18px;
  }

  #nav_button span:nth-of-type(3) {
    top: 27px;
  }

  #nav_button span:nth-of-type(4) {
    border: none;
    color: #000;
    font-size: .65rem;
    font-weight: bold;
    top: 34px;
  }

  .nav_active span:nth-of-type(1) {
    left: 10px !important;
    top: 18px !important;
    transform: rotate(-45deg) !important;
  }

  .nav_active span:nth-of-type(2),
  .nav_active span:nth-of-type(3) {
    left: 10px !important;
    top: 18px !important;
    transform: rotate(45deg) !important;
  }



/*--------------------
    footer
----------------------*/
  footer {
    background: #f44d80;
    color: #fff;
    margin-top: 15rem;
    padding-bottom: 5vw;
  }

  footer .footer_wrap > div {
    margin: 0;
    padding: 0;
    position: relative;
  }

  footer .footer_inner {

  }

  #footer_shop {
    height: auto;
    padding: 10vw 1vw 0;
    text-align: center;
    width: 100%;
  }

  #footer_shop a {
    border: 1px solid #fff;
    color: #fff;
    display: inline-block;
    font-size: 4vw;
    padding: 0.5em 1em;
    transition: .2s;
  }

  #footer_shop a:hover {
    color: #75dfea;
  }

  #footer_top h1 {
    margin: 12vw auto;
    width: 90vw;
  }

  #footer_top .footer_inner p {
    font-size: 3vw;
    font-weight: lighter;
    line-height: 2em;
    text-align: center;
  }

  #footer_middle {
    display: none;
  }

  footer ul {
    list-style: none;
  }

  #footer_bottom ul {
    padding: 0 20vw;
  }

  #footer_bottom ul li {
    margin: 1em 0;
  }

  #footer_bottom ul li:first-of-type {
    background: url(../images/common/icon_instagram.svg) center left/contain no-repeat;
  }

  #footer_bottom ul li:nth-of-type(2) {
    background: url(../images/common/icon_blog.svg) center left/contain no-repeat;
  }

  #footer_bottom ul li:last-of-type {
    background: url(../images/common/icon_blog.svg) center left/contain no-repeat;
  }

  #footer_bottom ul li a {
    color: #fff;
    display: block;
    font-size: 2.5vw;
    padding: 0.5em 0 0.5em 4em;
  }

  #footer_end {
    color: #fff;
    font-family: Ftr-Bk;
    font-size: 1rem !important;
    text-align: center;
  }

  #footer_end small {
    display: inline-block;
    transform: skew(-7deg);
  }

  #footer_shop a span {
    display: none !important;
  }

}

/*=========================================================================================================
    PC
===========================================================================================================*/
@media only screen and (min-width: 768px) {

  .sp-layout {
    display: none;
  }

  @font-face {
    font-family: 'NotoSans-Lt';
    src: url(../fonts/NotoSans-Lt.woff) format('woff');
  }

  @font-face {
    font-family: 'Ftr-Bk';
    src: url(../fonts/Ftr-Bk.woff) format('woff');
  }

  html {
    font-size: 62.5%;
  }

  body {
    color: #373737;
    font-family: NotoSans-Lt;
  }

  main {
    min-height: calc(100vh - 535px);
  }

/*--------------------
    header
----------------------*/
  header {
    color: #000;
  }

  header .header_logo h1 {
    height: 100px;
    position: relative;
    width: 300px;
  }

  header .header_logo h1 img {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

/*--------------------
    navigation
----------------------*/
  header nav ul {
    justify-content: end;
  }

  header nav ul li {
    max-width: 95px !important;
    padding: 0 !important;
  }

  header nav ul li a {
    color: #000;
    display: block;
    height: 55px;
    line-height: 55px;
    text-align: center;
    transition: .2s;
  }

  header nav ul li a:hover {
    color: #ff5a89;
  }

  header nav ul li a span {
    display: block;
    font-family: Ftr-Bk;
    font-size: 1.6em;
    transform: skew(-7deg);
  }

  /* header nav ul li:last-of-type a {
    background: #000 url(../images/common/icon_contact.svg) center center/45% no-repeat;
    color: #fff;
    transition: .2s;
  }

  header nav ul li:last-of-type a:hover {
    background: #ff5a89 url(../images/common/icon_contact.svg) center center/45% no-repeat;
  } */

/*--------------------
    footer
----------------------*/
  footer {
    background: #f44d80;
    color: #fff;
    margin-top: 15rem;
  }

  footer .footer_wrap > div {
    height: 250px;
    position: relative;
  }

  footer .footer_inner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  #footer_shop {
    height: auto;
    padding: 5em 1em 0;
    text-align: center;
    width: 100%;
  }

  #footer_shop a {
    border: 1px solid #fff;
    color: #fff;
    display: inline-block;
    font-size: 2em;
    padding: 0.5em 1em;
    transition: .2s;
  }

  #footer_shop a:hover {
    color: #75dfea;
  }

  #footer_top h1 {
    margin: 3rem 0;
    width: 36rem;
  }

  #footer_middle ul li,
  #footer_bottom ul li {
    margin: 1em 0;
  }

  #footer_bottom ul li:first-of-type {
    background: url(../images/common/icon_instagram.svg) center left/contain no-repeat;
  }

  #footer_bottom ul li:nth-of-type(2) {
    background: url(../images/common/icon_blog.svg) center left/contain no-repeat;
  }

  #footer_bottom ul li:last-of-type {
    background: url(../images/common/icon_blog.svg) center left/contain no-repeat;
  }

  #footer_middle ul li:before {
    content: "・";
  }

  #footer_middle ul li a,
  #footer_bottom ul li a {
    color: #fff;
    transition: .2s;
  }

  #footer_middle ul li a:hover,
  #footer_bottom ul li a:hover {
    color: #75dfea;
  }

  #footer_bottom ul li a {
    display: block;
    padding: 0.5em 0 0.5em 4em;
  }

  #footer_end {
    color: #fff;
    font-family: Ftr-Bk;
    font-size: 1rem !important;
    text-align: right;
  }

  #footer_end small {
    display: inline-block;
    transform: skew(-7deg);
  }



}
