/* ==================================================
  01. Header
================================================== */

/* ==================================================
  Header Base
================================================== */

.l-header,
#header {
  z-index: 10000;
  background: rgba(255, 255, 255, .97);
  border-bottom: 1px solid #eee7df;
  box-shadow: none;
  font-family: var(--mna-serif);
}

.l-header *,
#header * {
  box-sizing: border-box;
}

.l-header a,
#header a {
  color: inherit;
  text-decoration: none;
}

/* ==================================================
  Header Inner
================================================== */

.l-header__inner {
  width: min(calc(100% - 72px), 1240px);
  max-width: 1240px;
  min-height: 82px;
  height: 82px;
  margin-right: auto;
  margin-left: auto;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ==================================================
  Logo
================================================== */

.c-headLogo {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
}

.c-headLogo__link {
  display: flex;
  align-items: center;
  padding: 0;
}

.c-headLogo__img,
.c-headLogo img {
  width: auto !important;
  max-width: 240px !important;
  max-height: 60px !important;
  height: auto !important;
  object-fit: contain !important;
}

/* ==================================================
  Header Logo SVG Fix
================================================== */

.l-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  min-width: 120px;
}

.l-header__logo a,
.c-headLogo,
.c-headLogo__link {
  display: flex;
  align-items: center;
  width: auto;
  height: auto;
}

.l-header__logo img,
.c-headLogo__img {
  display: block;
  width: auto;
  height: 48px;
  max-width: 220px;
  object-fit: contain;
}

@media (max-width: 768px) {
  .l-header__logo {
    min-width: 96px;
  }

  .l-header__logo img,
  .c-headLogo__img {
    height: 36px;
    max-width: 160px;
  }
}



/* ==================================================
  Navigation
================================================== */

.c-gnavWrap {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.c-gnav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 28px;
  margin: 0;
  padding: 0;
}

.c-gnav > .menu-item {
  margin: 0;
  padding: 0;
}

.c-gnav > .menu-item > a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 0;
  padding: 4px 0 5px;
  color: var(--mna-text);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: .07em;
  white-space: nowrap;
  text-decoration: none;
}

.c-gnav > .menu-item > a:hover {
  color: var(--mna-gold);
}

.c-gnav > .menu-item > a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  height: 1px;
  background: var(--mna-gold);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .24s ease;
}

.c-gnav > .menu-item > a:hover::after,
.c-gnav > .current-menu-item > a::after,
.c-gnav > .current_page_item > a::after,
.c-gnav > .current-menu-ancestor > a::after {
  transform: scaleX(1);
}

.c-gnav > .current-menu-item > a,
.c-gnav > .current_page_item > a,
.c-gnav > .current-menu-ancestor > a {
  color: var(--mna-gold);
}

/* ==================================================
  Header CTA
================================================== */

/*
  最後のメニュー項目をCTA化。
  WordPressメニューで「掲載をご希望のナース様へ」を最後に配置。
*/

.c-gnav > .menu-item.mna-header-cta > a,
.c-gnav > .menu-item:last-child > a {
  justify-content: center;
  min-height: 40px;
  padding: 0 22px;
  border: 1px solid #2b1a10;
  background: #2b1a10;
  color: #fff;
  font-size: 12px;
  line-height: 1.3;
  letter-spacing: .06em;
}

.c-gnav > .menu-item.mna-header-cta > a:hover,
.c-gnav > .menu-item:last-child > a:hover {
  border-color: var(--mna-gold);
  background: var(--mna-gold);
  color: #fff;
}

.c-gnav > .menu-item.mna-header-cta > a::after,
.c-gnav > .menu-item:last-child > a::after {
  content: none;
}

/* ==================================================
  Dropdown
================================================== */

.c-gnav .sub-menu {
  min-width: 220px;
  padding: 10px 0;
  border: 1px solid #eee3d3;
  background: rgba(255, 255, 255, .98);
  box-shadow: 0 16px 40px rgba(45, 41, 36, .08);
}

.c-gnav .sub-menu .menu-item a {
  display: block;
  padding: 10px 18px;
  color: var(--mna-text);
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .05em;
}

.c-gnav .sub-menu .menu-item a:hover {
  background: #fbf7ef;
  color: var(--mna-gold);
}

/* ==================================================
  Header Buttons
================================================== */

