/* PC版のみ適用しない設定 */
.pc_none{
	display: none;
}

/* 左カラムのサイズ設定 */
.tbl_2c_c{
	width: 1000px;
	margin: 0px auto;
}

/* vertical-alignの個別設定 */
.va_m{ vertical-align: middle !important; }
.va_t{ vertical-align: top !important; }
.va_b{ vertical-align: bottom !important; }

/* 参加保護団体一覧ページ */
/* 参加保護団体一覧ページ > ヘッダー設定 */
.prtect_header{
	background: #B9B9B9;
	color: #fff;
	position: relative;
	height: 200px;
}
.prtect_header h1{
	margin: auto !important;
	width: 100%;
	border: none !important;
}
.prtect_header h1 img{
	width: 100%;
	height: auto;
}
.prtect_desc{
	padding: 0px;
	margin: 15px auto;
}

.prtect_list_a{
    display: flex;
    flex-wrap: wrap;
}
.prtect_list_label{
	margin: 20px 0 5px 0;
    font-size: 20px;
    font-weight: bold;
    line-height: 26px;
}
.prtect_desc .prtect_desc_howto{
	width: 1000px;
	margin: 0px auto;
	text-align: center;
}
.prtect_desc .prtect_desc_howto img{
	width: calc(25% - 15px);
	height: auto;
	margin: 5px;
}
.prtect_desc .link-txt {
    text-align: right;
    padding: 10px 10px 0;
}
.prtect_desc .link-txt a{
	color: #1396cc;
    font-size: 17px;
    font-weight: bold;
	position: relative;
	padding-left: 15px;
}
.prtect_desc .link-txt a:hover{
	color: #f00000;
}
.prtect_desc .link-txt a::before {
    content: "";
    border: 7px solid transparent;
    border-left: 7px solid #1396cc;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 0;
    height: 0;
}
/* 保護団体一覧 エリア別ボタン */
.prtect-list_area{
    display: flex;
    flex-wrap: wrap;
    margin: 10px 0;
    padding: 0;
}
.prtect-list_area li{
    list-style: none;
    width: calc(16% - 14px);
    text-align: center;
    margin: 10px;
    white-space: pre;
}
.prtect-list_area li a{
    color: #555;
    border: 1px solid #ccc;
    display: block;
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    padding: 20px;
    box-sizing: border-box;
    border-radius: 2px;
}
.prtect-list_area li.area-active a{
    color: #fff;
    background: #53c3f1;
    border: 1px solid #53c3f1;
    pointer-events: none;
    text-decoration: none;
}
.prtect-list_area li a:hover{
    opacity: 0.5;
}

