@charset "UTF-8";
/* 点滅 */
/* ローディングアニメ */
/* スクロールアニメ */
/* ページトップボタン */
/*リセット
--------------------------------------------*/
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: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

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

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

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

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

/*メディアクエリー
---------------------------------------------*/
/*変数
---------------------------------------------*/
/* 全体設定
---------------------------------------------*/
html {
  width: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
  font-size: 62.5%; }

body {
  width: 100%;
  overflow-x: hidden;
  background: #fff;
  color: #000;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 2.2rem;
  letter-spacing: 0.05rem; }
  @media screen and (min-width: 769px) {
    body {
      font-size: 1.4rem;
      line-height: 2.4rem; } }

img {
  width: 100%;
  height: auto;
  display: block; }

@media screen and (min-width: 769px) {
  .pcNone {
    display: none !important; } }

@media screen and (max-width: 768px) {
  .pcNone {
    display: block; } }

@media screen and (min-width: 769px) {
  .spNone {
    display: block; } }

@media screen and (max-width: 768px) {
  .spNone {
    display: none !important; } }

/* link setting
--------------------------------------*/
a {
  color: #000;
  text-decoration: none; }
  a:hover {
    transition: all 0.4s;
    color: #777; }

a {
  color: #000; }

.ff_ssp {
  font-family: 'Source Sans Pro', sans-serif;
  font-weight: 300; }

#wrap {
  width: 100%; }

#topArea {
  width: 100%; }
  @media screen and (max-width: 768px) {
    #topArea {
      height: 100vh;
      height: calc(var(--vh, 1vh) * 100);
      background-image: url(../images/main.jpg);
      background-size: cover;
      background-repeat: no-repeat;
      background-position: center top; } }

.flexbox {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap; }

.m_c {
  margin: 0 auto !important; }

.mt50 {
  margin-top: 50px !important; }

.mt100 {
  margin-top: 100px !important; }
  @media screen and (min-width: 769px) {
    .mt100 {
      margin-top: 170px !important; } }

.mb30 {
  margin-bottom: 30px !important; }
  @media screen and (min-width: 769px) {
    .mb30 {
      margin-bottom: 70px !important; } }

.ml10 {
  margin-left: 10% !important; }

.mr10 {
  margin-left: auto !important;
  margin-right: 10% !important; }

.w45 {
  width: 45% !important; }

.w55 {
  width: 55% !important; }

.w65 {
  width: 65% !important; }

.w90 {
  width: 90% !important; }

#mainArea {
  width: 100%;
  margin: 0px auto; }

#read {
  margin: 100px auto;
  text-align: center;
  font-size: 1.3rem;
  line-height: 2.9rem; }
  @media screen and (min-width: 769px) {
    #read {
      margin: 150px auto;
      font-size: 1.5rem;
      line-height: 3.4rem; } }

#selectArea {
  width: 100%;
  margin-bottom: 150px; }
  #selectArea .box_item {
    width: calc(97% / 5);
    transition: all .4s; }
    #selectArea .box_item:hover {
      opacity: .6; }
  @media screen and (min-width: 769px) {
    #selectArea {
      width: 600px;
      margin: 0 auto 250px; } }

.category_box {
  width: 100%;
  margin: 0 auto 150px; }
  @media screen and (min-width: 769px) {
    .category_box {
      width: 600px;
      margin-bottom: 250px; } }
  .category_box .ph_box {
    width: 90%;
    margin: 0 auto 50px;
    position: relative;
    text-align: center;
    letter-spacing: 0.1rem;
    color: #fff; }
    @media screen and (min-width: 769px) {
      .category_box .ph_box {
        margin-bottom: 80px; } }
    .category_box .ph_box .ttl {
      background: #b4ada9;
      border-top-left-radius: 100%;
      border-top-right-radius: 100%;
      position: relative;
      height: 280px; }
      @media screen and (min-width: 769px) {
        .category_box .ph_box .ttl {
          height: 400px; } }
      .category_box .ph_box .ttl p {
        font-size: 2rem;
        position: absolute;
        margin: auto;
        top: 50px;
        left: 0;
        right: 0;
        border: solid 1px #fff;
        border-radius: 50%;
        width: 90px;
        line-height: 4.5rem; }
        @media screen and (min-width: 769px) {
          .category_box .ph_box .ttl p {
            font-size: 2.5rem;
            top: 80px;
            width: 120px;
            line-height: 6rem; } }
  .category_box .bg02 {
    background: #b39978 !important; }
  .category_box .bg03 {
    background: #bccca3 !important; }
  .category_box .bg04 {
    background: #a99e93 !important; }
  .category_box .bg05 {
    background: #2c4d3c !important; }
  .category_box .slide_box {
    width: 100%;
    margin: 0 auto;
    padding: 0 15%;
    background: #b4ada9;
    box-sizing: border-box;
    margin-top: -140px; }
    .category_box .slide_box p {
      padding: 15px 0 20px;
      font-size: 1.5rem; }
    @media screen and (min-width: 769px) {
      .category_box .slide_box {
        margin-top: -200px; }
        .category_box .slide_box p {
          padding: 20px 0 25px;
          font-size: 2rem; } }
  .category_box .img_box {
    width: 90%;
    margin: 0 auto; }
    .category_box .img_box .flexbox img {
      width: 48%; }
  .category_box .txt {
    width: 90%;
    margin: 40px auto; }
    @media screen and (min-width: 769px) {
      .category_box .txt {
        text-align: center;
        margin: 70px auto; } }
  .category_box .flame {
    border: solid 1px #000;
    padding: 6px;
    box-sizing: border-box; }
    @media screen and (min-width: 769px) {
      .category_box .flame {
        padding: 8px; } }
  .category_box .price {
    width: 100%;
    box-sizing: border-box;
    color: #000;
    text-align: center; }
    .category_box .price a {
      display: inline-block;
      border-bottom: solid 1px #000;
      line-height: 1.2rem; }
      .category_box .price a:hover {
        color: #968983;
        border-bottom: solid 1px #968983; }

/* endArea
--------------------------------------*/
footer {
  width: 100%;
  padding-top: 100px;
  padding-bottom: 200px; }
  @media screen and (min-width: 769px) {
    footer {
      padding-top: 0; } }
  footer .sns {
    width: 60%;
    margin: 0px auto 50px;
    text-align: center; }
    @media screen and (min-width: 769px) {
      footer .sns {
        width: 250px;
        margin-bottom: 100px; } }
    footer .sns a img {
      display: inline-block;
      width: 35px;
      transition: all .4s; }
      footer .sns a img:hover {
        opacity: .6; }
  footer #logo {
    width: 250px;
    margin: 0px auto 20px;
    transition: all .4s; }
    @media screen and (min-width: 769px) {
      footer #logo {
        width: 300px; } }
  footer #copyright {
    text-align: center;
    font-size: 1rem;
    letter-spacing: 0.02rem;
    font-weight: 300; }

