/* 住民ポータル　トップページ　START */
/* 画面全体　START */
:root {
    --font-size:16px;

    /* components */
    /* border */
    --xclor-bg-city: var(--xclor-purple);
    --xclor-bl-default: var(--xclor-black); 
    --xclor-bl-outline: var(--xclor-blue);
    --xclor-bl-normal: var(--xclor-blue3);  
    --xclor-bl-hazard: var(--xclor-red);
    --xclor-bl-hazard-light:var(--xclor-red3);  
    --xclor-bl-announce: var(--xclor-gray);
    /* background */
    --xclor-bg-default: var(--xclor-black); 
    --xclor-bg-normal: var(--xclor-blue);   
    --xclor-bg-normal-table: var(--xclor-blue4);
    --xclor-bg-normal-table-even: var(--xclor-blue5);
    --xclor-bg-normal-table-odd: var(--xclor-blue6);     
    --xclor-bg-hazard: var(--xclor-red);
    --xclor-bg-hazard-hover:var(--xclor-red2);
    --xclor-bg-hazard-light:var(--xclor-pink);
    --xclor-bg-hazard-table:var(--xclor-pink2);
    --xclor-bg-hazard-table-even:var(--xclor-pink3);
    --xclor-bg-hazard-table-odd:var(--xclor-pink4);
    --xclor-bg-announce: var(--xclor-gray);
    --xclor-bg-announce-hover: var(--xclor-blue2);
    /* font */
    --xclor-ft-city:var(--xclor-purple);
    --xclor-ft-default: var(--xclor-black);  
    --xclor-ft-normal: var(--xclor-blue3);
    --xclor-ft-hazard: var(--xclor-red); 
    --xclor-ft-hazard-light: var(--xclor-red3); 
    /* label */
    --xclor-lb-hazard: var(--xclor-red);

    /* color */
    --xclor-black: #000033;
    --xclor-red: #de2e54;
    --xclor-red2: #FFB899;
    --xclor-red3: #813164;
    --xclor-pink: #f0d6e6;
    --xclor-pink2: #d383b4;
    --xclor-pink3:rgba(240, 214, 230, 0.3);
    --xclor-pink4:rgba(240, 214, 230, 0.5);
    --xclor-blue: #c8ddf1;
    --xclor-blue2: #b8cbde;
    --xclor-blue3: #0D62B2;
    --xclor-blue4: #73A9D9;
    --xclor-blue5: rgba(200, 221, 241, 0.3);
    --xclor-blue6: rgba(200, 221, 241, 0.5);
    --xclor-gray:#778899;
    --xclor-purple: #171745;
}

body {
    background: inherit;
}

body > div {
    padding: 0 32px;
}

h2.title {
    color:var(--xclor-ft-city);
}

main {
    padding: 0;
}

main .portal-rows:nth-child(1) {
    margin-top: 20px;
}

.btn_decision {
    font-size: 14px;
    cursor: pointer;
    font-weight: bold;
    display: flex;
    justify-content: space-around;
    align-items: center;
    min-height: 30px;
    min-width: 100px;
    margin-left: 8px;
    word-break: break-word;
}

.infoBox {
    width: 100%;
}
.infoBox .title_header {
    padding: 5px;
    justify-content: space-between;
    align-items: center;
    display: flex;
    margin-bottom: 0;
}

.infoBox .title_header h2 {
    font-size: var(--font-size-7);
    margin-bottom: 0;
}

.listBox {
    width: 100%;
}
.listBox ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.listBox ul li {
    margin: 0;
    padding: 5px 10px;
    font-size: var(--font-size-5);
}
.listBox ul li a:hover {
    box-shadow: inherit;
    text-decoration: underline;
    text-decoration-color: var(--xclor-bl-default);
}

.contBox {
    width: 100%;
    display: block;
}
.contBox .title_header {
    font-size: var(--font-size-11);
    padding: 5px;
    justify-content: space-between;
    align-items: center;
    display: flex;
    font-weight: bold;
    word-break: break-all;
}
.contBox h2,
.contBox h4 {
    font-size: var(--font-size-7) !important;
}
.contBox .title_header h3 {
    font-size: var(--font-size-7);
    margin: 0;
    font-weight: bold;
}
.contBox .title_border {
    border-bottom: 5px solid var(--xclor-bl-outline);
    box-shadow: 0px 2px 2px 0px var(--Gray-6);
    width: 100%;
    border-radius: 3px;
    margin-bottom: 10px;
}
.contBoxInner {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: space-between;
}
/* 画面全体　END */

