﻿@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&display=swap");
@import url("color.css");

* {
	box-sizing: border-box;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-weight: 400;
}
address, em {
	font-style: normal;
}

/* 共通設定 */
.viewpc {
	display: block;
}
.viewsp {
	display: none;
}
.viewtb {
	display: none;
}


/* ---------- reset  ---------- */
html, body {
    width: 100%;
    height: 100%;
    min-height: 100vh;
}

html {
	font-size: 62.5%;
}

body {
	background-color: #ffffff;
	color: var(--texcolor01);
	font-size: 1.6rem;
	line-height: 1.8em;
	letter-spacing: 0;
	-webkit-print-color-adjust: exact;
    color-adjust: exact;
}

dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,input,p,blockquote,fieldset,div {
	margin: 0;
	padding: 0;
}

table,pre,code,select,option,input,textarea,kbd,var,ins,del,samp {
	font-size: 1.4rem;
}

optgroup {
	font-size: 1.4rem;
	font-weight:600;
}

h1,h2,h3,h4,h5,h6 {
	font-weight: normal;
	font-size: 2rem;
}
p {
	font-size: 1.6rem;
	letter-spacing: -0.01em;
	line-height: 1.4;
	margin: 0 0 0.5em 0;
	text-align: left;
	font-weight: 400;

}
ul li,ol li {
	list-style: none;
}

table,th,td {
	margin: 0;
	padding: 0;
	border-collapse: separate;
	border-spacing: 0;
	text-align: center;
}

th,caption {
	text-align: left;
}

address,cite,dfn,em,b,strong,var,th,ins,del,samp {
	font-weight: normal;
	font-style: normal;
}

img,fieldset {
	border: none;
}
hr {
	border: solid var(--bordercolor_light);
	border-width:1px 0 0 0;
	height:1px;
	clear: right;
}
.align_center {
	text-align: center;
}

/* Link Style */

a,a:link,a:active,a:visited {
	color: var(--texcolor01);
	text-decoration: none;
	outline: none;
}
a:focus {
	outline: none;
}
a:hover {
	color: var(--texcolor01);
	text-decoration: none;
}

a img {
	border: 0;
}

.inner {
	width: 90%;
	max-width: 900px;
	margin: 0 auto;
	text-align: left;
	padding: 0;
}
.top_nomargin {
	margin-top: 0!important;
}
.bottom_nomargin {
	margin-bottom: 0!important;
}
.text_strong {
	font-weight: 600;
}
.text_middle {
	font-size: 1.6rem;
}
.text_big {
	font-size: 1.8rem;
}
.text_blue {
	color: var(--texblue);
}
.text_red {
	color: var(--texred);
}
.text_white {
	color: #ffffff;
}
.text_cap {
	font-size: 1.4rem;
	line-height: 1.3;
}
.text_long {
	letter-spacing: -0.1em;
}
.text_underline {
	text-decoration: underline;
}
.align_left {
	text-align: left!important;
}
.align_right {
	text-align: right!important;
}
.blockcontents {
	display: block;
}
.margintop0 {
	margin-top: 0px!important;
}
.margintop10 {
	margin-top: 10px!important;
}
.margintop20 {
	margin-top: 20px!important;
}
.margintop30 {
	margin-top: 30px!important;
}
.margintop40 {
	margin-top: 40px!important;
}
.marginbottom0 {
	margin-bottom: 0!important;
}
.marginbottom20 {
	margin-bottom: 20px!important;
}
.marginbottom30 {
	margin-bottom: 30px!important;
}
.marginbottom60 {
	margin-bottom: 60px!important;
}
.marginbottom140 {
	margin-bottom: 140px!important;
}
.marginleft0 {
	margin-left: 0!important;
}
.margintopmainus30 {
	margin-top: -30px;
}
.cap {
	font-size: 1.4rem;
	margin-top: 8px!important;
	line-height: 1.2!important;
}
.strong_copy {
	font-size: 2rem;
	text-align: center;
}
.big_copy {
	font-size: 2.8rem;
	margin-bottom: 0;
}
.flex_end {
	justify-content: flex-end!important;
}

 
/* ---------  clearfix --------- */

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
 
.clearfix {
	min-height: 1px;
}
 