/* 参加中の保護団体一覧 */
.prtect_list_h2{
	position: relative;
    background: #fff;
    border: 1px solid #E6E6E6;
    padding: 15px;
    font-size: 23px;
    font-weight: bold;
    color: #414141;
    padding-left: 35px;
}
.prtect_list_h2::before{
	content: "";
    width: 7px;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: 5px;
    background: rgb(130,214,255);
    background: linear-gradient(0deg, rgba(130,214,255,1) 0%, rgba(83,195,241,1) 35%, rgba(16,148,203,1) 100%);
}
/* 参加団体一覧 */
.prtect_list_l{
	display: flex;
    flex-wrap: wrap;
}
.prtect_list_detail{
	display: flex;
    flex-direction: column;
    width: 32%;
    margin: 15px 5px;
    padding: 15px;
    box-sizing: border-box;
    border: 3px solid #fff;
    background: #fff;
    position: relative;
    border-radius: 5px;
}
.prtect_list_detail.active{
    background-color: #fff;
    border-color: #15b7ab;
    box-shadow: 0px 0px 7px #15b7ab;
}
.prtect_list_detail.active::before{
	content: "現在ログイン中です";
    background-color: #15b7ab;
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    display: block;
	padding: 8px 15px 8px 38px;
    position: absolute;
    left: -10px;
    top: -10px;
    z-index: 2;
    border-radius: 5px;
	background-image: url(/img/protect/protect_md_icon.png);
    background-repeat: no-repeat;
    background-size: 27px;
    background-position: 4% 40%;
}
.prtect_list_detail .prtect_list_image{
	display: block;
    width: 280px;
    height: 190px;
    background: #fff;
    border-radius: 3px;
    box-sizing: border-box;
    position: relative;
}
.prtect_list_detail .prtect_list_image a{
	display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.prtect_list_detail .prtect_list_image img{
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    margin: auto;
    display: block;
    object-fit: contain;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
}
.prtect_list_detail .prtect_list_name{
	font-size: 17px;
    font-weight: bold;
    line-height: 25px;
    margin: 13px 0 3px;
    flex-grow: 1;
}
.prtect_list_detail .prtect_list_comment{
	border: 2px solid #ccc;
	font-size: 13px;
	line-height: 20px;
	padding: 10px;
	margin: 5px auto;
	box-sizing: border-box;
    overflow: hidden;
	width: 100%;
    min-height: 105px;
    max-height: 105px;
	background: #fff;
}
.prtect_list_detail .prtect_list_comment span{
	display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
}
.prtect_list_detail .prtect_list_data{
	overflow: hidden;
}
.prtect_list_detail .prtect_list_data dl{
	font-size: 0;
}
.prtect_list_detail .prtect_list_data dt,
.prtect_list_detail .prtect_list_data dd{
	display: block;
	font-size: 13px;
	word-break: keep-all;
}
.prtect_list_detail .prtect_list_data dt{
	font-weight: 700;
}
.prtect_list_detail .prtect_list_data dd{
	padding-left: 15px;
}
.prtect_list_detail .prtect_list_btn{
	width: 250px;
	margin: 10px auto;
}
.prtect_list_detail .prtect_list_btn a{
	display: block;
	text-decoration: none;
	color: #fff;
	background: #53C3F1;
	text-align: center;
	padding: 15px;
	border-radius: 5px;
	position: relative;
    margin: 0px auto;
    font-size: 16px;
    line-height: 1;
}
.prtect_list_detail .prtect_list_btn a::before{
    content: "この団体を支援する";
}
.prtect_list_detail .prtect_list_btn a:hover{
	background: #3cacd8;
}

.prtect_list_detail .prtect_list_btn.active a::before{
    content: "登録内容を確認する";
}
.prtect_list_detail .prtect_list_btn.active a{
	font-weight: 700;
    background: #15b7ab;
}
.prtect_list_detail .prtect_list_btn a:hover{
	background: #0c8f86;
}

.prtect_list_detail .prtect_list_btn a i{
	font-weight: 400;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	width: 0;
	height: 0;
	line-height: 0;
	margin: auto;
}
/* 参加中の保護団体一覧 > 全ての保護団体を表示するボタン */
.prtect_list_more{
	margin: 30px auto;
	width: 650px;
	display: block;
}
.prtect_list_more button{
	width: 100%;
	display: block;
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, 
	rgba(252,252,252,1) 29%, rgba(210,210,210,1) 71%, rgba(186,186,186,1) 100%);
	color: #6a6a6a;
    font-size: 20px;
    font-weight: bold;
    padding: 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
    cursor: pointer;
}
.prtect_list_more button:hover{
	color: #aaa;
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 29%, 
	rgba(235,235,235,1) 71%, rgba(204,204,204,1) 100%);
	border: 1px solid #eee;
}

