@charset "UTF-8";

/*--font----------------------*/

html {
  font-size: 62.5%;
}

body {
  font-size: 1.5rem;
  /* basic size 18px */
  background: #FFFFFF;
  color: #323232;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 500;
}

p {
  line-height: 2;
}

img {
  max-width: auto;
  width: 100%;
}

a {
  color: #323232;
  transition: .2s;
}

a:hover {
  transition: .2s;
}

.wrap {
  width: 100%;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

@media screen and (max-width:896px) {
  body {
    font-size: 1.5rem;
  }
}

sup {
  font-size: 80%;
  position: relative;
  top: -0.5em;
}


/*--container----------------------*/

.container {
  margin: 0 auto;
  width: 100%;
  max-width: 1660px;
}

@media screen and (max-width:1679px) {
  .container {
    width: 94%;
  }
}

@media screen and (max-width:480px) {
  .container {
    width: 92%;
  }
}


/*-------ぱんくず-----------------------------*/

ol.breadcrumb {
  padding: 0px;
  list-style: none;
  background-color: transparent;
  border-radius: 0;
  line-height: 50px;
  position: absolute;
  width: auto;
  display: inline-flex;
  justify-content: flex-start;
  font-size: 1.4rem;
  width: 100%;
  max-width: 1680px;
  left: 0;
  right: 0;
  margin: auto;
  top: 140px;
}

ol.breadcrumb li {
  list-style: none;
  color: #323232;
}

ol.breadcrumb li+li:before {
  content: ">";
  padding: 0 10px;
  font-family: neusa-next-std, sans-serif;
  font-weight: 500;
}

ol.breadcrumb li a {
  color: #003A60;
  white-space: nowrap;
  text-decoration: underline;
  font-family: neusa-next-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.05em;
}

ol.breadcrumb li a:hover {
  text-decoration: none;
}

ol.breadcrumb li a.nolink {
  pointer-events: none;
}

ol.breadcrumb li.active a {
  text-decoration: none;
  color: #323232;
}

@media screen and (max-width:1659px) {
  ol.breadcrumb {
    padding: 2% 2% 2% 3%;
    line-height: 1.6;
  }
}

@media screen and (max-width:896px) {
  ol.breadcrumb {
    font-size: 1.4rem;
    padding-left: 3%;
    top: 100px;
  }
}


/*------------- header NEW---------------------------------------------*/

.header {
  position: relative;
  border-bottom: 1px solid #F0EEEC;
  padding-top: 140px;
}

.headerMain {
  width: 100%;
  max-width: 1660px;
  height: 140px;
  align-items: center;
  font-family: neusa-next-std, sans-serif;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.02em;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: 0;
}

.headerMain .logo {
  width: 97px;
  position: relative;
  z-index: 4;
}

.spMenu, .spOnline {
  display: none;
}

.headNav {
  width: 80%;
}

.headNav .navMain {
  align-items: center;
  position: relative;
  z-index: 2;
}

.headNav .navMain li .arrow {
  display: none;
}

.headNav .navMain li a {
  border-bottom: 2px solid rgba(0, 58, 96, 0);
  padding: 0.2em 0.1em;
  font-size: 2rem;
}

.headNav .navMain li.clicked a {
  border-bottom: 2px solid rgba(0, 58, 96, 1.00);
}

.headNav .navMain li.about {
  margin-left: 3em;
}

.headNav .navMain li.online {
  margin-left: 3em;
}

.headNav .navMain li.online a {
  color: #FFFFFF;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 194px;
  height: 48px;
  font-size: 1.4rem;
  font-weight: 400;
  background: #65BA8C;
  border-radius: 4px;
  box-shadow: 0px 10px 50px 0px rgba(0, 58, 96, .1);
}

.headNav .navMain li.online a:hover {
  background: #508368;
  box-shadow: 0px 10px 30px 0px rgba(0, 58, 96, .3);
}

.headNav .navMain li.online a .label {
  position: relative;
  top: 0.1em;
}

.headNav .navMain li.online a img {
  width: 20px;
  margin-right: 13px;
}

.navSub {
  display: none;
  position: absolute;
  z-index: 3;
  background: #F9F8F7;
  padding: 1.8em 0 2em;
  width: 100%;
  left: 0;
  top: 140px;
}

.navSub ul {
  width: 46%;
  margin-left: 30%;
  min-width: 712px;
}

.navSub ul li {
  width: 33.333%;
}

.navSub-5 ul li {
  width: 100%;
}

.navSub ul li a {
  display: block;
  padding: 1em 1em;
  font-size: 1.6rem;
  align-items: center;
  font-family: neusa-next-std, sans-serif;
  font-weight: 500;
}

.navSub-1 {
  background: url("../images/common/header-pic_1.png") no-repeat center, #F9F8F7;
  background-size: 320px;
}

.navSub-2 {
  background: url("../images/common/header-pic_2.png") no-repeat center, #F9F8F7;
  background-size: 289px;
}

.navSub-3 {
  background: url("../images/common/header-pic_3.png") no-repeat center, #F9F8F7;
  background-size: 320px;
}

@media screen and (max-width:1659px) {
  .headerMain {
    padding: 0 2% 0 3%;
  }
  .headNav {
    width: 85%;
  }
  .headNav .navMain li {
    padding-right: 1em;
  }
  .headNav .navMain li.about {
    margin-left: 1em;
  }
  .headNav .navMain li.online {
    margin-left: 1em;
    padding-right: 0em;
  }
  .navSub ul {
    width: 50%;
    margin-left: 25%;
  }
}

@media screen and (max-width:1400px) {
  .headNav .navMain li a {
    font-size: 1.6vw;
  }
  .headNav .navMain li.online {
    margin-left: 0em;
  }
  .headNav .navMain li.online a {
    width: 160px;
  }
}

@media screen and (max-width:1200px) {
  .headNav {
    width: 70%;
    max-width: 588px;
    margin-top: 1em;
  }
  .headNav .navMain li a {
    font-size: 1.95rem;
  }
  .headNav .navMain li {
    padding-right: 0;
  }
  .headNav .navMain li:nth-child(1) {
    text-align: left;
    width: 22%;
  }
  .headNav .navMain li:nth-child(2) {
    text-align: center;
    width: 15%;
  }
  .headNav .navMain li:nth-child(3) {
    text-align: center;
    width: 38%;
  }
  .headNav .navMain li:nth-child(4) {
    text-align: right;
    width: 25%;
  }
  .headNav .navMain li:nth-child(5), .headNav .navMain li:nth-child(6), .headNav .navMain li:nth-child(7) {
    position: relative;
    top: 0.8em;
  }
  .headNav .navMain li.about {
    margin-left: 0;
  }
  .headNav .navMain li.online {
    margin-left: 0;
    margin-top: 1em;
    width: 32%;
    display: flex;
    justify-content: flex-end;
  }
  .navSub ul {
    width: 100%;
    min-width: auto;
    max-width: 588px;
    margin-left: 0;
    margin-left: calc(97% - 592px);
  }
}

@media screen and (max-width:896px) {
  .header {
    padding-top: 100px;
    z-index: 102;
  }
  .headerMain {
    width: 100%;
    height: 100px;
    padding: 0;
    z-index: 6;
  }
  .headerMain .logo {
    width: 59px;
    left: 3%;
  }
  .spMenu {
    display: block;
    position: relative;
    right: 4%;
    z-index: 2;
  }
  .spMenu img {
    width: 27px;
    height: 21px;
  }
  .spOnline {
    display: block;
    position: absolute;
    right: 90px;
    z-index: 1;
  }
  .spOnline img {
    width: 40px;
    height: 40px;
  }
  .headNav {
    width: 100%;
    max-width: 100%;
    display: none;
    background: #FFFFFF;
    position: absolute;
    top: 100px;
    margin-top: 0;
  }
  .headNav .navMain {
    width: 100%;
    background: #FFFFFF;
    border-top: 1px solid #A4A2A1;
  }
  .headNav .navMain li {
    width: 100%!important;
    position: relative;
    padding: 0;
    margin: 0!important;
    top: 0!important;
  }
  .headNav .navMain li .arrow {
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 5;
    padding-right: 5%;
    padding-left: 2%;
    height: 60px;
  }
  .headNav .navMain li .arrow img {
    width: 12px;
    position: relative;
    top: 1.4em;
  }
  .headNav .navMain li.clicked .arrow img {
    transform: rotate(180deg);
  }
  .headNav .navMain li a {
    padding: 0;
    padding-left: 3%;
    display: flex;
    align-items: center;
    border: none;
    border-bottom: 1px solid #A4A2A1;
    font-size: 1.6rem;
    width: 100%;
    height: 60px;
    box-sizing: border-box;
  }
  .headNav .navMain li.clicked a {
    border: none;
  }
  .headNav .navMain li:nth-child(7) a {
    border: none;
  }
  .headNav .navMain li.online a {
    width: 100%;
    height: 60px;
    font-size: 1.6rem;
    font-weight: 500;
    justify-content: flex-start;
    border: 0;
    border-radius: 0;
  }
  .navSub {
    display: none;
    z-index: 7;
    padding: 0;
    width: 100%;
    left: 0;
    top: 0px;
    opacity: 0;
    transform: .2s;
    background: #F0EEEC!important;
  }
  .navSub.active {
    opacity: 1;
  }
  .headNav .navMain li {
    transition: .4s;
    padding-bottom: 0px;
  }
  .headNav .navMain li.navMain-1.clicked {
    padding-bottom: 280px;
  }
  .headNav .navMain li.navMain-2.clicked {
    padding-bottom: 400px;
  }
  .headNav .navMain li.navMain-3.clicked {
    padding-bottom: 240px;
  }
  .headNav .navMain li.navMain-5.clicked {
    padding-bottom: 80px;
  }
  .navSub-1 {
    top: 160px;
  }
  .navSub-2 {
    top: 220px;
  }
  .navSub-3 {
    top: 280px;
  }
  .navSub-5 {
    top: 460px;
  }
  .navSub ul {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    border-top: 1px solid #A4A2A1;
  }
  .navSub ul li {
    width: 100%;
  }
  .navSub ul li a {
    display: flex;
    align-items: center;
    padding: 0;
    padding-left: 5%;
    height: 40px;
    border-bottom: 1px solid #A4A2A1;
  }
  .navSub ul li a:hover {
    background: #FFFFFF;
    color: #003A60;
  }
}

@media screen and (max-width: 480px) {
  .spMenu {
    right: 30px;
  }
}


/*トップページ用*/

.page-index .header {
  border-bottom: 0;
  padding-top: 0px;
  transition: .3s;
}

.page-index .header::after {
  transition: .4s;
  content: "";
  display: block;
  width: 100%;
  height: 140px;
  position: absolute;
  background: rgba(255, 255, 255, 0);
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
}

.page-index .header::after:hover {
  background: rgba(255, 255, 255, 1.00);
}

.page-index .header.active::after {
  background: rgba(255, 255, 255, 1.00);
}


/*商品一覧ページ用*/

.page-category .header {
  border-bottom: 0;
}

@media screen and (max-width:896px) {
  /*トップページ用*/
  .page-index .header {
    border-bottom: 0;
    padding-top: 0px;
    transition: .3s;
  }
  .page-index .header::after {
    height: 100px;
  }
  .page-index .header::after:hover, .page-index .header.active::after {
    background: rgba(255, 255, 255, 1.00);
  }
  .page-index .header::after:hover {
    background: rgba(255, 255, 255, 1.00);
  }
  .page-index .header.active::after {
    background: rgba(255, 255, 255, 1.00);
  }
}


/*------------- footer NEW---------------------------------------------*/

footer {
  position: relative;
  margin-bottom: -15px;
}


/*footerDeuter*/

.footerDeuter {
  background: #F9F8F7;
  padding: 4em 0 5em;
  font-family: neusa-next-std, sans-serif;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.02em;
}

.footerDeuter .dt-logo img {
  width: 107px;
  display: block;
  margin: 0 auto;
}

.footerDeuter .dt-sns {
  justify-content: center;
  margin-top: 2em;
  margin-bottom: 2em;
}

.footerDeuter .dt-sns li {
  width: 38px;
  margin: 0 0.8em;
}

.footerDeuter .dt-sns li:nth-child(1) {
  width: 42px;
  position: relative;
  top: -0.1em;
}

.footerDeuter .dt-nav ul {
  max-width: 1000px;
  margin: 0 auto;
  margin-bottom: 3em;
}

.footerDeuter .dt-nav ul li {
  font-size: 2rem;
}

.footerDeuter .dt-nav ul li.about {
  padding-left: 70px;
}

.footerDeuter .dt-nav .online a {
  color: #FFFFFF;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  height: 48px;
  width: 194px;
  font-size: 1.4rem;
  font-weight: 400;
  border-radius: 4px;
  background: #65BA8C;
  margin: 0 auto;
  padding-right: 0.2em;
  box-shadow: 0px 10px 50px 0px rgba(0, 58, 96, .1);
}

.footerDeuter .dt-nav .online a:hover {
  background: #508368;
  box-shadow: 0px 10px 30px 0px rgba(0, 58, 96, .3);
}

.footerDeuter .dt-nav .online a .label {
  position: relative;
  top: 0.04em;
}

.footerDeuter .dt-nav .online a img {
  width: 20px;
  margin-right: 15px;
  position: relative;
  top: -0.02em;
}

.footerDeuter .dt-nav .online a:hover {
  opacity: 0.9;
}


/*footerIp*/

.footerIp {
  background: #AAA8A7;
  color: #FFFFFF;
  padding: 1.35em 0;
  font-size: 90%;
}

.footerIp .container {
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1680px;
}

.footerIp .ip-left {
  align-items: center;
}

.footerIp .ip-logo {
  display: inline-block;
  width: 164px;
  margin-right: 2em;
}

.footerIp .ip-logo img {
  width: 100%;
}

.footerIp .ip-copyright {
  display: inline-block;
  font-weight: 300;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  font-family: neusa-next-std, sans-serif;
  font-weight: 400;
  font-style: normal;
}

.footerIp .ip-link {
  display: inline-flex;
}

.footerIp .ip-link li {
  margin-left: 15px;
}

.footerIp .ip-link li a {
  color: #FFFFFF;
  transition: .3s;
  font-weight: 300;
  font-size: 1.4rem;
}

@media screen and (max-width:1659px) {
  .footerIp .container {
    padding: 0 2% 0 2%;
  }
}

@media screen and (max-width:1200px) {
  .footerDeuter .dt-nav ul li {
    font-size: 1.95rem;
  }
  .footerDeuter .dt-nav ul {
    max-width: 640px;
    margin-bottom: 3em;
    justify-content: flex-start;
  }
  .footerDeuter .dt-nav ul li.about {
    padding-left: 0px;
  }
  .footerDeuter .dt-nav ul li:nth-child(1) {
    text-align: left;
    width: 22%;
  }
  .footerDeuter .dt-nav ul li:nth-child(2) {
    text-align: center;
    width: 15%;
  }
  .footerDeuter .dt-nav ul li:nth-child(3) {
    text-align: center;
    width: 38%;
  }
  .footerDeuter .dt-nav ul li:nth-child(4) {
    text-align: right;
    width: 25%;
    padding-right: 0;
  }
  .footerDeuter .dt-nav ul li:nth-child(5), .footerDeuter .dt-nav ul li:nth-child(6), .footerDeuter .dt-nav ul li:nth-child(7) {
    margin-right: 4em;
    margin-top: 1em;
  }
}

@media only screen and (max-width :960px) {
  /*footerIp*/
  .footerIp {
    padding: 1.35em 0 1.5em;
  }
  .footerIp .container {
    width: 94%;
    max-width: 480px;
  }
  .footerIp .ip-left {
    align-items: center;
  }
  .footerIp .ip-logo {
    display: block;
    margin: 0 auto;
  }
  .footerIp .ip-copyright {
    font-size: 1.6rem;
    text-align: center;
    width: 100%;
  }
  .footerIp .ip-link {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-top: 0.5em;
  }
  .footerIp .ip-link li {
    margin-left: 0;
  }
}

@media only screen and (max-width :896px) {
  .footerDeuter {
    padding: 3em 0 4em;
    ;
  }
  .footerDeuter .dt-logo img {
    width: 83px;
  }
  .footerDeuter .dt-sns {
    margin-top: 3em;
    margin-bottom: 3em;
  }
  .footerDeuter .dt-nav ul {
    width: 100%;
    justify-content: center;
    margin-bottom: 0;
  }
  .footerDeuter .dt-nav ul li {
    font-size: 2rem;
    width: 100%!important;
    text-align: center!important;
    margin-bottom: 1.8em;
  }
  .footerDeuter .dt-nav ul li:nth-child(5), .footerDeuter .dt-nav ul li:nth-child(6), .footerDeuter .dt-nav ul li:nth-child(7) {
    margin-right: 0em;
    margin-top: 0em;
  }
  .footerDeuter .dt-nav ul li.about {
    margin-top: 1em;
  }
}

@media only screen and (max-width :480px) {
  .footerIp .ip-copyright {
    font-size: 1.4rem;
  }
}


/*----PAGETOP-----------------------------------*/

#page-top {
  display: block;
  position: fixed;
  bottom: 20px;
  right: 20px;
  padding: 0;
  width: 60px;
  z-index: 101;
}

@media only screen and (max-width :896px) {
  #page-top {
    bottom: 0px;
    right: 10px;
    width: 50px
  }
}
