@charset "utf-8";

/* ==================================================
   近くの青色申告会を探す
-------------------------------------------------- */
.findArea {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 32px;
	margin-top: 56px;
}

.find_item {
	padding: 40px 52px;
	border-radius: 12px;
	background-color: var(--c_lightblue);
}

.find_location {
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--c_text) !important;
	font-weight: var(--fw_b);
	font-size: calc( var(--fz_main) * 1.3 );
	text-decoration: none !important;
}
.find_location:hover {
	opacity: .5;
}

.find_location span {
	display: flex;
	justify-content: center;
	align-items: center;
}
.find_location span::before,
.find_location span::after {
	content: "";
	display: inline-block;
	background: var(--bg_cc_contain);
}
.find_location span::before {
	width: 28px;
	height: 28px;
	margin-right: 16px;
	background-image: url("../images/find_icon-location.webp");
}
.find_location span::after {
	width: 9px;
	height: 16px;
	margin-left: 40px;
	background-image: url("../images/btn_arrow.webp");
}

.find_zipcode {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 8px 28px;
}

.find_zipcode_title {
	grid-column: 1 / 3;
	grid-row: 1 / 2;
	font-weight: var(--fw_b);
	font-size: calc( var(--fz_main) * 1.3 );
}
.find_zipcode_title::before {
	content: "〒";
	margin-right: 12px;
}

.find_zipcode_input {
	grid-column: 1 / 2;
	grid-row: 2 / 3;
}

.find_zipcode_input input {
	width: 100%;
	padding: 12px 24px;
	border: 0;
	border-radius: 8px;
	background-color: #fff;
}

.find_zipcode_input .notes {
	margin-top: 0;
	font-size: calc( var(--fz_main) * .8 );
}

.find_zipcode_submit {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	height: 56px;
	border: 0;
	border-radius: 28px !important;
	background-color: var(--c_yellow);
	cursor: pointer;
	transition: var(--transition);
}
.find_zipcode_submit:hover {
	background-color: var(--c_lightyellow);
}

@media only screen and (max-width: 1080px) {
	.findArea {
		column-gap: 2.963vw;
	}

	.find_item {
		padding: 3.704vw 4.815vw;
	}

	.find_zipcode {
		grid-template-columns: 1fr;
	}

	.find_zipcode_title {
		grid-column: 1 / 2;
	}

	.find_zipcode_submit {
		grid-column: 1 / 2;
		grid-row: 3 / 4;
		width: 60%;
		margin: 20px auto 0;
	}
}

@media only screen and (max-width: 720px) {
	.findArea {
		grid-template-columns: 1fr;
		row-gap: 32px;
	}

	.find_location {
		aspect-ratio: 50 / 19;
	}

	.find_zipcode_submit {
		width: 100%;
	}
}



/* ==================================================
   近くの青色申告会を探す-検索結果一覧
-------------------------------------------------- */
/* ----- 郵便番号 ----- */
.find_result_zipcodeArea .find_zipcode {
	width: 582px;
	margin: auto;
}

.find_result_zipcodeArea_note {
	margin-top: 16px;
	text-align: center;
}

@media only screen and (max-width: 767px) {
	.find_result_zipcodeArea .find_zipcode {
		width: 100%;
	}
}

@media only screen and (max-width: 500px) {
	.find_result_zipcodeArea_note {
		text-align: left;
	}

	.find_result_zipcodeArea_note .ib {
		display: inline;
	}
}


/* ----- 検索結果 ----- */
.find_resultArea {
	margin-top: 28px;
}

.find_result_count {
	text-align: center;
}

.find_result_countNum {
	padding: 0 12px;
	color: var(--c_blue);
	font-weight: var(--fw_b);
	font-size: var(--fz_lg);
}

.find_result_listArea {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	margin-top: 8px;
}

.find_result_list {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 24px 0;
	border-top: 1px solid var(--c_bdc);
	border-bottom: 1px solid var(--c_bdc);
}

.find_result_list_name {
	font-weight: var(--fw_b);
	font-size: calc(var(--fz_base) * 1.5);
	line-height: 1.5;
}

.find_result_list_access {
	margin-top: 8px;
	color: #888;
	line-height: 1.6;
}

.find_result_list_detail {
	margin-top: 20px;
}

.find_result_list_detail li {
	display: grid;
	grid-template-columns: 6em auto;
	gap: .75em;
	font-size: 1.6rem;
	line-height: 1;
}
.find_result_list_detail li:nth-of-type(n + 2) {
	margin-top: .75em;
}

.find_result_list_item {
	padding: 5px 0;
	border-right: 1px dotted var(--c_text);
}

.find_result_list_taxOffice,
.find_result_list_area {
	display: flex;
	flex-wrap: wrap;
}

.find_result_list_taxOffice span {
	padding: 3px 0;
	color: var(--c_blue);
	line-height: 1.3;
}
.find_result_list_taxOffice span:nth-of-type(n + 2)::before {
	content: "/";
	margin-right: .25em;
	margin-left: .25em;
	color: var(--c_text);
}

.find_result_list_area span {
	margin: 2px 4px 2px 0;
	padding: 2px 8px;
	border-radius: 4px;
	background-color: var(--c_blue);
	color: #fff;
	font-size: var(--fz_xs);
	line-height: 1.3;
}

.find_result_list_more {
	margin-top: 24px;
	font-size: 1.6rem;
}

.find_result_list_more a {
	width: 208px;
	height: 50px;
	margin: auto;
}

.find_result_backBtn {
	margin-top: 80px;
}