/* 団体情報の修正ページ */
.editform_box{
    width: 80%;
    margin: 20px auto;
    padding: 20px 30px;
    border: 5px solid #f5f5f5;
}
.editform_box_inner{
	margin: 10px;
	padding: 0px;
	border-bottom: 1px solid #ccc;
	box-sizing: border-box;
	display: flex;
}
.editform_box_inner .edit_col-l{
    width: 155px;
    padding: 0;
    margin: 10px 20px 10px 0;
    box-sizing: border-box;
}
.editform_box_inner .edit_col-l span{
	padding: 5px 0px;
    box-sizing: border-box;
    display: block;
    color: #fff;
    background: #a0a0a0;
    font-size: 13px;
    font-weight: bold;
    text-align: center;
    padding: 7px;
    border-radius: 5px;
}
.editform_box_inner .edit_col-r{
	width: calc(100% - 190px);
	padding: 10px 0;
	margin-bottom: 10px;
}
.editform_box_inner .edit_col-r .prtext_img{
	font-size: 0;
}
.editform_box_inner .edit_col-r .prtext_img img{
	max-width: 260px;
	width: 100%;
	height: auto;
}
.editform_box_inner .edit_col-r .notice{
    margin: 5px 0 0;
}
.editform_box_inner .edit_col-r .notice_list{
	margin: 5px 0;
	padding: 0px 20px;
}
.editform_box_inner .edit_col-r .notice_list li{
	list-style: disc;
	font-size: 14px;
}

.editform_box_inner .edit_col-r input[type="text"]{
    border: 1px solid #ccc;
    padding: 4px;
    border-radius: 5px;
}
.editform_box_inner .edit_col-r input[type="file"]{
    display: none;
}
.editform_box_inner .edit_col-r .region-check  input[type="checkbox"]{
	display: none;
}
.editform_box_inner .edit_col-r textarea{
    border: 1px solid #aaa;
    color: #333;
    background: #fff;
    padding: 5px;
    box-sizing: border-box;
    border-radius: 5px;
    resize: vertical;
}
.editform_box .formbtn{
    margin: 40px auto;
    width: 50%;
}

/* 担当者名 > 代表者 */
.editform_box_inner .edit_col-r  .groupname_owner{
	display: flex;
	align-items: center;
	margin: 5px 0;
}
.editform_box_inner .edit_col-r  .groupname_owner_lb{
	width: 70px;
	font-weight: 700;
}
.editform_box_inner .edit_col-r  .groupname_owner_de{
	font-size: 20px;
	font-weight: 700;
}

/* 入力フォーム・エラーメッセージ表示 */
.parsley-custom-error-message{
	color: #ff0000;
	font-size: 15px;
	line-height: 30px;
}
input.parsley-error,
textarea.parsley-error{
	background-color: #ffd5d5;
}

/* 団体登録申請完了ページ */
.regist_h2{
	position: relative;
    margin: 0 0 5px 0;
    font-size: 20px;
    font-weight: bold;
    line-height: 28px;
    border-bottom: 1px solid #dadada;
}
.regist_backbtn{
	width: 700px;
	margin: 30px auto;
}
.regist_backbtn a{
	color: #333;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	display: block;
}
.regist_backbtn a:hover{
	color: #aaa;
}
.regist_backbtn a img{
	max-width: 100%;
    height: auto;
    display: block;
    margin-bottom: 10px;
    border: 2px solid #333;
}

/* ご支援商品の登録方法 */
.howto_listregist{
	width: 920px;
	padding: 40px;
	margin: 20px auto;
	box-sizing: border-box;
	background: #EFEFEF;
}
.howto_listregist .stepbox{
	width: 100%;
	display: table;
	margin: 20px 0;
}
.howto_listregist .stepbox_label{
	width: 180px;
	color: #fff;
	background: #1CBBFF;
	border-radius: 10px 0 0 10px;
	padding: 15px;
	box-sizing: border-box;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	display: table-cell;
	vertical-align: middle;
}
.howto_listregist .stepbox_text{
	color: #333;
	background: #fff;
	border-radius: 0px 10px 10px 0;
	font-size: 17px;
	line-height: 27px;
	font-weight: bold;
	padding: 15px 30px;
	text-align: left;
	display: table-cell;
	vertical-align: middle;
}