/* ヘッダー　START */
.header-menu {
    display: inherit;
    background: inherit;
}

#headerArea {
    height: 120px;
    margin: 0 auto;
    border-bottom: var(--xclor-bg-city) 8px solid;
    padding-bottom: 8px;
    box-sizing: content-box;
}

#hlogo img {
    width: 100%;
}

#clogo img {
    width: 270px;
}

.hdNavi {
    padding: 0px;
    width: 280px;
    height: 100%;
    float:right;
}

#hlogo {
    position: absolute;
    top: 20px;
    height: 60px;
    display: flex;
    align-items: center;
}

#hlogo a:hover {
    text-decoration: none;
    box-shadow: inherit;
}

#slogo {
    position: absolute;
    top: 20px;
    left: calc(50% - 300px);
    height: 60px;
    display: flex;
    align-items: center;
}

#clogo {
    display: flex;
    height: 102px;
    position: absolute;
    left: calc(50% - 130px);
    align-items: center;
}

#clogo a:hover {
    text-decoration: none;
    box-shadow: inherit;
}

.hdNavi .acsbltys {
    display: flex;
    flex-direction: column;
    align-items: end;
    height: 100%;
    background: transparent;
    padding: 0;
}

.hdNavi .acsbltys li {
    padding: 0px;
    margin-right: 4px;
}

.hdNavi ul li {
    padding: 10px;
    font-size: 14px;
    vertical-align: middle;
    word-break: keep-all;
}

.acc-item {
    display: flex;
    align-items: center;
}

.cts_box {
    height: 45px;
    padding: 5.6px;
    border-style: solid;
    border-width: 1px;
    border-color: var(--Gray-6);
    text-align: center;
    width: 205px;
    margin-left: 4px;
    display: flex;
    justify-content: space-around;
}

.cts_box button {
    font-size: 18px !important;
    padding: 0 8px;
    border-radius: 4px;
    border: 1px solid var(--Gray-6);
    min-width: 36px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cts_box button.active {
    background: var(--Gray-7);
    border: 1px solid var(--Gray-7);
    color: var(--White);
}

#actualInfo {
    display: none;
    font-size: var(--font-size-7);
    font-weight: bold;
    background: var(--xclor-bg-hazard);
    color: var(--White);
    padding: 5px 10px;
    border: 1px solid var(--Gray-7);
    width: 160px;
    word-break: break-all;
}

#actualInfo.active {
    display: flex;
    align-items: center;
    justify-content: center;
}

#siteusage {
    align-self: end;
    margin-left: 16px;
    font-weight: bold;
    background-color: var(--Gray-6);
    width: auto;
    padding: 4px 8px;
    border-radius: 4px;
    line-height: 1.4;
    word-break: break-word;
    cursor: pointer;
    border: 1px solid var(--xclor-bl-default);
    text-align: center;
    font-size: 14px;
    max-width: 170px;
}

#siteusage a {
    text-decoration: none;
    color: var(--xclor-ft-default);
}

/* ヘッダー　END */

/* 緊急情報　START */
div#infoArea.infoBox {
    border: 2px solid var(--xclor-bl-hazard);
}
div#infoArea .title_header {
    background: var(--xclor-bg-hazard);
    color: var(--White);
    border: 2px solid var(--xclor-bl-hazard);
}
div#infoArea.infoBox .btn_decision {
    color: var(--White);
    background: var(--xclor-bg-hazard);
    border: 1px var(--White) solid;
}
div#infoArea.infoBox .btn_decision:hover {
    background-color: var(--xclor-bg-hazard-hover);
    color: var(--xclor-ft-hazard);
}
div#infoArea.infoBox a {
    color: var(--Black)
}
div#infoArea.infoBox a:hover {
    text-decoration: underline;
    text-decoration-color: var(--Black);
}
/* 緊急情報 END */

