/*
 * ====================================================
 * globalmenu.css 
 * ====================================================
 */

/* ----------------------------------------------------
 * PC用グローバルメニュー
 * ---------------------------------------------------- */
.headermenu {
  width: 100%;
  background-image: url(https://silverbirch-cat.net/img/background_image_globalmenu.png);
  background-repeat: repeat;
}


.headermenu ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: inline-flex; /* 横並び */
  gap: 10px; /* li間の隙間 */
}

.headermenu ul li {
  margin: 0;
}

.headermenu ul li a {
  display: inline-block;
  padding: 10px 20px;
  color: #2b2b2b; /* 文字白 */
  background-color: #f5f5f5; /* 水色ベース */
  border: 2px solid #ffffff; /* 枠線 */
  border-radius: 8px;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  transition: all 0.3s ease;
  line-height: 1.2em;
  white-space: nowrap;
}

/* ホバー時 */
.headermenu ul li a:hover {
  transform: scale(1.1); /* 少し大きくなる */
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); /* 影 */
  background-color: #33aaff; /* 少し濃い水色 */
}

/* ----------------------------------------------------
 * スマホ用ハンバーガーメニュー
 * ---------------------------------------------------- */
.hamburger-check {
  display: none;
}


#nav-drawer {
  position: relative;
}

.nav-unshown {
  display: none;
}

#nav-open {
  display: none;
  position: absolute;
  top: 15px;
  right: 15px;
  width: 30px;
  height: 22px;
}

#nav-open span,
#nav-open span:before,
#nav-open span:after {
  position: absolute;
  height: 3px;
  width: 25px;
  border-radius: 3px;
  background: #555;
  display: block;
  content: '';
  cursor: pointer;
}

#nav-open span:before {
  bottom: -8px;
}

#nav-open span:after {
  bottom: -16px;
}

#nav-close {
  display: none;
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: black;
  opacity: 0;
  transition: .3s ease-in-out;
}

#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9998;
  width: 90%;
  max-width: 330px;
  height: 100%;
  background: #fff;
  transition: .3s ease-in-out;
  -webkit-transform: translateX(-105%);
  transform: translateX(-105%);
}

#nav-input:checked ~ #nav-close {
  display: block;
  opacity: .5;
}

#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
  box-shadow: 6px 0 25px rgba(0,0,0,.15);
}

#nav-content ul {
  list-style: none;
  margin: 0;
  padding: 2em 0;
}

#nav-content li {
  border-bottom: 1px solid #e5e5e5;
}

#nav-content li a {
  display: block;
  color: #333;
  padding: 1em 1.5em;
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  #nav-open {
    display: inline-block;
  }
  .global-menu {
    display: none;
  }
}














/*
 * ====================================================
 * グローバルメニューの縦横中央ぞろえ設定
 * ====================================================
 */

/* 
 * 1. メニュー全体を囲む .headermenu の設定
 * ----------------------------------------------------
 * ここでメニューブロック全体を、縦にも横にも中央に配置します。
 */
.headermenu {
  display: flex;
  justify-content: center; /* 中身（ul）を水平方向の中央に配置 */
  align-items: center;   /* 中身（ul）を垂直方向の中央に配置 */
  width: 100%;
  min-height: 90px; /* メニューバーの最低限の高さを確保（数値はお好みで調整してください） */
}

/* 
 * 2. メニュー項目を並べる <ul> の設定
 * ----------------------------------------------------
 * ここで各メニュー項目（li）を横並びにし、
 * ロゴや文字、アイコンの高さがズレないように垂直方向を揃えます。
 */
.headermenu ul {
  display: flex;
  align-items: center;   /* 全てのメニュー項目を垂直方向に揃える */
  list-style: none;      /*箇条書きの黒点を消す*/
  margin: 0;
  padding: 0;
  gap: 15px; /* 各メニュー項目の間の余白（数値はお好みで調整してください） */
}

/* 
 * 3. 各メニュー項目 <li> とリンク <a> の設定
 * ----------------------------------------------------
 * 見た目を整えます。
 */
.headermenu li {
  margin: 0;
  padding: 0;
}

.headermenu li a {
  text-decoration: none; /* 下線を消す */
  color: #333;            /* 文字色を濃いグレーに */
  font-weight: bold;     /* 文字を少し太く */
  text-align: center;    /* NEWSなどの2行テキストを中央揃えに */
  display: flex;         /* リンク内のアイコンなどを中央に配置するため */
  align-items: center;
}

/* 画像の下にできる余分な隙間を消すための設定 */
.headermenu li img {
  vertical-align: middle; 
}




.footer {
    background: url("https://silverbirch-cat.net/img/background_image_globalmenu.png") repeat-x center top;
    background-size: cover; /* 全体をカバーさせたい場合 */
    color: #black;            /* 文字が見やすいように（必要なら調整） */
    padding: 40px 0;        /* 上下の余白を確保（お好みで） */
}


/* IPPA */
.side_banner {
    display: flex;
    justify-content: center;
}

.side_banner img {
    max-width: 100%;   /* 画面幅を超えない */
    height: auto;      /* 縦横比を保って縮小 */
}





/* 影響を受けないようにするリセット用クラス */
.nocss, 
.nocss * {
  all: unset;               /* すべてのスタイルをリセット */
  display: inline-block;    /* 画像をブロックではなくインライン扱いに */
  cursor: pointer;          /* カーソルをリンク風に */
}

.nocss img {
  all: unset;               /* 画像にも他のスタイルが当たらないように */
  display: inline-block;
  max-width: 180px;
  height: auto;
}







/* ページトップボタン */
.page-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  background: #007bff;
  color: white;
  font-size: 20px;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
  transition: opacity 0.3s, transform 0.3s;
  opacity: 0;
  pointer-events: none;
  z-index: 999;
}

/* スクロールしたときに表示 */
.page-top.show {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}




/* --- ヘッダー下のスペース調整 --- */

/* PC表示 (599px以上) */
@media screen and (min-width: 599px) {
	.headermenu {
		margin-bottom: 30px; /* PC用のスペース（ここの数値で調整） */
	}
}

/* スマホ表示 (599px以下) */
@media screen and (max-width: 599px) {
	.headermenu {
		margin-bottom: 15px; /* スマホ用のスペース（ここの数値で調整） */
	}
}