/* 団体登録ページ */
.prtext_regist_form{
	width: 865px;
    border-bottom: 1px solid #ccc;
    padding: 10px 7px 16px;
    margin: 10px auto;
    box-sizing: border-box;
}
.prtext_regist_form .prtext_regist_form_l{
	display: inline-block;
	vertical-align: top;
	width: 150px;
	margin: 0px;
	padding: 0px;
}
.prtext_regist_form .prtext_regist_form_c{
	display: inline-block;
	vertical-align: top;
	width: 500px;
	margin: 0px 10px;
	padding: 0px;
}
.prtext_regist_form .prtext_regist_form_r{
	display: inline-block;
	vertical-align: top;
	width: 160px;
	margin: 0px;
	margin-left: 10px;
	padding: 0px;
}
/* 登録フォーム・注意事項 */
.prtect_regist_info{
	width: auto;
	border: none;
	padding: 0px 5px;
	margin: 15px auto;
	box-sizing: border-box;
	font-size: 14px;
}
.prtect_regist_info2{
	background: #ffe2e2;
	padding: 15px 20px;
	width: 865px;
	margin: 20px auto;
	box-sizing: border-box;
	border-radius: 3px;
}
/* 240521 SNSの入力について */
.prtect_regist_sns_info{
    background: #fef7f5;
    border: 2px solid #f15353;
    padding: 20px;
    margin: 10px auto 0;
    display: block;
    text-align: center;
    font-size: 16px;
    border-radius: 5px;
}

/* 登録フォーム・（左側）ラベル */
.prtext_regist_form .prtext_regist_form_l span{
	display: block;
    color: #fff;
    background: #838383;
    font-size: 13px;
    font-weight: bold;
    text-align: center;
    padding: 10px;
    border-radius: 5px;
    min-height: 41px;
    box-sizing: border-box;
}
/* 登録フォーム */
input[type="file"]{
	display: none;
}
.prtext_regist_form .prtext_regist_form_c input{
	border: 1px solid #a0a0a0;
	border-radius: 5px;
	padding: 7px;
    font-size: 16px;
    box-sizing: border-box;
}
.prtext_regist_form .prtext_regist_form_c textarea{
	width: 100%;
    border: 1px solid #a0a0a0;
    border-radius: 5px;
    padding: 7px;
    font-size: 16px;
    resize: vertical;
    box-sizing: border-box;
}
.prtext_regist_form .prtext_regist_form_c input::placeholder,
.prtext_regist_form .prtext_regist_form_c textarea::placeholder{
    color: #bbb;
}
.prtext_regist_form .prtext_regist_form_c button,
.edit_col-r .label_button,
.prtext_regist_form .prtext_regist_form_c .label_button{
    color: #555;
	padding: 10px 20px;
	border: 1px solid #ccc;
	border-radius: 5px;
	margin: 3px;
	font-size: 14px;
	font-weight: bold;
	cursor: pointer;
	background: #eee;
	display: inline-block;
	position: relative;
}
.prtext_regist_form .prtext_regist_form_c .prtext_img{
	font-size: 0;
}
.prtext_regist_form .prtext_regist_form_c .prtext_img.noimage{
	position: relative;
    width: 300px;
    min-height: 200px;
    border: 3px dashed #ccc;
    background: #eee;
    margin-bottom: 10px;
	cursor: pointer;
	display: block;
}
.prtext_regist_form .prtext_regist_form_c .prtext_img img{
	max-width: 300px;
	width: 100%;
	height: auto;
}

.prtext_regist_form .prtext_regist_form_c .prtext_img.noimage > span{
	font-weight: 700;
    font-size: 15px;
    text-align: center;
    color: #aaa;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    height: 20px;
    display: block;
}
.prtext_regist_form .prtext_regist_form_c .prtext_img.noimage > span:before{
	content: "画像ファイルを読み込む";
}

