/* デザイン配下ファイルと同様のCSS変数 */
:root {
  --brand: #d7000f;
  --brand-accent: #ffb400;
}

@media screen and (max-width: 767px) {
  #sp-footer {
    padding-bottom: 0 !important;
  }
  #sp-footer #copyright {
    margin-bottom: 0 !important;
    padding-bottom: 10px !important;
    background: #555 !important;
    border: none !important;
  }
  #sp-footer #copyright + * {
    display: none !important;
  }
  #footer {
    display: none !important;
  }
}
/* --- SP専用フッター --- */
#sp-footer.sp-footer {
  display: none;
}
@media screen and (max-width: 767px) {
  #sp-footer.sp-footer {
    display: block !important;
    position: static;
    width: 100vw;
    background: #fff;
    box-shadow: 0 -2px 8px rgba(0,0,0,0.08);
    padding-bottom: 8px;
    margin: 0 auto 0 auto;
  }
  #sp-footer.sp-footer #footLink {
    width: 100%;
    margin: 0 auto 8px auto;
    font-size: 15px;
    border-collapse: collapse;
    background: #f3f3f3;
    border: 1px solid #e0e0e0;
  }
  #sp-footer.sp-footer #footLink tr {
    background: #f3f3f3;
  }
  #sp-footer.sp-footer #footLink td {
    padding: 12px 0 12px 0;
    text-align: center;
    border: 1px solid #e0e0e0;
    font-size: 15px;
    color: #222;
    background: #f3f3f3;
    box-sizing: border-box;
  }
  #sp-footer.sp-footer .f_logo_area {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 8px 0 0 0;
  }
  #sp-footer.sp-footer .pit_logo {
    margin-right: 16px;
  }
  #sp-footer.sp-footer .proto_logo img {
    vertical-align: middle;
  }
  #sp-footer.sp-footer #copyright,
  #sp-footer.sp-footer #copyright02 {
    background: #555;
    color: #fff;
    text-align: center;
    padding: 10px 0;
    font-size: 12px;
    margin-top: 8px;
  }
  /* bodyの下余白は不要 */
}
@media (max-width: 767px) {
  .logo_box {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
  }
}
/* PCのみ: .logo_box＋nav 横並び中央寄せ・gap調整 */
@media (min-width: 856px) {
  .global-header {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 100%;
    background: linear-gradient(90deg, #d7000f 0%, #b8000d 80%);
    border-bottom: 1px solid #aa000c;
  }
  .logo-nav-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 32px;
    width: auto;
    margin: 0 auto;
  }
  .logo_box {
    display: flex;
    align-items: center;
    gap: 18px;
    flex-shrink: 0;
    margin: 0;
  }
  .design-global-nav {
    display: flex;
    align-items: center;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0;
    margin: 0;
  }
  .design-global-nav ul {
    display: flex;
    gap: 18px;
    margin: 0;
    padding: 0;
    list-style: none;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: thin;
  }
}
@media (max-width: 767px) {
  .logo-nav-wrap {
    display: block;
    width: 100%;
    margin: 0;
  }
  .logo_box {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 4px 0;
  }
  .design-global-nav {
    margin: 0;
    padding: 0;
    width: 100%;
  }
  .design-global-nav ul {
    display: flex;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: thin;
  }
}
.logo_box {
  margin-bottom: 2px !important;
}
.design-global-nav {
  margin-top: 0 !important;
}
/* デザイン準拠：グローバルナビゲーション */
.design-global-nav {
  background: linear-gradient(90deg, #d7000f 0%, #b8000d 80%);
  border-bottom: 1px solid #aa000c;
  padding: 0 0 0 0;
  margin: 0 0 0 0;
  width: 100%;
  overflow-x: auto;
}
.design-global-nav ul {
  list-style: none;
  margin: 0;
  padding: 0 16px;
  display: flex;
  gap: 18px;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: thin;
}
.design-global-nav li {
  flex: 0 0 auto;
}
.design-global-nav a {
  text-decoration: none;
  font-size: 0.66rem;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  padding: 10px 0;
  position: relative;
  display: inline-block;
  white-space: nowrap;
  transition: color 0.2s;
}
.design-global-nav a:hover {
  color: #fff;
}
.design-global-nav a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 2px;
  background: #ffb400;
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s;
}
.design-global-nav a:hover:after {
  transform: scaleX(1);
}
@media screen and (max-width: 767px) {
  .design-global-nav ul {
    gap: 12px;
    padding: 0 8px;
  }
  .design-global-nav a {
    font-size: 0.62rem;
    padding: 10px 0;
  }
}
/* PC用navは従来通り */
.desktop-nav {
  display: block;
}
@media screen and (max-width: 767px) {
  .desktop-nav {
    display: none;
  }
}

