@import url(https://fonts.googleapis.com/earlyaccess/mplus1p.css);
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
figure {
  margin: 0;
  padding: 0;
}

@media only screen and (min-width: 1200px) {
  .row {
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
  }
}

.rows {
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
}

@media only screen and (min-width: 1200px) {
  .grid4 {
    width: 25%;
  }
}

@media only screen and (min-width: 1200px) {
  .grid6 {
    width: 50%;
  }
}

body {
  background: linear-gradient(to bottom, #f5f5f5 0%, #f0f9fd 100%);
  margin: 0;
  padding: 0;
}

img {
  max-width: 100%;
  height: auto;
}

.bg_body {
  padding: 0 0 20px;
  margin: 0 auto;
  max-width: 1350px;
  background-color: #fff;
  box-shadow: 0 0 8px gray;
}

.wrap {
  padding: 0;
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .wrap {
    max-width: 767px;
  }
}
@media only screen and (min-width: 1200px) {
  .wrap {
    max-width: 1200px;
  }
}

@media only screen and (max-width: 767px) {
  .topimg {
    margin: 0;
    padding: 0;
    text-align: center;
  }
}
@media only screen and (min-width: 1200px) {
  .topimg {
    margin: 0 0 10px;
    padding: 0;
    text-align: center;
  }
}

/* --------------------------------
 * menu
 * -------------------------------- */
@media only screen and (max-width: 767px) {
  .dropmenu_container {
    display: none;
  }
}
@media only screen and (min-width: 1200px) {
  .dropmenu_container {
    width: 100%;
    height: 45px;
    background-color: #fff;
    margin: 0;
  }
}

@media only screen and (min-width: 768px) {
  #dropmenu {
    list-style-type: none;
    width: 760px;
    padding: 0;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 1024px) {
  #dropmenu {
    list-style-type: none;
    width: 1018px;
    padding: 0;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 1200px) {
  #dropmenu {
    list-style-type: none;
    width: 1200px;
    margin: 0 auto;
    padding: 0;
    cursor: pointer;
  }
}

#dropmenu li {
  position: relative;
  float: left;
  margin: 0 2px;
  padding: 0;
  text-align: center;
  width: 24.6%;
}

#dropmenu li a {
  display: block;
  margin: 0;
  padding: 14px 0;
  background: #8fd5e1;
  color: #fff;
  font-weight: bold;
  line-height: 1;
  text-decoration: none;
  border-radius: 7px;
}
@media only screen and (min-width: 1200px) {
  #dropmenu li a {
    font-size: 18px;
  }
}

#dropmenu li ul {
  list-style: none;
  position: absolute;
  z-index: 100;
  top: 100%;
  left: 0;
  width: 100%;
  margin: 0;
  padding: 0;
}

#dropmenu li ul li {
  overflow: hidden;
  width: 100%;
  height: 0;
  color: #000;
  transition: .2s;
  margin: 0;
}

#dropmenu li ul li a {
  padding: 13px 15px;
  background: #fafeff;
  color: #000;
  text-align: left;
  font-size: 14px;
  font-weight: normal;
  border-radius: 0;
}

#dropmenu > li:hover > a {
  background: #96deea;
}

#dropmenu > li:hover li:hover > a {
  background: #96deea;
}

#dropmenu li:hover > ul > li {
  overflow: visible;
  height: auto;
}

#dropmenu li ul li ul {
  top: 0;
  left: 100%;
}

#dropmenu li:last-child ul li ul {
  left: -100%;
  width: 100%;
}

#dropmenu li ul li ul li a {
  background: #fafeff;
}

#dropmenu li:hover ul li ul li:hover > a {
  background: #96deea;
}

#dropmenu li ul li ul:before {
  position: absolute;
  content: "";
  top: 13px;
  left: -20px;
  width: 0;
  height: 0;
  border: 5px solid transparent;
  border-left-color: #000;
}