/* お知らせ　START */
div#oshiraseArea.infoBox {
    border: 2px solid var(--xclor-bl-announce);
}
div#oshiraseArea .title_header {
    background: var(--xclor-bg-announce);
    color: var(--White);
    border: 2px solid var(--xclor-bl-announce);
}
div#oshiraseArea.infoBox .btn_decision {
    color: var(--White);
    background: var(--xclor-bg-announce);
    border: 1px var(--White) solid;
}
div#oshiraseArea.infoBox .btn_decision:hover {
    background-color: var(--xclor-bg-announce-hover);
}
div#oshiraseArea.infoBox ul li a div{
    color: var(--Black);
}
#oshirase-listBox {
    overflow-y: auto;
    max-height: 13lh;
}
.listbox-item-date {
    font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
    min-width: 163px;
}
/* お知らせ　END */
/* 気象情報　START */
.kishoTable {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 4px;
}
.kishoTable th {
    background: var(--Gray-4);
}
.kishoTable th p {
    font-weight: bold;
    font-size: var(--font-size-5);
}
.kishoTable th, .kishoTable td {
    border: 2px var(--Gray-4) solid;
}
@media(min-width: 481px) {
    .kishoTable th {
        width: 20%;
    }
}
.reportTime {
    font-size: var(--font-size-3);
    font-weight: 100;
}
.meteHeader {
    font-weight: normal;
    text-align: left;
    padding: 5px;
    word-break: break-word;
}
.meteBody {
    padding: 5px 10px;
}

.margin-kisyou {
    margin-bottom: 2px;
}
/* 気象情報　END */

/* 避難情報、避難所　START */
.commonColumn {
    min-width: 500px;
}
.commonColumn {
    min-height: 150px;
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 110px;
    background-color: var(--xclor-bg-normal);
}
.columnBox {
    flex: 1;
    border-radius: 5px;
    color: var(--xclor-ft-normal);
    padding: 10px;
}
.active .columnBox {
    background-color: var(--xclor-bg-hazard-light);
    color:var(--xclor-ft-hazard-light);
}
.active .columnBox a{
    color:var(--xclor-ft-hazard-light);
}
.active .columnBox a:hover{
    text-decoration-color: var(--xclor-bl-hazard-light);
}
.columnBox h3.title_header {
    padding: 5px;
    justify-content: space-between;
    align-items: center;
    display: flex;
    font-size: var(--font-size-5);
    font-weight: bold;
    margin-bottom: 0;
}

.columnBox .btn_decision {
    background: var(--xclor-bg-normal);
    color: var(--xclor-ft-normal);
    border: 1px var(--xclor-bl-normal) solid;
    height: 25px;
    font-size: var(--font-size-4)
}

.active .columnBox .btn_decision {
    background: var(--xclor-bg-hazard-light);
    color: var(---xclor-ft-hazard-light);
    border: 1px var(--xclor-bl-hazard-light) solid;
}

.columnBox h3.title_header + div {
    padding: 5px 10px;
}

table.listViewTable {
    border: 2px solid var(--Gray-7);
    font-size: var(--font-size-4);
    width: 100%;
    margin-left: 0px;
    margin-right: 0px;
    margin-top: 0px;
    padding: 10px;
    background-color: var(--White);
}

table.listViewTable .master {
    text-align: left;
    border-radius: 0;
    padding: 8px;
}

table.listViewTable h5 {
    font-size: var(--font-size-6);
    margin: 0;
    font-weight: bold;
}

.topTable th.viewH {
    background: var(--xclor-bg-normal-table);
    color: var(--White);
    border: 1px solid var(--Gray-7);
    padding: 6px 3px;
    line-height: 130%;
    word-break: break-all;
}
.active .topTable th.viewH {
    background: var(--xclor-bg-hazard-table);
}

th.viewH {
    border: 1px solid var(--Gray-6);
    background: var(--xclor-bg-normal-table);
    color: var(--xclor-ft-normal);
    padding: 3px;
    text-align: center;
    line-height: 130%;
}
.active th.viewH {
    border: 1px solid var(--Gray-6);
    background: var(--xclor-bg-hazard-table);
}
td.viewL {
    border: 1px solid var(--Gray-7);
    padding: 8px 3px;
}

td.viewR {
    border: 1px solid var(--Gray-7);
    padding: 8px 3px;
    text-align: right;
}

td.viewC {
    border: 1px solid var(--Gray-7);
    padding: 8px 3px;
    text-align: center;
}
.viewC.hinanjyoNabiTable {
    padding: 0.6em 3px;
}
.viewC.hinanjyoNabiTable:hover {
    color: var(--White);
    opacity: 0.8;
    cursor: pointer;
    background-color: var(--xclor-bg-normal);
}

.viewC.hinanjyoNabiTable i {
    padding: 4px 0;
}

div.hinanjyoListArea {
    max-height: 320px;
    overflow-y: auto;
    padding: 5px 10px;
    width: 100%;
}

div.tableArea {
    max-height: 500px;
    overflow-y: auto;
    padding: 5px 10px;
    width: 100%;
}
/* 避難情報、避難所　END */

/* 防災マップ　START */
.main {
    margin: 5px;
    width: 100%;
}