.l-header__menuBtn,
.l-header__customBtn,
.c-iconBtn {
  color: var(--mna-text);
  box-shadow: none;
  outline: none;
  -webkit-tap-highlight-color: transparent;
}

.l-header__menuBtn:hover,
.l-header__customBtn:hover,
.c-iconBtn:hover {
  color: var(--mna-gold);
}

.l-header__menuBtn:focus,
.l-header__menuBtn:focus-visible,
.l-header__customBtn:focus,
.l-header__customBtn:focus-visible,
.c-iconBtn:focus,
.c-iconBtn:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* ==================================================
  Desktop Responsive
================================================== */

@media (max-width: 1240px) {
  .l-header__inner {
    width: min(calc(100% - 48px), 1120px);
  }

  .c-headLogo__img,
  .c-headLogo img {
    max-width: 220px !important;
    max-height: 58px !important;
  }

  .c-gnav {
    gap: 22px;
  }

  .c-gnav > .menu-item > a {
    font-size: 12px;
  }

  .c-gnav > .menu-item.mna-header-cta > a,
  .c-gnav > .menu-item:last-child > a {
    padding: 0 18px;
    font-size: 12px;
  }
}

/* ==================================================
  Mobile Header Fixed
================================================== */

@media (max-width: 1024px) {
  /*
    iPhone Safariで上に謎の余白が出るため、
    bodyには padding-top を付けない。
  */
  html,
  body {
    padding-top: 0 !important;
    overflow-x: hidden !important;
  }

  .l-header,
  #header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 10000 !important;
    width: 100% !important;
    background: rgba(255, 255, 255, .96) !important;
    border-bottom: 1px solid rgba(216, 199, 170, .48) !important;
    box-shadow: 0 8px 28px rgba(45, 34, 24, .04) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  .admin-bar .l-header,
  .admin-bar #header {
    top: 32px !important;
  }

  .l-header__inner {
    width: calc(100% - 40px) !important;
    max-width: none;
    min-height: 78px !important;
    height: 78px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .c-headLogo {
    display: flex !important;
    align-items: center !important;
    flex: 0 1 auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .c-headLogo__link {
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
  }

  .c-headLogo__img,
  .c-headLogo img {
    width: auto !important;
    max-width: 186px !important;
    max-height: 52px !important;
    height: auto !important;
    object-fit: contain !important;
  }

  .c-gnav,
  .c-gnavWrap {
    display: none !important;
  }

  .l-header__menuBtn,
  .c-iconBtn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(184, 137, 49, .45) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .9) !important;
    color: var(--mna-text) !important;
    box-shadow: none !important;
    outline: none !important;
    flex: 0 0 48px !important;
  }

  .l-header__menuBtn:hover,
  .c-iconBtn:hover {
    border-color: var(--mna-gold) !important;
    background: #fff !important;
  }

  /*
    固定ヘッダー分の余白。
    bodyではなくコンテンツ側に付ける。
  */
  .l-content,
  #content,
  main {
    padding-top: 78px;
  }

  /*
    SWELLのFVがあるトップでは、FVがヘッダー下から自然に始まるようにする。
  */
  body.home .l-content,
  body.home #content,
  body.home main {
    padding-top: 78px;
  }
}

@media (max-width: 782px) {
  .admin-bar .l-header,
  .admin-bar #header {
    top: 46px !important;
  }
}

/* ==================================================
  Small Mobile
================================================== */

@media (max-width: 640px) {
  .l-header__inner {
    width: calc(100% - 32px) !important;
    min-height: 76px !important;
    height: 76px !important;
  }

  .c-headLogo__img,
  .c-headLogo img {
    max-width: 178px !important;
    max-height: 50px !important;
  }

  .l-header__menuBtn,
  .c-iconBtn {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    flex-basis: 46px !important;
  }

  .l-content,
  #content,
  main,
  body.home .l-content,
  body.home #content,
  body.home main {
    padding-top: 50px;
  }
}

@media (max-width: 390px) {
  .l-header__inner {
    width: calc(100% - 28px) !important;
  }

  .c-headLogo__img,
  .c-headLogo img {
    max-width: 164px !important;
    max-height: 46px !important;
  }

  .l-header__menuBtn,
  .c-iconBtn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    flex-basis: 44px !important;
  }
}