* html .clearfix {
	height: 1px;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.clear {
	clear: both;
}


/* ===============
btn
================*/
.btn a {
	background-color: var(--themecolor_lightblue);
	border-radius: 6px;
	padding: 8px 20px;
	font-size: 1.4rem;
	color: #fff;
	transition: 0.2s all ease 0s;
}
.btn a:hover {
	opacity: 0.7;
}
.btn_e a {
	background: url("../../common/images/arrow_right_w.svg") no-repeat 97% center var(--themecolor_lightblue);
	background-size: 8px;
	border-radius: 6px;
	padding: 8px 30px 8px 8px;
	font-size: 1.4rem;
	color: #fff;
	transition: 0.2s all ease 0s;
}
.btn_wide a {
	padding: 8px 50px 8px 20px;
	transition: 0.2s all ease 0s;
}
.btn_e a:hover {
	opacity: 0.7;
}
.btn_e a span {
	font-size: 1.3rem;
}


input[type="button"].print_btn {
	-webkit-writing-mode: horizontal-tb !important;
    -webkit-appearance: button;
	background-color: var(--themecolor_lightblue);
	border: none;
	border-radius: 6px;
	padding: 4px 20px 2px 20px;
	font-size: 1.4rem;
	color: #fff;
	transition: 0.2s all ease 0s;
	cursor: pointer;
}
input[type="button"].print_btn:hover {
	opacity: 0.7;	
}

/* ===============
header
================*/
header {
	width: 100%;
	height: 48px;
	background-color: var(--themecolor);
	padding: 6px 0;
	position: fixed;
	z-index: 9999;
}
header h1 {
	width: 400px;
	padding: 9px 0 0 0;
	transition: 0.4s all ease 0s;
	opacity: 0;
}
header.scroll-nav h1 {
	width: 400px;
	opacity: 1;
}
header h1 img {
	width: 100%;
	height: auto;
}
header ul.btn_language {
	position: absolute;
	right: 10px;
	top: 6px;
    width: 160px;
    height: 36px;
    padding: 0 0 6px 0;
	box-sizing:border-box;
	z-index: 9999;
}
header .btn_language > li {
    width: 100%;
    height: 36px;
    line-height: 34px;
    background-color: #fff;
	padding: 0 0 0 10px;
	border-radius: 6px;
	font-size: 1.4rem;
	border: 1px solid #fff;
}
header .btn_language > li a {
    display: flex;
    justify-content: space-between;
}
header .btn_language > li a span.arrow {
	display: block;
	width: 20px;
	height: 34px;
	background: url("../../common/images/arrow_down_w.svg") no-repeat center center var(--themecolor);
	background-size: 10px;
	margin-left: auto;
	border-radius: 0 6px 6px 0;
}
header .btn_language > li a:hover {
}
header ul.btn_language_second-level {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
}
header .btn_language > li:hover {
	background: var(--bgcolor_lightblue);
	transition: 0.2s all ease 0s;
}
header .btn_language_second-level li {
}
header .btn_language_second-level li a:hover {
    background: var(--bgcolor_lightblue);
}
header .init-bottom {
	position: relative;
}
header .btn_language {
    zoom: 1;
}
header .btn_language > li.btn_language_single {
    position: relative;
}
header li.btn_language_single ul.btn_language_second-level {
  position: absolute;
  top: 30px;
	left: 0;
  width: 100%;
	text-indent: 10px;
  background-color: #fff;
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
}
header li.btn_language_single:hover ul.btn_language_second-level {
    top: 35px;
    visibility: visible;
    opacity: 1;
    background-color: #fff;
    border: 1px solid var(--themecolor);
}
header li.btn_language_single:hover ul.btn_language_second-level li a:hover {
    background-color: var(--bgcolor_lightblue);
}


/* ===============
main
================*/
main {
	width: 100%;
	padding-top: 48px;
}


/* ===============
#topimage 
================*/
#topimage {
	width: 100%;
	margin: 0 auto;
	background-color: var(--bgcolor_lightpink);
	padding: 6px 0 0 0;
}
#topimage .logo_jed {
	width: 40%;
	max-width: 230px;
	margin: 0 0 0 auto;
}
#topimage .inner {
	position: relative;
}
#topimage .index_title {
  text-align: center;
}
#topimage .index_title h1 {
	text-align: center;
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
}
#topimage img {
	width: 100%;
	height: auto;
}

/* ===================
.place_setting
====================== */
.place_setting {
	width: 100%;
	height: 52px;
	margin: -4px auto 0 auto;
	background-color: var(--bgcolor_lightpink);
	padding: 5px 0 6px 0;
	position: sticky;
	top: 46px;
	z-index: 2000;
}
.place_setting .placeset_btnarea a {
	width: 90%;
	max-width: 600px;
    display: flex;
    justify-content: space-between;
    background-color: #fff;
    border-radius: 6px;
	border: 1px solid var(--themecolor);
	margin: 5px auto 0 auto;
	font-size: 1.4rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.place_setting .placeset_btnarea a:hover {
	background-color: var(--bgcolor_lightblue);
}
.place_setting .placeset_btnarea a span.arrow {
	display: block;
	width: 40px;
	background: url("../../common/images/icon_location_w.svg") no-repeat center center var(--themecolor_lightblue);
	background-size: 17px;
	margin-top: -3px;
	margin-left: auto;
	border-radius: 0 5px 5px 0;
}
.place_setting .placeset_btnarea p {
	line-height: 20px;
}
.place_setting .placeset_btnarea a p {
	width: calc(100% - 42px);
	display: inline-block;
	font-size: 1.4rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	padding: 3px 0 0 8px;
}
.place_setting .placeset_btnarea a p span {
	font-size: 1.2rem;
}

/* ===================
.place_setmenu
====================== */
.place_setmenu {
	width: 100%;
	margin: 0 auto;
	justify-content: space-between;
	display: flex;
	align-items: stretch;
}
.place_setmenu div {
	flex-basis: 32%;
}

#btn_here {
	letter-spacing: -0.03em;	
}
#btn_here a {
	display: block;
	width: 100%;
	height: 100%;
	background: url("../../common/images/icon_current_w.svg") no-repeat center 8px var(--themecolor_lightblue);
	background-size: 26px;
	padding: 36px 4px 6px 4px!important;
	transition: 0.2s all ease 0s;
	font-size: 1.4rem;
	text-align: center;
	line-height: 2.4;
}
#btn_listselect {
	letter-spacing: -0.03em;
}
#btn_listselect a {
	display: block;
	width: 100%;
	height: 100%;
	background: url("../../common/images/icon_tourist_w.svg") no-repeat center 7px var(--themecolor_lightblue);
	background-size: 18px;
	padding: 32px 4px 6px 4px!important;
	transition: 0.2s all ease 0s;
	line-height: 1.3;
	font-size: 1.4rem;
	text-align: center;
}
#btn_nameselect {
	letter-spacing: -0.03em;
}
#btn_nameselect a {
	display: block;
	width: 100%;
	height: 100%;
	background: url("../../common/images/icon_list_w.svg") no-repeat center 6px var(--themecolor_lightblue);
	background-size: 20px;
	padding: 32px 4px 6px 4px!important;
	transition: 0.2s all ease 0s;
	line-height: 1.3;
	font-size: 1.4rem;
	text-align: center;
}

/* ===================
#popup_spotlist
====================== */
#popup_spotlist {
	display: none;
}
#popup_spotlist.active {
	display: block;
	background-color: #fff;
	padding: 10px 16px 16px 16px;
	width: 90%;
	max-width: 600px;
	height: auto;
	max-height: 80vh;
	overflow-y: auto;
	overflow-x: hidden;
	margin: 0 auto;
	border: 1px solid var(--themecolor);
	position: absolute;
	top: 41px;
	left: 50%;
  	transform: translateX(-50%);
  	-webkit-transform: translateX(-50%);
	z-index: 999;
}

#place_spotlist {
	display: none;
}
#place_spotlist.active {
	display: block;
}
#place_namelist_container {
	display: none;
}
#place_namelist_container.active {
	display: block;
}