div.mapContainer {
    box-sizing: border-box;
    background: var(--White);
    box-shadow: 0px 2px 4px 0px var(--Gray-6);
    border-radius: 5px;
    border-style: solid;
    border-width: 2px;
    border-color: var(--xclor-bl-default);
}

.ptlc-top-map {
    height: 600px;
}

.mapbox {
    margin: 10px;
}

.mapbox .box {
    width: 100%;
    margin: 10px 0;
    background: var(--Gray-6);
    border: 1px solid var(--Gray-7);
    box-sizing: border-box;
    position: relative;
}

.pop > div {
    height: inherit;
    margin-bottom: inherit;
}
/* 防災マップ　END */
/* 公共情報・気象情、その他　START */
.contBoxInner .commonColumnBox {
    max-width: calc(25% - 10px);
    min-width: calc(25% - 10px);
}
div.title_header {
    font-size: 2rem;
    font-weight: bold;
}
div.title_header a:hover {
    text-decoration: underline;
    box-shadow: inherit;
}
div.commonColumnBox {
    background-size: auto 50%;
    background-position-y: 90%;
}
.columnBox a {
    color: var(--xclor-ft-normal);
    font-size: var(--font-size-13);
    font-weight: bold;
}
/* 公共情報・気象情、その他　END */
/* フッター　START */
#footerMenu .box {
    width: 96%;
    margin: 0 auto;
    text-align: center;
}
#footerMenu ul li {
    display: inline-block;
    font-weight: bold;
    padding: 5px 20px;
    font-size: var(--font-size-5);
}
#footerMenu ul li a {
    text-decoration: underline;
    color: var(--Gray-7);
}
#footer {
    display: table;
    width: 96%;
    margin: 0 auto;
    padding: 25px 0;
}
#footer .copy {
    font-size: 0.75rem;
}
/* フッター　END */

/*  771px以上1100px以下
------------------------------------------------ */
@media (max-width : 1200px) {

	#innerheader {
		display: flex;
        justify-content: space-between;
	}

	#headerL{
		padding: 5px;
	}

	#hlogo{
		position: inherit;
	}

	#hlogo img {
		width:100px;
	}
	#clogo{
		position: static;
		margin-left:32px;
	}
	#clogo img{
		width:240px;
	}

	#slogo{
		position: inherit;
		/* height: 60px; */
		height: fit-content;
		display: flex;
		align-items: center;
	}
	#actual{
		font-size: 1.2rem;
		padding: 3px 10px;
	}
	.hdNavi {
		width:270px;
	}
	.hdNavi .acsbltys {
		padding:0px;
		margin-bottom: 0px;
	}
	#actualInfo {
		font-size: 1.3rem;
		padding: 4px 6px;
	}
    .header-menu .cts_box div span {
        width: 140px;
    }
}

@media (max-width : 900px) {
	#clogo {
		position: inherit;
		margin: 4px 24px;
		flex-direction: column;
		justify-content: center;
	}

	#siteusage {
		font-size: 14px;
		margin-top: 8px;
	}

    .hdNavi {
        display: none;
    }

    .phone-menu {
        width: 70px;
        min-height: 55px;
        justify-content: center;
    }
    .phone-menu-list {
        height: 120px !important;
        background: var(--Gray-6);
        top:0;
        left:0;
        overflow-y: hidden !important;
    }
    .phone-menu-list > ul > li {
        border-bottom: none;
        text-align: center;
        color: var(--Black)
    }
    .phone-menu-list > ul > li div {
        margin: auto;
    }

    .phone-menu-toggle {
        padding: 5px;
        background-position-y: 0px;
        background-size: 40px;
        border: 1px solid var(--Black);
        align-items: end;
        z-index: 1010;
    }

    #innerheader {
		order: 1;
		align-items: center;
		width: 100%;
		justify-content: space-between;
	}

    #bousaiArea .contBoxInner {
        justify-content: center;
    }
}