/* SP時のみ表示するグローバルナビゲーション */
.sp-global-nav {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp-global-nav {
    display: block;
    margin: 0 0 8px 0;
  }
  .sp-global-nav ul {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    white-space: nowrap;
    gap: 0;
    padding: 0;
    margin: 0;
    list-style: none;
    background: none;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .sp-global-nav ul li {
    flex: 0 0 auto;
    min-width: 110px;
    margin: 0 4px 0 0;
  }
  .sp-global-nav ul li:last-child {
    margin-right: 0;
  }
  .sp-global-nav ul li a {
    display: block;
    padding: 8px 6px;
    background: #f5f7fa;
    border-radius: 5px;
    color: #222;
    font-size: 0.98em;
    text-align: center;
    text-decoration: none;
    font-weight: 500;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03);
    transition: 0.2s;
  }
  .sp-global-nav ul li a:hover {
    background: #e1e5ea;
  }
}

/* Modal styles for hamburger menu */
#common_modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

#common_modal.active {
  opacity: 1;
  visibility: visible;
}

#common_modal .menu_area {
  position: absolute;
  top: 0;
  left: -280px;
  width: 280px;
  height: 100%;
  background: #fff;
  overflow-y: auto;
  transition: left 0.3s ease;
}

#common_modal.active .menu_area {
  left: 0;
}

#common_modal .relation_box {
  padding: 20px;
}

#common_modal .relation_box ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#common_modal .relation_box li {
  border-bottom: 1px solid #eee;
}

#common_modal .relation_box a {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 20px;
  text-decoration: none;
  color: #333;
  font-weight: 500;
}

#common_modal .relation_box a:hover {
  color: #d7000f;
}

/* デスクトップナビゲーション表示制御 - デザインファイルと同様 */
.desktop-nav {
  display: block;
}

/* モバイルメニューボタンは小さい画面でのみ表示 */
.header_modal_open {
  display: none;
}

/* 小さい画面(767px以下)でハンバーガーメニューを表示 */
@media screen and (max-width: 767px) {
  .header_modal_open {
    display: inline-flex;
  }
  .desktop-nav {
    display: none;
  }
  
  .header_modal_open {
    display: block;
  }
  
  #common_modal .menu_area {
    width: 80%;
    max-width: 300px;
  }
}

/* フッタースタイル */
#footer {
  background: #f8f9fa;
  border-top: 1px solid #e1e5ea;
  margin-top: 40px;
  padding: 0;
}

.desktop-footer {
  display: block;
  padding: 20px 0;
  background: #ffffff;
}

.desktop-footer .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.footer_nav p {
  text-align: center;
  margin: 0 0 20px 0;
  font-size: 12px;
  line-height: 1.6;
}

.footer_nav a {
  color: #333;
  text-decoration: none;
  margin: 0 4px;
}

.footer_nav a:hover {
  text-decoration: underline;
}

.footer_main {
  text-align: center;
}

.footer_logo p {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.mobile-footer {
  display: none;
  background: #ffffff;
}

#copy_right {
  text-align: center;
  font-size: 10px;
  color: #666;
  padding: 10px 0;
  border-top: 1px solid #e1e5ea;
  background: #f0f0f0;
}

