@charset "UTF-8";
/* ==========================================================================
   Foundation
   ========================================================================== */
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html {
  font-size: 10px; }
  @media screen and (min-width: 93.8125em) {
    html {
      font-size: 12.5px; } }

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, button, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  -webkit-font-smoothing: antialiased;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  font-family: "Sawarabi Gothic" '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体','Yu Gothic', YuGothic, 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ','Meiryo','M PLUS 1p','ＭＳ Ｐゴシック',sans-serif; }

/* IE8〜11はメイリオ */
@media screen\0 {
  html, body, div, span, object, iframe,
  h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  abbr, address, cite, code,
  del, dfn, em, img, ins, kbd, q, samp,
  small, strong, sub, sup, var,
  b, i,
  dl, dt, dd, ol, ul, li,
  fieldset, form, label, legend,
  table, caption, tbody, tfoot, thead, tr, th, td,
  article, aside, button, canvas, details, figcaption, figure,
  footer, header, hgroup, menu, nav, section, summary,
  time, mark, audio, video {
    font-family: 'Segoe UI', Meiryo, sans-serif; } }

body {
  line-height: 1; }

p {
  line-height: 2em;
  letter-spacing: 0.1em;
  color: #333; }

h1, h2, h3, h4, h5, h6 {
  line-height: 1.25em; }

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

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; }

li {
  list-style: none; }

img {
  vertical-align: bottom; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit; }

/*---------------------------------------
  Base
----------------------------------------*/
*,
::before,
::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

html {
  font-size: 62.5%;
  min-width: 1240px; }

body {
  font-size: 1.46em;
  letter-spacing: 0.05em; }

/*---------------------------------------
  anchor link
----------------------------------------*/
/*---------------------------------------
  list style
----------------------------------------*/
/*---------------------------------------
  address
----------------------------------------*/
@media screen and (max-width: 47.9375em) {
  html {
    min-width: auto; } }

@font-face {
  font-family: "Lato", sans-serif;
  font-weight: 900;
  font-style: normal;
  src: url("/common/fonts/Lato-Black.woff2") format("woff2"); }

/* ==========================================================================
   Layout
   ========================================================================== */
.l-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 13.2rem; }
  .l-header__logo img {
    width: 16.6rem;
    height: 5rem; }
  .l-header__nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 3rem; }

@media screen and (max-width: 47.9375em) {
  .l-header {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 4rem; }
    .l-header__logo img {
      width: 12rem;
      height: 3.6rem; }
    .l-header__nav {
      gap: 2rem; } }

.l-footer {
  text-align: center;
  color: #fff;
  margin-top: 8rem;
  margin-bottom: 4rem; }
  .l-footer p {
    color: #fff;
    margin: 0; }

@media screen and (max-width: 47.9375em) {
  .l-footer {
    margin-top: 6rem;
    margin-bottom: 6rem; }
    .l-footer p {
      font-family: "Yu Gothic", sans-serif; } }

/* ==========================================================================
   Object
   ========================================================================== */
/* Component
   ----------------------------------------------------------------- */
.c-btn {
  position: relative;
  width: 19rem;
  height: 5rem;
  background-color: #fff;
  border: 2px solid #fff;
  border-radius: 10rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-decoration: none;
  overflow: hidden;
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease; }
  .c-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: #000;
    -webkit-transition: left 0.3s ease;
    -o-transition: left 0.3s ease;
    transition: left 0.3s ease;
    z-index: 1; }
  .c-btn:hover::before {
    left: 0; }
  .c-btn span {
    font-family: "Yu Gothic", sans-serif;
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #070707;
    position: relative;
    z-index: 2;
    -webkit-transition: color 0.3s ease;
    -o-transition: color 0.3s ease;
    transition: color 0.3s ease; }
  .c-btn:hover span {
    color: #fff; }

/* Project
  ----------------------------------------------------------------- */
/*---------------------------------------
  Top Page
----------------------------------------*/
.l-container {
  position: relative;
  width: 100%;
  min-height: 100vh; }

.l-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: -1; }
  .l-background__images {
    position: relative;
    width: 100%;
    height: 100%; }
  .l-background__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    -webkit-transition: opacity 0.5s ease;
    -o-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease; }
    .l-background__image.active {
      opacity: 1; }
    .l-background__image--1 {
      background-image: url("../img/bg-image_1.jpg"); }
    .l-background__image--2 {
      background-image: url("../img/bg-image_2.jpg"); }