.find_result_backBtn.btn a {
	position: relative;
	margin: auto;
	border: 2px solid var(--c_yellow);
	background-color: transparent;
	background-image: url("../images/btn_arrow_back.webp");
	background-position: 16px center;
}

@media only screen and (max-width: 1080px) {
	.find_result_listArea {
		gap: 2.963vw;
	}
}

@media only screen and (max-width: 767px) {
	.find_result_listArea {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.find_result_list {
		padding: 32px 0;
	}
	.find_result_list:nth-of-type(n + 2) {
		border-top: 0;
	}

	.find_result_list_detail {
		margin-top: 20px;
	}

	.find_result_list_more {
		margin-top: 28px;
	}

	.find_result_backBtn {
		margin-top: 10.43vw;
	}
}

@media only screen and (max-width: 500px) {
	.find_result_list_name {
		font-size: var(--fz_md);
	}
}


/* ==================================================
   近くの青色申告会を探す-検索結果詳細
-------------------------------------------------- */
.find_detail {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 40px;
	align-items: flex-start;
}

.find_detail_mapArea {
	aspect-ratio: 1 / 1;
}

.find_detail_mapArea iframe {
	width: 100%;
	height: 100%;
}

.find_detail_info h4 {
	margin-bottom: 8px;
	padding: 8px 20px;
	border-radius: 6px;
	background-color: var(--c_blue);
	color: #fff;
	font-weight: var(--fw_r);
}

.find_detail_infoArea > section:nth-of-type(n + 2) {
	margin-top: 32px;
}

.find_detail_comment {
	padding: 22px 32px;
	border-radius: 6px;
	background-color: var(--c_lightblue);
}

.find_detail_comment h4 {
	display: flex;
	align-items: center;
	margin-bottom: 10px;
	border-bottom: 1px solid var(--c_text);
}
.find_detail_comment h4::before {
	content: "";
	display: block;
	width: 24px;
	height: 24px;
	margin-right: 4px;
	background-color: var(--c_text);
	-webkit-mask: url("../images/icon-comment.svg") no-repeat center center / contain;
	mask: url("../images/icon-comment.svg")no-repeat center center / contain;
}

.find_detail_website {
	width: 276px;
	height: 66px;
	margin-top: 40px;
}

.find_detail_website a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 100%;
	height: 100%;
	border: 2px solid var(--c_blue);
	border-radius: 33px;
	color: var(--c_blue) !important;
	text-decoration: none !important;
}
.find_detail_website a:hover {
	opacity: .5;
}
.find_detail_website a::after {
	content: "";
	display: block;
	position: absolute;
	right: 16px;
	top: 50%;
	width: 16px;
	height: 16px;
	background-color: var(--c_blue);
	-webkit-mask: url("../images/icon-external_link.svg") no-repeat center center / contain;
	mask: url("../images/icon-external_link.svg") no-repeat center center / contain;
	transform: translateY(-50%);
}

@media only screen and (min-width: 768px) {
	.find_detail_info a[href*="tel:"],
	.find_detail_taxOffice_info a[href*="tel:"] {
		color: var(--c_text) !important;
		text-decoration: none !important;
	}
}

@media only screen and (max-width: 1280px) {
	.find_detail {
		column-gap: 3.125vw;
	}
}

@media only screen and (max-width: 767px) {
	.find_detail {
		grid-template-columns: 1fr;
		row-gap: 32px;
	}

	.find_detail_infoArea > section:nth-of-type(n + 2) {
		margin-top: 24px;
	}

	.find_detail_mapArea {
		aspect-ratio: 100 / 61;
	}

	.find_detail_website {
		margin: 32px auto 0;
	}

	.find_detail_taxOfficeArea h4 {
		margin-top: 40px !important;
	}
}

@media only screen and (max-width: 500px) {
	.find_detail_comment {
		padding: 16px 24px;
	}
}


/* ----- 所轄税務署 ----- */
.find_detail_taxOffice_wrapper {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.find_detail_taxOffice {
	border: 1px solid var(--c_bdc);
}

.find_detail_taxOffice h5 {
	padding: 10px;
	background-color: var(--c_navy);
	color: #fff;
	font-weight: var(--fw_r);
	text-align: center;
}

.find_detail_taxOffice_info {
	padding: 16px 24px 24px;
}

.find_detail_taxOffice_info li:not(.find_detail_taxOffice_area) > * {
	margin-left: .5em;
}

.find_detail_taxOffice_area {
	display: grid;
	grid-template-columns: 4.5em auto;
	gap: .75em;
	margin-top: 12px;
	padding: 12px 16px;
	border-radius: 6px;
	background-color: var(--c_gray_bg);
	font-size: 1.6rem;
	line-height: 1;
}

.find_detail_taxOffice_area .find_result_list_item {
	font-size: var(--fz_xs);
}

@media only screen and (max-width: 1280px) {
	.find_detail_taxOffice_wrapper {
		gap: 1.875vw;
	}

	.find_detail_taxOffice_info {
		/* padding: 1.719vw 2.5vw; */
		padding: 1.25vw 1.875vw 1.875vw;
	}
}

@media only screen and (max-width: 767px) {
	.find_detail_taxOffice_wrapper {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.find_detail_taxOffice_info {
		padding: 12px 20px;
	}

	.find_detail_taxOffice_info li > span {
		display: block;
		margin-left: 0;
	}
}


/* ----- 一覧へ戻るボタン ----- */
.find_detail_backBtn {
	margin-top: 80px;
}

.find_detail_backBtn a {
	margin: auto;
	background-image: url("../images/btn_arrow_back.webp") !important;
	background-position: 16px center !important;
}

@media only screen and (max-width: 767px) {
	.find_detail_backBtn {
		margin-top: 10.43vw;
	}
}