@media screen and (max-width: 767px) {
  .desktop-footer {
    display: none;
  }
  
  .mobile-footer {
    display: block;
    padding: 20px;
  }
  
  #footLink {
    width: 100%;
    margin-bottom: 20px;
  }
  
  #footLink td {
    width: 50%;
    padding: 8px 4px;
    text-align: center;
    border-bottom: 1px solid #e1e5ea;
  }
  
  #footLink a {
    color: #333;
    text-decoration: none;
    font-size: 12px;
  }
  
  #footLink a:hover {
    text-decoration: underline;
  }
  
  .f_logo_area {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 20px;
  }
  
  .clearfix::after {
    content: "";
    display: table;
    clear: both;
  }
}

/* --- header/グローバルヘッダー中央寄せ --- */
.global-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 0 10px;
  background: linear-gradient(90deg, #d7000f 0%, #b8000d 80%);
  border-bottom: 1px solid #aa000c;
}
.logo_box {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: nowrap;
  margin-left: auto;
  margin-right: auto;
}
.logo_gn_kuruma img {
  display: block;
  height: 24px;
  width: auto;
}

/* --- nav（グローバルナビゲーション）枠・背景消す --- */
nav.design-global-nav {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0;
}
nav.design-global-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 18px;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: thin;
}
nav.design-global-nav li { flex: 0 0 auto; }
nav.design-global-nav a {
  text-decoration: none;
  font-size: .66rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .85);
  padding: 10px 0;
  position: relative;
  display: inline-block;
  white-space: nowrap;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}
nav.design-global-nav a:hover { color: #fff; }
nav.design-global-nav a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 2px;
  background: #ffb400;
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s;
}
nav.design-global-nav a:hover:after { transform: scaleX(1); }

/* Header */
header { background: #fff; text-align: center; }
.global-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 10px 16px;
  color: #fff;
  background: linear-gradient(90deg, var(--brand) 0%, #b8000d 80%);
  border-bottom: 1px solid #aa000c;
}
.logo_box { display: flex; align-items: center; gap: 18px; flex-wrap: nowrap; }
.logo_box .logo_gn_kuruma{ margin: 0; }
.logo_box > a.header_modal_open {
  display: inline-flex;
  position: absolute;
  top: 6px;
  left: 6px;

  width: 35px;
  height: 35px;
  border: 1px solid rgba(255, 255, 255, .35);
  border-radius: 5px;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .15);
  backdrop-filter: blur(4px);
  transition: .25s, box-shadow .25s, border-color .25s;
}
.logo_box > a.header_modal_open:hover {
  background: rgba(255, 255, 255, .28);
  border-color: rgba(255, 255, 255, .55);
  box-shadow: 0 2px 6px -2px rgba(0, 0, 0, .25);
}
.logo_gn_kuruma img { display: block; height: 24px; width: auto; }
header nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 18px;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: thin;
}
header nav li { flex: 0 0 auto; }
header nav a {
  text-decoration: none;
  font-size: .66rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .85);
  padding: 10px 0;
  position: relative;
  display: inline-block;
  white-space: nowrap;
}
header nav a:hover { color: #fff; }
header nav a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 2px;
  background: var(--brand-accent);
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s;
}
header nav a:hover:after { transform: scaleX(1); }

/* Footer */
footer { text-align: center; padding: 20px; font-size: .7rem; color: #999; }

/* Responsive */
@media screen and (max-width: 767px) {
  header nav ul { gap:14px; }
  
  /* 880px以下でグローバルナビゲーションを非表示、ハンバーガーメニューを表示 */
  .desktop-nav {
    display: none;
  }
  
  .header_modal_open {
    display: inline-flex !important;
  }
}
@media screen and (max-width: 767px) {
  .global-header { flex-wrap:wrap; gap:14px; }
  header nav ul { gap:12px; }
  header nav ul { gap:10px; } 
}

/* Footer copyright styling */
#copy_right {
    background-color: #000;
    color: #fff;
    text-align: center;
    padding: 10px 0;
    font-size: 12px;
}