.set_place {
	width: 100%;
	margin: 0 auto 10px auto;
}
.set_place p {
	text-align: center;
	font-weight: 600;
}
.set_place p span {
	display: block;
	font-size:1.2rem;
	font-weight: normal;
}

.search_form {
	position: relative;
	width: 100%;
	display: block;	
	margin: 0 auto 10px auto;
}
.search_area {
	width: 100%;
	height: 60px;
	display: block;
	margin: 18px auto 0 auto;
}
.place_input {
	width: 100%;
	display: block;
	height: 50px;
	padding: 0 10px; 
	position: absolute; 
	left:0;
	top:0; 
	border-radius: 6px;
	outline:0;
	border: 1px solid var(--bordercolor_middle);
	margin-bottom: 60px;
}
.place_btn {
	width: 50px;
	height: 50px;
	position:absolute; 
	right: 0;
	top:0;
	color:#666;
	border:none;
	background: url("../../common/images/icon_search.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 20px;
	text-indent: -9999px;
	border-top: 1px solid var(--bordercolor_middle);
	border-right: 1px solid var(--bordercolor_middle);
	border-bottom: 1px solid var(--bordercolor_middle);
	border-radius: 0 6px 6px 0;
	cursor: pointer;
	transition: 0.2s all ease 0s;
}
.place_btn:hover {
	background: url("../../common/images/icon_search_w.svg") no-repeat center center var(--themecolor);
	background-size: 20px;
}

.spotlist_index {
	width: 100%;
	position: relative;
	margin: 10px auto;
}
.spotlist_index ul {
	border-top: 1px solid var(--bordercolor_middle);	
}
.spotlist_index ul li {
	border-bottom: 1px solid var(--bordercolor_middle);
}
.spotlist_index ul li a {
	display: block;
	font-size: 1.4rem;
	padding: 6px 0;
	line-height: 1.5;
	transition: 0.2s all ease 0s;
}
.spotlist_index ul li a:hover {
	background-color: var(--bgcolor_lightblue);
}
.spotlist_index ul li.namelist_top a {
	background: url("../../common/images/arrow_right.svg") no-repeat 98% center;
	background-size: 7px;
}
.spotlist_index ul li.namelist_top a:hover {
	background: url("../../common/images/arrow_right.svg") no-repeat 98% center var(--bgcolor_lightblue);
	background-size: 7px;	
}

.pagenation ul {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center!important;
	font-size: 1.2rem;
	gap: 0px 2px;
}
.pagenation li a {
	font-size: 1.4rem;
	display: block;
	padding: 3px 8px;
	text-align: center;
	border: 1px solid var(--themecolor);
	border-radius: 4px;
	background-color: var(--bgcolor_lightblue);
	transition: 0.2s all ease 0s;
}
.pagenation li.current {
	font-size: 1.4rem;
	display: block;
	padding: 3px 10px;
	text-align: center;
	border: 1px solid var(--themecolor);
	border-radius: 4px;
	background-color: var(--themecolor);
	color: #fff;
}
.pagenation li a:hover {
	font-size: 1.4rem;
	display: block;
	padding: 3px 8px;
	text-align: center;
	border: 1px solid var(--themecolor);
	border-radius: 4px;
	background-color: var(--themecolor);
	color: #fff;
}



/* ===============
#index_maincontents
================*/
#index_maincontents {
	width: 100%;
	margin: 0 auto;
}

/* ===============
.main_nav 
================*/
.main_nav {
	width: 100%;
	border-bottom: 1px solid var(--themecolor);
	border-top: 1px solid var(--themecolor);
	background-color: var(--bgcolor_lightblue);
	position: sticky;
	top: 98px;
	box-sizing: border-box;
	z-index: 1503;
}
.main_nav ul {
	width: 100%;
	max-width: 604px;
	margin: 0 auto;
	height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: nowrap;
}
.main_nav ul li {
	flex-basis: calc(25% - 1px);
	width: 100%;
	display: block;
	line-height: 1.3;
	font-size: 1.6rem;
	text-align: center;
}
.main_nav ul li.current a {
	background-color: var(--themecolor);
	color: #fff;
	transition: 0.2s all ease 0s;
}
.main_nav ul li a {
	width: 100%;
	height: 50px;
	display: block;
	padding: 15px 0;
	text-align: center;
	background-color: var(--bgcolor_lightblue);
	border-left: 1px solid var(--themecolor);
	transition: 0.2s all ease 0s;
}
.main_nav ul li:last-child a {
	border-right: 1px solid var(--themecolor);
}
.main_nav ul li a:hover {
	background-color: var(--themecolor);
	color: #fff;
}

