.loading-indicator {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(97,97, 97, 0.7);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
 }

 .spinner {
    border: 4px solid rgba(255, 255, 255, 0.3);
    border-top: 4px solid #000;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
 }
 
 @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
 }

.station-label p {
    font-weight: bold;
    font-size: 10px;
    text-align: center;
    color: rgb(255, 255, 255);
    padding: 2px 4px;
    border-radius: 4px;
    white-space: nowrap;
    pointer-events: none;
    display: inline-block;
    transition: width 0.3s ease-in-out, height 0.3s ease-in-out;
}

.prefecture-label p {
    font-size: 15px;
    text-align: center;
    padding: 0;
    margin: 0;
    white-space: nowrap;
    position: absolute;
    transform: translate(-50%, -50%);
    pointer-events: none;
    display: inline-block;
    background-color: transparent;
    border: none;
}

.municipality-label p {
    font-size: 10px;
    position: absolute;
    transform: translate(-50%, -6px);
    white-space: nowrap;
}

.no-data-label p {
    font-family: 'Noto Sans', "Hiragino Sans", '游ゴシック体','游ゴシック', YuGothic,"Hiragino Kaku Gothic ProN", sans-serif;
	font-weight: 400;
    position: absolute; /* 絶対位置指定 */
    font-size: 1.8rem;
    opacity: 0.7;
    color: rgb(79, 79, 79);
    background-color: rgb(255, 255, 255);
    padding: 100%; /* パディング（余白）の設定 */
    top: 30%;
    left: 20%;
    transform: translate(-50%, -50%); /* 中央に合わせるために要素を移動 */
    white-space: nowrap;
}

.volcano_icon .volcano_level05 {
	background: url("../images/volcano/volcano_level05.7598e21b6d48.svg") no-repeat left center;
	background-size: 23px;
	padding-left: 22px;
    width: 23px;
    height: 23px;
}
.volcano_icon .volcano_level04 {
	background: url("../images/volcano/volcano_level04.e45c9ca3f144.svg") no-repeat left center;
	background-size: 23px;
	padding-left: 22px;
    width: 23px;
    height: 23px;
}
.volcano_icon .volcano_level03 {
	background: url("../images/volcano/volcano_level03.22edfacd668d.svg") no-repeat left center;
	background-size: 23px;
	padding-left: 22px;
    width: 23px;
    height: 23px;
}
.volcano_icon .volcano_level02 {
	background: url("../images/volcano/volcano_level02.71e59792c737.svg") no-repeat left center;
	background-size: 23px;
	padding-left: 22px;
    width: 23px;
    height: 23px;
}
.volcano_icon .volcano_caution01 {
	background: url("../images/volcano/volcanoother_level03.04acf09a6e2c.svg") no-repeat left center;
	background-size: 16px;
	padding-left: 22px;
    width: 18px;
    height: 18px;
}
.volcano_icon .volcano_caution02 {
	background: url("../images/volcano/volcanoother_level02.e441d37290cf.svg") no-repeat left center;
	background-size: 16px;
	padding-left: 22px;
    width: 18px;
    height: 18px;
}
.volcano_icon .volcano_caution03 {
	background: url("../images/volcano/volcanoother_level01.053fdc50322f.svg") no-repeat left center;
	background-size: 16px;
	padding-left: 22px;
    width: 18px;
    height: 18px;
}
.volcano_icon .volcano_caution04 {
	background: url("../images/volcano/volcano_area.df68cdae80ca.svg") no-repeat left center;
	background-size: 23px;
	padding-left: 22px;
    width: 23px;
    height: 23px;
}

.index_maparea .map_popup.popup_volcano01 {
	display: none;
	left: -57px;
	top: -103px;
	left: 50%;
    bottom: 0;
    transform: translateX(-50%); 
    transition: height 0.3s ease, padding 0.3s ease; 
    height: 0; 
    overflow: visible; 	
}
.index_maparea .map_popup.popup_volcano02 {
	display: none;
    top: -65px;
    left: 53%;
    bottom: 0;
    transform: translateX(-50%); 
    transition: height 0.3s ease, padding 0.3s ease; 
    height: 0; 
    overflow: visible; 	
}

.index_maparea .map_popup.active_popup01 {
	display: block;
	height: 100px;
    padding: 12px;
}

.index_maparea .map_popup.active_popup02 {
	display: block;
	height: 60px;
    padding: 12px;
}

.custom-popup .leaflet-popup-tip {
    display: none;
  }

.index_maparea .map_popup table, th, td {
    border: 0px;
}
table, th, td {
    border: 0px;
}

.index_maparea .map_popup table.popup_table {
    white-space: nowrap;
	margin-bottom: 0;
	font-size: 1.3rem;
	border-top: 1px solid var(--bordercolor01);
	background-color: #fff;
}

.index_maparea .map_popup table.alert_table {
    white-space: nowrap;
	border-top: 1px solid var(--emergencycolor);
}
.index_maparea .map_popup table.alert_table th {
	background-color: var(--bgcolor06);
	border-bottom: 1px solid var(--emergencycolor);
}
.index_maparea .map_popup table.alert_table td {
	border-bottom: 1px solid var(--emergencycolor);
	color: var(--emergencycolor);
	font-weight: 700;
}

@media all and (min-width: 768px) and (max-width: 999px) {
    .index_maparea .map_popup.popup_volcano01 {
        transform: translateX(-50%) scale(0.9);
        top: -8px;
        left: 36%;
    }

    .index_maparea .map_popup.active_popup01 {
        height: 71px;
        padding: 10px;
    }

    .index_maparea .map_popup.popup_volcano02 {
        top: -13px;
        left: 45%;
    }

    .index_maparea .map_popup.active_popup02 {
        height: 34px;
    }

}

@media all and (max-width: 767px) {
    .index_maparea .map_popup.popup_volcano01 {
        transform: translateX(-50%) scale(0.85);
        top: -3px;
        left: 37%;
    }

    .index_maparea .map_popup.active_popup01 {
        height: 60px;
        padding: 0px;
    }

    .index_maparea .map_popup.popup_volcano02 {
        top: -4px;
        left: 46%;
    }

    .index_maparea .map_popup.active_popup02 {
        height: 57px;
        padding: 1px;
    }
}