.l-main {
  position: relative;
  width: calc(100% - 16rem);
  margin: 8rem;
  padding: 4rem;
  background: rgba(0, 0, 0, 0.7);
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
  border-radius: 3rem;
  border: 10px solid #fff;
  z-index: 1; }

.c-shop-card,
.c-access-card,
.c-section-title {
  opacity: 0;
  -webkit-transform: translateY(20px);
  -ms-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: opacity 0.6s ease, -webkit-transform 0.6s ease;
  transition: opacity 0.6s ease, -webkit-transform 0.6s ease;
  -o-transition: opacity 0.6s ease, transform 0.6s ease;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transition: opacity 0.6s ease, transform 0.6s ease, -webkit-transform 0.6s ease; }
  .c-shop-card.fade-in,
  .c-access-card.fade-in,
  .c-section-title.fade-in {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); }

.c-nav-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.1rem;
  cursor: pointer;
  -webkit-transition: opacity 0.3s ease;
  -o-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease; }
  .c-nav-item:hover {
    opacity: 0.5; }
  .c-nav-item__text {
    font-family: "Segoe UI", sans-serif;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 1.33;
    color: #fff;
    text-align: center; }
  .c-nav-item__line {
    width: 100%;
    height: 0.1rem;
    background-color: #fff;
    -webkit-transform-origin: right;
    -ms-transform-origin: right;
    transform-origin: right;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    -o-transition: transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease; }
  .c-nav-item:hover .c-nav-item__line {
    -webkit-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0); }

.c-section-title {
  margin-bottom: 4rem; }
  .c-section-title__en {
    font-family: "Segoe UI", sans-serif;
    font-weight: 700;
    font-size: 8rem;
    line-height: 1.33;
    letter-spacing: 0.1em;
    color: #fff;
    margin: 0; }
  .c-section-title__ja {
    font-family: "Yu Gothic", sans-serif;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    margin: 0; }

.c-shop-card {
  width: 100%;
  max-width: 30rem;
  min-width: 25rem;
  margin: 0 auto; }
  .c-shop-card__image {
    position: relative;
    width: 100%;
    height: 30rem;
    border-radius: 50%;
    overflow: hidden;
    border: 1rem solid #fff;
    margin-bottom: 4rem; }
    .c-shop-card__image a {
      display: block;
      width: 100%;
      height: 100%;
      position: relative;
      overflow: hidden; }
      .c-shop-card__image a::before {
        content: '';
        position: absolute;
        top: -50%;
        left: -50%;
        width: 200%;
        height: 200%;
        background: -webkit-linear-gradient(45deg, transparent 30%, rgba(255, 255, 255, 0.8) 50%, transparent 70%);
        background: -o-linear-gradient(45deg, transparent 30%, rgba(255, 255, 255, 0.8) 50%, transparent 70%);
        background: linear-gradient(45deg, transparent 30%, rgba(255, 255, 255, 0.8) 50%, transparent 70%);
        -webkit-transform: translateX(-100%) translateY(-100%) rotate(45deg);
        -ms-transform: translateX(-100%) translateY(-100%) rotate(45deg);
        transform: translateX(-100%) translateY(-100%) rotate(45deg);
        -webkit-transition: -webkit-transform 0.6s ease;
        transition: -webkit-transform 0.6s ease;
        -o-transition: transform 0.6s ease;
        transition: transform 0.6s ease;
        transition: transform 0.6s ease, -webkit-transform 0.6s ease;
        z-index: 2; }
      .c-shop-card__image a:hover::before {
        -webkit-transform: translateX(100%) translateY(100%) rotate(45deg);
        -ms-transform: translateX(100%) translateY(100%) rotate(45deg);
        transform: translateX(100%) translateY(100%) rotate(45deg); }
    .c-shop-card__image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      -webkit-transition: -webkit-transform 0.3s ease;
      transition: -webkit-transform 0.3s ease;
      -o-transition: transform 0.3s ease;
      transition: transform 0.3s ease;
      transition: transform 0.3s ease, -webkit-transform 0.3s ease; }
    .c-shop-card__image a:hover img {
      -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
      transform: scale(1.1); }
  .c-shop-card__content {
    position: relative;
    padding: 1rem; }
  .c-shop-card__title {
    font-family: "Yu Gothic", sans-serif;
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    text-align: center;
    margin: 0 0 2rem 0; }
  .c-shop-card__info {
    font-family: "Yu Gothic", sans-serif;
    font-weight: normal;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    margin-bottom: 2.4rem; }
    .c-shop-card__info p {
      margin: 0 0 1rem 0;
      color: #fff; }
  .c-shop-card__address-group, .c-shop-card__contact-group, .c-shop-card__hours-group {
    line-height: 1.6; }
  .c-shop-card__social {
    margin: 0; }
  .c-shop-card__instagram {
    width: 4.3rem;
    height: 4.3rem;
    -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
    transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
    -o-transition: transform 0.3s ease, opacity 0.3s ease;
    transition: transform 0.3s ease, opacity 0.3s ease;
    transition: transform 0.3s ease, opacity 0.3s ease, -webkit-transform 0.3s ease; }
    .c-shop-card__instagram:hover {
      -webkit-transform: scale(1.2);
      -ms-transform: scale(1.2);
      transform: scale(1.2);
      opacity: 0.7; }

.c-access-card {
  width: 100%;
  height: 43.2rem;
  position: relative; }
  .c-access-card__image {
    width: 100%;
    height: 29.7rem; }
    .c-access-card__image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover; }
  .c-access-card__content {
    position: absolute;
    bottom: 0;
    left: 0.3rem;
    right: 0;
    height: 10rem;
    padding: 0; }
  .c-access-card__title {
    font-family: "Yu Gothic", sans-serif;
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    margin: 0 0 1rem 0;
    display: inline; }
  .c-access-card__address {
    font-family: "Yu Gothic", sans-serif;
    font-weight: normal;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    margin: 0 19rem 0 0; }
  .c-access-card__station {
    font-family: "Yu Gothic", sans-serif;
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.2em;
    color: #fff;
    margin: 0 0 1rem 0;
    display: inline; }
  .c-access-card__map-btn {
    position: absolute;
    right: 0;
    bottom: 0; }

