@charset "utf-8";
/* CSS Document */
body {
  color: #fff;
}
@media screen and (max-width: 1280px) {
    .header_d .menu-bt .line > div {
        background-color: #fff;

    }
}
.columnbox1 {
  margin-top: -50px;
  z-index: 0;
}
.columnbox1 .titlebox3 {
  margin: 0 auto 60px;
}
.columnbox1 h3 {
  font-family: "Zen Old Mincho", serif;
}
/* ====== ニュース ====== */
.nm-section .more {
  justify-content: flex-end;
}
.nm-section {
  width: 100%;
  align-items: stretch;
  background: #d7ccc3;
  color: #3f332c;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  line-height: 1.7;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: stretch;
}
.nm-section a {
  text-decoration: none;
  color: inherit;
}
.nm-col, .newstop_b1 {
  display: flex;
  flex-direction: column;
  padding: clamp(80px, 4.5vw, 100px) clamp(50px, 4vw, 100px);
  box-sizing: border-box;
  min-height: 100%;
}
/* ====== 右：News ====== */
.newstop_b1 {
  background: #C4B9B1;
}
.newstop_b1 .webgene-blog .webgene-item {
  border-bottom: 1px solid rgba(112, 112, 112, 0.2);
}
.newstop_b1 .webgene-blog .webgene-item a > .flex {
  padding: 16px 0;
}
.newstop_b1 .webgene-blog .webgene-item a .date {
  width: 100px;
}
.newstop_b1 .webgene-blog .webgene-item a .catelabel {
  border: #000 solid 1px;
  border-radius: 50px;
}
.newstop_b1 .webgene-blog .webgene-item a .cate_txt {
  width: 94px;
  text-align: center;
  padding: 3px 3px;
  box-sizing: border-box;
}
/* ====== 左：Media ====== */
.nm-col {
  background: #D5CCC7;
}
/* 見出し（アイコン＋英字） */
.nm-ttl {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.ttl-icon {
  width: 18px;
  height: 18px;
  position: relative;
}
.ttl-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("https://viennoiserie-selfish.jp/system_panel/uploads/images/index2.svg") no-repeat center / contain;
}
.ttl-text {
  letter-spacing: .08em;
}
.nm-row {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(63, 51, 44, .18);
}
.nm-date {
  flex: 0 0 110px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 14px;
  opacity: .85;
}
.nm-body {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nm-section .nm-row {
  gap: 12px;
}
.nm-section .nm-row .date {
  flex: 0 0 94px; /* 日付は固定幅 */
  font-size: 13px;
}
.nm-section .nm-row .title {
  width: clamp(250px, 22vw, 400px);
  flex: 1 1 auto; /* 余白に合わせて伸縮 */
  min-width: 0; /* ←これが重要（はみ出し防止） */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 768px) {
  .nm-section {
    grid-template-columns: 1fr !important;
  }
  .nm-section .nm-row .date {
    flex: 0 0 94px;
    font-size: 13px;
  }
  .nm-section .nm-row .title {
    /* 幅固定はNG */
    flex: 1 1 auto;
    min-width: 0; /* ←はみ出し防止 */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
@media (max-width: 576px) {
  .nm-section .nm-row .date {
    flex-basis: 86px;
    font-size: 12.5px;
  }
  .nm-section .nm-row .title {
    flex: 1 1 auto;
    min-width: 0;
  }
  /* 念のための横スクロール保険 */
  .nm-section {
    overflow-x: hidden;
  }
  .nm-section img, .nm-section iframe {
    max-width: 100%;
    width: 100%;
    height: auto;
    display: block;
  }
}
/* ========== column2_c ========== */
.column2_c .inner {
  max-width: 1920px;
}
.column2_c .content {
  margin-left: 150px;
}
.column2_c .imgboxwrap {
  position: relative;
  min-height: clamp(320px, 40vw, 560px); /* キャンバスの高さ */
}
/* 汎用：枠と影（必要なら） */
.column2_c .imgboxwrap .imgbox {
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0, 0, 0, .12);
}
.column2_c .imgboxwrap .imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.column2_c .imgboxwrap .imgbox:nth-child(1) {
  position: relative;
  left: 0;
  top: 0;
  width: clamp(360px, 75%, 800px);
  aspect-ratio: 4 / 3;
  z-index: 1;
}
/* 2枚目＝小さい写真（右下） */
.column2_c .imgboxwrap .imgbox:nth-child(2) {
  position: relative;
margin-right: 0;
    margin-left: auto;
  width: clamp(280px, 55%, 520px); /* 小さめサイズ */
  aspect-ratio: 4 / 3;
  z-index: 2;
}
@media (max-width:1080px) {
  .column2_c .content {
    margin-left: 0px;
    padding-left: clamp(20px, 5vw, 80px);
    padding-right: clamp(20px, 5vw, 80px);
  }
  .column2_c .imgboxwrap {
    min-height: clamp(280px, 40vw, 520px);
  }
  /* 1枚目：左上の大きい画像 */
  .column2_c .imgboxwrap .imgbox:nth-child(1) {
    width: clamp(320px, 54vw, 540px);
    aspect-ratio: 4 / 3;
    left: 0;
    top: 0;
  }
  /* 2枚目：右下の小さい画像 */
  .column2_c .imgboxwrap .imgbox:nth-child(2) {
    width: clamp(240px, 42vw, 420px);
      position: absolute;
    aspect-ratio: 4 / 3;
    right: 0;
    bottom: 0;
  }
  /* テキスト側との横ギャップも可変にしたい場合（任意） */
  .column2_c .inner {
    gap: clamp(24px, 4.8vw, 56px);
  }
}
@media (max-width:576px) {
  /* キャンバスは自動高さにして縦積みへ */
  .column2_c .imgboxwrap {
    min-height: auto;
  }
  /* 2枚とも通常フローに戻して全幅表示 */
  .column2_c .imgboxwrap .imgbox:nth-child(1), .column2_c .imgboxwrap .imgbox:nth-child(2) {
    position: static;
    width: 100%;
    aspect-ratio: auto;
    box-shadow: none; /* 影を弱めたい場合は残してもOK */
  }
  /* 2枚目の間隔（1枚目の下にマージン） */
  .column2_c .imgboxwrap .imgbox:nth-child(2) {
    margin-top: clamp(10px, 4vw, 16px);
  }
  /* テキスト側との横ギャップも少し詰める（任意） */
  .column2_c .inner {
    gap: clamp(16px, 4vw, 24px);
  }
}
/* ========== topbox2 ========== */
.topbox2 {
  position: relative;
  padding: clamp(48px, 8vw, 88px) 0 120px;
}
.topbox2 .more, .columnbox1 .more, .column2_c .more {
  justify-content: flex-end;
  margin-right: 0;
  margin-left: auto;
}
.topbox2 .more {
  margin-right: 0;
  margin-left: auto;
}
/* 2カラム本体 */
.topbox2 .inner {
  max-width: 1400px;
  margin: 0 0 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 5vw, 150px);
  align-items: start;
}
.topbox2 .txtbox {
  padding-left: 50px;
  position: relative;
}
.topbox2 .txtbox::after {
  content: "";
  position: absolute;
  bottom: 30px; /* ← 下寄せ */
  left: -80px; /* ← 左寄せ */
  width: clamp(120px, 16vw, 200px);
  height: clamp(120px, 16vw, 200px);
  background: url("https://viennoiserie-selfish.jp/system_panel/uploads/images/index1.svg") no-repeat center / contain;
  pointer-events: none;
  transform: translate(-25%, 25%); /* 左下に少しはみ出す */
  z-index: -1; /* テキストの裏に置きたい場合は -1 */
}
/* 右：大きな写真（薄い枠付き） */
.topbox2 .imgbox {
  position: relative;
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0, 0, 0, .12);
  outline-offset: -2px;
  max-height: 800px;
  aspect-ratio: 448 / 580;
}
.topbox2 .imgbox img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
/* 左下の小写真（セクションの外縁に少し重ねる） */
.topbox2 .ph-sub {
  position: absolute;
  left: 0;
  bottom: clamp(-40px, -3vw, -20px);
  width: clamp(180px, 22vw, 280px);
  border-radius: 2px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, .12);
  z-index: 5;
}
.topbox2 .ph-sub img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
@media (max-width: 1080px) {
  .topbox2 {
    position: relative;
    padding: clamp(48px, 8vw, 88px) 0 0px;
  }
  .topbox2 .inner {
    grid-template-columns: 1fr;
  }
  /* 並び順：写真 上 → テキスト 下 */
  .topbox2 .rightbox {
    grid-column: 1;
    grid-row: 1;
  }
  .topbox2 .txtbox {
    grid-column: 1;
    grid-row: 2;
  }
  /* 写真サイズの上限＆中央寄せ */
  .topbox2 .rightbox {
    display: flex;
    justify-content: center;
  }
  .topbox2 .rightbox .imgbox {
    max-height: 420px; /* 好みで 520–680px */
    margin: 0 auto;
  }
  .topbox2 .rightbox .imgbox img {
    width: 100%;
    height: auto;
    object-fit: cover;
  }
  /* サブ写真＆ドット位置 */
  .topbox2 .ph-sub {
    position: relative;
    width: clamp(220px, 52vw, 340px);
  }
  .topbox2 .dots {
    left: clamp(12px, 8vw, 40px);
    bottom: auto;
    top: clamp(40px, 8vw, 80px);
  }
  .topbox2 .txtbox {
    width: 80%;
    padding: 0 60px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (max-width:768px) {
  .columnbox1 {
    padding-top: 150px;
  }
  .topbox2 .txtbox {
    width: 100%;
    padding: 0 20px;
    margin-right: auto;
    margin-left: auto;
  }
}
/* ---------- topbox1 (base) ---------- */
.topbox1 .more {
  justify-content: flex-end;
}
.topbox1 .box_wrap {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start; /* 上揃え */
  gap: clamp(28px, 6vw, 150px); /* 既存のgapを踏襲 */
  position: relative;
}

.topbox1 .leftbox, .topbox1 .rightbox {
  width: auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
    align-items: flex-start;
}
.topbox1 .box_wrap{
  display:grid !important;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr); /* 左を約25%広く */
  gap: clamp(24px, 6vw, 80px);
  align-items:start;
}
.topbox1 .leftbox {
  margin-top: -50px;
    min-width: 0;
}
.topbox1 .leftbox img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.topbox1 .leftbox .txt-wrwp {
  gap: 50px;
  flex-direction: column;
  align-items: flex-start;
}

.topbox1 .rightbox{
  display:flex !important;
  flex-direction:column;
  gap:clamp(12px, 2vw, 24px);
  min-width:0;
  position:relative;                /* ← これ追加 */
}

/* 右上に index0.svg を配置 */
.topbox1 .rightbox::after{
  content:"";
  position:absolute;
  top:-150px;
  right:12px;
  width: clamp(120px, 18vw, 200px);
  height: clamp(120px, 18vw, 200px);
  background:url("https://viennoiserie-selfish.jp/system_panel/uploads/images/index0.png") no-repeat center / contain;
  pointer-events:none;              /* クリック邪魔しない */
  z-index:-1;
}

/* === 2枚重ね＋英字ウォーターマーク（見本再現） === */
.bottombox {
  position: relative;
  display: flex;
  align-items: flex-end; /* 下辺で揃える */
  justify-content: center;
  gap: 0;
  min-height: clamp(360px, 38vw, 560px);
  z-index: 2;
  overflow: hidden;
}
/* 左上：縦長写真（上に浮かせる） */
.bottombox .img1 {
  position: absolute;
  left: 0;
  top: 0;
  width: clamp(260px, 28vw, 380px);
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  border-radius: 2px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .15);
  z-index: 6; /* 下の横長より前に */
}
/* 下：横長写真（中央） */
.bottombox .img2 {
  position: relative;
  width: clamp(310px, 40vw, 460px);
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
  margin-inline: auto;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .15);
  z-index: 1;
  transform: translateX(50px);
}
/* 背面の大きな英字 */
.bottombox .wm {
  position: absolute;
  left: 0;
  bottom: -0.15em; /* 少し食い下げる */
  margin: 0;
  font-family: "Zen Old Mincho", "Yu Mincho", serif;
  font-weight: 400;
  font-size: clamp(48px, 12vw, 160px);
  letter-spacing: .06em;
  color: rgba(255, 255, 255, .9);
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  z-index: 5; /* 画像の背面 */
}
.bottombox .wm {
  /* 既存の指定はそのまま活かす */
  animation: wm-flow 22s linear infinite;
  will-change: transform;
}
/* 0〜10%は静止 → その後ゆっくり左へ流す → 先頭に戻る */
@keyframes wm-flow {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-110%);
  } /* 画面外まで流し切る */
}
/* スマホ調整：縦積みに切り替え */
@media (max-width: 768px) {
  .bottombox {
    min-height: auto;
    padding-top: 24px;
  }
  .bottombox .img1 {
    position: static; /* 流れに戻す */
    width: 60%;
    margin: 0 auto 18px 0;
    max-height: 400px;
  }
  .bottombox .img2 {
    width: 92%;
    margin: 0 auto;
  }
  .bottombox .wm {
    font-size: clamp(38px, 14vw, 96px);
    left: 4%;
    bottom: -0.1em;
  }
}