/* ===================
.bread_crumb
====================== */
.bread_crumb {
	width: 90%;
	max-width: 900px;
	margin: 8px auto 4px auto;
}
.bread_crumb ul {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.bread_crumb ul li {
	font-size: 1.4rem;
	padding-left: 30px;
	position: relative;
	line-height: 1.3;
}
.bread_crumb ul li h2 {
	font-size: 1.4rem;	
}
.bread_crumb ul li a {
	text-decoration: underline;
	position: relative;
	display: inline-block;
}
.bread_crumb ul li a:hover {
	text-decoration: none;
}
.bread_crumb ul li:before {
	position: absolute;
	right: -22px;
	top: 8%;
	content: ">";
	display: inline-block;
	width: 10px;
	height: auto;
}
.bread_crumb ul li:first-child {
	padding-left: 0;
}
.bread_crumb ul li:last-child:before {
	content: ""!important;
}

/* ===================
.main_contents
====================== */
.main_contents {
	width: 100%;
	min-height: calc(100vh - 390px);
	margin: 0 auto;
}
.main_contents .inner {
	width: 90%;
	max-width: 900px;
	margin: 0 auto;
	position: relative;
}

.placeset_alert {
	width: 100%;
	margin: 0 auto 20px auto;
}
.placeset_alert p {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 600;
}

.place_error {
	width: 100%;
	margin: 30px auto;
}
.place_error h3 {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 600;
	margin-bottom: 20px;
}
.place_error p {
	text-align: center;
	font-size: 1.4rem!important;
	line-height: 1.6;
}


/* ===================
.emergency_topics
====================== */
.emergency_topics {
	width: 100%;
	margin: 10px auto;
}
.emergency_topics p {
	text-align: center;	
	font-size: 1.6rem;
}

.emergencytopics_main {
	background-color: var(--bgcolor_lightpink);
	padding: 8px 14px 14px 14px;
	border-radius: 8px;
}
.emergencytopics_main h3 {
	font-size: 1.6rem;
	font-weight: 600;
	margin-bottom: 10px;
	text-align: center;
}
.emergencytopics_main .emergencyinfo_area {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 4px;
	flex-wrap: wrap;
}
.emergencytopics_main .emergencyinfo_area div {
	border: 2px solid var(--texred);
	text-align: left;
	background-color: #fff;
	align-items: center;
	display: flex;
	padding: 0 6px 0 0;
}
.emergencytopics_main .emergencyinfo_area div span {
	display: inline-block;
	width: 50px;
	height: 50px;	
	margin-right: 6px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_tsunami {
	background: url("../../common/images/icon_tsunami_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_earthquake {
	background: url("../../common/images/icon_earthquake_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_civilprotec {
	background: url("../../common/images/icon_civilpro_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_evacuation {
	background: url("../../common/images/icon_evacuation_w.svg") no-repeat center center var(--texred);
	background-size: 27px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_weather {
	background: url("../../common/images/icon_weather_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_volcanic {
	background: url("../../common/images/icon_volcano_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_cyclone {
	background: url("../../common/images/icon_cyclone_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}
.emergencytopics_main .emergencyinfo_area div span.icon_heat {
	background: url("../../common/images/icon_heat_w.svg") no-repeat center center var(--texred);
	background-size: 30px;
}


/* ===================
.emergency_detail 
====================== */
.emergency_detail {
	width: 100%;
	max-width: 900px;
	display: block;
	margin: 20px auto 20px auto;
	border: 2px solid var(--bordercolor_light);
	padding: 10px;
}

.emergency_detail .emergency_item {
	width: 100%;
	min-height: 30px;
	margin: 0 auto;
}
.emergency_detail .emergency_item a {
	display: flex;
	width: 100%;
	padding: 10px;
	background: url("../../common/images/arrow_right.svg") no-repeat 97% center;
	background-size: 12px;
}
.emergency_detail .emergency_item a:hover {
	background: url("../../common/images/arrow_right.svg") no-repeat 97% center var(--bgcolor_lightblue);
	background-size: 12px;
}
.emergency_detail .emergency_item p {
	display: inline-block;
	margin-right: 20px;
}
.emergency_detail p.emergency_datetime {
	font-size: 1.4rem;
	margin: 0 20px 4px 0!important;
	line-height: 2;
	display: block;
}
.emergency_detail .emergency_place {
	font-size: 1.4rem;
	margin: 0;
	line-height: 2;
}
.emergency_detail .emergency_add {
	font-size: 1.4rem;
	margin: 0;
	line-height: 2;
}
.emergency_detail .emergency_title {
	font-size: 1.8rem;
	font-weight: 600;
	margin: 0;
}
.emergency_detail .emergency_alart {
	font-size: 1.8rem;
	font-weight: 600;
	margin: 0;
	color: var(--texred);
}
.emergency_detail .emergency_noalart {
	font-size: 1.5rem;
	font-weight: 500;
	margin: 0!important;
}
.emergency_detail .emergency_area {
	background-color: var(--bgcolor_lightpink);
	padding: 4px;
	margin-bottom: 2px;
	margin-right: 20px!important;
	display: block;
}
.emergency_detail .emergency_status {
	font-weight: 600!important;
	line-height: 2;
}

.emergency_detail h3 {
	font-size: 1.6rem;
	display: inline-block;
	margin: 0 0 4px 0;
	padding: 4px 10px;
	line-height: 1.6;
}
.emergency_detail h3.evacuation_h3 {
	background-color: var(--bgcolor_lightpink);
	padding: 4px 10px;
}
.emergency_detail h4 {
	font-size: 1.4rem;
	color: var(--texblue);
	font-weight: 600;
}
.emergency_detail p {
	font-size: 1.4rem;
}
.emergency_detail dl {
	width: 100%;
	font-size: 1.4rem;
	margin-bottom: 8px;
	display: flex;
  	flex-wrap: wrap;
}
.emergency_detail dl dt {
	box-sizing: border-box;
	display: flex;
  	align-items: center;
  	width: 240px;
  	padding: 6px 0;
  	line-height: 1.3;
  	border-bottom: 1px solid var(--bordercolor_light);
}
.evacuation_item dl dt {
	border-bottom: none;
}
.emergency_detail dl dd {
	box-sizing: border-box;
	display: flex;
  	align-items: center;
  	width: calc(100% - 240px);
  	margin-left: 0;
 	padding: 6px 0;
 	line-height: 1.3;
  	border-bottom: 1px solid var(--bordercolor_light);
}
.evacuation_item dl dd {
	border-bottom: none;
}
.emergency_detail dl dd span {
	font-size: 1.6rem;
	font-weight: 600;
	color: var(--texbrightblue);
}
.emergency_detail dl dd span.alert_level05 {
	font-size: 1.4rem;
	background-color: var(--alart05_color);
	color: #fff;
	padding: 4px 8px;
}
.emergency_detail dl dd span.alert_level04 {
	font-size: 1.4rem;
	background-color: var(--alart04_color);
	color: #fff;
	padding: 4px 8px;
}
.emergency_detail dl dd span.alert_level03 {
	font-size: 1.4rem;
	background-color: var(--alart03_color);
	color: #fff;
	padding: 4px 8px;
}


.emergency_detail p {
	margin: 0;
}
.emergency_detail p.cap {
	font-size: 1.2rem;
	margin-bottom: 14px;
}
.emergency_detail p.emergency_time {
	color: var(--texbrightblue);
	margin: 4px;
}

.emergency_map {
	width: 100%;
	height: auto;
	margin: 0 auto;
	text-align: center;
}



/* ===================
.emergencyinfo_menu
====================== */
.emergencyinfo_menu {
	width: 100%;
	margin: 0 auto;
	font-size: 1.4rem;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 30px;
	position: relative;
}
.emergencymenu li.menu_top {
  border-top: 1px solid var(--themecolor);
  border-radius: 6px;
}
.emergencymenu li.menu_top > a {
   border-radius: 6px;
}
.emergencymenu > li {
   position: relative;

}
.emergencymenu li div {
	display: inline-block;
  line-height: 1;
}
.emergencymenu li > a {
   width: 240px;
    display: flex;
   justify-content: flex-start;
   align-items: center;
   line-height: 1;
  transition: 0.2s all ease 0s;
  border-left: 1px solid var(--themecolor);
  border-right: 1px solid var(--themecolor);
  border-bottom: 1px solid var(--themecolor);
}
.emergencymenu li a:hover {
	background-color: var(--bgcolor_lightblue);
  transition: all .2s ease;
  cursor: pointer;
}
.emergencymenu li:hover > ul {
	visibility: visible;
	top: 40px;
	opacity: 1;
	transition: all .2s ease;
	border-top: 1px solid var(--themecolor);
}
.emergencymenu ul {
   visibility: hidden;
   position: absolute;
   top: 34px;
   width: 240px;
    opacity: 0;
    z-index: 1;
}
.emergencymenu ul li {
  height: 41px;
  transition: all .2s ease;
  background-color: #fff;
}
.emergencymenu ul li ul li a {
	width: 240px;
	height: 40px;
	display: block;
	transition: all .2s ease;
}

.emergencymenu li a span.arrow {
	display: block;
	width: 20px;
	height: 40px;
	background: url("../../common/images/arrow_down_w.svg") no-repeat center center var(--themecolor);
	background-size: 10px;
	margin-left: auto;
}

.emergencymenu li span.menu_icon {
	display: inline-block;
	width: 40px;
	height: 40px;
	margin-right:4px;
	border-radius: 0!important;
}
.emergencymenu li span.topicon {
   border-radius: 6px 0 0 6px!important;
}

.emergencymenu li.menu_tsunami > a span.menu_icon {
	background: url("../../common/images/icon_tsunami.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_earthquake > a span.menu_icon {
	background: url("../../common/images/icon_earthquake.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_weather > a span.menu_icon {
	background: url("../../common/images/icon_weather.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_volcanic > a span.menu_icon {
	background: url("../../common/images/icon_volcano.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_cyclone > a span.menu_icon {
	background: url("../../common/images/icon_cyclone.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_heat > a span.menu_icon {
	background: url("../../common/images/icon_heat.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_evacuation > a span.menu_icon {
	background: url("../../common/images/icon_evacuat.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_civilprotec > a span.menu_icon {
	background: url("../../common/images/icon_civilpro.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_evacuation > a span.menu_icon {
	background: url("../../common/images/icon_evacuation.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}
.emergencymenu li.menu_none > a span.menu_icon {
	background: url("../../common/images/icon_none.svg") no-repeat center center var(--bgcolor_lightblue);
	background-size: 30px;
}


/* ===================
.emergencyinfo_select
====================== */
.emergencyinfo_select {
	width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.emergencyinfo_select label {
	margin-right: 6px;
	white-space: nowrap;
	font-size: 14px;
}
.emergencyinfo_select input[type="checkbox"]  {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }

.emergencyinfo_select input[type="checkbox"] {
    cursor: pointer;
    padding-left: 30px;
    vertical-align: middle;
    position: relative;
  }
 .emergencyinfo_select input[type="checkbox"]::before,
 .emergencyinfo_select input[type="checkbox"]::after {
    content: "";
    display: block; 
    position: absolute;
  }
 .emergencyinfo_select input[type="checkbox"]::before {
    background-color: #fff;
    border-radius: 0%;
    border: 1px solid var(--bordercolor_dark);
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    top: 50%;
    left: 5px;
  }
 .emergencyinfo_select input[type="checkbox"]::after {
    border-bottom: 3px solid var(--themecolor);
    border-left: 3px solid var(--themecolor);
    opacity: 0;
    height: 6px;
    width: 11px;
    transform: rotate(-45deg);
    top: -8px;
    left: 10px;
  }
 .emergencyinfo_select input[type="checkbox"]:checked::after {
    opacity: 1;
  }


/* ================
#emergencydetail_main
================== */
#emergencydetail_main {
	width: 90%;
	margin: 30px auto 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#emergencydetail_main h2 {
	font-size: 2.2rem;
	font-weight: 600;
	margin-bottom: 10px;
	line-height: 1.3;
}
#emergencydetail_main h3 {
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 6px;
	position: relative;
	padding-left: 20px;
}
#emergencydetail_main h3:before {
	content: "●";
	color: var(--themecolor);
	left: 0;
	top: 4px;
	position: absolute;
}
#emergencydetail_main #infodetail_textarea {
	flex-basis: 100%;
}
#emergencydetail_main #infodetail_textarea p {
	text-align: center;
	line-height: 1.8;
}
#emergencydetail_main #emergencydetail_textarea01 {
	flex-basis: 42%;
}
#emergencydetail_main #emergencydetail_imgarea {
	flex-basis: 56%;
}
#emergencydetail_main #emergencydetail_imgarea img {
	width: 100%;
	height: auto;
	border: 1px solid var(--bordercolor_middle);
}
#emergencydetail_textarea02 {
	flex-basis: 100%;
}
#emergencydetail_textarea01 p,
#emergencydetail_textarea02 p {
	line-height: 1.6;
	margin-bottom: 1.5em;
}
#emergencydetail_btnarea {
	margin: 30px auto;
	flex-basis: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap:14px;
}

.board_link {
	position: relative;
	display: block;
	display: flex;
	justify-content: flex-end;
	margin-bottom: 20px;
}
.board_link a {
	display: inline-block;
	padding: 6px 30px 6px 12px;
	font-size: 1.4rem;
}


/* ================
emergency category
================== */
.emergency_mainitem {
	width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 4px 20px;
	flex-wrap: wrap;
}
.emergency_mainitem .emergency_alart,
.emergency_mainitem .emergency_noalart {
	flex-basis: 100%;
	text-align: center;
}

.emergency_mainitem dl {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
.emergency_mainitem dl dt {
	flex-basis: 80px;
	margin-right: 20px;
	font-weight: 500;
	white-space: nowrap;
}
.emergency_mainitem dl dd {
	flex-basis: 700px;
	width: 100%;
	word-wrap: break-word;
    overflow-wrap: break-word;
}
.emergency_mainitem dl dd span {
	display: block;
}
.evacuation_detail_municipality {
	background-color: #cc5e71;
	color: #fff;
	width: fit-content;
}
.evacuation_detail_head {
	color: #FF2800;
}
.evacuation_detail_sortValue {
	background-color: #AA00AA;
	color: #fff;
}

#emergency_mainitem_imgarea {
	width: 100%;
	max-width: 500px;
	margin: 10px auto 20px auto;
}
#emergency_mainitem_imgarea img {
	width: 100%;
	height: auto;
}

#emergency_mainitem_txtarea p {
	line-height: 1.6;
}


#weatheralart_sample {
	width: 100%;
	margin: 0 auto 20px auto;
	display: flex;
	justify-content: center;
	gap: 6px;
	align-items: center;
	flex-wrap: wrap;
}
#weatheralart_sample .weatheralart_sample_index {
	display: flex;
	flex-basis: 100%;
	justify-content: center;	
	gap: 18px;
	flex-wrap: wrap;
}
#weatheralart_sample div {
	flex-basis: auto;
	font-size: 14px;
	line-height: 30px;
	display: flex;
	align-items: center;
}
#weatheralart_sample .weatheralart_sample_index div span {
	display: inline-block;
	width: 40px;
	height: 30px;
	margin-right: 6px;
}
#weatheralart_sample .weatheralart_sample_index div span.weather_alart03 {
	background-color: var(--texred);
}
#weatheralart_sample .weatheralart_sample_index div span.weather_alart03 {
	background-color: var(--alart03_color);
}
#weatheralart_sample .weatheralart_sample_index div span.weather_alart04 {
	background-color: var(--alart04_color);
}
#weatheralart_sample .weatheralart_sample_index div span.weather_alart05 {
	background-color: var(--alart05_color);
}
#emergency_weather_detail {
	width: 100%;
	margin: 20px auto;
	border-top: 1px solid var(--bordercolor_middle);
	padding-top: 20px;
	display: flex;
	justify-content: center;
	gap: 20px;
	flex-wrap: wrap;
}
#emergency_weather_detail .emergency_weather_item {
	flex-basis: auto;
	display: block;
	padding: 4px 10px;
}
#emergency_weather_detail .alartlevel03 {
	background-color: var(--alart03_color);
	color: #fff;
}
#emergency_weather_detail .alartlevel04 {
	background-color: var(--alart04_color);
	color: #fff;
}
#emergency_weather_detail .alartlevel05 {
	background-color: var(--alart05_color);
	color: #fff;
}