/* ==================================================
  PC Header Normal / Sticky Fix
================================================== */

@media (min-width: 1025px) {

  /* PCではbodyやmainに余白を付けない */
  body {
    padding-top: 0 !important;
  }


  /* ヘッダー本体 */
  .l-header,
  #header {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 96px !important;
    background: rgba(255, 255, 255, .97) !important;
    border-bottom: 1px solid #eee7df !important;
    box-shadow: none !important;
  }

  /* SWELLの追尾時も同じ高さに固定 */
  .l-header.-fixed,
  .l-header.is-fixed,
  .l-header[data-scrolled="true"],
  body.-fixedHeader .l-header,
  body.is-fixedHeader .l-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: auto !important;
    min-height: 86px !important;
    background: rgba(255, 255, 255, .97) !important;
    box-shadow: 0 10px 28px rgba(45, 34, 24, .05) !important;
  }

  .admin-bar .l-header.-fixed,
  .admin-bar .l-header.is-fixed,
  .admin-bar body.-fixedHeader .l-header,
  .admin-bar body.is-fixedHeader .l-header {
    top: 32px !important;
  }

  /* ヘッダー内側 */
  .l-header__inner {
    width: min(calc(100% - 72px), 1240px) !important;
    max-width: 1240px !important;
    height: 96px !important;
    min-height: 96px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .l-header.-fixed .l-header__inner,
  .l-header.is-fixed .l-header__inner,
  body.-fixedHeader .l-header .l-header__inner,
  body.is-fixedHeader .l-header .l-header__inner {
    height: 86px !important;
    min-height: 86px !important;
  }

  /* ロゴ */
  .c-headLogo {
    display: flex !important;
    align-items: center !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .c-headLogo__link {
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
  }

  .c-headLogo__img,
  .c-headLogo img {
    width: auto !important;
    max-width: 250px !important;
    max-height: 64px !important;
    height: auto !important;
    object-fit: contain !important;
  }

  .l-header.-fixed .c-headLogo__img,
  .l-header.-fixed .c-headLogo img,
  .l-header.is-fixed .c-headLogo__img,
  .l-header.is-fixed .c-headLogo img,
  body.-fixedHeader .l-header .c-headLogo__img,
  body.-fixedHeader .l-header .c-headLogo img,
  body.is-fixedHeader .l-header .c-headLogo__img,
  body.is-fixedHeader .l-header .c-headLogo img {
    max-width: 230px !important;
    max-height: 58px !important;
  }

  /* ナビ */
  .c-gnavWrap {
    flex: 1 !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    height: auto !important;
  }

  .c-gnav {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 28px !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .c-gnav > li,
  .c-gnav > .menu-item {
    display: flex !important;
    align-items: center !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .c-gnav > li > a,
  .c-gnav > .menu-item > a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 4px 0 5px !important;
    margin: 0 !important;
    color: var(--mna-text) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    letter-spacing: .07em !important;
    white-space: nowrap !important;
    background: transparent !important;
  }

  .c-gnav > li > a:hover,
  .c-gnav > .menu-item > a:hover {
    color: var(--mna-gold) !important;
  }

  /* CTA：最後のメニューだけ小さいボタンに戻す */
  .c-gnav > li:last-child,
  .c-gnav > .menu-item:last-child {
    height: auto !important;
    min-height: 0 !important;
    background: transparent !important;
  }

  .c-gnav > li:last-child > a,
  .c-gnav > .menu-item:last-child > a,
  .c-gnav > .menu-item.mna-header-cta > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    height: auto !important;
    min-height: 42px !important;
    padding: 0 24px !important;
    margin: 0 !important;
    border: 1px solid #2b1a10 !important;
    background: #2b1a10 !important;
    color: #fff !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
    letter-spacing: .06em !important;
  }

  .c-gnav > li:last-child > a:hover,
  .c-gnav > .menu-item:last-child > a:hover,
  .c-gnav > .menu-item.mna-header-cta > a:hover {
    border-color: var(--mna-gold) !important;
    background: var(--mna-gold) !important;
    color: #fff !important;
  }

  .c-gnav > li:last-child > a::after,
  .c-gnav > .menu-item:last-child > a::after,
  .c-gnav > .menu-item.mna-header-cta > a::after {
    content: none !important;
  }
}