.p-shop {
  margin-bottom: 15rem;
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto; }
  .p-shop__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(30rem, 1fr));
    gap: 3rem;
    width: 100%; }

.p-access {
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto; }
  .p-access__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6rem;
    width: 100%; }

@media screen and (max-width: 47.9375em) {
  .l-main {
    width: calc(100% - 2rem);
    margin: 1rem;
    padding: 2rem;
    border: 3px solid #fff; }
  .c-section-title__en {
    font-size: 4rem; }
  .p-shop {
    margin-bottom: 8rem; }
    .p-shop__grid {
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      gap: 3rem;
      width: 100%; }
  .p-access__grid {
    grid-template-columns: 1fr;
    gap: 3rem;
    width: 100%; }
  .c-nav-item__text {
    font-size: 1.4rem; }
  .c-shop-card {
    width: 100%;
    max-width: 27rem; }
    .c-shop-card__image {
      height: 27rem;
      margin-bottom: 1rem; }
    .c-shop-card__title {
      margin: 0 0 1.5rem 0; }
  .c-access-card {
    width: 100%;
    margin-bottom: 5rem; }
    .c-access-card__station {
      font-size: 1.4rem; }
    .c-access-card__address {
      margin-right: 14rem;
      font-size: 1.4rem; }
    .c-access-card__map-btn {
      width: 14rem;
      height: 3.5rem; }
      .c-access-card__map-btn span {
        font-size: 1.2rem; }
  .c-shop-card__contact-group a {
    color: #fff !important;
    text-decoration: none; }
  .c-access-card__address a {
    color: #fff !important;
    text-decoration: none; } }

/* Utility
  ----------------------------------------------------------------- */
/* link
----------------------------------------------------------------------------- */
a:link {
  text-decoration: none; }

a:visited {
  text-decoration: none; }

a:hover {
  text-decoration: none; }

@media screen and (max-width: 47.9375em) {
  .u-anchor {
    padding-top: 60px;
    margin-top: -60px; } }

/* font
----------------------------------------------------------------------------- */
.u-en {
  font-family: "PT Sans Narrow", sans-serif; }

/* 表示
----------------------------------------------------------------------------- */
.u-pc {
  display: block; }

.u-sp {
  display: none; }

@media screen and (max-width: 47.9375em) {
  .u-pc {
    display: none; }
  .u-sp {
    display: block; } }