/* ================
#weekly_weather
================== */
#weekly_weather {
	width: 100%;
	margin: 40px auo 0 auto;
	background-color: var(--bordercolor_bright);
	padding: 16px 10px;
}
#weekly_weather h3 {
	text-align: center;
	font-size: 1.6rem;
	margin-bottom: 10px;
}
#weeklyweather_index {
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: nowrap;
	gap: 1px;
}
#weeklyweather_index .weeklyweather_item {
	flex-basis: 14%;
	width: 100%;
	background-color: #fff;
	padding: 4px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 1.4;
	display: flex;
	flex-wrap: wrap;
}
#weeklyweather_index .weeklyweather_item .weeklyweather_date {
	flex-basis: 100%;
	text-align: center;	
}
#weeklyweather_index .weeklyweather_item .weeklyweather_img {
	flex-basis: 100%;
	width: auto;
	height: 90px;
	display: flex;
	align-items: center;
}
#weeklyweather_index .weeklyweather_item .weeklyweather_img img {
	text-align: center;
	display: block;
	height: auto;
	max-width: 80px;
	margin: 0 auto;
}
#weeklyweather_index .weeklyweather_item .weeklyweather_tempc {
	flex-basis: 100%;
	text-align: center;
}
#weeklyweather_index .weeklyweather_item .weeklyweather_tempf {
	flex-basis: 100%;
	text-align: center;
}
#weeklyweather_index .weeklyweather_item span.high_fig {
	color: var(--texred);
}
#weeklyweather_index .weeklyweather_item span.low_fig {
	color: var(--texbrightblue);
}

