@charset "UTF-8";
* {
  font-family: "Zen Maru Gothic", sans-serif !important;
  color: #333;
}

html,
body {
  background-color: #f0f0f0;
}

body.page,
body.post {
  margin: 0px;
}

div.site {
  max-width: 1180px;
  margin: 0 auto;
  background-color: #fff;
}

.m-0 {
  margin: 0px;
}

.mt-2 {
  margin-top: 20px;
}

.mt-4 {
  margin-top: 20px;
}

.me-2 {
  margin-right: 20px;
}

@media screen and (min-width: 640px) {
  .w30 {
    width: 30% !important;
  }
}

.grecaptcha-badge {
  visibility: hidden;
}

.btn {
  text-decoration: none;
  display: block;
  margin: 10px auto;
  text-align: center;
  width: 200px;
  font-weight: bold;
}
.btn:visited {
  color: white;
}
.btn:hover {
  opacity: 0.8;
}

.text-white {
  color: white;
}

.btn-primary {
  color: white;
  border-radius: 10px;
  padding: 20px;
  background-color: #63b4e5;
}
.btn-primary:hover {
  color: white;
}

.menu-image {
  position: relative;
}
.menu-image figcaption {
  padding: 5px;
  background-color: rgba(0, 0, 0, 0.6);
  color: white;
  text-align: right;
  position: absolute;
  right: 0;
  bottom: 0;
}

.menu-info-box {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.menu-info-box h3 {
  color: #63b4e5;
  font-size: 16px;
}

@media screen and (min-width: 640px) {
  .pc-flex-colum {
    display: flex;
    gap: 30px;
  }
  .pc-flex-colum:nth-child(odd) {
    flex-direction: row-reverse;
  }
  .pc-flex-colum > div {
    width: 100%;
  }
}

@media screen and (min-width: 640px) {
  .pc-flex-colum + .pc-flex-colum {
    margin-top: 30px;
  }
}

.menu-box h3 {
  color: #63b4e5;
  text-align: center;
}
.menu-box h3::before,
.menu-box h3::after {
  content: "〜";
}
.menu-box .menu-price {
  text-align: right;
}

.accent-text {
  background-color: #63b4e5;
  color: white;
  padding: 20px;
}
.accent-text a {
  color: white;
}

.youtube {
  width: 100%;
  aspect-ratio: 16/9;
}

.youtube iframe {
  margin: auto;
  width: 100%;
  height: 100%;
}

.button-box-2column {
  display: flex;
  justify-content: center;
  gap: 10px;
}
.button-box-2column a {
  font-size: 14px;
}

.w-100 {
  width: 100%;
}

header#artxcafe-header {
  width: 100%;
  height: 160px;
  background-size: cover;
  background-position: center center;
  display: flex;
  justify-content: center;
  align-items: center;
}
header#artxcafe-header h1 {
  margin: 0 auto;
  text-transform: uppercase;
  font-size: 32px;
  text-align: center;
}
header#artxcafe-header h1 a {
  text-decoration: none;
  color: inherit;
  -webkit-text-stroke: 1px white;
  /* webkitのベンダープレフィックス */
  text-stroke: 1px red;
  /*　ベンダープレフィックスのない指定方法 */
}
header#artxcafe-header p {
  margin: 0 auto;
  text-align: center;
  font-size: 14px;
  color: inherit;
  text-shadow: -1px -1px 0 white, -1px 0 0 white, -1px 1px 0 white, 0 -1px 0 white, 0 1px 0 white, 1px -1px 0 white, 1px 0 0 white, 1px 1px 0 white;
}

#pc-site-navigation {
  display: none;
  background-color: #63b4e5;
}
@media screen and (min-width: 960px) {
  #pc-site-navigation {
    /*　画面サイズが1024pxからはここを読み込む　*/
    display: block;
  }
}
#pc-site-navigation .menu-menu-1-container {
  width: 100%;
}
#pc-site-navigation ul#primary-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-around;
  font-size: 12px;
}
#pc-site-navigation ul#primary-menu > li.menu-item {
  padding: 15px 5px;
  flex-grow: 1;
  text-align: center;
  position: relative;
}
#pc-site-navigation ul#primary-menu > li.menu-item a {
  text-decoration: none;
  color: white;
  font-weight: 700;
}
#pc-site-navigation ul.sub-menu {
  display: none;
  position: absolute;
  background-color: #63b4e5;
  list-style: none;
  margin: 0;
  padding: 0;
  width: 200px;
  top: 48px;
}
#pc-site-navigation ul.sub-menu li {
  padding: 15px 5px 15px 10px;
}
#pc-site-navigation ul#primary-menu li:hover ul.sub-menu {
  display: block;
}