#prtext_imgbtn.parsley-error + .prtext_img.noimage{
	background-color: #ffd5d5;
}
#prtext_imgbtn.parsley-error + .prtext_img.noimage > span:before{
	color: #ff0000;
}

.prtext_regist_form .prtext_regist_form_c .prtect_regist_info{
	width: auto;
    border: none;
    padding: 0px 5px;
    margin: 15px auto;
    box-sizing: border-box;
    font-size: 14px;
}

.prtect_regist_info2{
	background: #ffe2e2;
    padding: 15px 20px;
    width: 865px;
    margin: 20px auto;
    box-sizing: border-box;
    border-radius: 3px;
}


.form_2colbox{
	display: flex;
	flex-wrap: nowrap;
	align-items: baseline;
}
.form_2colbox .form_2col{
	display: flex;
	flex-wrap: nowrap;
	align-items: baseline;
	width: 50%;
}
.form_2col .form_2col_cl{
	width: 50px;
	text-align: right;
}
.form_2col .form_2col_cr{
	width: calc(100% - 60px);
}
.form_2col .form_2col_cr input[type="text"]{
	width: 100%;
}

.regist-check-box-reg{
	display: flex;
	flex-wrap: wrap;
}
.regist-check-box-reg dt{
	width: 80px;
	font-weight: 700;
	margin: 0 20px 0 0;
	text-align: right;
	font-size: 14px;
	line-height: 21px;
}
.regist-check-box-reg dd {
	width: calc(100% - 100px);
	font-size: 17px;
	line-height: 21px;
}

.prtext_regist_form .prtext_regist_form_c .notice{
	margin: 5px 0;
}
.region-check{
    margin-bottom: 15px;
}
/* 登録フォーム */
.prtext_regist_form .prtext_regist_form_c .region-check input{
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	   -moz-appearance: none;
			appearance: none;
}
.region-check label{
    color: #333;
	display: inline-block;
    vertical-align: top;
    width: 23%;
    margin: 5px 0;
    font-size: 14px;
	white-space: pre;
	cursor: pointer;
}
.region-check label input[type="checkbox"] + span{
	position: relative;
	padding: 0px 30px;
	border-color: #555;
}
.region-check label span{
	display: inline-block;
	vertical-align: top;
}
.region-check label input[type="checkbox"] + span::before,
.region-check label input[type="checkbox"] + span::after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	box-sizing: border-box;
}
.region-check label input[type="checkbox"] + span::before{
	z-index: 0;
	background-color: transparent;
	width: 20px;
	height: 20px;
	border: 1px solid #a0a0a0;
	border-radius: 5px;
}
.region-check label input[type="checkbox"] + span::after{
	z-index: 1;
    margin: 3px 7px;
    width: 7px;
    height: 12px;
}
.region-check label input[type="checkbox"]:checked + span::before{
	background-color: #1CBBFF;
    border-color: #1CBBFF;
}
.region-check label input[type="checkbox"]:checked + span::after{
	    border: 3px solid #fff;
    border-width: 0 3px 3px 0;
	-webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
#region-allcheck,
#region-allreset{
    padding: 7px 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
    margin: 3px;
    font-size: 14px;
    font-weight: bold;
    cursor: pointer;
    background: #eee;
    display: inline-block;
    vertical-align: top;
    width: calc(50% - 10px);
    box-sizing: border-box;
	text-align: center;
}