/* ===============
#disasterinfo_contents
================*/
#disasterinfo_contents h2 {
	font-size: 2.2rem;
	margin: 30px 0 20px 0;
	border-bottom: 3px solid var(--bordercolor_middle);
	padding: 4px 0 5px 0px;
	color: var(--themecolor);
	font-weight: 500;
	line-height:1.4;
}
#disasterinfo_contents h2 span {
	display:inline-block;
	position:relative;
}
#disasterinfo_contents h2 span::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -8px;
	width: 100%;
	height: 3px;
	background-color: var(--themecolor);
}





/* ===============
#emergencycontact_contents
================*/
#emergencycontact_contents h2 {
	font-size: 2.2rem;
	margin: 30px 0 20px 0;
	border-bottom: 3px solid var(--bordercolor_middle);
	padding: 4px 0 5px 0px;
	color: var(--themecolor);
	font-weight: 500;
	line-height:1.4;
}
#emergencycontact_contents h2 span {
	display:inline-block;
	position:relative;
}
#emergencycontact_contents h2 span::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -8px;
	width: 100%;
	height: 3px;
	background-color: var(--themecolor);
}

.emergencycontact_item {
	width: 100%;
	margin: 0 auto 30px auto;
	border: 2px solid var(--bordercolor_bright);
}
.emergencycontact_item h3 {
	font-size: 1.8rem;
	background-color: var(--themecolor);
	color: #fff;
	display: flex;
	padding: 10px;
}
.emergencycontact_item h4 {
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 6px;
	position: relative;
	padding: 10px;
}
.emergencycontact_item p {
	margin: 10px 20px 1em 20px;
	line-height: 1.7;	
}
.emergencycontact_item p.emergency_callnum a {
	font-size: 2rem;
	color: var(--texred);
	font-weight: 600;
	text-decoration: underline;
}
.emergencycontact_item p.emergency_link a {
	font-size: 1.6rem;
	color: var(--themecolor);
	text-decoration: underline;
}
.emergencycontact_item p a:hover {
	text-decoration: none;
}
.emergencycontact_item p.link_text {
	text-align: right;
}
.emergencycontact_item p.link_text a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/arrow_right.svg") no-repeat 99% center;
	background-size: 8px;
	padding-right: 20px;
}
.emergencycontact_item p.link_open a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/icon_winopen.svg") no-repeat 99% center;
	background-size: 16px;
	padding-right: 20px;
}
.emergencycontact_item p.link_text a:hover {
	text-decoration: underline;
}
	