#mobile-site-navigation {
  display: block;
  background-color: #63b4e5;
}
@media screen and (min-width: 960px) {
  #mobile-site-navigation {
    display: none;
  }
}
#mobile-site-navigation #menu-btn-check {
  display: none;
}
#mobile-site-navigation .menu-btn {
  height: 48px;
  width: 48px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
#mobile-site-navigation .menu-btn span,
#mobile-site-navigation .menu-btn span:before,
#mobile-site-navigation .menu-btn span:after {
  content: "";
  display: block;
  height: 3px;
  width: 25px;
  border-radius: 3px;
  background-color: #ffffff;
  position: absolute;
}
#mobile-site-navigation .menu-btn span:before {
  bottom: 8px;
}
#mobile-site-navigation .menu-btn span:after {
  top: 8px;
}
#mobile-site-navigation #menu-btn-check:checked ~ .menu-btn span {
  background-color: rgba(255, 255, 255, 0);
  /*メニューオープン時は真ん中の線を透明にする*/
}
#mobile-site-navigation #menu-btn-check:checked ~ .menu-btn span::before {
  bottom: 0;
  transform: rotate(45deg);
}
#mobile-site-navigation #menu-btn-check:checked ~ .menu-btn span::after {
  top: 0;
  transform: rotate(-45deg);
}
#mobile-site-navigation div.menu-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 1s;
}
#mobile-site-navigation div.menu-content ul {
  display: block;
  margin: 0 auto;
  list-style: none;
  margin: 0 40px 30px;
  padding: 0;
}
#mobile-site-navigation div.menu-content ul li {
  border-bottom: solid 1px #fff;
  line-height: 300%;
  position: relative;
  padding-left: 5px;
}
#mobile-site-navigation div.menu-content ul li::after {
  content: "＞";
  color: white;
  font-size: 10px;
  position: absolute;
  right: 5px;
}
#mobile-site-navigation div.menu-content ul li.menu-item-has-children::after {
  content: none;
}
#mobile-site-navigation div.menu-content ul li a {
  text-decoration: none;
  color: white;
}
#mobile-site-navigation div.menu-content ul li ul.sub-menu {
  margin-right: 0px;
  margin-bottom: 0px;
}
#mobile-site-navigation div.menu-content ul li ul.sub-menu li:last-child {
  border: none;
}
#mobile-site-navigation #menu-btn-check:checked ~ div.menu-content {
  max-height: 20000px;
  transition: all 1s;
}

#main-visual {
  background-color: #d2c49f;
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  /* これで自動的に高さが決まる */
  overflow: hidden;
  /* はみ出し防止 */
  /* ロゴ配置（PC：上下中央・左から1/3） */
}
#main-visual img {
  width: 100vw;
  /* 画面幅いっぱい */
  height: calc(100vh - 180px);
  /* 高さは画面高さ−200px */
  object-fit: cover;
  /* アスペクト比を維持しつつ切り抜き */
  display: block;
  margin: 0 auto;
}
#main-visual .background-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* 親幅いっぱい */
  height: 100%;
  /* 親高さいっぱい */
  object-fit: cover;
  /* アスペクト比維持＋切り抜き */
  z-index: 0;
}
#main-visual .tone-overlay {
  position: absolute;
  inset: 0;
  background: url("https://test.artxcafe.com/wp-content/uploads/2025/08/01.png");
  background-repeat: repeat;
  /* タイル状に繰り返す */
  background-size: auto;
  /* 拡大縮小せず元サイズのまま */
  background-position: 0 0;
  /* 左上から開始 */
  opacity: 1;
  /* 濃さを調整 */
  pointer-events: none;
  /* 背景なのでクリック透過 */
  z-index: 1;
}
#main-visual .hero-logo {
  position: absolute;
  left: 50%;
  top: 10%;
  transform: translateX(-50%);
  width: 30%;
  z-index: 2;
  /* 動画/オーバーレイより前面 */
}
#main-visual .hero-logo img {
  display: block;
  width: min(28vw, 360px);
  /* 画面に応じて縮む上限 */
  height: auto;
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.3));
  /* 透過PNGならそのままでOK。背景が必要ならここで指定 */
}
#main-visual .main-visual-signature {
  z-index: 3;
  position: absolute;
  position: absolute;
  bottom: 5px;
  right: 5px;
  font-size: 0.75rem;
}
#main-visual .main-visual-signature span {
  color: white;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  opacity: 0.9;
}