/* 入力チェックマーク */
.prtext_regist_form_r .form_checker{
	color: #fff;
    background: #aaa;
    font-size: 14px;
    line-height: 1;
    font-weight: bold;
    margin: 0px auto;
    height: 40px;
    padding: 13px;
    display: block;
    text-align: center;
    border-radius: 5px;
    box-sizing: border-box;
}
.prtext_regist_form_r .form_checker.ch-red,
.prtext_regist_form_r.parsley-success .form_checker.ch-green{
	display: block;
}
.prtext_regist_form_r .form_checker.ch-green,
.prtext_regist_form_r.parsley-success .form_checker.ch-red{
	display: none;
}
.prtext_regist_form_r .form_checker.ch-red{
	background: #F15353;
}
.prtext_regist_form_r .form_checker.ch-green{
	background: #09c66e;
}
/* 入力フォームぼたん */
.formbtn,
.editform_btn{
	width: 865px;
	margin: 30px auto;
	text-align: center;
}
/*.formbtn input{
	display: none;
}*/
.regist_check_btn,
.formbtn button,
.editform_box .formbtn .regist_check_btn{
    font-size: 20px;
    font-weight: bold;
    color: #555;
    border-radius: 5px;
    background: #fff;
    border: 1px solid #bbb;
    padding: 15px;
    width: 350px;
    display: block;
    margin: auto;
    text-align: center;
    box-shadow: 2px 2px 0px #eee;
    cursor: pointer;
    background: #efefef;
}
.regist_check_btn:focus,
.regist_check_btn:hover,
.formbtn button:hover{
	background: #dbdbdb;
}
/* 入力フォーム・エラーメッセージ表示 */
.prtext_regist_form_c .parsley-custom-error-message{
	color: #ff0000;
    font-size: 15px;
    line-height: 1.3;
    margin: 7px 0;
}

/* 入力フォーム確認画面 */
#regist-modal{
	background: rgba(0, 0, 0, 0.5);
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	margin: auto;
	width: 100%;
	display: none;
}
#regist-modal-window{
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 965px;
	height: 80%;
	padding: 30px;
	box-sizing: border-box;
	background: #fff;
	overflow: auto;
	z-index: 3;
}
#regist-modal-window h2.regist-check_h2{
	background: #53C3F1;
	color: #fff;
	font-size: 18px;
	padding: 12px;
	margin-bottom: 20px;
	border: none !important;
}
#regist-modal-window .regist-box{
	width: 80%;
	margin: 30px auto 50px;
}
#regist-modal-window .regist-box p{
	margin-bottom: 20px;
}
#regist-modal-window .regist-check-box{
	padding: 15px;
	margin: 0px auto;
	border-bottom: 1px solid #ccc;
}
#regist-modal-window .regist-check-box .regist-check-box_l{
	display: table-cell;
	vertical-align: top;
	width: 130px;
    font-size: 13px;
	padding-right: 15px;
	text-align: right;
	font-weight: bold;
}
#regist-modal-window .regist-check-box .regist-check-box_r{
	display: table-cell;
	vertical-align: top;
	width: calc(100% - 190px);
	padding-left: 15px;
	border-left: 3px solid #aaa;
}
#regist-modal-window .regist-check-box .regist-check-box_r img{
	max-width: 100%;
	height: auto;
}
#regist-modal-window .regist-btn-box{
	width: 80%;
	margin: 20px auto;
	text-align: center;
}
#regist-modal-window .regist-btn-box button{
	width: 500px;
	margin: 0px auto;
	padding: 20px;
	color: #fff;
	background: #777;
	font-weight: bold;
	font-size: 20px;
	text-align: center;
	border-radius: 5px;
	cursor: pointer;
}
#regist-modal-window .regist-btn-box button:hover{
	background: rgb(88, 88, 88);
}
#regist-modal-window .regist-btn-box .regist-btn-ok{
	background: #FF6969;
	width: 500px;
    margin: 0px auto;
    padding: 20px;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    border-radius: 5px;
    cursor: pointer;
}
#regist-modal-window .regist-btn-box .regist-btn-ok:hover{
	background: #e25050;
}