/* ---------- <=1080px ---------- */
@media (max-width:1080px){
  .topbox1 .more{ justify-content:center; }

 .topbox1 .rightbox::after{
  content:"";
  position:absolute;
  top:0px;
  right:12px;
    }
    
  .topbox1 .box_wrap{
    grid-template-columns:1fr !important;
    gap:clamp(20px,5vw,40px);
  }

  /* パディングは親側で。左右の%幅・calc は使わない */
  .topbox1 .leftbox,
  .topbox1 .rightbox{
    width:100%;
  }

  /* もし内側に .imgbox 等があるなら、可変に */
  .topbox1 .leftbox .imgbox{
    width:100%;
    margin:0 auto;
    padding-right:0;
  }
  .topbox1 .leftbox{ margin-top:0; } /* スマホでは段差を解消 */

  .topbox1 .rightbox {
    width: 80%;
      margin: auto auto;
  }
  .topbox1 .rightbox .bottombox {
    width: 100%;
    align-items: flex-start;
    padding-top: 70px;
  }
  .topbox1 .rightbox .bottombox .img1 {
    width: 40%;
    padding-top: 0;
  }
  .topbox1 .rightbox .bottombox .img2 {
    width: 60%;
    padding-top: 0;
  }
}
/* ---------- <=768px ---------- */
@media (max-width:768px) {
  .topbox1 .box_wrap {
    gap: 30px;
  }
  .topbox1 .leftbox .txtbox {
    margin-top: 0;
  }
  .topbox1 .leftbox .imgbox {
    width: 100%;
  }
  .topbox1 .leftbox {
    gap: 30px;
  }
  .topbox1 .leftbox .txt-wrwp {
    gap: 40px;
    align-items: flex-start;
    flex-direction: column;
  }

  .topbox1 .rightbox {
    width: 100%;
  }
  .topbox1 .rightbox .topbox .timebox .time span {
    font-size: 22px;
  }
}
/* ---------- <=576px ---------- */
@media (max-width:576px) {
  .topbox1 .rightbox .bottombox {
    padding-top: 50px;
  }
}
.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;
}
/* ---------- 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 ---------- */
.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; /* クリック操作を邪魔しない */
}
.fv {
  position: relative;
}
/* 100vh化・黒幕 */
body.on .fv {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
body.on .fv::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, .2);
  z-index: 1;
  pointer-events: none;
}
/* 右下の情報ラベル（帯） */
.fv .label {
  position: absolute;
  right: 0;
  bottom: 0;
  background: #6A5A51;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 16px clamp(0px, 2.8vw, 36px) 12px;
  z-index: 10;
}
.fv .label p {
  color: #fff;
}
.fv .label .info-box {
  display: flex;
  gap: clamp(10px, 4vw, 48px);
  align-items: center;
}
.fv .label .info-item {
  gap: 12px;
  flex-wrap: nowrap;
}
.fv .label .info-title {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  min-width: 64px;
  border: 1px solid rgba(255, 255, 255, .4);
  border-radius: 2px;
  height: 60px;
}
/* ロゴとキャッチコピー */
.fv .logo {
  position: absolute;
  top: 40px;
  left: 5%;
  z-index: 10;
}
.fv .txtbox {
  position: absolute;
  top: 20%;
  right: 10%;
  z-index: 10;
  align-items: flex-start;
  color: #fff;
}
.fv .txtbox .title1 {
  color: #fff;
  font-weight: 400;
  font-size: clamp(26px, 5.2vw, 40px);
  letter-spacing: .4em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  white-space: nowrap;
}
body.on .fv .txtbox .title1 {
  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 .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 {
  top: 50%;
  z-index: 10;
  position: absolute;
  left: clamp(24px, 8vw, 100px);
  z-index: 50;
  align-items: flex-start;
}
.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 {
  position: relative;
}
.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 p {
  color: #fff;
}
.mainmenu_box .nav_box .ul .li a {
  position: relative;
  color: #fff;
  text-decoration: none;
  align-items: center;
  gap: 12px;
}
.mainmenu_box .nav_box .line {
  display: flex; /* ← これが大事（横に余白を作る） */
  align-items: center;
  gap: .6em; /* 文字と線の間隔 */
  color: #fff;
  margin: 0 0 clamp(12px, 2vw, 20px);
  letter-spacing: .12em;
  font-weight: 400;
}
.mainmenu_box .nav_box .line::after {
  content: "";
  flex: 1 1 auto; /* 右側の余白ぶん伸びる */
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, .65), rgba(255, 255, 255, .55) 60%, transparent);
  transform: translateY(1px); /* 視覚調整 */
}
/* 赤丸ホバー */
.mainmenu_box .nav_box .ul .li a::before {
  content: "";
  position: absolute;
  left: -20px;
  top: 50%;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  background: #EDCA81;
  transform: translate(-.8em, -50%) scale(.6);
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
  pointer-events: none;
}
.mainmenu_box .nav_box .ul .li a:hover::before, .mainmenu_box .nav_box .ul .li a:focus-visible::before {
  opacity: 1;
  transform: translate(-.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(-.2em, -50%) scale(1);
}
/* スライダー全画面＆ズーム演出 */
.fv .swiper {
  z-index: 1;
  position: relative;
}
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 .img-box {
  position: relative;
  z-index: 1;
}
.fv .fv_icon {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 35%;
  z-index: 5;
}
.fv .fv_icon img {
  mix-blend-mode: multiply;
  opacity: .4;
}
/* アニメーション定義 */
@keyframes fvtxt {
  0% {
    opacity: 0;
    transform: translateX(50px);
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
    -ms-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
/* ---------- 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) {
  .mainmenu_box {
    top: 30%;
  }
  .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) {}