/*  770px以下
------------------------------------------------ */
@media (max-width : 770px) {
    body > div {
        padding: 0 0.3rem;
    }

    main {
        padding: 0 10px;
    }

	#headerArea{
		display: flex;
		flex-wrap: wrap;
		justify-content: stretch;
		width: 100%;
        height: inherit;
	}

	.hdNavi {
		display: none;
		position: absolute;
		width:100%;
		height: 280px;
		top:0;
		text-align: center;
		z-index: 5;
	}
	.hdNavi .acsbltys {
		display:flex;
		flex-direction: column;
		align-items:center;
		height:100%;
		width: 100%;
		padding-top: 16px;
		padding-bottom: 16px;
	}
	.hdNavi .acsbltys .acc-item {
		margin: 2px 0;
		padding: 8px 20px;
		border-radius: 5px;
		border:1px solid var(--Gray-7);
	}

	.hdNavi.open {
		display:block;
		position: absolute;
		width:100%;
		text-align: center;
	}
	#clogo {
		left: calc(50% - 100px);
	}
	#clogo img{
		width:200px;
	}
	#hlogo img {
		width:80px;
	}

	@media (max-width : 640px) {
		.hdNavi .acsbltys .acc-item.until640 {
			display:none;
		}
		.hdNavi {
			height:190px;
		}
		.listbox-item-font {
			font-size: smaller;
		}
		.listbox-item-date {
			min-width: 138px;
		}
		#actualInfo {
			font-size: 1.2rem;
		}
        .commonColumn {
            min-width: 100%;
        }
        .contBoxInner .commonColumnBox {
            max-width: calc(50% - 10px);
            min-width: calc(50% - 10px);
        }
	}

	@media (max-width : 445px) {
		#clogo {
			margin-left: 8px;
			margin-right: 8px;
		}
		#clogo img{
			width:180px;
		}
		#actualInfo {
			font-size: 1.1rem;
			padding: 4px 2px;
            width: 100px;
		}
	}
}
/* 住民ポータル　トップページ　END */

/* 住民ポータル　ページ共通  START*/
.breadcrumb {
    margin-top: 10px;
}

.custombox {
    display: block;
    padding: 0 30px;
}

.custombox dl:nth-child(even) {
    background-color: var(--xclor-bg-normal-table-even);
}
.custombox dl:nth-child(odd) {
    background-color: var(--xclor-bg-normal-table-odd);
}
.custombox table th {
    background-color: var(--xclor-bg-normal-table);
    color:var(--White);
}
.custombox.active dl:nth-child(even) {
    background-color: var(--xclor-bg-hazard-table-even);
}
.custombox.active dl:nth-child(odd) {
    background-color: var(--xclor-bg-hazard-table-odd);
}
.custombox.active table th {
    background-color: var(--xclor-bg-hazard-table);
    color:var(--White);
}
.custombox dl{
    width: 100%;
    display: table;
    margin: 10px 0;
    padding: 10px;
}
.custombox dl dd,
.custombox dl dt{
    display: table-cell;
    padding: 5px;
}
.custombox dl dd p.day {
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.2;
    padding-bottom: 5px;
}
.custombox table {
    border-collapse: collapse;
    border: 2px solid var(--Gray-7);
}
.custombox table th,
.custombox table td {
    border: 1px solid var(--Gray-6);
}
.custombox a {
    color:var(--Black)
}
.custombox a:hover{
    text-decoration: underline;
    text-decoration-color: var(--Black);
    box-shadow: inherit;
}
.custombox .x-button {
    background-size: 20px 20px;
    padding: 8px 15px
}
.custombox .fukidashi {
    padding: 8px 24px;
}

.infoTitle {
    background: var(--xclor-bg-normal);
    color: var(--xclor-ft-normal);
    font-size: var(--font-size-6);
    padding: 8px;
    font-weight: bold;
}
.active .infoTitle {
    background: var(--xclor-bg-hazard-light);
    color: var(--xclor-ft-hazard-light);
}

.external-link::after {
    margin-left: 3px;
    content: "\f08e";
    font-family: FontAwesome;
}

.protal-content-main {
    width: 100%;
}

p.description {
    margin: 8px auto 24px auto;
}

@media (max-width : 770px) {
    .list-table th,
    .list-table td {
        padding: 4px !important;
        font-size: var(--font-size-4);
    }
    .list-table th.sp-none,
    .list-table td.sp-none { 
        display: none;
    }
    .custombox {
        padding: 0 5px;
    }
    .custombox span.daytime {
        font-size: var(--font-size-4);
    }
}

.master-icon > div {
    width: inherit;
}

.link-item-wrapper {
    margin-top: 32px;
    margin-bottom: 32px;
    border: thin solid var(--xclor-bl-default);
}

.link-item-title {
    background-color: var(--xclor-bg-normal-table);
    color: var(--White);
    width: 100%;
    font-weight: bold;
    font-size: var(--font-size-5);
    padding: 8px;
}

.active .link-item-title {
    background-color: var(--xclor-bg-hazard-table);
}

.link-item {
    padding: 8px;
}

.link-item p {
    font-size: var(--font-size-5);
    line-height: var(--font-size-7);
}

.pop >

/* 住民ポータル　ページ共通  END*/