/* スマホ縦向け：9:16にして高さ優先でフィット、横は中央トリミング */
@media (max-width: 640px), (max-aspect-ratio: 3/4) {
  #main-visual {
    aspect-ratio: 9/12;
  }
  #main-visual .hero-logo {
    top: 5%;
    /* 真ん中よりちょっと上 */
    width: 80%;
  }
  #main-visual .hero-logo img {
    width: min(80vw, 360px);
    /* スマホでは少し大きめ可 */
  }

  #main-visual .background-video {
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    width: auto;
    transform: translate(-50%, -50%);
    object-fit: cover;
    object-position: 50% 50%;
  }
}
#masthead {
  position: relative;
  /* ← これが無いと z-index は効きません */
  z-index: 9999;
}

footer#colophon {
  min-height: 100px;
  background-color: #63b4e5;
}
footer#colophon h2 {
  text-align: center;
  font-weight: normal;
  font-size: 1.2rem;
}
footer#colophon h2::before {
  content: "-";
  margin-right: 15px;
}
footer#colophon h2::after {
  content: "-";
  margin-left: 15px;
}
footer#colophon .snslink-box {
  background-color: #eee;
  padding: 30px 15px;
}
footer#colophon .snslink-box nav.snslink {
  height: 150px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
footer#colophon .snslink-box nav.snslink i {
  font-size: 16px;
  color: white;
  background-color: #63b4e5;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}
footer#colophon .snslink-box nav.snslink a {
  text-decoration: none;
}
footer#colophon div.contact-form-box {
  background-color: #fff;
  padding: 30px 15px;
}
footer#colophon .form-submit-btn {
  background-color: #63b4e5;
  margin: 0 auto;
  color: white;
  width: 200px;
  padding: 20px;
  cursor: pointer;
  border-radius: 10px;
  display: block;
}
footer#colophon .wpcf7-form-control {
  max-width: 100%;
}
footer#colophon div.site-info-box {
  padding: 30px 15px;
}
footer#colophon div.site-info-box .site-info-inner-box {
  padding-bottom: 30px;
}
footer#colophon div.site-info-box .site-info-inner-box h2,
footer#colophon div.site-info-box .site-info-inner-box p {
  color: white;
  text-align: center;
}
footer#colophon div.site-info-box .site-info-inner-box p {
  font-size: 0.75rem;
}
footer#colophon div.site-info-box ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
footer#colophon div.site-info-box ul li {
  color: white;
  padding: 10px 0px;
  border-bottom: 1px solid #fff;
}
footer#colophon div.site-info-box ul li span {
  color: white;
  padding-left: 15px;
  display: inline-block;
}
footer#colophon div.site-info-box ul li h3 {
  margin: 0px;
  color: white;
  margin-bottom: 5px;
  font-weight: normal;
  font-size: 1rem;
}
footer#colophon div.site-info-box ul a {
  text-decoration: none;
  text-align: center;
}
@media screen and (min-width: 960px) {
  footer#colophon div.site-info-box {
    display: flex;
    justify-content: space-around;
  }
  footer#colophon div.site-info-box .site-info-inner-box {
    width: 40%;
  }
}
footer#colophon div.twitter-box {
  margin: 0 auto;
  max-width: 600px;
}

@media screen and (min-width: 640px) {
  .pair-box {
    display: flex;
    flex-wrap: wrap;
  }
}

.artist-box,
.shop-box {
  margin: 30px auto;
}
.artist-box h2,
.shop-box h2 {
  margin: 30px auto;
  color: #63b4e5;
  font-size: 1.2rem;
}
@media screen and (min-width: 640px) {
  .artist-box,
.shop-box {
    padding-bottom: 100px;
    position: relative;
    width: 45%;
  }
  .artist-box img,
.shop-box img {
    height: 400px;
  }
  .artist-box .deteil-button,
.shop-box .deteil-button {
    position: absolute;
    bottom: 0px;
    left: 50%;
    transform: translateX(-50%);
  }
}

@media screen and (min-width: 640px) {
  .shop-box > div {
    flex-direction: row-reverse;
  }
}

@media screen and (min-width: 960px) {
  .artist-detail .artist-detail-innerbox,
.artist-detail .product-box {
    display: flex;
    justify-content: space-around;
  }
  .artist-detail .artist-detail-innerbox div,
.artist-detail .product-box div {
    width: 45%;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
  }
}
.artist-detail .artist-detail-innerbox:nth-child(odd),
.artist-detail .product-box:nth-child(odd) {
  flex-direction: row-reverse;
}
.artist-detail .artist-detail-innerbox table,
.artist-detail .product-box table {
  border-collapse: collapse;
}
.artist-detail .artist-detail-innerbox tr,
.artist-detail .product-box tr {
  border-bottom: dashed 1px #63b4e5;
}
.artist-detail .artist-detail-innerbox th,
.artist-detail .product-box th {
  min-width: 150px;
  color: #63b4e5;
  font-weight: normal;
  padding: 10px 0px;
}
.artist-detail .artist-detail-innerbox td,
.artist-detail .product-box td {
  padding: 10px 0px;
}
.artist-detail nav.snslinks ul {
  list-style: none;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 0 auto;
  padding: 0;
}
.artist-detail nav.snslinks ul i {
  font-size: 16px;
  color: white;
  background-color: #63b4e5;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.artist-detail nav.snslinks ul a {
  text-decoration: none;
}
@media screen and (min-width: 960px) {
  .artist-detail .product-box + .product-box {
    margin-top: 40px;
  }
}

