@import url(https://fonts.googleapis.com/earlyaccess/sawarabimincho.css);
body {
  margin: 0;
  padding: 0;
  background: url("../img/bg_information.png");
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI","Noto Sans Japanese","Hiragino Kaku Gothic ProN", Meiryo, sans-serif; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #537492; }
  a:hover {
    text-decoration: underline; }

@media only screen and (max-width: 767px) {
  .wrap {
    margin: 0 15px;
    box-sizing: border-box; } }
@media only screen and (min-width: 768px) {
  .wrap {
    max-width: 1100px;
    width: calc(100% - 40px);
    margin: 0 auto; } }

@media only screen and (max-width: 767px) {
  .hero {
    margin: 40px 0 20px; } }
@media only screen and (min-width: 768px) {
  .hero {
    margin: 70px 0 45px; } }
@media only screen and (min-width: 768px) {
  .hero .sub_ttl {
    margin-left: 5px; } }
.hero h1 {
  font-family: 'Sawarabi Mincho';
  margin: 0;
  padding: 0;
  z-index: 99; }
  @media only screen and (max-width: 767px) {
    .hero h1 {
      font-size: 1.8rem;
      letter-spacing: 0.07rem;
      text-align: center; } }
  @media only screen and (min-width: 768px) {
    .hero h1 {
      margin: 0;
      font-size: 4.0rem;
      letter-spacing: 0.3rem; } }
.hero p {
  font-family: 'Sawarabi Mincho';
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 99; }
  @media only screen and (max-width: 767px) {
    .hero p {
      text-align: center;
      font-size: 0.95rem; } }
  @media only screen and (min-width: 768px) {
    .hero p {
      font-size: 1.5rem;
      text-align: left; } }

@media only screen and (max-width: 767px) {
  .prod {
    margin: 0 0 40px; } }
@media only screen and (min-width: 768px) {
  .prod {
    margin: 0 0 75px; } }
.prod__content {
  display: flex;
  width: 100%; }
  @media only screen and (max-width: 767px) {
    .prod__content {
      flex-direction: column; } }
  @media only screen and (min-width: 768px) {
    .prod__content {
      justify-content: space-between; } }
  @media only screen and (max-width: 767px) {
    .prod__content-cover {
      margin: 0 auto 35px;
      width: 75%; } }
  @media only screen and (min-width: 768px) {
    .prod__content-cover {
      margin: 0 auto;
      width: 27%;
      align-self: center; } }
  .prod__content-cover .note {
    padding: 0;
    font-size: 0.75rem; }
    @media only screen and (max-width: 767px) {
      .prod__content-cover .note {
        text-align: center;
        margin: 10px 0 0; } }
    @media only screen and (min-width: 768px) {
      .prod__content-cover .note {
        text-align: left;
        margin: 10px 0 0 15px; } }
  @media only screen and (max-width: 767px) {
    .prod__content-inner {
      width: 100%; } }
  @media only screen and (min-width: 768px) {
    .prod__content-inner {
      width: 67%; } }
  .prod__content-inner .slide {
    list-style: none;
    display: flex; }
    @media only screen and (max-width: 767px) {
      .prod__content-inner .slide {
        margin: 0;
        padding: 0; } }
    @media only screen and (min-width: 768px) {
      .prod__content-inner .slide {
        margin: 0 auto;
        padding: 0; } }
    .prod__content-inner .slide li {
      margin: 0 5px; }
    .prod__content-inner .slide .slick-slide:not(.slick-center) {
      -webkit-filter: opacity(80%);
      -moz-filter: opacity(80%);
      -o-filter: opacity(80%);
      -ms-filter: opacity(80%);
      filter: opacity(80%);
      transition: 0.2s linear; }
  .prod__content-inner .slide_nav {
    list-style: none;
    display: flex;
    position: relative;
    padding: 0; }
    @media only screen and (max-width: 767px) {
      .prod__content-inner .slide_nav {
        margin: 20px auto 0; } }
    @media only screen and (min-width: 768px) {
      .prod__content-inner .slide_nav {
        margin: 30px auto 0; } }
    .prod__content-inner .slide_nav li {
      position: relative;
      overflow: hidden;
      cursor: pointer; }
      @media only screen and (max-width: 767px) {
        .prod__content-inner .slide_nav li {
          width: 150px;
          height: 90px; } }
      @media only screen and (min-width: 768px) {
        .prod__content-inner .slide_nav li {
          width: 150px;
          height: 100px; } }
      .prod__content-inner .slide_nav li img {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto; }
        .prod__content-inner .slide_nav li img:hover {
          opacity: 0.8; }

.awards {
  text-align: center;
  margin: 0 0 35px;
  font-weight: 600; }
  @media only screen and (max-width: 767px) {
    .awards {
      font-size: 1.0rem; } }
  @media only screen and (min-width: 768px) {
    .awards {
      font-size: 1.2rem; } }

.slick-prev::before, .slick-next::before {
  color: #fff !important; }

.slick-prev {
  left: 5px !important;
  z-index: 99; }

.slick-next {
  right: 5px !important;
  z-index: 99; }

.shortcut {
  display: flex; }
  @media only screen and (max-width: 767px) {
    .shortcut {
      flex-direction: column; } }
  @media only screen and (min-width: 768px) {
    .shortcut {
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
      align-items: stretch;
      align-content: flex-start; } }
  .shortcut__item {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    height: 80px;
    position: relative; }
    @media only screen and (max-width: 767px) {
      .shortcut__item {
        width: 100%;
        margin: 0 auto 20px; } }
    @media only screen and (min-width: 768px) {
      .shortcut__item {
        width: calc(100% / 3 - 20px);
        text-align: center;
        margin: 0 auto 50px; } }
    .shortcut__item a {
      display: block;
      width: 100%; }
      @media only screen and (max-width: 767px) {
        .shortcut__item a {
          font-size: 1.1rem; } }
      @media only screen and (min-width: 768px) {
        .shortcut__item a {
          font-size: 1.25rem; } }
      .shortcut__item a::after {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 1;
        pointer-events: auto;
        content: "";
        background-color: transparent; }
  .shortcut__contact {
    display: flex;
    flex-direction: column; }
    .shortcut__contact a {
      font-size: 1.1rem; }
  .shortcut__en {
    width: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    height: 80px; }
    @media only screen and (max-width: 767px) {
      .shortcut__en {
        margin: 0 auto 20px;
        display: flex;
        justify-content: center;
        align-items: center; } }
    @media only screen and (min-width: 768px) {
      .shortcut__en {
        text-align: center;
        margin: 0 auto 50px;
        font-size: 1.2rem;
        line-height: 80px; } }
    .shortcut__en a {
      text-decoration: none;
      color: #537492;
      font-size: 1.15rem; }
      .shortcut__en a:hover {
        text-decoration: underline; }
  @media only screen and (max-width: 767px) {
    .shortcut__en-contact {
      display: flex;
      flex-direction: column; } }

.info {
  display: flex; }
  @media only screen and (max-width: 767px) {
    .info {
      box-sizing: border-box;
      flex-direction: column; } }
  @media only screen and (min-width: 768px) {
    .info {
      justify-content: space-between; } }
  .info__content {
    display: flex;
    width: 100%;
    position: relative;
    z-index: 99; }
    @media only screen and (max-width: 767px) {
      .info__content {
        margin: 0 0 40px;
        padding: 0 15px;
        box-sizing: border-box;
        flex-direction: column; } }
    @media only screen and (min-width: 768px) {
      .info__content {
        justify-content: space-between; } }
    .info__content-intro {
      display: flex;
      flex-direction: column; }
      @media only screen and (max-width: 767px) {
        .info__content-intro {
          width: 100%;
          order: 2;
          margin: 0 0 10px; } }
      @media only screen and (min-width: 768px) {
        .info__content-intro {
          width: 45%;
          display: flex; } }
      .info__content-intro p {
        margin: 0;
        padding: 0; }
        @media only screen and (max-width: 767px) {
          .info__content-intro p {
            font-size: 0.95rem;
            line-height: 1.75rem; } }
        @media only screen and (min-width: 768px) {
          .info__content-intro p {
            font-size: 1.0rem;
            line-height: 1.8rem; } }
    .info__content-detail {
      display: flex;
      flex-direction: column; }
      @media only screen and (max-width: 767px) {
        .info__content-detail {
          width: 100%;
          order: 2; } }
      @media only screen and (min-width: 768px) {
        .info__content-detail {
          width: 51%;
          display: flex; } }
      .info__content-detail-item {
        background: #fff;
        box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
        box-sizing: border-box;
        margin: 0 0 35px !important; }
        @media only screen and (max-width: 767px) {
          .info__content-detail-item {
            padding: 30px 20px; } }
        @media only screen and (min-width: 768px) {
          .info__content-detail-item {
            display: flex;
            flex-direction: column;
            padding: 50px 40px; } }
        .info__content-detail-item:last-child {
          margin: 0; }
        .info__content-detail-item h2 {
          font-family: 'Sawarabi Mincho';
          color: #333;
          padding: 0;
          letter-spacing: 0.05em; }
          @media only screen and (max-width: 767px) {
            .info__content-detail-item h2 {
              margin: 0 0 10px;
              font-size: 1.25rem; } }
          @media only screen and (min-width: 768px) {
            .info__content-detail-item h2 {
              margin: 0 0 15px;
              font-size: 1.5rem;
              line-height: 1.5rem; } }
        .info__content-detail-item dl {
          display: flex;
          flex-wrap: wrap;
          width: 100%;
          margin: 0 0 5px;
          padding: 0; }
          @media only screen and (max-width: 767px) {
            .info__content-detail-item dl {
              font-size: 0.95rem; } }
          .info__content-detail-item dl:last-child {
            margin: 0; }
          .info__content-detail-item dl dt {
            margin: 0 6px 0 0;
            padding: 0;
            color: #333; }
          .info__content-detail-item dl dd {
            margin: 0;
            padding: 0;
            color: #333; }

.list-prod {
  display: flex; }
  @media only screen and (max-width: 767px) {
    .list-prod {
      flex-direction: column; } }
  @media only screen and (min-width: 768px) {
    .list-prod {
      justify-content: space-between;
      margin: 70px 0 0; } }
  .list-prod h4 {
    color: #333;
    padding: 0;
    font-family: 'Sawarabi Mincho';
    border-bottom: #ccc solid 1px; }
    @media only screen and (max-width: 767px) {
      .list-prod h4 {
        font-size: 1.0rem;
        line-height: 1.4rem;
        margin: 0 0 15px; } }
    @media only screen and (min-width: 768px) {
      .list-prod h4 {
        font-size: 1.05rem;
        letter-spacing: 0.04em;
        margin: 0 0 18px;
        padding: 0; } }
  .list-prod__normal {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
    box-sizing: border-box; }
    @media only screen and (max-width: 767px) {
      .list-prod__normal {
        margin: 0 0 35px;
        padding: 30px 20px; } }
    @media only screen and (min-width: 768px) {
      .list-prod__normal {
        width: 19%;
        padding: 40px 30px; } }
  @media only screen and (min-width: 768px) {
    .list-prod__normal-item {
      text-align: center; } }
  .list-prod__normal-image {
    margin: 0 auto; }
    @media only screen and (max-width: 767px) {
      .list-prod__normal-image {
        width: 50%; } }
    @media only screen and (min-width: 768px) {
      .list-prod__normal-image {
        width: 100%; } }
  .list-prod__limited {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
    box-sizing: border-box; }
    @media only screen and (max-width: 767px) {
      .list-prod__limited {
        padding: 30px 20px; } }
    @media only screen and (min-width: 768px) {
      .list-prod__limited {
        width: 78%;
        padding: 40px 30px; } }
  .list-prod__limited-inner {
    display: flex; }
    @media only screen and (max-width: 767px) {
      .list-prod__limited-inner {
        flex-direction: column; } }
    @media only screen and (min-width: 768px) {
      .list-prod__limited-inner {
        justify-content: space-between; } }
  @media only screen and (max-width: 767px) {
    .list-prod__limited-a {
      width: 100%;
      margin: 0 0 35px;
      padding: 0 0 30px;
      border-bottom: #ccc solid 1px; } }
  @media only screen and (min-width: 768px) {
    .list-prod__limited-a {
      width: 22%;
      padding-right: 10px;
      border-right: #ccc solid 1px; } }
  @media only screen and (min-width: 768px) {
    .list-prod__limited-a-item {
      text-align: center; } }
  @media only screen and (max-width: 767px) {
    .list-prod__limited-b {
      width: 100%; } }
  @media only screen and (min-width: 768px) {
    .list-prod__limited-b {
      width: 78%;
      padding-left: 15px; } }
  .list-prod__liited-b-content {
    display: flex; }
    @media only screen and (max-width: 767px) {
      .list-prod__liited-b-content {
        flex-direction: column; } }
    @media only screen and (min-width: 768px) {
      .list-prod__liited-b-content {
        justify-content: space-between;
        margin-top: 43px; } }
  .list-prod h5 {
    color: #333;
    padding: 0;
    border-top: #fff solid 1px;
    border-bottom: #fff solid 1px;
    font-weight: normal; }
    @media only screen and (max-width: 767px) {
      .list-prod h5 {
        font-size: 0.9rem;
        line-height: 1.4rem;
        margin: 0 0 10px; } }
    @media only screen and (min-width: 768px) {
      .list-prod h5 {
        font-size: 0.95rem;
        letter-spacing: 0.04em;
        margin: 0 0 7px;
        padding: 0; } }
  .list-prod__item {
    box-sizing: border-box; }
    @media only screen and (max-width: 767px) {
      .list-prod__item {
        width: 100%;
        margin: 0 0 20px;
        padding: 0 0 30px;
        border-bottom: #ccc solid 1px; }
        .list-prod__item:last-child {
          margin: 0;
          padding: 0; } }
    @media only screen and (min-width: 768px) {
      .list-prod__item {
        width: 33%;
        border-right: #ccc solid 1px;
        min-height: 300px;
        text-align: center; }
        .list-prod__item:first-child {
          padding-right: 13px; }
        .list-prod__item:last-child {
          padding-left: 13px; } }
    .list-prod__item p {
      margin: 0 0 15px;
      padding: 0; }
      @media only screen and (max-width: 767px) {
        .list-prod__item p {
          font-size: 0.9rem; } }
    .list-prod__item:last-child {
      border: none; }
    .list-prod__item .price {
      margin: 0;
      padding: 0; }
    .list-prod__item-image {
      width: 100%; }
  @media only screen and (max-width: 767px) {
    .list-prod__limited-image {
      text-align: center; } }
  @media only screen and (min-width: 768px) {
    .list-prod__limited-image {
      height: 200px; } }
  @media only screen and (max-width: 767px) {
    .list-prod__link {
      margin: 20px 0 0; } }
  @media only screen and (min-width: 768px) {
    .list-prod__link {
      margin: 30px 0 0; } }
  .list-prod__link a {
    text-decoration: none;
    color: #fff;
    background: #000;
    font-size: 0.9rem;
    position: relative; }
    @media only screen and (max-width: 767px) {
      .list-prod__link a {
        margin: 0 auto;
        padding: 10px 0;
        display: block;
        width: 60%;
        text-align: center; } }
    @media only screen and (min-width: 768px) {
      .list-prod__link a {
        padding: 12px 28px; } }
    .list-prod__link a:hover {
      opacity: 0.8; }
  .list-prod__link .icon {
    margin-right: 8px; }
    @media only screen and (max-width: 767px) {
      .list-prod__link .icon {
        font-size: 1.0rem; } }
    @media only screen and (min-width: 768px) {
      .list-prod__link .icon {
        font-size: 0.85rem; } }

@media only screen and (max-width: 767px) {
  .bookstore {
    padding: 60px 0 0; } }
@media only screen and (min-width: 768px) {
  .bookstore {
    padding: 80px 0 0; } }
.bookstore__ttl {
  font-family: 'Sawarabi Mincho';
  margin: 0 0 10px;
  padding: 0; }
  @media only screen and (max-width: 767px) {
    .bookstore__ttl {
      font-size: 1.2rem; } }
  @media only screen and (min-width: 768px) {
    .bookstore__ttl {
      font-size: 1.4rem; } }
.bookstore p {
  margin: 0 0 10px;
  padding: 0;
  word-break: break-all; }
  @media only screen and (max-width: 767px) {
    .bookstore p {
      font-size: 0.95rem;
      line-height: 1.75rem; } }
  @media only screen and (min-width: 768px) {
    .bookstore p {
      font-size: 1.0rem;
      line-height: 1.8rem; } }
.bookstore a {
  color: #596d92;
  text-decoration: none; }

.profile {
  background-repeat: repeat; }
  @media only screen and (max-width: 767px) {
    .profile {
      padding: 60px 0 0; } }
  @media only screen and (min-width: 768px) {
    .profile {
      padding: 80px 0 0; } }
  .profile__content {
    width: 100%; }
    @media only screen and (max-width: 767px) {
      .profile__content {
        margin: 0 0 20px; } }
    @media only screen and (min-width: 768px) {
      .profile__content {
        margin: 0 0 30px; } }
    .profile__content:last-child {
      margin: 0; }
    .profile__content-ttl {
      font-family: 'Sawarabi Mincho';
      margin: 0 0 10px;
      padding: 0; }
      @media only screen and (max-width: 767px) {
        .profile__content-ttl {
          font-size: 1.2rem; } }
      @media only screen and (min-width: 768px) {
        .profile__content-ttl {
          font-size: 1.4rem; } }
    .profile__content-inner {
      display: flex; }
      @media only screen and (max-width: 767px) {
        .profile__content-inner {
          flex-direction: column; } }
      @media only screen and (min-width: 768px) {
        .profile__content-inner {
          justify-content: space-between; } }
    @media only screen and (max-width: 767px) {
      .profile__content-text_area {
        width: 100%;
        order: 2;
        margin: 20px 0 0; } }
    @media only screen and (min-width: 768px) {
      .profile__content-text_area {
        width: 65%; } }
    .profile__content-txt {
      margin: 0 0 15px;
      padding: 0;
      word-break: break-all; }
      @media only screen and (max-width: 767px) {
        .profile__content-txt {
          font-size: 0.95rem;
          line-height: 1.75rem; } }
      @media only screen and (min-width: 768px) {
        .profile__content-txt {
          font-size: 1.0rem;
          line-height: 1.8rem; } }
      .profile__content-txt:last-child {
        margin: 0; }
    @media only screen and (max-width: 767px) {
      .profile__content-img {
        width: 100%;
        order: 1; } }
    @media only screen and (min-width: 768px) {
      .profile__content-img {
        width: 33%; } }
    .profile__content-youtube_item {
      display: flex; }
      @media only screen and (max-width: 767px) {
        .profile__content-youtube_item {
          flex-direction: column; } }
      @media only screen and (min-width: 768px) {
        .profile__content-youtube_item {
          justify-content: space-between; } }
    .profile__content-youtube {
      -webkit-position: relative;
      -moz-position: relatigve;
      position: relative;
      -webkit-padding-top: 56.25%;
      -moz-padding-top: 56.25%;
      width: 100%;
      height: 0%;
      overflow: hidden; }
      @media only screen and (max-width: 767px) {
        .profile__content-youtube {
          width: 100%;
          margin: 0 0 25px; }
          .profile__content-youtube:last-child {
            margin: 0; } }
      @media only screen and (min-width: 768px) {
        .profile__content-youtube {
          width: 32%; } }
      @media only screen and (min-width: 768px) {
        .profile__content-youtube ifame {
          -webkit-position: absolute;
          -moz-position: absolute;
          position: absolute;
          top: 0;
          right: 0;
          width: 100%;
          -webkit-height: 50%;
          margin-top: 50px;
          margin-left: 0;
          margin-bottom: 80px;
          margin-right: 0; } }
      .profile__content-youtube p {
        padding: 0; }
        @media only screen and (max-width: 767px) {
          .profile__content-youtube p {
            margin: 0; } }
        @media only screen and (min-width: 768px) {
          .profile__content-youtube p {
            margin: 10px 0 0; } }

@media only screen and (max-width: 767px) {
  .media {
    padding: 60px 0; } }
@media only screen and (min-width: 768px) {
  .media {
    padding: 80px 0 110px; } }
.media__content {
  width: 100%; }
  .media__content-ttl {
    font-family: 'Sawarabi Mincho';
    margin: 0 0 10px;
    padding: 0; }
    @media only screen and (max-width: 767px) {
      .media__content-ttl {
        font-size: 1.2rem; } }
    @media only screen and (min-width: 768px) {
      .media__content-ttl {
        font-size: 1.4rem; } }
.media ul {
  margin: 0;
  padding: 0 0 0 20px; }
  .media ul li {
    margin: 0 0 15px; }
.media__txt {
  margin: 3px 0 0;
  padding: 0;
  word-break: break-all; }

.shoplist {
  background: #fff;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
  box-sizing: border-box; }
  @media only screen and (max-width: 767px) {
    .shoplist {
      margin: 0 0 30px;
      padding: 30px 15px; } }
  @media only screen and (min-width: 768px) {
    .shoplist {
      display: flex;
      flex-direction: column;
      margin: 0 0 50px;
      padding: 50px 40px; } }
  .shoplist__ttl {
    padding: 0;
    font-family: 'Sawarabi Mincho'; }
    @media only screen and (max-width: 767px) {
      .shoplist__ttl {
        font-size: 1.3rem;
        margin: 0 0 25px; } }
    @media only screen and (min-width: 768px) {
      .shoplist__ttl {
        font-size: 1.6rem;
        margin: 0 0 45px; } }
  @media only screen and (max-width: 767px) {
    .shoplist__block {
      margin: 0 0 30px; } }
  @media only screen and (min-width: 768px) {
    .shoplist__block {
      margin: 0 0 45px; } }
  .shoplist__block:last-child {
    margin: 0; }
  .shoplist__block h3 {
    padding: 0 0 15px;
    border-bottom: #ccc solid 1px; }
    @media only screen and (max-width: 767px) {
      .shoplist__block h3 {
        margin: 0; } }
    @media only screen and (min-width: 768px) {
      .shoplist__block h3 {
        margin: 0; } }
  .shoplist__block table {
    width: 100%; }
    .shoplist__block table tr {
      display: flex;
      width: 100%;
      border-bottom: #ccc solid 1px;
      box-sizing: border-box; }
      @media only screen and (max-width: 767px) {
        .shoplist__block table tr {
          flex-direction: column;
          padding: 15px 0; } }
      @media only screen and (min-width: 768px) {
        .shoplist__block table tr {
          padding: 15px 10px; } }
    .shoplist__block table th {
      text-align: left;
      font-weight: normal; }
      @media only screen and (max-width: 767px) {
        .shoplist__block table th {
          width: 100%;
          margin: 0;
          font-size: 1.1rem; } }
      @media only screen and (min-width: 768px) {
        .shoplist__block table th {
          width: 35%; } }
    @media only screen and (max-width: 767px) {
      .shoplist__block table td {
        width: 100%; } }
    @media only screen and (min-width: 768px) {
      .shoplist__block table td {
        width: 65%; } }
    .shoplist__block table td a {
      text-decoration: none;
      color: #6E90AF; }

.banner {
  text-align: center; }
  @media only screen and (max-width: 767px) {
    .banner {
      margin: 0 0 60px; } }
  @media only screen and (min-width: 768px) {
    .banner {
      margin: 0 0 80px; } }
  .banner img {
    border: #ccc solid 1px; }
    .banner img:hover {
      opacity: 0.8; }

@media only screen and (min-width: 768px) {
  .sponly {
    display: none !important; } }

@media only screen and (max-width: 767px) {
  .pconly {
    display: none !important; } }

.global_head {
  margin: 0;
  padding: 0; }