/* モーダル内コンテンツ */
#header .menu{
  position: fixed;
  left: -100%;
  top: -40px;
  z-index: 10001;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(2px);
  width: 100%;
  height: 100%;
  transition: top 0.3s cubic-bezier(0.4, 0.0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0.0, 0.2, 1);
  opacity: 0;
}
#header .menu.active{
  top: 0;
  left: 0;
  opacity: 1;
}
#header .menu a{
  text-decoration: none;
}
#header .menu ul{
  list-style: none;
  padding: 0;
  margin: 0;
}
#header .menu__header{
  display: flex;
  align-items: center;
  height: 50px;
  background: #CE0C14;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.16);
  padding: 0 10px;
}
#header .menu__header button{
  border: none;
  background: #CE0C14;
}
#header .menu__header button:hover{
  cursor: pointer;
}
#header .menu__content{
  overflow-y: scroll;
  width: 100%;
  height: calc(100% - 50px);
  opacity: 0;
  transition-delay: 0.3s;
  transition: opacity 0.3s 0.2s cubic-bezier(0.4, 0.0, 0.2, 1);
}
#header .active .menu__content{opacity: 1;}
#header .active .menu__content a {color: #333;}
#header .active .menu__content .gnavi_tab_area {
  max-width: 856px;
  margin: 0 auto;
}
#header .active .menu__content .gnavi_tab_area .current_box ul {
  display: table;
  width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  border-bottom: 1px solid #d5d5d5;
}
#header .active .menu__content .gnavi_tab_area .current_box li {
  display: table-cell;
  width: 50%;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  line-height: 54px;
  vertical-align: middle;
}
#header .active .menu__content .gnavi_tab_area .current_box li a {
  display: block;
  font-weight: normal;
  border-bottom: 2px solid #FFF;
}
#header .active .menu__content .gnavi_tab_area .current_box li .active {
  color: #CE0C14;
  font-weight: bold;
  border-bottom: 2px solid #CE0C14;
}
#header .gnavi_tab_area .tab_content .menu_box,
#header .gnavi_tab_area .tab_content .relation_box {display: none;}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box {padding: 0 10px;}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl {  
  border-bottom: 1px solid #d5d5d5;
  margin: 30px 0;
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl.adjust {margin-top: 0;}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl dt,
#header .active .menu__content .gnavi_tab_area .tab_content li {
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl dt {
  font-size: 22px;
  font-weight: bold;
  text-align: left;
  margin: 30px 0 15px;
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl.adjust dt {margin: 0;}
#header .active .menu__content .gnavi_tab_area .tab_content li a,
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl.adjust dt {
  color: #333333;
  font-weight: bold;
  text-decoration: none;
  -ms-word-break: break-all;
  word-break: break-all;
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl dd {
  margin: 0;
}
#header .active .menu__content .gnavi_tab_area .tab_content li a {
  display: flex;
  align-items: center;
  font-size: 14px;
  padding: 5px 25px 5px 20px;
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl.adjust dt a{
  display: block;
  font-size: 22px;
  padding: 30px 0 25px;
}
#header .active .menu__content .gnavi_tab_area .tab_content li img {display: block;}
#header .active .menu__content .gnavi_tab_area .tab_content li span {padding-left: 20px;}
#header .active .menu__content .gnavi_tab_area .tab_content li::after,
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl.adjust dt::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #636363;
  border-right: 2px solid #636363;
  margin-top: -4px;
  transform: translateX(-50%) rotate(45deg);
}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl dd ul li:last-child {margin-bottom: 20px;}
#header .active .menu__content .gnavi_tab_area .tab_content .menu_box dl dd ul li a {line-height: 40px;}