/* 250723 */
.prtect_listmap_all-area{
    width: 70%;
    margin: 0 auto;
    line-height: 0;
}
.prtect_listmap_all-area img{
    width: 100%;
    height: auto;
}
.prtect_listmap__box{
    max-width: 1000px;
    border: 5px solid #53c3f1;
    border-radius: 20px;
    background-color: #e4f7ff;
    padding: 7px;
    box-sizing: border-box;
    width: 90%;
    margin: 20px auto;
    position: relative;
    z-index: 1;
}
.prtect_listmap__box .prtect_listmap{
    margin: 0;
}
.prtect_listmap__box .prtect_listmap_label{
    color: #2db0e6;
    font-size: 28px;
    font-weight: 700;
    margin: 20px 10px 22px 20px;
    padding: 10px 20px 20px 10px;
    box-sizing: border-box;
    line-height: 1;
    position: absolute;
    left: 0;
    top: 0;
    border-bottom: 3px solid #53c3f1;
    overflow: hidden;
    height: 80px;
}

.prtect_listmap__box .prtect_listmap_area{
    border: 2px solid #53c3f1;
    padding: 10px;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 10px;
    margin: 0;
    width: 130px;
    cursor: pointer;
    position: absolute;
    text-align: center;
    box-shadow: 0 5px 0px #53c3f1;
}

.prtect_listmap__box .prtect_listmap_area.hover{
    opacity: .5;
    background: rgb(220,243,252);
    background: linear-gradient(0deg, rgba(220,243,252,1) 33%, rgba(255,255,255,1) 68%);
}
.prtect_listmap__box .prtect_listmap_area.area_tohoku{
    right: 20px;
    top: 85px;
}
.prtect_listmap__box .prtect_listmap_area.area_kanto{
    bottom: 35px;
    right: 30px;
}
.prtect_listmap__box .prtect_listmap_area.area_tokai{
    right: 275px;
    top: 55px;
}

.prtect_listmap__box .prtect_listmap_area.area_kansai{
    left: 335px;
    top: 130px;
}
.prtect_listmap__box .prtect_listmap_area.area_chugoku{
    left: 180px;
    bottom: 160px;
}
.prtect_listmap__box .prtect_listmap_area.area_kyushu{
    left: 35px;
    bottom: 70px;
}
.prtect_listmap__box .prtect_listmap_area .prtect_listmap_area_lbl{
    color: #2db0e6;
    font-size: 19px;
    font-weight: 700;
    line-height: 1;
    margin: 5px 0 10px;
    text-align: center;
    letter-spacing: -1px;
    display: block;
}
.prtect_listmap__box .prtect_listmap_area .prtect_listmap_area_txt{
    line-height: 1;
    text-align: left;
    width: 90%;
    margin: 0 auto;
    color: #555;
    display: block;
    letter-spacing: -1.5px;
}
.prtect_listmap__box .prtect_listmap_area .prtect_listmap_area_txt span{
    font-size: 13px;
    line-height: 1;
    margin: 3px 0;
    display: inline-block;
    vertical-align: top;
    color: #777;
}
.prtect_listmap__box .prtect_listmap_area .prtect_listmap_area_txt span::after{
    content: "";
    padding: 0 7px 0 0;
}
/* 団体一覧用モーダル */
.prtect_listmodal{
    display: none;
}
.prtect_listmodal-box{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    z-index: 101;
    width: 720px;
    height: 80%;
    max-height: 1000px;
    margin: auto;
    padding: 15px 20px;
    background-color: #fff;
    border-radius: 5px;
    box-sizing: border-box;
    overflow: auto;
    display: none;
}
.prtect_listmodal-ray{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background-color:rgba(222, 244, 252, 0.85);
    z-index: 100;
    border-radius: 13px;
}
.prtect_listmodal-box{
    border: 3px solid #53c3f1;
    border-radius: 15px;
    background-color: rgba(241 251 255 / 71%);
    box-sizing: border-box;
}
.prtect_listmodal-box .prtect_listmodal-prev{
    font-size: 14px;
    font-weight: 700;
    margin: 0;
    cursor: pointer;
    display: inline-block;
    color: #777;
}
.prtect_listmodal-box .prtect_listmodal-prev::before{
    content: "\f0d9";
    font-family: FontAwesome;
    margin-right: 10px;
}
.prtect_listmodal-box .prtect_listmodal-prev:hover{
    color: #2db0e6;
}
.prtect_listmodal-box .prtect_listmodal_map_area_lbl{
    color: #777;
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
    border-bottom: 5px solid #b8b8b8;
    padding: 0 0 10px;
    margin: 0 0 20px;
    text-align: center;
    position: relative;
}
.prtect_listmodal-box .prtect_listmodal_map_area_lbl::before{
    content: "";
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100px;
    height: 5px;
    background-color: #53c3f1;
}
.prtect_listmodal-box .prtect_listmodal_map_area_lbl .area_lbl_big{
    color: #1aade9;
    font-size: 25px;
    margin-right: 7px;
}

