/* ================================================
   UMJ メガメニュー — ロゴ対応版
   ================================================ */
/* 固定ヘッダー(56px)にアンカー着地が隠れないよう余白を確保 */
html { scroll-padding-top: 64px; }
body.umj-scroll-lock {
  position: fixed;
  inset: var(--umj-lock-scroll-y) 0 auto 0;
  width: 100%;
  overflow: hidden;
}
.umj-mega-nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 9999;
  background: rgba(10,15,28,.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 0 22px;
  display: flex; align-items: center; height: 56px; gap: 0;
  transition: background-color .22s ease, border-color .22s ease, box-shadow .22s ease;
}

body.admin-bar .umj-mega-nav {
  top: var(--wp-admin--admin-bar--height, 32px);
}
.umj-mega-nav.is-scrolled {
  background: rgba(8,12,22,.99);
  border-bottom-color: rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.22);
}
/* ロゴラッパー */
.umj-mega-logo-wrap {
  display: flex; align-items: center;
  flex-shrink: 0; margin-right: 18px;
  text-decoration: none;
}
/* WordPressカスタムロゴ */
.umj-mega-logo-wrap .custom-logo-link,
.umj-mega-logo-wrap .custom-logo-link img {
  display: block;
}
.umj-mega-logo-wrap .custom-logo-link img {
  height: 32px !important;
  width: auto !important;
  max-width: 130px;
  filter: brightness(0) invert(1);
  opacity: .9;
  transition: opacity .2s;
}
.umj-mega-logo-wrap:hover .custom-logo-link img { opacity: 1; }
/* 直接imgタグのロゴ */
.umj-mega-logo-img {
  height: 32px; width: auto;
  max-width: 130px;
  filter: brightness(0) invert(1);
  opacity: .9;
  display: block;
  transition: opacity .2s;
}
.umj-mega-logo-wrap:hover .umj-mega-logo-img { opacity: 1; }
/* テキストロゴ（フォールバック） */
.umj-mega-logo-text {
  font-family: 'Oswald', sans-serif;
  font-size: 22px; font-weight: 700;
  color: #fff; letter-spacing: .1em;
}
.umj-mega-logo-dot { color: #C41230; }
/* ナビ項目 */
.umj-mega-items { display: flex; flex: 1; }
.umj-mega-item { position: relative; }
.umj-mega-trigger {
  display: flex; align-items: center; gap: 4px;
  padding: 0 12px; height: 56px;
  font-size: 12.5px; font-weight: 700;
  color: rgba(255,255,255,.68);
  cursor: pointer; border: none; background: none;
  white-space: nowrap; transition: color .15s;
  font-family: inherit;
}
.umj-mega-trigger:hover,
.umj-mega-trigger:focus-visible,
.umj-mega-item:hover .umj-mega-trigger,
.umj-mega-item:focus-within .umj-mega-trigger,
.umj-mega-item.is-open .umj-mega-trigger { color: #fff; }
.umj-mega-trigger svg { transition: transform .2s; }
.umj-mega-item:hover .umj-mega-trigger svg,
.umj-mega-item:focus-within .umj-mega-trigger svg,
.umj-mega-item.is-open .umj-mega-trigger svg { transform: rotate(180deg); }
/* ドロップダウン */
.umj-mega-drop {
  display: none; position: absolute;
  top: 56px; left: 0; min-width: 340px;
  background: rgba(10,15,28,.98);
  border: 1px solid rgba(255,255,255,.09);
  border-top: 2px solid #C41230;
  border-radius: 0 0 10px 10px;
  padding: 16px; flex-direction: column; gap: 4px;
  box-shadow: 0 16px 48px rgba(0,0,0,.45);
  z-index: 10000;
}
.umj-mega-item:hover .umj-mega-drop,
.umj-mega-item:focus-within .umj-mega-drop,
.umj-mega-item.is-open .umj-mega-drop { display: flex; }
.umj-mega-svc {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 12px; border-radius: 7px;
  text-decoration: none; transition: background .15s;
}
.umj-mega-svc:hover,
.umj-mega-svc:focus-visible { background: rgba(255,255,255,.07); }
.umj-mega-svc--more { opacity: .6; margin-top: 2px; }
.umj-mega-svc--more:hover { opacity: 1; }
.umj-mega-svc-ico {
  width: 32px; height: 32px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
  background: rgba(255,255,255,.06);
}
.umj-mega-svc-ico--red { background: rgba(196,18,48,.18); }
.umj-mega-svc-name {
  display: block;
  font-size: 13px; font-weight: 700; color: #fff;
  margin-bottom: 1px; line-height: 1.3;
}
.umj-mega-svc-desc {
  display: block;
  font-size: 11px; color: rgba(255,255,255,.42); line-height: 1.4;
}
/* テキストリンク */
.umj-mega-plain-link {
  display: flex; align-items: center;
  padding: 0 12px; height: 56px;
  font-size: 12.5px; font-weight: 700;
  color: rgba(255,255,255,.62);
  text-decoration: none; transition: color .15s;
  white-space: nowrap;
}
.umj-mega-plain-link:hover,
.umj-mega-plain-link:focus-visible { color: #fff; }
/* CTA */
.umj-mega-cta { display: flex; gap: 8px; flex-shrink: 0; align-items: center; }
.umj-mega-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 8px 16px; border-radius: 4px;
  font-size: 12.5px; font-weight: 700;
  text-decoration: none; white-space: nowrap; transition: .18s;
}
.umj-mega-btn--red { background: #C41230; color: #fff; }
.umj-mega-btn--red:hover,
.umj-mega-btn--red:focus-visible { background: #9e0e26; color: #fff; }
.umj-mega-btn--ghost { border: 1.5px solid rgba(255,255,255,.25); color: rgba(255,255,255,.72); }
.umj-mega-btn--ghost:hover,
.umj-mega-btn--ghost:focus-visible { background: rgba(255,255,255,.08); color: #fff; }
.umj-mega-logo-wrap:focus-visible,
.umj-mega-trigger:focus-visible,
.umj-mega-svc:focus-visible,
.umj-mega-plain-link:focus-visible,
.umj-mega-btn:focus-visible,
.umj-mega-sp-btn:focus-visible,
.umj-sp-group a:focus-visible,
.umj-sp-contact-link:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}
/* SPハンバーガー */
.umj-mega-sp-btn {
  display: none; margin-left: auto;
  background: none; border: none; cursor: pointer;
  width: 44px; height: 44px;
  padding: 8px; flex-direction: column; gap: 5px;
  align-items: center; justify-content: center;
}
.umj-mega-sp-btn span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: .25s; }
/* SPメニュー */
.umj-mega-sp-menu {
  display: none; position: fixed;
  top: 56px; left: 0; right: 0; bottom: 0;
  background: rgba(10,15,28,.99);
  overflow-y: auto; padding: 24px 22px;
  z-index: 9998;
}

body.admin-bar .umj-mega-sp-menu {
  top: calc(56px + var(--wp-admin--admin-bar--height, 32px));
}

@media (max-width: 782px) {
  body.admin-bar .umj-mega-nav {
    top: 46px;
  }

  body.admin-bar .umj-mega-sp-menu {
    top: 102px;
  }
}
.umj-mega-sp-menu.open { display: block; }
.umj-sp-group { margin-bottom: 26px; }
.umj-sp-group-hd {
  font-family: 'Oswald', sans-serif;
  font-size: 10px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.38);
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  margin-bottom: 10px;
}
.umj-sp-group a {
  display: flex; align-items: center;
  min-height: 44px;
  padding: 11px 8px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  font-size: 15px; font-weight: 700;
  color: rgba(255,255,255,.75); text-decoration: none;
}
.umj-sp-group a:hover,
.umj-sp-group a:focus-visible { color: #fff; }
.umj-sp-contact { margin-top: 20px; }
.umj-sp-contact-link {
  display: block;
  text-align: center;
  padding: 14px;
  border-radius: 5px;
  background: #C41230;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
}
.umj-sp-contact-link:hover,
.umj-sp-contact-link:focus-visible { background: #9e0e26; color: #fff; }
@media(max-width:960px){
  .umj-mega-items, .umj-mega-cta { display: none; }
  .umj-mega-sp-btn { display: flex; }
  .umj-mega-nav { padding: 0 18px; }
}

@media (max-width: 896px) {
  body.wp-child-theme-cat-so01_child #header .header__inner {
    min-height: 60px;
    align-items: center;
  }

  body.wp-child-theme-cat-so01_child #navHam.sp {
    display: block !important;
    position: static !important;
    flex: 0 0 44px;
    width: 44px !important;
    height: 44px !important;
    margin-left: auto;
  }

  body.wp-child-theme-cat-so01_child #navHam nav {
    display: block !important;
    position: fixed !important;
    top: 0 !important;
    left: -300px !important;
    bottom: 0 !important;
    width: 300px !important;
    max-width: 78vw;
    background: #fff;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    opacity: 0 !important;
    z-index: 10000;
    transition: left .35s ease, opacity .35s ease;
  }

  body.wp-child-theme-cat-so01_child #navHam.open nav {
    left: 0 !important;
    opacity: 1 !important;
  }

  body.wp-child-theme-cat-so01_child #navHam .toggle_btn {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    width: 30px;
    height: 30px;
    margin: 7px auto;
    z-index: 10001;
  }

  body.wp-child-theme-cat-so01_child #navHam #mask {
    display: none;
  }

  body.wp-child-theme-cat-so01_child #navHam.open #mask {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.72);
    z-index: 9999;
  }
}

@media (max-width: 767px) {
  body.wp-child-theme-cat-so01_child #navHam nav {
    left: -220px !important;
    width: 220px !important;
  }

  body.wp-child-theme-cat-so01_child #navHam.open nav {
    left: 0 !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .umj-mega-nav *,
  .umj-mega-nav *::before,
  .umj-mega-nav *::after,
  .umj-mega-sp-menu *,
  .umj-mega-sp-menu *::before,
  .umj-mega-sp-menu *::after {
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.001ms !important;
  }
}