#dropmenu li:last-child ul li ul:before {
  position: absolute;
  content: "";
  top: 13px;
  left: 200%;
  margin-left: -20px;
  border: 5px solid transparent;
  ZZborder-right-color: #000;
}

#accordion {
  margin: 5px 0 10px;
}
@media only screen and (min-width: 1200px) {
  #accordion {
    display: none;
  }
}

#accordion ul {
  margin: 0;
  padding: 0;
}

#accordion ul li {
  list-style: none;
  background: #8fd5e1;
  border-bottom: #fff solid 1px;
  text-align: center;
  padding: 15px 0;
}

#accordion li a {
  color: #fff;
  text-decoration: none;
}

#accordion ul li ul li {
  list-style: none;
  background: #fff;
  text-align: center;
  padding: 15px 0;
}

.close {
  display: none;
}

/* --------------------------------
 * entry
 * -------------------------------- */
@media only screen and (max-width: 767px) {
  .entry {
    padding: 0;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 768px) {
  .entry {
    max-width: 760px;
    padding: 0;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 1024px) {
  .entry {
    max-width: 1018px;
    padding: 0;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 1200px) {
  .entry {
    max-width: 1200px;
    padding: 20px 0 0;
    margin: 0 auto 30px;
  }
}

#text {
  text-align: center;
  margin: 0;
  padding: 9px 0 6px;
  font-size: 1.3em;
  font-weight: bold;
  background-color: #00afcc;
  color: #fff;
}
@media only screen and (max-width: 767px) {
  #text {
    margin: 0 3px;
    font-size: 20px;
  }
}
@media only screen and (min-width: 768px) {
  #text {
    font-size: 1.3em;
  }
}