/* ===============
#usefulinfo_contents
================*/
#usefulinfo_contents h2 {
	font-size: 2.2rem;
	margin: 30px 0 20px 0;
	border-bottom: 3px solid var(--bordercolor_middle);
	padding: 4px 0 5px 0px;
	color: var(--themecolor);
	font-weight: 500;
	line-height:1.4;
}
#usefulinfo_contents h2 span {
	display:inline-block;
	position:relative;
}
#usefulinfo_contents h2 span::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -8px;
	width: 100%;
	height: 3px;
	background-color: var(--themecolor);
}

.usemenu_list {
	width: 100%;
	margin: 30px auto;
}
.usemenu_list .usemenu_item {
	width: 100%;
	margin: 0 auto 30px auto;
	border: 2px solid #eaeaea;
}
.usemenu_list .usemenu_item h3 {
	font-size: 1.8rem;
	background-color: var(--themecolor);
	color: #fff;
	display: flex;
	padding: 10px;
}
.usemenu_list .usemenu_item h4 {
	font-size: 1.6rem;
	font-weight: 600;
	margin: 10px 20px 0 20px;
}
.usemenu_list .usemenu_item p {
	margin: 10px 20px 1em 20px;
	line-height: 1.7;
}
.usemenu_list .usemenu_item p.link_text {
	text-align: right;
	line-height: 1.3;
}
.usemenu_list .usemenu_item p.link_text a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/arrow_right.svg") no-repeat 99% center;
	background-size: 8px;
	padding-right: 20px;
}

.usemenu_list .usemenu_item p a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/arrow_right.svg") no-repeat 99% center;
	background-size: 8px;
	padding-right: 30px;
}
.usemenu_list .usemenu_item p.link_open a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/icon_winopen.svg") no-repeat 99% center;
	background-size: 16px;
	padding-right: 26px;
}
.usemenu_list .usemenu_item p a:hover {
	text-decoration: underline;
}



#usefulinfo_contents .commcard_item {
	width: 100%;
	margin: 0 auto 30px auto;
	border: 2px solid var(--bordercolor_bright);
}
#usefulinfo_contents .commcard_item h3 {
	font-size: 1.8rem;
	background-color: var(--themecolor);
	color: #fff;
	display: flex;
	padding: 10px;
}
.commcard_item .cssacc {
	border-bottom: 1px solid var(--themecolor);
}
.commcard_item label {
    display: block;
    cursor: pointer;
    transition: all 0.5s;
}

.commcard_item label p {
	line-height: 1.6;
	padding: 12px 30px 12px 12px;
	font-size: 1.6rem;
	background: url(../../common/images/arrow_down.svg) no-repeat 98% center #eaeaea;
	background-size: 20px;
	margin-bottom: 0;
	border-bottom: 1px solid var(--themecolor);
}
.commcard_item label p span {
	display: block;
	font-size: 1.4rem;
}
.commcard_item label p:hover {
	background: url(../../common/images/arrow_down.svg) no-repeat 98% center var(--bgcolor_lightblue);
	background-size: 20px;
	margin-bottom: 0;
	border-bottom: 1px solid var(--themecolor);
}
.commcard_item .cssacc:checked + label p {
	line-height: 1.6;
	padding: 12px 30px 12px 12px;
	font-size: 1.6rem;
	background: url(../../common/images/arrow_up.svg) no-repeat 98% center var(--bgcolor_lightblue);
	background-size: 20px;
	margin-bottom: 0;
	border-bottom: 0px solid var(--themecolor);
}

.commcard_item input {
    display: none;
}
.commcard_item .accshow {
	width: 100%;
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
    background-color: var(--bordercolor_bright);
   	border-bottom: 1px solid var(--themecolor);
}
.cssacc:checked + label + .accshow {
    height: auto;
    opacity: 1;
}
.commcard_item .accshow p {
	line-height: 1.6;
	padding: 12px;
	font-size: 1.8rem;
	font-weight: 600;
	color: var(--themecolor);
	background-color: #fff;
	margin-bottom: 0;
}
.commcard_item .accshow p span {
	font-size: 1.4rem;
	display: block;
}


/* ===============
#flowchart_contents
================*/
#flowchart_contents h2 {
	font-size: 2.2rem;
	margin: 30px 0 20px 0;
	border-bottom: 3px solid var(--bordercolor_middle);
	padding: 4px 0 5px 0px;
	color: var(--themecolor);
	font-weight: 500;
	line-height:1.4;
}
#flowchart_contents h2 span {
	display: inline-block;
	position: relative;
}
#flowchart_contents h2 span::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -8px;
	width: 100%;
	height: 3px;
	background-color: var(--themecolor);
}
#flowchart_contents h3 {
	color: var(--themecolor);
	font-size: 2rem;
	font-weight: 600;
	line-height:1.4;
	margin-bottom: 30px;
}

