@charset "UTF-8";
/* =========================================================
   TRANSPLANT — claude theme からの移植スタイル
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;0,900;1,600&display=swap');

/* =========================================================
   WAVE TRANSITION  (KV からメニューへ流れ込む波線 / summer.css より移植)
   ========================================================= */
.cover::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:90px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 90' preserveAspectRatio='none'%3E%3Cpath fill='%23eaf7fd' d='M0,48 C180,90 360,12 540,30 C720,48 900,96 1080,72 C1260,48 1380,30 1440,42 L1440,90 L0,90 Z'/%3E%3C/svg%3E") no-repeat center/cover;
  pointer-events:none;
  z-index:2;
}
/* =========================================================
   WAVE MENU  (index 下のメニュー部分 / index.html より移植)
   変数は .wave-menu にスコープしてグローバルを汚さない
   ========================================================= */
.wave-menu{
  position:relative;
  /* グラデーションを上に、その下（一番下）に nav_bg.png を敷く。
     グラデーション下端は透明なので画像が下から透けて見える */
  background:
    linear-gradient(180deg,#d4edfb 0%,#d4edfb 15%,rgba(212,237,251,0) 60%),
    url(../images/bg/nav_bg.png) bottom center / 100% auto no-repeat;
  padding: 15px 0 40px;
  /* 帯の高さをウィンドウ幅に比例させる（1920px時に320px）。
     320/1920×100vw = 16.666vw。画像は横100%（高さ28.125vw）なので
     どの画面幅でも同じ割合でトリミングされ、見え方が一定になる。
     1920px以上では 320px で頭打ち（それ以上大きくしない）。 */
  min-height: min(calc(100vw * 320 / 1920), 320px);
  overflow:hidden;
}
.wave-menu__band{
  position:relative;
  z-index:2;
  width:min(96%,1360px);
  margin-inline:auto;
}
.wave-menu__list{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  margin:0;
  padding:0;
  list-style:none;
}
.wave-menu__list li{
  position:relative;
  flex:0 0 auto;
}
.wave-menu__list a{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px 10px;
  transition:transform .25s,color .25s;
  text-decoration:none;
}
.wave-menu__list a:hover{
  transform:translateY(-3px);
}
.wave-menu__icon{
  flex:none;
  width:44px;
  height:44px;
  margin-right:14px;
  color:var(--blue);
}
.wave-menu__icon svg,
.wave-menu__icon img{
  width:100%;
  height:100%;
  display:block;
}
.wave-menu__txt{
  display:flex;
  flex-direction:column;
  line-height:1.6;
}
.wave-menu__en{
  font-weight:700;
  font-size:1.02rem;
  letter-spacing:.06em;
  color:var(--navy-deep);
}
.wave-menu__ja{
  font-size:.74rem;
  font-weight:500;
  letter-spacing:.04em;
}
/* bubbles + leaves decorations */
.wave-menu__deco{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  overflow:hidden;
}
.wave-menu .bubble{
  position:absolute;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.9),rgba(255,255,255,.18) 60%,transparent 70%);
  border:1px solid rgba(255,255,255,.6);
}
.wave-menu .bubble.b1{
  width:26px;
  height:26px;
  left:4%;
  top:18px;
}
.wave-menu .bubble.b2{
  width:14px;
  height:14px;
  left:9%;
  bottom:24px;
}
.wave-menu .bubble.b3{
  width:34px;
  height:34px;
  right:6%;
  top:14px;
}
.wave-menu .bubble.b4{
  width:16px;
  height:16px;
  right:13%;
  bottom:30px;
}
.wave-menu .bubble.b5{
  width:10px;
  height:10px;
  left:48%;
  bottom:14px;
}
.wave-menu .bubble.b6{
  width:20px;
  height:20px;
  right:24%;
  bottom:18px;
}
.wave-menu__leaf{
  position:absolute;
  right:1%;
  bottom:-6px;
  width:120px;
  opacity:.55;
  color:var(--blue-soft);
}
/* base.css の .index-bar 既存スタイルを打ち消す
   （JS スクロールスパイ用に index-bar / index-bar__list クラスは残すため） */
.wave-menu.index-bar{
  position:static;
  box-shadow:none;
}
.wave-menu .index-bar__list{
  width:auto;
  background:transparent;
}
.wave-menu .index-bar__list a{
  text-transform:none;
}
.wave-menu .index-bar__list a::after{
  display:none;
}
/* =========================
   RESPONSIVE-1650
   ========================= */
@media(max-width:1650px){
  .wave-menu{
    padding: 10px 0 40px;
  }
}


/* =========================
   RESPONSIVE-1200
   ========================= */
@media(max-width:1200px){
.wave-menu{
    padding: 0 0 40px;
  }

.wave-menu__en {
    font-size: 0.9rem;
}
}


/* =========================
   RESPONSIVE-1024
   ========================= */
@media(max-width:1024px){
  .wave-menu__en{
    font-size:.84rem;
    letter-spacing:.02em;
    white-space:nowrap;        /* SUMMER SALE / SUMMER FESTA を1行に収める */
  }
  .wave-menu__list a{
    flex-direction:column;
    padding: 10px 6px 20px;          /* 左右パディングを詰めて文字スペースを確保 */
  }
  .wave-menu__icon{
    width:32px;
    height:32px;
    margin-right:0;
    margin-bottom:3px;
  }
  
  .wave-menu__en {
  	margin-bottom: -5px;
  }
}


/* =========================
   RESPONSIVE-767
   ========================= */
@media(max-width:767px){
  .wave-menu{
    padding:14px 0 24px;
    /* SP は画像が低い（横幅×0.28）ので、コンテンツ高さに任せる */
    min-height:0;
  }
  .wave-menu__list li{
    flex:0 0 33.333%;
  }
  .wave-menu__en{
    font-size:.74rem;
  }
  .wave-menu__ja{
    font-size:.62rem;
  }
}


/* =========================
   RESPONSIVE-640
   ========================= */
/* base.css は 640px 以下で .index-bar を display:none にするため復活させる */
@media(max-width:640px){
  .wave-menu.index-bar{
    display:block;
  }
  
.wave-menu__band {
	margin-top: -20px;
}

.wave-menu__list a {
padding: 10px 6px;
}
}
