﻿@charset "utf-8";
/* CSS Document */
html, body {
  width: 100%;
  /*overflow: auto;*/
}
/* ▼基本デザイン */
/* ----------------------------------------------------- */
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-family: "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}
a:link, a:visited, a:hover, a:active {
  color: #111;
}
img {
  max-width: 100%;
  height: auto;
}
li {
  list-style: none;
  margin: 0;
  padding: 0;
}
a {
  -webkit-transition: 0.2s ease-in-out;
  -moz-transition: 0.2s ease-in-out;
  -o-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
a:hover {
  opacity: 0.65;
}
a, a:hover, a:visited {
  text-decoration: none !important;
}
.pure-toggle-label {
  display: none !important;
}
h5 {
  line-height: 1;
  height: auto;
  text-indent: 0;
  width: auto;
}
#wrapper {
  width: 100%;
}
#wrapper p {
  font-size: 15px;
  line-height: 1.8;
  text-align: justify;
}
.writer_pics img, .writer_box img {
  border-radius: 100%;
  border: 1px solid #e1dfdf;
}
b {
  font-weight: normal;
  font-size: 12px;
}
b::before {
  content: "";
  background: url(https://www.receno.com/sp/img/favorite-on.svg) center left no-repeat;
  background-size: auto;
  background-size: auto;
  padding-left: 20px;
  background-size: cover;
  margin-right: 5px;
}
/* ▼header */
/* ----------------------------------------------------- */
.h-info {
  background-color: #c6cccf !important;
  text-align: center;
}
.h-info a {
  color: #fff;
  font-size: 14px;
  font-weight: bold;
}
.header_logo img {
  width: 263px;
}
.header_logo {
  margin: 0 auto;
  text-align: center;
  padding: 63px 0 50px 0;
}
.header_logo a {
  display: flex;
}
.header_inner {
  display: flex;
  position: relative;
}
.header_inner_2 {
  position: fixed;
  width: 100%;
  top: 0;
  background-color: rgba(255, 255, 255, 0.9);
  display: none;
  z-index: 1;
}
.header_inner_2 .header_logo img {
  width: 180px;
}
.header_inner_2 .header_logo {
  margin: 0 auto;
  text-align: center;
  padding: 23px 0 25px 0;
}
.header_inner .drawer-toggle.drawer-hamburger {
  position: absolute;
  top: 38%;
}
.header_inner_2 .drawer-toggle.drawer-hamburger {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}
.icon_menu {
  width: 84px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: absolute;
  right: 44px;
  top: 26%;
}
.header_inner .icon_menu {
  top: 44%;
}
.icon_menu a {
  display: block;
  width: 34px;
}
/* ▼footer */
/* ----------------------------------------------------- */
footer {
  background-color: #e4e8e9 !important;
}
.f_header {
  padding: 115px 0 78px 0;
  text-align: center;
  position: relative;
  width: 90%;
  margin: 0 auto;
}
.menu_logo {
  text-align: center;
  width: 263px;
  margin: 0 auto;
}
.menu_sns {
  position: absolute;
  right: 0;
  height: 100px;
  bottom: 28px;
  display: flex;
  gap: 6px;
  opacity: 0.5;
}
.menu_sns img {
  width: 34px;
}
.f_mag_d_categories {
  width: 90%;
  margin: 0 auto;
}
.menu_category ul {
  display: grid;
  grid-gap: 14px;
  justify-content: space-between;
  padding-bottom: 64px;
  grid-template-columns: 1fr 1fr 1fr 1fr;
}
@media screen and (max-width: 1200px) {
  .menu_category ul {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media screen and (min-width: 1500px) {
  .menu_category ul {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  }
}
.menu_category ul li a {
  display: flex;
  align-items: center;
  background-color: rgba(255, 255, 255, 0.7);
}
.menu_category ul li img {
  height: 90px;
}
.menu_category ul li p {
  font-size: 13px !important;
  padding: 0 20px;
  line-height: 1.4 !important;
  font-weight: bold;
  text-align: left !important;
}
.mh3_menu a {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif !important;
  border-top: 1px solid #6e6e6e;
  padding: 10px 0 20px 0;
  display: block;
  letter-spacing: 1px;
  font-weight: normal;
  font-size: 17px;
}
.menu_logo_receno {
  width: 170px;
  margin: 0 auto;
  padding: 110px 0 110px 0;
  display: block;
}
.menu_logo_receno a {
  display: block;
}
.f_bottom {
  background-color: #a9b0b4;
  color: #fff;
}
.f_bottom p {
  text-align: center !important;
  font-family: garamond-premier-pro, serif !important;
  font-size: 14px;
  letter-spacing: 1px;
  font-weight: normal;
  padding: 15px 0;
}
/* ▼グローバルナビ */
/* ----------------------------------------------------- */
.drawer-toggle.drawer-hamburger {
  position: relative;
  left: 30px;
}
.drawer-menu .menu_category ul {
  grid-template-columns: 1fr 1fr;
}
.drawer-menu .menu_category h3 a {
  font-size: 16px !important;
}
.drawer-menu .menu_category li a p {
  font-size: 12px !important;
}
.drawer-nav {
  width: 35rem;
  background-color: #e4e8e9;
}
.drawer--left .drawer-nav {
  left: -35rem;
}
.drawer--left.drawer-open .drawer-hamburger {
  left: 35rem;
}
.drawer-menu {
  width: 90%;
  margin: 0 auto;
}
nav .menu_category ul li a {
  border: 1px solid #1111111;
}
.drawer-menu .drawer_logo {
  display: flex;
  flex-direction: column;
  padding: 70px 0 50px 0;
}
.drawer-menu .menu_logo {
  width: 220px;
  margin: 0 auto;
  padding-bottom: 30px;
  text-align: center;
}
.drawer-menu .menu_logo a {
  display: block;
}
.drawer-menu .menu_sns {
  height: 34px;
  bottom: 0;
  display: flex;
  gap: 6px;
  margin: 0 auto;
  position: relative;
}
form .btn {
  width: 21px;
  padding-left: 13px;
}
#searchform1 {
  display: flex;
  justify-content: space-between;
  width: 315px;
  margin: 0 auto;
  background-color: #fff;
  border-top: 1px solid #9b9b9b;
  border-right: 1px solid #9b9b9b;
  border-left: 1px solid #9b9b9b;
  padding: 2px 0;
}
#search_q, #search_q2 {
  width: 86%;
  padding: 10px 15px;
  color: #ccc !important;
  border: none;
  outline: none;
}
.menu_personal {
  display: flex;
  justify-content: space-between;
  padding: 0;
  width: 315px;
  margin: 0 auto;
  margin-bottom: 0px;
  margin-bottom: 0px;
  border: 1px solid #9b9b9b;
  margin-bottom: 50px;
}
.menu_personal li {
  width: 50%;
  font-size: 13px;
}
.menu_personal li a {
  display: block;
  width: 100%;
  text-align: center;
  padding: 10px 0;
}
.menu_personal li:first-child a::before {
  content: "";
  background: url("../img/menu_mypage.svg") center left no-repeat;
  background-size: auto;
  background-size: auto;
  background-size: auto;
  padding-left: 20px;
  background-size: cover;
  margin-right: 5px;
}
.menu_personal li:nth-child(2) a::before {
  content: "";
  background: url("../img/menu_shiori.svg") center left no-repeat;
  background-size: auto;
  background-size: auto;
  background-size: auto;
  padding-left: 20px;
  background-size: cover;
  margin-right: 5px;
}
.menu_personal li:first-child {
  border-right: 1px solid #9b9b9b;
}
.drawer-menu .menu_logo_receno {
  padding: 20px 0 90px 0;
  width: 130px;
  margin: 0 auto;
}
.drawer_global {
  margin-left: calc(50% - 56%);
  margin-right: calc(50% - 56%);
  border-bottom: 1px solid #9b9b9b;
}
.menu_global {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.menu_global li {
  width: 33.3%;
}
.menu_global li a {
  text-align: center;
  display: block;
  font-size: 13px;
  padding: 20px 0;
}
.menu_global li:nth-child(2) {
  border-right: 1px solid #9b9b9b;
  border-left: 1px solid #9b9b9b;
}
.menu_global li a::before {
  content: "";
  background-size: auto;
  padding-left: 20px;
  padding-top: 3px;
  padding-bottom: 3px;
  background-size: cover;
  margin-right: 6px;
}
.menu_read {
  background-color: #c7ced0;
  text-decoration: underline !important;
}
.menu_global li .menu_shop::before {
  background: url("../img/n_shop_on.svg") center left no-repeat;
}
.menu_global li .menu_read::before {
  background: url("../img/n_mag_on.svg") center left no-repeat;
}
.menu_global li .menu_store::before {
  background: url("../img/n_store_on.svg") center left no-repeat;
}





/* ▼幅毎の調整 
/* ----------------------------------------------------- */
@media only screen and (max-width: 1200px) and (orientation:portrait) {}
@media only screen and (max-width: 1200px) and (orientation: landscape) {}
@media screen and (max-width: 1200px) {}
@media screen and (max-width: 1440px) {}
/* ------------------------------------------------------------------------------------------------------ */
/* ▼スマホ
/* ------------------------------------------------------------------------------------------------------ */
@media screen and (max-width: 479px) {
  #wrapper p {
    font-size: 0.8125rem;
  }
  a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  /* ▼header */
  /* ----------------------------------------------------- */
  .h-info a {
    font-size: 0.68rem !important;
  }
  .header_inner .header_logo img {
    width: 10rem !important;
  }
  .header_logo {
    padding: 1.8rem 0 1.6rem 0rem;
  }
  .header_logo a {
    display: flex;
  }
  .header_inner {
    display: flex;
    position: relative;
  }
  .header_inner_2 {
    position: fixed;
    width: 100%;
    top: 0;
    background-color: rgba(255, 255, 255, 0.9);
    display: none;
    z-index: 1;
  }
  .header_inner_2 .header_logo img {
    width: 8rem !important;
  }
  .header_inner_2 .header_logo {
    margin: 0 auto;
    text-align: center;
    padding: 1.4rem 0 1.4rem 0.5rem;
  }
  .header_inner .drawer-toggle.drawer-hamburger {
    position: absolute;
    top: 22%;
  }
  .header_inner_2 .drawer-toggle.drawer-hamburger {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .icon_menu {
    right: 4%;
    width: 4rem;
    top: 28%;
  }
  .header_inner .icon_menu {
    top: 34%;
  }
  .icon_menu a {
    width: 1.7rem !important;
  }
  /* ▼footer */
  /* ----------------------------------------------------- */
  .f_header {
    padding: 7rem 0 5rem 0;
    text-align: center;
    position: relative;
    width: 90%;
    margin: 0 auto;
  }
  .menu_logo {
    width: 13rem;
    padding-bottom: 1rem;
  }
  .menu_sns {
    position: relative;
    right: 0;
    height: auto;
    bottom: 0;
    display: flex;
    gap: 6px;
    margin: 0 auto;
    padding-top: 1rem;
    justify-content: center;
  }
  .menu_sns img {
    width: 2rem;
  }
  .menu_category ul {
    display: grid;
    grid-gap: 0.5rem;
    justify-content: space-between;
    padding-bottom: 64px;
    grid-template-columns: 1fr 1fr;
    overflow-x: scroll;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 0 6% 3rem 6%;
  }
  .menu_category ul li {
    min-width: 15rem;
  }
  .menu_category ul li a {
    display: flex;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.7);
  }
  .menu_category ul li img {
    height: 5.65rem;
  }
  .menu_category ul li p {
    font-size: 0.75rem !important;
    padding: 0 0.85rem;
  }
  .mh3_menu a {
    font-size: 1rem;
  }
  .menu_logo_receno {
    width: 8rem;
    margin: 0 auto;
    padding: 2rem 0 4rem 0;
    display: block;
  }
  .menu_logo_receno a {
    display: block;
  }
  .f_bottom {
    background-color: #a9b0b4;
    color: #fff;
  }
  .f_bottom p {
    font-size: 0.75rem !important;
    padding: 0.5rem 0;
  }
  /* ▼グローバルナビ */
  /* ----------------------------------------------------- */
  .drawer-hamburger-icon, .drawer-hamburger-icon::after, .drawer-hamburger-icon::before {
    height: 1px;
  }
  .drawer-toggle.drawer-hamburger {
    position: relative;
    left: 2%;
  }
  .drawer-menu .menu_category ul {
    grid-template-columns: 1fr;
    width: 100%;
    margin: 0 auto;
    padding: 0 0 3rem 0;
  }
  .drawer-menu .menu_category h3 a {
    font-size: 1rem !important;
  }
  .drawer-menu .menu_category li a p {
    font-size: 0.75rem !important;
  }
  .drawer-nav {
    width: 20rem;
  }
  .drawer--left .drawer-nav {
    left: -20rem;
  }
  .drawer--left.drawer-open .drawer-hamburger {
    left: 20rem;
  }
  .drawer-menu {
    width: 90%;
    margin: 0 auto;
    height: 100vh;
    transform: translate3d(0, 0, 0) !important;
    /*実機でナビの中をスクロールした時のずれ防止*/
  }
  nav .menu_category ul li a {
    border: 1px solid #1111111;
  }
  .drawer-menu .drawer_logo {
    display: flex;
    flex-direction: column;
    padding: 4rem 0 3rem 0;
  }
  .drawer-menu .menu_logo {
    width: 12rem;
    margin: 0 auto;
    padding-bottom: 2.5rem;
  }
  .drawer-menu .menu_logo a {
    display: block;
  }
  .drawer-menu .menu_sns {
    height: auto;
    bottom: 0;
    display: flex;
    gap: 6px;
    margin: 0 auto;
    position: relative;
  }
  form .btn {
    width: 1.2rem;
    padding-left: 5%;
  }
  #searchform1 {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
    background-color: #fff;
    border-top: 1px solid #9b9b9b;
    border-right: 1px solid #9b9b9b;
    border-left: 1px solid #9b9b9b;
    padding: 2px 0;
  }
  #search_q, #search_q2 {
    padding: 0.75rem 0.75rem;
  }
  .menu_personal {
    width: 100%;
    margin-bottom: 1rem;
  }
  .menu_personal li {
    width: 50%;
    font-size: 0.8rem;
  }
  .menu_personal li a {
    padding: 0.5rem 0;
  }
  .menu_personal li:first-child a::before {
    padding-left: 20px;
    margin-right: 5px;
  }
  .menu_personal li:nth-child(2) a::before {
    padding-left: 20px;
    margin-right: 5px;
  }
  .menu_personal li:first-child {
    border-right: 1px solid #9b9b9b;
  }
  .drawer-menu .menu_logo_receno {
    padding: 1rem 0 5rem 0;
    width: 7rem;
    margin: 0 auto;
  }
  .menu_global li a {
    text-align: center;
    display: block;
    font-size: 0.75rem;
    padding: 20px 0;
  }
  .menu_global li a::before {
    padding-left: 1.2rem;
    padding-top: 0.4rem;
    padding-bottom: 0.4rem;
    margin-right: 0.3rem;
  }
  .drawer-hamburger {
    width: 1.5rem !important;
  }
  .drawer-hamburger-icon::before {
    top: -0.6em !important;
  }
  .drawer-hamburger-icon::after {
    top: 0.5rem !important;
  }
  .drawer-open .drawer-hamburger-icon::after {
    top: -0.5rem !important;
  }
    header li.drawer_global,
    header li.drawer_logo,
    header li.drawer_category {
      float: none !important;
      width: auto !important;
    }
    
    
  /* ▼ナビスクロール問題対応 */
  /* ----------------------------------------------------- */
  .drawer--top.drawer-open .drawer-nav {
    overflow-Y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }
  .drawer--left.drawer-open .drawer-nav, .drawer--left .drawer-hamburger, .drawer--left.drawer-open .drawer-navbar .drawer-hamburger {
    overflow-Y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }
  .drawer--right.drawer-open .drawer-nav, .drawer--right .drawer-hamburger, .drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
    overflow-Y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }
}