#flowchart_contents .flowchart_item {
	width: 100%;
	max-width: 700px;
	margin: 20px auto;	
}
#flowchart_contents .flowchart_item a {
	display: block;
	font-size: 1.6rem;
	line-height: 1.3;
	width: 100%;
	border: 2px solid var(--themecolor);
	border-radius: 6px;
	padding: 16px 20px 16px 16px;
	background: url("../../common/images/arrow_right.svg") no-repeat 97% center;
	background-size: 12px;
	transition: 0.2s all ease 0s;
}
#flowchart_contents .flowchart_item a:hover {
	background: url("../../common/images/arrow_right.svg") no-repeat 97% center var(--bgcolor_lightblue);
	background-size: 12px;
}
#flowchart_contents .flowchart_item a span {
	font-size: 1.4rem;
}

#flowchart_main {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	align-items: flex-start;
}
#flowchart_main .flowchart_textarea {
	flex-basis: 42%;
	margin-right: 2%;
	margin-bottom: 40px;
}
#flowchart_main .flowchart_textarea_wide {
	flex-basis: 100%;
	margin-bottom: 40px;
}
#flowchart_main .flowchart_textarea h3 {
	margin-top: 20px;
	margin-bottom: 10px;
}
#flowchart_main .flowchart_textarea h4 {
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 6px;
	position: relative;
	padding-left: 20px;
}
#flowchart_main .flowchart_textarea h4:before {
	content: "●";
	color: var(--themecolor);
	left: 0;
	top: 0;
	position: absolute;
}
#flowchart_main .flowchart_textarea h5,
#flowchart_main .flowchart_textarea_wide h5 {
	font-size: 1.7rem;
	font-weight: 600;
	margin-bottom: 6px;
	color: var(--texred);
}
#flowchart_main .flowchart_textarea p,
#flowchart_main .flowchart_textarea_wide p  {
	line-height: 1.6;
	margin-bottom: 1.5em;
}
#flowchart_main .flowchart_imgarea {
	flex-basis: 56%;
	margin-bottom: 20px;
}
#flowchart_main .flowchart_imgarea img {
	width: 100%;
	height: auto;
	border: 1px solid var(--bordercolor_middle);
}
#flowchart_contents .flowchart_imgarea_single {
	flex-basis: 100%;
	margin-bottom: 20px;
	text-align: center;
}
#flowchart_contents .flowchart_imgarea_single img {
	width: 50%;
	height: auto;
	margin: 0 auto;
	border: 1px solid var(--bordercolor_middle);
}
#flowchart_main .flowchart_imgarea img.noline {
	border: none;
}
#flowchart_main .flowchart_imgarea_s {
	flex-basis: 56%;
	margin-bottom: 20px;
	text-align: center;
}
#flowchart_main .flowchart_imgarea_s img {
	max-width: 400px;
	height: auto;
}

#flowchart_main .flowchart_imgarea p.link_text {
	text-align: right;
	display: block;
	margin: 0 0 20px auto;
}
#flowchart_main .flowchart_imgarea p.link_text a {
	color: var(--themecolor);	
	font-weight: 600;
	background: url("../../common/images/arrow_right.svg") no-repeat 99% center;
	background-size: 8px;
	padding-right: 20px;
}
#flowchart_main .flowchart_imgarea p.flowchartimg_cap {
	text-align: right;
	display: block;
}

.flowchart_fig {
	flex-basis: 100%;
	text-align: center;
	width: 100%;
	margin: 0 auto 60px auto;
}
.flowchart_fig img {
	width: 100%;
	height: auto;
	max-width: 600px;
}

.flowchart_column {
	flex-basis: 100%;
	width: 100%;	
	margin: 0 auto 30px auto;
	background-color: var(--bordercolor_bright);
	padding: 16px;
}
.flowchart_column ul {
	margin-left: 30px;
}
.flowchart_column ul li {
	list-style-type: disc;
	line-height: 1.5;
}

.flowchart_btn {
	display: inline-block;
	float: right;
}
.flowchart_btn a {
	display: block;
	margin: 10px 0 20px auto;
}



/* ===============
.evacuation_contents
================*/
.evacuation_contents {
	width: 100%;
	margin: 0 auto;
}
.evacuation_contents h2 {
	font-size: 2.2rem;
	margin: 0px 0 20px 0;
	border-bottom: 3px solid var(--bordercolor_middle);
	padding: 4px 0 5px 0px;
	color: var(--themecolor);
	font-weight: 500;
	line-height:1.4;
}
.evacuation_contents h2 span {
	display: inline-block;
	position: relative;
}
.evacuation_contents h2 span::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -8px;
	width: 100%;
	height: 3px;
	background-color: var(--themecolor);
}


/* ================
#error_contents
================== */
#error_contents {
	width: 100%;
	margin: 40px auto;
	text-align: center;
}

#error_contents h2 {
	font-size: 2rem;
	font-weight: 600;
	text-align: center;
	margin: 0 auto 10px auto;
}
#error_contents p {
	text-align: center;
	margin: 0 auto 4em auto;
}

#error_contents #error_code {
	display: inline-block;
	margin: 0 auto 30px auto;	
	border: 1px solid var(--bordercolor_light);
	padding: 8px 10px;
}

/* ================
#pagetop
================== */
#pagetop {
	display: none;
	position: fixed;
	right: 5px;
	bottom: 58px;
	width: 50px;
	height: 50px;
	z-index: 5;
}
#pagetop a {
	display: block;
	background: url("../../common/images/arrow_up_w.svg") no-repeat center center var(--themecolor_lightblue);
	background-size: 20px;
	width: 100%;
	height: 100%;
	overflow: hidden;
	text-indent: 200%;
	white-space: nowrap;
	opacity: 0.6!important;
	border-radius: 6px;
	transition: 0.2s all ease 0s;
}
#pagetop a:hover {
	background: url("../../common/images/arrow_up_w.svg") no-repeat center center var(--themecolor_lightblue);
	background-size: 20px;
 	opacity: 1!important;
 	border-radius: 6px;
}


/* ===================
footer
====================== */
footer {
	clear: both;
	display: block;
	width: 100%;
	height: 50px;
	margin: 0 auto 0 auto;
	background-color: var(--bordercolor_bright);
	padding: 10px 0;
  	position: sticky;
    top: 100vh;
}
footer p {
	font-size: 1.2rem;
	text-align: center;
	margin: 5 auto;
	line-height: 1;
}