.takuto-box {
  margin: 0 60px;
}

@media (max-width: 640px) {
  .takuto-box {
    margin: 0 20px;
  }
}
/* スクロールダウンの位置 */
.scroll {
  position: absolute;
  right: 50%;
  transform: translateX(50%);
  bottom: 25%;
  writing-mode: vertical-rl;
  color: white;
}
.scroll span {
  font-size: 0.75rem;
  color: white;
}

/* 線のアニメーション部分 */
.scroll::before {
  animation: scroll 2s infinite;
  background-color: white;
  bottom: -100px;
  content: "";
  height: 80px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}

/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
h1.entry-title {
  text-align: center;
  color: #63b4e5;
}

.artxcafe-section-box {
  padding: 30px 15px;
}
.artxcafe-section-box h1 {
  color: white;
  font-size: 1.4rem;
  font-weight: bold;
  background: #63b4e5;
  box-shadow: 0px 0px 0px 5px #63b4e5;
  border: dashed 2px white;
  padding: 0.2em 0.5em;
}
.artxcafe-section-box h2 {
  color: #63b4e5;
  font-size: 1.2rem;
  margin: 30px auto;
}
.artxcafe-section-box h2::before {
  content: "●";
}
.artxcafe-section-box h2.menuheader {
  text-align: center;
}
.artxcafe-section-box h2.menuheader::before, .artxcafe-section-box h2.menuheader::after {
  content: "〜";
}
@media screen and (min-width: 640px) {
  .artxcafe-section-box div.artxcafe-section-inner {
    /*　画面サイズが1024pxからはここを読み込む　*/
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    flex-direction: row;
  }
  .artxcafe-section-box div.artxcafe-section-inner > figure {
    width: 45%;
  }
  .artxcafe-section-box div.artxcafe-section-inner > div {
    width: 45%;
  }
}
.artxcafe-section-box div.artxcafe-section-inner section.pair-box {
  margin: 30px 0px;
  display: block;
}
@media screen and (min-width: 640px) {
  .artxcafe-section-box div.artxcafe-section-inner section.pair-box {
    width: 32%;
  }
}
.artxcafe-section-box div.artxcafe-section-inner section.pair-box figure {
  margin: 0px;
  position: relative;
}
.artxcafe-section-box div.artxcafe-section-inner section.pair-box figure img {
  vertical-align: top;
}
@media screen and (min-width: 640px) {
  .artxcafe-section-box div.artxcafe-section-inner section.pair-box figure img {
    height: 280px;
    display: block;
    margin: 0 auto;
  }
}
.artxcafe-section-box div.artxcafe-section-inner section.pair-box figure figcaption {
  position: absolute;
  background-color: rgba(0, 0, 0, 0.4);
  width: 100%;
  text-align: center;
  bottom: 0;
  color: white;
  font-size: 1rem;
  padding: 5px;
  box-sizing: border-box;
}
.artxcafe-section-box div.artxcafe-section-inner section.pair-box > div {
  text-align: center;
}
.artxcafe-section-box div.artxcafe-section-inner.cafe-box {
  border-top: 1px solid silver;
}
.artxcafe-section-box:nth-child(odd) div.artxcafe-section-inner {
  flex-direction: row-reverse;
}
.artxcafe-section-box img {
  max-height: 80vh;
  display: block;
  margin: 0 auto;
}

/* ライン公式ボタン */
.ctabutton-box {
  position: fixed;
  bottom: 30px;
  right: 30px;
}

#ctabutton-box-inner {
  background-color: white;
  box-shadow: 0px 0px 5px #333;
  padding: 15px 30px;
  border-radius: 30px;
  animation: pulse 2s infinite;
  display: flex;
}

#ctabutton-box-inner iframe {
  margin-bottom: 0px;
}

.link-button-box {
  gap: 20px;
}

.link-button-box .btn {
  background-color: #8b4513;
  color: white;
  border-radius: 20px;
  padding: 10px 20px;
  cursor: pointer;
}

@keyframes pulse {
  0% {
    transform: scale(1);
  }
  60% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  80% {
    transform: scale(0.95);
  }
  90% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}

/*# sourceMappingURL=artxcafe_style.css.map */