.prtect_listmodal_map_area{
    color: #26b6f1;
    width: 95%;
    position: relative;
    margin: 20px auto;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link{
    width: calc(20% - 8px);
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link.prf_area{
    width: 100%;
}
.prtect_listmodal_map_area .map_area__bgmap{
    position: relative;
    background-color: #dcf3fc;
    display: none;
}
.prtect_listmodal_map_area .map_area__bgmap img{
    margin: 0 auto;
    display: block;
    mix-blend-mode: multiply;
}
.prtect_listmodal_map_area .map_area__bgmap.tohoku{
    width: 100%;
    height: 600px;
}
.prtect_listmodal_map_area .map_area__bgmap.tohoku img{
    height: 600px;
}
.prtect_listmodal_map_area .map_area__bgmap img{
    width: 100%;
    max-width: 500px;
    height: auto;
    display: block;
    margin: 0 auto;
    object-fit: contain;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link a{
    color: #797979;
    text-decoration: none;
    padding: 15px;
    display: block;
    margin: 3px;
    border: 1px solid #ccc;
    background-color: #eee;
    border-radius: 10px;
    /* width: 100px; */
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    box-shadow: 2px 2px 0 #53c3f147;
    position: relative;
}

.prtect_listmodal_map_area .prtext_listmodal_map_area_link a span{
    position: relative;
    z-index: 1;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link a::after{
    content: "";
    position: absolute;
    z-index: 0;
    left: 0;
    right: 0;
    top: 0;
    left: 0;
    right: 0;
    bottom: 5px;
    background-color: #fff;
    border-radius: 10px;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link.prf_area a{
    color: #fff;
    background-color: #53c3f1;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link.prf_area a::after{
    background-color: #1aade9;
}

.prtect_listmodal_map_area .prtext_listmodal_map_area_link a:hover::after{
    background-color: #f7f7f7;
}
.prtect_listmodal_map_area .prtext_listmodal_map_area_link.prf_area a:hover::after{
    background-color: #2aaadd;
}

.map_area__bgmap {
    width: 600px;
    height: 500px;
    margin: 0 auto;
    background-color: #fff;
}

/* 未ログイン用（ログインボタン） */
#user_loginbtn{
    width: 600px;
    margin: 30px auto;
    text-align: center;
}
#user_loginbtn .gray_btn{
    padding: 20px;
    font-weight: 700;
    margin: 5px 0;
}


/* その他幅、余白設定 */
.w10p{ width: 10%; }
.w20p{ width: 20%; }
.w30p{ width: 30%; }
.w40p{ width: 40%; }
.w50p{ width: 50%; }
.w60p{ width: 60%; }
.w70p{ width: 70%; }
.w80p{ width: 80%; }
.w90p{ width: 90%; }
.w100p{ width: 100%; }

/* その他装飾 */
.red{ color: #ff0000; }
.bold{ font-weight: bold; }
.d-block{ display: block; }
.txt-big{ font-size: 16px; }
.txt-small{ font-size: 13px; }

