@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;700;900&display=swap');

.sp-none{display: flex !important; }
.pc-none{display: none;}
@media screen and (max-width: 1000px) {
  .sp-none{display: none !important;}
  .pc-none{display: block;}
}


/* フォント指定 */
body { font-family: 'Noto Sans JP', 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'BIZ UDPGothic', Meiryo, sans-serif; background-color: #fff; }
div#panoDIV.cursorMoveMode { cursor: move; cursor: url(indexdata/graphics/cursors_move_html5.cur), move; }
div#panoDIV.cursorDragMode { cursor: grab; cursor: -moz-grab; cursor: -webkit-grab; cursor: url(indexdata/graphics/cursors_drag_html5.cur), default; }
#maptop { z-index: 1; position: fixed; width: 100%; }
#kensakuarea { width: 750px; position: relative; float: left; margin: 0 0 0 220px; z-index: 9; }
#navigation { }
#navigation { flex-direction: column; }
#navigation ul { display: table; width: 100%; text-align: center; }
#navigation ul li { display: table-cell; width: 170px; max-width: 170px; float: left; background: none; margin: 0 10px 0 0; height: auto; border-radius: 0; box-shadow: none; }
#navigation ul li a { display: block; color: #fff; text-decoration: none; font-size: 10px; padding: 8px; margin-right: 10px; border-radius: 10px; box-shadow: 0px 2px 3px rgba(0, 0, 0, 0.3); text-align: center; float: none; width: auto; height: auto; }
.btn1 a { display: block; color: #fff; text-decoration: none; font-size: 10px; padding: 8px; margin: 5px 0 0 10px; border-radius: 10px; box-shadow: 0px 2px 3px rgba(0, 0, 0, 0.3); text-align: center; float: none; width: auto; height: auto; background: #e8b005; width: 160px; }
.btn2 a { display: block; color: #fff; text-decoration: none; font-size: 10px; padding: 8px; margin: 5px 0 0 10px; border-radius: 10px; box-shadow: 0px 2px 3px rgba(0, 0, 0, 0.3); text-align: center; float: none; height: auto; background: #659933; width: 120px; }
.btn2-2 a { display: block; color: #fff; text-decoration: none; font-size: 10px; padding: 8px; margin: 5px 0 0 10px; border-radius: 10px; box-shadow: 0px 2px 3px rgba(0, 0, 0, 0.3); text-align: center; float: right; height: auto; background: #e8b005; width: 120px; }
#setumei { width: 260px; margin: 10px 0 0 10px; background-color: #666; float: left; padding: 20px 20px 10px 20px; text-align: left; color: #fff; font-size: x-small; letter-spacing: 1px; }
#setumeisp { width: 300px; margin: 10px 0 0 10px; background-color: #666; float: left; padding: 20px 20px 10px 20px; text-align: left; color: #fff; font-size: medium; letter-spacing: 1px; }
#batu { text-align: right; margin: 0 10px 0 0; font-size: x-large; }
#batu a { color: #fff; text-decoration: none; }
#batusp { text-align: right; margin: -30px 10px 0 0; font-size: 60px; }
#batusp a { color: #fff; text-decoration: none; }
.btn { background: transparent url(btn.png) no-repeat 0 0; display: block; width: 35px; height: 35px; position: absolute; top: 10px; right: 20px; cursor: pointer; z-index: 100; }
.peke { background-position: -35px 0; top: 10px; z-index: 101; }
#menu li { width: 250px; }
#menu li a { color: #fff; display: block; padding: 10px 5px 10px 15px; }
h2 { border: none; background-color: transparent; height: auto; font-weight: bold; color: #fff; font-size: 16px; }
SELECT { padding: 5px 5px 5px 5px; }
.drawr { display: none; background-color: rgba(0, 130, 255, 1); position: absolute; top: 0px; right: 0; width: 100%; padding: 60px 0 20px 50px; z-index: 100; }
#loader-bg { display: none; position: fixed; width: 100%; height: 100%; top: 0px; left: 0px; background: #fff; z-index: 1; }
#loader { display: none; position: fixed; top: 50%; left: 50%; width: 200px; height: 200px; margin-top: -100px; margin-left: -100px; text-align: center; color: #fff; z-index: 2; }
.d-flex { display: flex; }
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }
.gap-3 { gap: 1rem; }
.mb-3 { margin-bottom: 1rem; }
.logo-container { display: flex; }
.logo-container { display: flex; justify-content: flex-start; align-items: center; max-width: calc(100% - 80px); max-height: 40px; }
.logo-container a { justify-content: start; }
.logo-container img { max-height: 40px; margin: 0; }
#maptop-sp { display: none; }
#info-panel { display: none; position: fixed; left: 0; top: 50%; transform: translateY(-50%); background-color: rgba(0, 0, 0, 0.7); color: white; padding: 10px; border-radius: 5px; font-family: Arial, sans-serif; font-size: 14px; }
.top-left-container { display: none; }
.hamburger-menu { font-size: 30px; color: #292828; background: none; border: none; cursor: pointer; margin-right: 20px; font-weight: bold; }
.g-manu-btn { width: 160px; padding: 5px 5px; }
button.favorite-route:hover { background-color: unset !important; }
button#mytoolBtn { width: 120px; margin-left: 10px; }
.mypage-link-btn img { width: 50px; height: 50px; cursor: pointer; }

/* ハンバーガーメニュー - サイドバーデザイン */
.menu-content { position: fixed; top: 0; right: -100%; max-width: 350px; width: 100vw; height: calc(100% - 70px); background-color: #fff; display: flex; flex-direction: column; padding: 0; transition: right 0.4s ease-in-out; z-index: 99999; border: none; box-shadow: -2px 0 10px rgba(0, 0, 0, 0.3); overflow-y: auto; border: 8px solid #003366; border-radius: 20px; box-sizing: border-box;}
.menu-content.show { display: flex; right: 0; }
.close-menu-btn { position: absolute; top: 8px; right: 12px; background-color: transparent; border: none; font-size: 30px; color: #fff; cursor: pointer; transition: color 0.3s; z-index: 10; line-height: 1; font-weight: normal; }
.close-menu-btn:hover { color: #ffcccc; }
.kensaku-menu-name { position: relative; top: 0; left: 0; transform: none; font-size: 18px; color: #fff; background-color: #003366; padding: 0 20px; margin: 0; text-align: left; font-weight: bold; display: flex; align-items: center; height: 50px; min-height: 50px; }
.kensaku-exhibitors-select-container { padding: 15px; background-color: #fff; border-bottom: none; display: none;}
.kensaku-exhibitors-select-container form { width: 100%; }
.kensaku-exhibitors-select-container select { width: 100%; padding: 8px 35px 8px 12px; border: 1px solid #ccc; border-radius: 15px; font-size: 13px; background-color: #2b6cb0; color: #fff; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23fff' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; cursor: pointer; height: auto; }
.button-row { display: flex; flex-direction: column; gap: 0; flex-grow: 0; padding: 15px; }
/* .button-row > button { flex: 1 1 auto !important; width: 100%; white-space: nowrap; border-radius: 25px; margin: 0 0 10px 0; padding: 12px 20px; text-align: left; border: none; font-size: 14px; cursor: pointer; color: #fff; transition: opacity 0.2s; position: relative; height: auto; display: flex; align-items: center; font-weight: bold; } */
.button-row > button:hover { opacity: 0.9; }
.button-row > button::after { content: '›'; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); font-size: 20px; color: #000; }
.button-row > button:last-child { margin-bottom: 0; }
/* #osusumeBtnSp { background-color: #c50000; }
#stampBtnSp { background-color: #008800; }
#couponBtnSp { background-color: #008800; }
#seminarBtnSp { background-color: #008800; } */
.qr-image-container { justify-content: center !important; padding: 20px; background-color: #fff; border-top: none; text-align: center;}
.qr-image-container img { width: 80px; height: auto; }
.flags-container { display: flex; justify-content: center; gap: 15px; width: 100%; padding: 15px 20px; background-color: #fff; border-top: none; }
.flags-container li { list-style: none; cursor: pointer; }
.flags-container img { width: 35px; height: 35px; border-radius: 50%; border: 2px solid #ddd; transition: border-color 0.2s; }
.flags-container img:hover { border-color: #004a8f; }
/* #menu-content li.guide-button { background-color: #fff; color: #333; padding: 0 15px; border-radius: 0; text-align: left; font-size: 13px; font-weight: normal; list-style: none; cursor: pointer; border: none; border-bottom: 1px solid #ccc; margin: 0; transition: background-color 0.2s ease; position: relative; height: 50px; display: flex; align-items: center; } 
#menu-content li.guide-button:hover { background-color: #f5f5f5; }
#menu-content li.guide-button::after { content: '›'; position: absolute; right: 15px; top: 50%; transform: translateY(-50%); font-size: 20px; color: #999; }*/
.dmap-menu-btn,.menu-item{width: 100% !important; max-width: 330px; padding: 3px 10px; border-radius: 0px !important; color: #000 !important; border: unset !important; letter-spacing: 0px; font-size: 14px; cursor: pointer; text-align: left; background-color: #fff; border-bottom: 1px solid #ccc !important; line-height: 3; font-weight:bold; position: relative;}
.menu-item{max-width: 275px; margin-left: 15px;}
.dmap-menu-btn::after{content: "\f105"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; right: 10px; top: 50%; transform: translateY(-50%); z-index: 99;}
.d-flex{padding: 0;}
.flags-container{display: none;}

.dmap-map-btn {
  display: inline-block;
  padding: 8px 12px;
  font-size: 14px;
  text-align: center;
  text-decoration: none;
  background-color: #f0f0f0;
  color: #333;
  border: 1px solid #ccc;
  border-radius: 5px;
  cursor: pointer;
  margin: 2px;
  white-space: nowrap;
}

.company-info{padding: 15px; margin-top: 20px;}
.company-info p{font-size: 13px;}

@media screen and (max-width: 1000px) {
  #maptop { display: none; }
  #maptop-sp { background-color: #fff; display: block; height: 60px; position: fixed; top: 0; left:0; z-index: 1000; width: 100%; box-shadow:0 2px 5px rgba(142, 141, 141, 0.7);}
  #navigation{position: relative;}
  #navigation .logo-container{position: absolute; top:50%; left:0%; transform: translateY(-50%); display: flex; width: 100%; max-width: calc(100% - 46px); justify-content: space-between;}
  .hamburger-menu { position: absolute; top:14px; right:-5px; font-size: 30px; color: #000; background: none; border: none; cursor: pointer; margin-right: 20px; font-weight: bold; line-height: 0.6;}
  .menu-content { width: 100vw; max-width: unset; box-shadow:unset;}
  .dmap-menu-btn,.menu-item{width: 100% !important; max-width: unset; padding: 3px 10px; border-radius: 0px !important; color: #000 !important; border: unset !important; letter-spacing: 0px; font-size: 14px; cursor: pointer; text-align: left; background-color: #fff; border-bottom: 1px solid #ccc !important; line-height: 3; font-weight:bold; position: relative; height: unset !important;}
  .menu-item{max-width: 300px; margin-left: 15px;}
  .dmap-menu-btn::after{content: "\f105"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; right: 10px; top: 50%; transform: translateY(-50%); z-index: 99;}
  .d-flex{padding: 0;}
  .flags-container{display: none;}
  .ha-menu-txt{font-size: 9px; font-weight: normal;}
}