@media only screen and (max-width: 767px) {
  .newarrivalContainer {
    padding: 0;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrivalContainer {
    padding: 0;
    margin: 0;
  }
}

.newarrival {
  width: 100%;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .newarrival {
    margin: 10px 0 0;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival {
    margin: 10px 0 0;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival {
    margin: 10px 0 0;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival {
    margin: 10px 0 0;
  }
}
.newarrival .item-list {
  flex-wrap: wrap;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block {
    width: 50%;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block {
    width: 25%;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block {
    width: 25%;
  }
}
.newarrival .item-list .block .box {
  padding: 8px 0;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box {
    width: calc(100% - 7px);
    margin: 0 auto 20px;
    padding: 0;
    border: #ccc solid 1px;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box {
    width: calc(100% - 13px);
    margin: 0 auto 20px;
    padding: 0;
    border: #ccc solid 1px;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box {
    width: calc(100% - 13px);
    margin: 0 auto 20px;
    padding: 0;
    border: #ccc solid 1px;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box {
    width: calc(100% - 13px);
    margin: 0 auto 20px;
    padding: 0;
    border: #ccc solid 1px;
  }
}
.newarrival .item-list .block .box figure {
  width: 100%;
  position: relative;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box figure {
    background-color: #eee;
    box-sizing: border-box;
    padding: 20px;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box figure {
    background-color: #eee;
    box-sizing: border-box;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box figure {
    background-color: #eee;
    box-sizing: border-box;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box figure {
    background-color: #eee;
    box-sizing: border-box;
  }
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box figure img {
    max-width: 90%;
    max-height: 90%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box figure img {
    max-width: 90%;
    max-height: 90%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box figure img {
    max-width: 93%;
    max-height: 93%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box figure img {
    max-width: 100%;
    max-height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box figure .spacer {
    padding-bottom: 100%;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box figure .spacer {
    padding-bottom: 97%;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box figure .spacer {
    padding-bottom: 97%;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box figure .spacer {
    padding-bottom: 97%;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box figure:hover img {
    opacity: 0.7;
  }
}
.newarrival .item-list .block .box .detail h4 {
  line-height: 21px;
  overflow: hidden;
  background-color: #888;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box .detail h4 {
    white-space: normal;
    text-overflow: ellipsis;
    height: 3.2em;
    font-size: 0.8rem;
    margin: 0;
    padding: 3px 4px;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box .detail h4 {
    white-space: normal;
    text-overflow: ellipsis;
    height: 3.2em;
    font-size: 0.8rem;
    margin: 0;
    padding: 3px 4px;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box .detail h4 {
    white-space: normal;
    text-overflow: ellipsis;
    height: 3.2em;
    font-size: 0.8rem;
    margin: 0;
    padding: 3px 4px;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box .detail h4 {
    white-space: normal;
    text-overflow: ellipsis;
    height: 3.2em;
    font-size: 0.8rem;
    margin: 0;
    padding: 3px 4px;
  }
}
.newarrival .item-list .block .box .detail h4 a {
  color: #fff;
  text-decoration: none;
  font-weight: normal;
  vertical-align: middle;
  text-align: center;
}
.newarrival .item-list .block .box .detail h4 a:hover {
  text-decoration: underline;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box .detail .price {
    margin: 10px 0 2px 0;
    color: #000;
    font-size: 0.9em;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box .detail .price {
    margin: 10px 0 2px 0;
    color: #000;
    font-size: 0.9em;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box .detail .price {
    margin: 10px 0 2px 0;
    color: #000;
    font-size: 0.9em;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box .detail .price {
    margin: 10px 0 2px 0;
    color: #000;
    font-size: 0.9em;
  }
}
.newarrival .item-list .block .box .detail .itemDetail {
  display: inline-block;
  border-radius: 5px;
  color: #fff;
  background-color: #ccc;
}
@media only screen and (max-width: 767px) {
  .newarrival .item-list .block .box .detail .itemDetail {
    padding: 4px 40px 4px 40px;
    margin-bottom: 10px;
    font-size: 0.8rem;
  }
}
@media only screen and (min-width: 768px) {
  .newarrival .item-list .block .box .detail .itemDetail {
    padding: 4px 40px 4px 40px;
    margin-bottom: 10px;
    font-size: 0.8rem;
  }
}
@media only screen and (min-width: 1024px) {
  .newarrival .item-list .block .box .detail .itemDetail {
    padding: 4px 40px 4px 40px;
    margin-bottom: 10px;
    font-size: 0.8rem;
  }
}
@media only screen and (min-width: 1200px) {
  .newarrival .item-list .block .box .detail .itemDetail {
    padding: 4px 40px 4px 40px;
    margin-bottom: 10px;
    font-size: 0.8rem;
    transition-duration: 300ms;
    transition-property: border,background;
  }
  .newarrival .item-list .block .box .detail .itemDetail:hover {
    background-color: #D3D3D3;
  }
}
.newarrival .item-list .block .box .detail .itemDetail a {
  display: block;
  color: #fff;
  text-decoration: none;
}

@media only screen and (max-width: 767px) {
  .more_link {
    font-family: 'Noto Sans Japanese';
    text-align: center;
    color: #fff;
    background-color: #00afcc;
    border-radius: 20px;
    padding: 3px 0;
    margin: 5px auto 0;
    width: 170px;
  }
  .more_link a {
    text-decoration: none;
    color: #fff;
    font-size: 18px;
  }
}
@media only screen and (min-width: 1200px) {
  .more_link {
    font-family: 'Noto Sans Japanese';
    text-align: center;
    color: #fff;
    background-color: #00afcc;
    border-radius: 20px;
    padding: 3px 0;
    margin: 5px auto 0;
    width: 170px;
  }
  .more_link:hover {
    opacity: 0.5;
  }
  .more_link a {
    text-decoration: none;
    color: #fff;
    font-size: 18px;
  }
  .more_link a:hover {
    color: #fff;
  }
}

/* --------------------------------
 * topics
 * -------------------------------- */
@media only screen and (max-width: 767px) {
  .ta_container {
    margin: 25px 3px 20px;
  }
}
@media only screen and (min-width: 1200px) {
  .ta_container {
    max-width: 1200px;
    margin: 20px auto 30px;
  }
}

h3 {
  text-align: center;
  font-size: 36px;
  color: #00afcc;
  font-weight: bold;
  border-bottom: #00afcc solid 4px;
  margin: 0 0 8px;
}

h1 {
  text-align: center;
  margin: 0 auto 10px;
  padding: 8px 0 8px;
  font-size: 1.3em;
  font-weight: bold;
  background-color: #00afcc;
  color: #fff;
}
h1:first-child {
  margin-top: 0;
}
h1 img {
  padding-right: 10px;
}
@media only screen and (max-width: 767px) {
  h1 img {
    width: 30px;
    margin-right: 10px;
  }
}
@media only screen and (min-width: 1200px) {
  h1 img {
    width: 21px;
    margin-right: 0;
  }
}

h1::after {
  position: absolute;
  top: 2px;
  left: 0;
  z-index: 2;
  content: '';
  width: 20%;
  height: 3px;
  background-color: #333;
}

.topics_area {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .topics_area {
    display: flex;
    flex-direction: column;
  }
}
@media only screen and (min-width: 1200px) {
  .topics_area {
    display: flex;
  }
}

@media only screen and (max-width: 767px) {
  .topics_main {
    width: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .topics_main {
    width: 75%;
  }
}

@media only screen and (max-width: 767px) {
  .topics_sub {
    width: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .topics_sub {
    width: 25%;
    margin-left: 15px;
  }
}

.post_container {
  margin: 20px auto 0;
  padding: 0;
}
.post_container img {
  max-width: 100%;
  height: auto;
}
.post_container *::-ms-backdrop, .post_container img {
  max-height: 100%;
}
.post_container .topic_container {
  list-style: none;
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 5px;
    padding: 0;
    width: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: flex-start;
    margin: 0;
    padding: 0;
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container .topic {
    width: 49.1%;
    display: flex;
    -ms-flex-pack: justify;
    -moz-box-pack: justify;
    -webkit-box-pack: justify;
    flex-direction: column;
    margin: 0 0 15px;
    padding: 0;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container .topic {
    width: 23.8%;
    display: block;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
  }
}
.post_container .topic_container .topic:first-child {
  margin-top: 0;
}
.post_container .topic_container .topic .pic {
  border: #3B3B3B solid 1px;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  align-content: center;
  overflow: hidden;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container .topic .pic {
    width: 100%;
    padding: 10px 15px;
    margin: 0;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container .topic .pic {
    width: 100%;
    margin: 0 auto;
  }
}
.post_container .topic_container .topic .pic a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  align-content: center;
  overflow: hidden;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container .topic .pic a {
    width: 150px;
    height: 100px;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container .topic .pic a {
    width: 200px;
    height: 170px;
  }
}
.post_container .topic_container .topic .date {
  float: left;
  font-size: 14px;
  margin: 10px 0 2px;
  color: #979797;
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container .topic .caption {
    width: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container .topic .caption {
    width: 100%;
    position: relative;
    overflow: hidden;
    margin-top: 0;
    margin-bottom: 20px;
    line-height: 22px;
  }
}
@media only screen and (max-width: 767px) {
  .post_container .topic_container .topic .caption a {
    text-decoration: none;
    color: #000;
    text-overflow: ellipsis;
    white-space: wrap;
  }
}
@media only screen and (min-width: 768px) {
  .post_container .topic_container .topic .caption a {
    text-decoration: none;
    color: #000;
    white-space: wrap;
  }
}
@media only screen and (min-width: 1024px) {
  .post_container .topic_container .topic .caption a {
    text-decoration: none;
    color: #000;
    white-space: wrap;
  }
}
@media only screen and (min-width: 1200px) {
  .post_container .topic_container .topic .caption a {
    text-decoration: none;
    color: #000;
    white-space: wrap;
  }
}
.post_container .topic_container .topic .caption a:hover {
  color: #3E1300;
  text-decoration: underline;
}
.post_container .topic_container .topic .caption h6 {
  background: none;
  font-size: 15px;
  margin: 0;
  padding: 0;
  text-align: left;
  font-weight: 600;
}
