@charset "utf-8";
/* CSS Document */

.fv .label {
    position: absolute;
    right: 0px;     
    bottom: 30px;
    z-index: 9;                 
    pointer-events: auto;        
}
.fv .label img {
    display: block;
    width: clamp(270px, 30vw, 360px); 
    max-width: calc(100% - 32px); 
    height: auto;
	margin-left: auto;
}

body {
  color: #fff;
}

.access_wrap .mapbox>div{
  height:100%;
}
.header_d {
    position: fixed;
    background-color: transparent;
}
body:not(.on) .swiper {
  overflow: visible;

}
/* 画像の基本 */
body:not(.on) .swiper-img img {
}
body:not(.on) .pbox_wrap .box-item::before {
  content: "";
  position: absolute;
  left: 0;
  right: 10%;
  background: #7b1c26;
  z-index: -2;
}
/* ----------fv ---------- */
.fv .swiper {
  width: 100%;
  height: 100vh; /* フルスクリーンにしたい場合 */
}
body:not(.on) .fv .swiper {
	height: auto!important;
}
.fv .swiper-slide {
  width: 100%;
  height: 100%;
}
.fv .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.fv .swiper-img {
  position: relative; /* 擬似要素の基準にする */
}
.fv .swiper-img::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2); /* ← 20%の黒 */
  pointer-events: none; /* クリック操作を邪魔しない */
}
/* ---------- cate1 ---------- */
.cate1 {
  background: #212121;
  position: relative;
}
.cate.cate1::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(360px, 55vh, 720px);
  background: linear-gradient(0deg, #212121 0%, /* 下端しっかり濃い */ rgba(33, 33, 33, 0.9) 25%, /* 中間もやや濃く */ rgba(33, 33, 33, 0.6) 55%, /* 徐々に薄く */ rgba(33, 33, 33, 0.0) 100% /* 上端で透明にフェード */
    );
  z-index: 1;
  pointer-events: none;
}
.cate1 .rightbox .en_title_a {
  margin-bottom: clamp(-80px, -12vw, -150px);
  margin-left: clamp(-40px, -6vw, -80px);
}
/* ===== 2カラム ===== */
.cate1 .box_wrap {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0;
  align-items: center;
  margin: 0 auto;
  color: #fff;
  z-index: 5;
  position: relative;
}
/* ===== 左：コラージュ ===== */
.concept-left {
  --size: clamp(140px, 15vw, 220px);
  position: relative;
  width: calc(var(--size) * 3);
  height: calc(var(--size) * 3);
  margin: 0 auto;
}
/* 共通 */
.concept-left .tile {
  position: absolute;
  width: var(--size);
  height: var(--size);
  border-radius: 12px;
  overflow: hidden;
  transform: rotate(45deg);
  box-shadow: 0 10px 22px rgba(0, 0, 0, .28), 0 0 0 1px rgba(255, 255, 255, .08) inset;
}
.concept-left .tile img {
  width: 160%;
  height: 160%;
  object-fit: cover;
  transform: rotate(-45deg) translateX(-5%) translateY(-20%);
}
.concept-left .t1 { /* 上 */
  left: 50%;
  top: 0;
  transform: translate(-50%, calc(var(--size) / 6)) rotate(45deg);
}
.concept-left .t2 { /* 左 */
  left: 0;
  top: 50%;
  transform: translate(calc(var(--size) / 6), -50%) rotate(45deg);
}
.concept-left .t3 { /* 右 */
  right: 0;
  top: 50%;
  transform: translate(calc(-1 * var(--size) / 6), -50%) rotate(45deg);
}
.concept-left .t4 { /* 下 */
  left: 50%;
  bottom: 0;
  transform: translate(-50%, calc(-1 * var(--size) / 6)) rotate(45deg);
}
/* ===== 右：テキスト ===== */
.cate1 .rightbox {
  color: #fff;
}
.cate1 .rightbox .txtbox {
  align-items: flex-start;
  background: rgba(33, 33, 33, 0.7);
  padding: clamp(40px, 6vw, 80px) clamp(20px, 4vw, 60px) clamp(0px, 10vw, 120px);
}
:root {
  --header-h: 100px;
  --header-bg-h: 100px;
}
:root:has(.fv) {
  --header-h: 0px;
  --header-bg-h: 100px;
}
/* ---------- fv ---------- */
body.on .fv {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
body.on .fv::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.2); /* ← 20％透過黒 */
  z-index: 1;
  pointer-events: none; /* クリックを通す */
}
.fv .fv_icon {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 35%;
  z-index: 5;
}
.fv .fv_icon img {
  mix-blend-mode: multiply;
  opacity: 0.4;
}
.fv .img-box {
  position: relative;
  z-index: 1;
}
@keyframes fvtxt {
  0% {
    opacity: 0;
    transform: translateX(50px);
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
    -ms-filter: blur(0px);
    filter: blur(0px);
  }
}
.fv .swiper {
  z-index: 1;
  position: relative;
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
body.on .fv .swiper-slide {
  width: 100% !important;
  height: 100vh;
}
body.on .fv .swiper-slide .swiper-img {
  width: 100% !important;
  height: 100vh;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
.fv .swiper-slide-active .swiper-img, .fv .swiper-slide-duplicate-active .swiper-img, .fv .swiper-slide-prev .swiper-img {
  animation: zoomUp 10s linear 0s normal both;
}
body.on .fv .swiper-slide img {
  display: block !important;
  opacity: 0;
  height: auto;
  width: 100%;
}
.fv .top_box {
  position: absolute;
  left: clamp(24px, 8vw, 100px);
  z-index: 50;
  align-items: flex-start;
}
.fv .top_box .imgbox img {
  width: auto;
  height: clamp(60px, 12vw, 100px);
}
.fv .txtbox {
  align-items: flex-start;
  font-family: 'Hina Mincho', 'Hiragino Mincho ProN', 'Yu Mincho', serif;
  color: #fff;
}
.fv .txtbox h1 {
  font-weight: 400;
  font-size: clamp(36px, 5.2vw, 53px);
  letter-spacing: .06em;
}
/* 「夜」だけ大きく */
.fv .txtbox h1 > span {
  font-size: clamp(48px, 6.8vw, 70px);
}
.fv .txtbox p {
  font-size: clamp(22px, 3.3vw, 35px);
}
body.on .fv .txtbox h1 {
  opacity: 0;
  -ms-filter: blur(6px);
  filter: blur(6px);
  animation-name: blurin2;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
  animation-delay: 1s;
}
body.on .fv .txtbox p {
  opacity: 0;
  -ms-filter: blur(6px);
  filter: blur(6px);
  animation-name: blurin2;
  animation-duration: 2.5s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
  animation-delay: 1s;
}
body.on .mainmenu_box {
  opacity: 0;
  -ms-filter: blur(6px);
  filter: blur(6px);
  animation-name: blurin2;
  animation-duration: 3.5s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
  animation-delay: 1s;
}
.mainmenu_box .mene_box {
  max-width: 280px;
  margin-left: auto;
}
.mainmenu_box .mene_box .nav_box {
  padding: 30px 0;
}
.mainmenu_box .mene_box .nav_box .ul {
  margin-bottom: 20px;
}
.mainmenu_box .mene_box .nav_box .ul .li {
  padding: 15px 0;
}
.mainmenu_box .mene_box .nav_box .ul .li a {
  justify-content: flex-start;
  gap: 15px;
}
.mainmenu_box .mene_box .nav_box .ul .li p {
  font-size: 16px;
  font-weight: 500;
  color: #fff;
}
.mainmenu_box .nav_box .ul .li a {
  position: relative;
  padding-left: 1.8em;
  color: #fff;
  text-decoration: none;
  align-items: center;
  gap: 12px;
}
/* ホバーで出る赤い丸（初期は見えない） */
.mainmenu_box .nav_box .ul .li a::before {
  content: "";
  position: absolute;
  left: 0.4em;
  top: 50%;
  width: 0.6em;
  height: 0.6em;
  border-radius: 50%;
  background: #ff3a3a;
  transform: translate(-0.8em, -50%) scale(0.6); /* 左外から小さく */
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
  pointer-events: none;
  box-shadow: 0 0 0 2px rgba(255, 58, 58, .25) inset; /* うっすら縁取り */
}
/* ホバー＆キーボードフォーカスで表示 */
.mainmenu_box .nav_box .ul .li a:hover::before, .mainmenu_box .nav_box .ul .li a:focus-visible::before {
  opacity: 1;
  transform: translate(-0.2em, -50%) scale(1); /* 少し内側へ＆拡大 */
}
/* お好みで：選択中／現在ページに常時表示 */
.mainmenu_box .nav_box .ul .li.is-active a::before, .mainmenu_box .nav_box .ul .li a[aria-current="page"]::before {
  opacity: 1;
  transform: translate(-0.2em, -50%) scale(1);
}
.edge_scrollbox {
  position: absolute;
  left: 0px;
  top: 50%;
  bottom: 0;
  width: 28px;
  flex-direction: column;
  gap: 12px;
  z-index: 9999;
  cursor: pointer;
  pointer-events: auto;
}
/* 「Scroll」縦書き＋すぐ下に短い横線 */
.edge_scroll {
  writing-mode: vertical-rl;
  font-family: 'Zen Old Mincho', 'Yu Mincho', serif;
  font-size: clamp(18px, 2vw, 24px);
  letter-spacing: .14em;
  color: #fff;
  margin-left: 8px;
  position: relative;
}
/* 下へ伸びる縦ライン（トラック） */
.edge_scrollbox .line {
  position: relative;
  width: 1px;
  flex: 1 1 auto;
  background: rgba(255, 255, 255, .35);
  border-radius: 1px;
  overflow: hidden;
}
/* 中央から伸びる白バー（演出用） */
.edge_scrollbox .line::after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 0%;
  background: #fff;
  transition: height .6s ease;
  box-shadow: 0 0 8px rgba(255, 255, 255, .35);
}
/* ホバーで上下にフル伸長 */
.edge_scrollbox:hover .line::after {
  height: 100%;
}
/* ---------- newstop_b ---------- */
.newstop_b .webgene-blog .webgene-item {
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: none;
}
.newstop_b .webgene-blog .webgene-item a .date {
  margin-right: 20px;
}
.newstop_b .webgene-blog .webgene-item a h3 {
  flex: 1;
  min-width: 0;
}
.newstop_b .webgene-blog .webgene-item a .catelabel {
  border: #fff solid 1px;
  border-radius: 50px;
  padding: 4px 10px;
}
/* ---------- cate2 ---------- */
.cate2 {
  padding-bottom: clamp(60px, 10vw, 150px);
}
.cate2 .box_wrap {
  flex-wrap: nowrap;
}
/* タイトル */
.cate2 .access_title {
  margin-bottom: clamp(30px, 5vw, 60px);
}
.cate2 .access_title .en_title_a {
  font-family: "WindSong", cursive;
  font-weight: 400;
  letter-spacing: .05em;
  font-size: clamp(48px, 9vw, 120px);
  transform: rotate(-10deg);
  margin: 0;
  display: inline-block;
}
.cate2 .access_title .jp_title {
  text-align: center;
  margin-top: -10px;
}
/* レイアウト */
.cate2 .box_wrap {
  justify-content: space-between;
  gap: 0;
}
/* 左側 */
.cate2 .leftbox {
  width: 50%;
  align-items: flex-start;
  flex-direction: column;
  gap: clamp(20px, 3vw, 40px);
  z-index: 5;
  flex: 1 1 55%;
}
.cate2 .access_wrap {
  padding-left: clamp(0px, 8vw, 150px);
}
.access_wrap .mapbox {
  width: clamp(350px, 80vw, 780px);
  height: clamp(280px, 53vw, 420px);
  overflow: hidden;
  position: relative;
}
.access_wrap .mapbox iframe {
  width: 100% !important;
  height: 100% !important;
  display: block;
  border: 0;
}
/* 店舗情報 */
.cate2 .access_info {
  color: #fff;
  font-family: "Noto Serif JP", serif;
  display: flex;
  justify-content: flex-start;
  flex-direction: column;
  gap: 20px;
  max-width: 480px;
}
.cate2 .row1 {
  display: flex;
  align-items: baseline;
  gap: clamp(12px, 2vw, 20px);
  border-bottom: 1px solid rgba(255, 255, 255, .3);
  padding: 14px 0;
}
/* 左：見出し（固定幅） */
.cate2 .row1 .dt1 {
  flex: 0 0 clamp(88px, 12ch, 140px);
  margin: 0;
  letter-spacing: .05em;
}
/* 右：内容（残り全部） */
.cate2 .row1 .dd1 {
  flex: 1 1 auto;
  margin: 0;
  line-height: 1.9;
}
/* 最後の行だけ区切り線を消す */
.cate2 .row1:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.cate2 .access_btn {
  position: absolute;
  bottom: 0;
  right: 50px;
}
.cate2 .rightbox {
  width: 50%;
  height: 100%;
  position: absolute;
  right: 0;
  overflow: hidden;
}
.cate2 .rightbox .imgbox {
  min-height: 800px;
}
.cate2 .rightbox .imgbox img {
  width: 100%;
  height: 700px;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}
/* ---------- cate3 ---------- */
.pagetitle_party .pagetitle-container {
  align-items: center;
  margin: 0 auto;
  height: clamp(240px, 34vw, 300px);
}
.cate3 {
  position: relative;
  overflow: hidden;
  background: #151515;
}
.bgbox {
  position: absolute;
  inset: 0;
  height: clamp(500px, 70vh, 900px);
  overflow: hidden;
  z-index: 1;
}
.bgbox .bg1 {
  width: 100%;
  height: clamp(400px, 60vh, 800px);
  max-height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
/* ▼ グラデーションを重ねる */
.bgbox::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(300px, 45vh, 600px);
  background: linear-gradient(0deg, #151515 0%, rgba(21, 21, 21, 0.85) 30%, rgba(21, 21, 21, 0.5) 60%, rgba(21, 21, 21, 0) 100%);
  z-index: 1;
  pointer-events: none;
}
.cate3 .titlebox1, .cate4 .titlebox1 {
  text-align: left;
  width: clamp(200px, 50vw, 500px);
  z-index: 5;
  position: relative;
}


.cate3 .titlebox1 .jp_title, .cate4 .titlebox1 .jp_title {
  width: 100%;
  text-align: right;
}
.cate3 .partybox_wrap {
  gap: clamp(40px, 8vw, 120px);
  z-index: 5;
  position: relative;
  flex-direction: column;
}
.cate3 .partybox_wrap .box-item {
  gap: 70px;
  max-width: 1280px;
}
.cate3 .partybox_wrap .box-item .txtbox {
  flex-direction: column;
  gap: 30px;
  width: calc(50% - 45px);
  align-items: flex-start;
}
.cate3 .partybox_wrap .box-item .imgbox {
  flex-direction: column;
  gap: 20px;
  width: calc(50% - 45px);
  aspect-ratio: 66/ 46;
  overflow: hidden;
  align-items: flex-start;
  position: relative;
}
.cate3 .partybox_wrap .box-item .imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  z-index: 1;
}
.cate3 .partybox_wrap .box-item .imgbox::after {
  position: absolute;
  content: '';
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  box-shadow: inset 0 0 20px 25px #151515;
  z-index: 5;
  pointer-events: none;
}
.cate3 .partybox_wrap .box-item .txtbox .txt-top {
  position: relative;
  display: block; /* ← これで幅100%になる */
  width: 100%; /* 念のため指定 */
  padding-bottom: 10px;
  margin-bottom: 16px;
}
.cate3 .partybox_wrap .box-item .txtbox .txt-top::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background: linear-gradient(90deg, #B4A638 0 20px, #707070 60px 100%);
  opacity: 1;
  z-index: 1;
}
/* ---------- cate4 ---------- */
.cate4 {
  position: relative;
  overflow: hidden;
}
.cate4 .more1 {
  margin-top: clamp(20px, 5vw, 40px);
}
.cate4 .default_txt2 {
  line-height: 2;
}
.cate4 .bgbox::after {
  background: linear-gradient(0deg, #212121 0%, rgba(33, 33, 33, 0.85) 30%, rgba(33, 33, 33, 0.5) 60%, rgba(33, 33, 33, 0) 100%);
}
.pbox_wrap {
  gap: clamp(40px, 8vw, 120px);
}
.pbox_wrap .box-item {
  gap: clamp(0px, 8vw, 120px);
  width: 100%;
  height: auto;
  position: relative;
  display: flex;
  align-items: center;
  z-index: 1;
}
/* 背景をbox-itemの裏に敷く */
.pbox_wrap .box-item::before {
  content: "";
  position: absolute;
  inset: 0;
  left: 0;
  right: 10%;
  background: #7b1c26;
  z-index: 0;
}
.pbox_wrap .boxitem1::before {
  content: "";
  position: absolute;
  inset: 0;
  right: 0;
  left: 10%;
  background: #7b1c26;
  z-index: 0;
}
.pbox_wrap .boxitem1 {
  gap: 30px;
}
.pbox_wrap .box-item .txtbox {
  flex-direction: column;
  gap: 30px;
}
.pbox_wrap .box-item .imgbox {
  position: relative;
  aspect-ratio: 530 / 560;
  width: clamp(260px, 32vw, 420px);
  max-height: 400px;
}
/* 中の画像は枠いっぱいでOK */
.pbox_wrap .box-item .imgbox .item1 {
  aspect-ratio: 530 / 560;
  width: 100%;
  height: auto;
  max-height: 400px;
  object-fit: cover;
  display: block;
  z-index: 1;
  position: absolute;
  right: -30px;
}
.pbox_wrap .box-item .imgbox .item2 {
  position: absolute;
  left: clamp(-60px, -10vw, -150px);
  bottom: clamp(-60px, -10vw, -150px);
  height: clamp(260px, 30vw, 350px);
  width: auto;
  object-fit: contain;
  z-index: 2;
  transform: rotate(-2deg);
}
.pbox_wrap .boxitem1 .imgbox .item1 {
  right: clamp(-150px, -10vw, -220px);
}
.cate4 .titlebox1 .jp_title {
  margin-top: 0;
}
.news_b .date, .news_b .title {
  color: #fff;
}
.news_b .catename {
  color: #151515;
}
.news_b.news_list .contents .webgene-blog .webgene-item {
  width: calc(100% / 4 - 120px / 4);
}
.cate5 .titlebox2 {
  justify-content: flex-start;
  padding-bottom: 70px;
}
.cate5 .box-item {
  gap: 70px;
}
.cate5 .box-item .txtbox {
  flex-direction: column;
  gap: 50px;
  width: calc(50% - 45px);
  align-items: flex-start;
}
.cate5 .box-item .imgbox {
  flex-direction: column;
  gap: 20px;
  width: calc(50% - 45px);
  align-items: flex-start;
}
.sns_a .titlebox {
  color: #767676;
  gap: 20px;
  justify-content: flex-start;
}
.sns_a .imgbox {
  border-radius: 10px;
  overflow: hidden;
}
.sns_a .swiper-slide {
  width: 230px;
}
.sns_a .swiper-container {
  padding: 0;
}
body:not(.on) .sns_a .swiper-container .swiper-wrapper {
	width: 100%;
	display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    justify-content: center;
    align-items: center;
	flex-direction: row;
}
.sns_a .swiper-container .swiper-wrapper .swiper-slide {
  opacity: 1;
  flex: 0 0 auto;
  width: 260px;
  scroll-snap-align: start;
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px) {
  .cate1 .box_wrap {
    grid-template-columns: 1fr; /* ← 1カラムに変更 */
    grid-template-rows: auto auto; /* 上下に配置 */
  }
  .cate1 .leftbox, .cate1 .rightbox {
    width: 100%; /* 横幅いっぱい */
  }
  .cate1 .rightbox {
    margin-top: -240px;
  }
  .cate1 .concept-left {
    margin: 0 auto;
    margin-right: 50px;
    margin-left: auto;
  }
  .cate1 .box_wrap {
    gap: 40px;
    flex-direction: column;
  }
  .cate1 .box_wrap .newstop_b {
    width: 100%;
  }
  .cate3 .box_wrap {
    gap: 60px;
  }
  .cate3 .box_wrap .leftbox {
    gap: 90px;
    margin-bottom: auto;
  }
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px) {
  .pbox_wrap .boxitem1 {
    gap: 50px;
  }
  .pbox_wrap .boxitem1 .imgbox .item1 {
    right: -90px;
  }
  .cate1 .rightbox {
    margin-top: -40px;
  }
  .cate1 .concept-left {
    margin: 0 auto;
    margin-right: 0px;
    margin-left: auto;
  }
  .cate2 .access_btn {
    position: relative;
    left: auto;
    right: auto;
  }
  .cate3 .box_wrap {
    flex-direction: column;
  }
  .cate3 .box_wrap .leftbox {
    width: 100%;
    flex-direction: row;
  }
  .cate3 .box_wrap .leftbox {
    gap: 50px;
  }
  .cate3 .box_wrap .leftbox .left-top {
    width: calc(60% - 25px);
  }
  .cate3 .box_wrap .leftbox .left-bottom {
    width: calc(40% - 25px);
  }
  .cate3 .box_wrap .leftbox .left-top h2 {
    margin-right: auto;
  }
  .cate3 .box_wrap .rightbox {
    width: 100%;
    align-items: center;
  }
  .cate3 .box_wrap .rightbox .imgbox {
    width: 70%;
    margin: 0 auto 50px auto;
  }
  .cate4 .pbox_wrap .box-item {
    flex-direction: column;
  }
  .cate4 .pbox_wrap .box-item .txtbox {
    width: 100%;
    gap: 30px;
    align-items: center;
  }
  .cate4 .pbox_wrap .box-item .imgbox {
    width: 70%;
  }
  .news_b.news_list .contents .webgene-blog .webgene-item {
    width: calc(100% / 2 - 50px / 2);
  }
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px) {
  .pc-hide {
    display: flex;
  }
  .cate3 .partybox_wrap .box-item {
    gap: 20px;
  }
  .cate3 .partybox_wrap .box-item .imgbox {
    width: 100%;
  }
  .cate3 .partybox_wrap .box-item .txtbox {
    gap: 0px;
    width: 100%;
  }
  .newstop_b .webgene-blog .webgene-item a .date {
    margin-right: 10px;
  }
  .newstop_b .webgene-blog .webgene-item a .date {
    width: 90px;
  }
  .cate4 .box_wrap {
    gap: 80px;
  }
  .cate4 .box_wrap .box-item .txtbox {
    gap: 20px;
  }
  .sns_a .swiper-slide {
    width: 140px; /* ← スマホ時の画像幅を小さく */
  }
  .sns_a .webgene-item {
    width: 150px; /* ← 記事全体の幅も合わせて小さく */
  }
  .sns_a .titlebox {
    gap: 10px;
    font-size: 14px;
  }
}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px) {
  .cate3 .titlebox1, .cate4 .titlebox1 {
  width: auto;
      padding-right: 20px;
}
  
  .pbox_wrap .box-item::before {
    content: "";
    position: absolute;
    inset: 0;
    left: 0;
    right: 0;
    background: #7b1c26;
    z-index: 0;
  }
  .cate1 .concept-left {
    --size: 110px;
  }
  .cate1 .rightbox {
    margin-top: -10px;
  }
  .cate1 .rightbox .en_title_a {
    margin-bottom: -200px;
    margin-left: 10px;
  }
  .cate2 .access_wrap {
    padding-left: 0px;
    width: 100%;
  }
  .access_wrap .mapbox {
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  .cate1 .box_wrap {
    gap: 30px;
  }
  .pbox_wrap .boxitem1 .imgbox .item1 {
    right: -10px;
  }
  .pbox_wrap .boxitem1 .imgbox .item2 {
    height: 200px;
  }
  .newstop_b .webgene-blog .webgene-item a > .label {
    width: 100%;
  }
  .newstop_b .webgene-blog .webgene-item a .catelabel {
    padding: 0px 5px;
  }
  .newstop_b .webgene-blog .webgene-item {
    padding-bottom: 5px;
    margin-bottom: 5px;
  }
  .news_b.news_list .contents .webgene-blog {
    width: 90%;
    margin: 0 auto;
    gap: 40px;
  }
  .news_b.news_list .contents .webgene-blog .webgene-item {
    width: 100%;
  }
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px) {}