﻿@charset "UTF-8";
body:has(.page-reform-area){
	& .whole {
		width: 100%;
		margin-left: auto;
		margin-right: auto;
		padding: 3.2rem 0 0;
	}

	& .area-h2-wapper{
		margin: 0 auto 2.4rem;
		& .area-step-list{
			display: flex;
			gap: 0 4rem;
			align-items: center;
			justify-content: center;
			& > li{
				position: relative;
				&:not(:last-child){
					&::after{
						content:'';
						background-color: #52B4E9;
						width: 0.75rem;
						height: 0.9rem;
						clip-path: polygon(0 0,100% 50%,0 100%);
						display: block;
						position: absolute;
						top: 50%;
						transform: translateY(-50%);
						right: calc(-1 * (47.5 / 375 * 100vw) / 2);
					}
				}
				& .area-step-wrapper{
					display: flex;
					align-items: center;
					gap: 0 0.8rem;
					& .area-step{
						width: 4rem;
						height: 4rem;
						border-radius: 50%;
						background-color: #52B4E9;
						color: #fff;
						display: flex;
						flex-direction: column;
						align-items: center;
						justify-content: center;
						font-size: calc(1rem * var(--rf-rem-multiply) * 0.6875);
						font-weight: var(--rf-font-weight-800);
						& .area-step-num{
							font-size: calc(1rem * var(--rf-rem-multiply) * 1.125);
							font-weight: var(--rf-font-weight-800);
							margin-top: -0.2rem;
							line-height: 1;
							font-family: var(--rf-font-family-round);
						}
					}
				}
				& .area-title{
					font-size: calc(1rem * var(--rf-rem-multiply) * 0.9375);
					font-weight: var(--rf-font-weight-500);
				}
			}
		}
	}
	& .area-area-wapper{
		display: flex;
		flex-direction: column;
		gap: 4rem 0;
		margin: 0 auto 6rem;
		& #zip-area,
		& #categories-area,
		& [id*="panel-x"]{
			box-shadow: 0px 0px 5px 0px #00000026;
			border-radius: 10px;
			& .area-header {
				min-height: 5.2rem;
				background-color: #53b4e9;
				color: #fff;
				font-size: calc(1rem * var(--rf-rem-multiply) * 1.125);
				font-weight: var(--rf-font-weight-600);
				padding: 0.6rem 1.8rem;
				display: flex;
				align-items: center;
				border-top-left-radius: 10px;
				border-top-right-radius: 10px;
				gap: 0 0.8rem;
				& .area-step{
					width: 4rem;
					height: 4rem;
					border-radius: 50%;
					background-color: #fff;
					color: #52B4E9;
					display: flex;
					flex-direction: column;
					align-items: center;
					justify-content: center;
					font-size: calc(1rem * var(--rf-rem-multiply) * 0.6875);
					font-weight: var(--rf-font-weight-800);
					& .area-step-num{
						font-size: calc(1rem * var(--rf-rem-multiply) * 1.125);
						font-weight: var(--rf-font-weight-800);
						margin-top: -0.2rem;
						line-height: 1;
						font-family: var(--rf-font-family-round);
					}
				}
				& .area-title{
					font-size: calc(1rem * var(--rf-rem-multiply) * 1.125);
					font-weight: var(--rf-font-weight-500);
				}
			}
			& .area-body {
				padding: 1.8rem 2rem;
				font-size: calc(1rem * var(--rf-rem-multiply) * 0.875);
				font-weight: var(--rf-font-weight-400);
				& .area-radio-list{
					display: flex;
					flex-wrap: wrap;
					align-items: stretch;
					gap: 1.2rem 1.5rem;
					& >li{
						width: calc((100% - 1.5rem) / 2);
					}
					& label{
						padding: 0.6rem 0;
						width: 100%;
						display: flex;
						align-items: flex-start;
						gap: 0 0.8rem;
					}
					& [type="radio"]{
						margin: 0;
						position: relative;
						flex-shrink: 0;
					}
				}
			}
		}
		& .usrtmpl-areabody1 {
			padding-bottom: 1.6rem;
			font-size: calc(1rem * var(--rf-rem-multiply) * 0.625);
			font-weight: var(--rf-font-weight-300);
			line-height: calc(16 / 10);
		}
		& .area-footer {
			border-bottom-left-radius: 10px;
			border-bottom-right-radius: 10px;
		}
	}
	& #zip-area,
	& #panels-area,
	& #search-possible,
	& #search-impossible,
	& #search-error,
	& #search-impossible-buyable {
		display: none;
	}

	& #categories-area label {
		display: inline-block;
		width: 100px;
	}

	& .search-by-zip-caption {
		border-bottom: #D7D7D7 solid 1px;
		font-size: calc(1rem * var(--rf-rem-multiply) * 1);
		font-weight: var(--rf-font-weight-600);
		padding-bottom: 1.2rem;
		margin-bottom: 1.2rem;
	}
	& .search-by-zip-explain {
		font-size: calc(1rem * var(--rf-rem-multiply) * 0.875);
		font-weight: var(--rf-font-weight-400);
		margin-bottom: 1.2rem;
	}
	& .search-by-zip-wrapper{
		display: flex;
		gap: 0 0;
		align-items: center;
		font-size: calc(1rem * var(--rf-rem-multiply) * 1);
		font-weight: var(--rf-font-weight-400);
		& >*{
			&:nth-child(1){
				margin-right: calc(14 / 375 * 100vw);
			}
			&:nth-child(2){
				margin-right: calc(8 / 375 * 100vw);
				width: calc(58 / 375 * 100vw);
			}
			&:nth-child(3){
				margin-right: calc(8 / 375 * 100vw);
			}
			&:nth-child(4){
				margin-right: calc(23 / 375 * 100vw);
				width: calc(70 / 375 * 100vw);
			}
		}
		&[name="zip1"]{
			width: calc(60 / 375 * 100vw);
		}
		&[name="zip2"]{
			width: calc(80 / 375 * 100vw);
		}
		& #search-by-zip{
			border-radius: 5px!important;
			font-size: calc(1rem * var(--rf-rem-multiply) * 1);
			padding: 0.7rem 2.3rem;
			width: calc(80 / 375 * 100vw);
		}
	}
	& #search-possible,
	& #search-impossible,
	& #search-impossible-buyable{
		& .rf-text{
			font-size: calc(1rem * var(--rf-rem-multiply) * 0.875);
			font-weight: var(--rf-font-weight-600);
			line-height: calc(26 / 14);
			margin: 1.6rem 0 0;
		}
		&#search-possible{
			& .rf-text{
				color: #165BB2;
			}
		}
		&#search-impossible,
		&#search-impossible-buyable{
			& .rf-text{
				color: #FF0000;
			}
		}
		& .search-contact-btn{
			margin: 3.2rem auto 0;
			display: flex;
			justify-content: center;
			& a{
				text-align: center;
				display: flex;
				flex-direction: column;
				padding: 0.6rem 4rem;
				min-height: 5rem;
				align-items: center;
				justify-content: center;
				background-color: #165BB2;
				color: white;
				min-width: 100%;
				border-radius: 40px;
				position: relative;
				font-size: calc(1rem * var(--rf-rem-multiply) * 1);
				font-weight: var(--rf-font-weight-600);
				line-height: calc(24 / 16);
				&::after{
					content:'';
					background-image: url(../../img/usr/reform/common/arrow-white-right@2x.png);
					background-repeat: no-repeat;
					background-size: contain;
					width: 1.2rem;
					height: 2rem;
					display: block;
					position: absolute;
					right: 2rem;
					top: 50%;
					transform: translateY(-50%);
				}
			}
		}
	}

	& #search-error {
		color: #165BB2;
		font-weight: bold;
	}
	& #search-error {
		color: red;
	}
	& #panels-area{
		& .panel-area-head{
			font-size: calc(1rem * var(--rf-rem-multiply) * 0.9375);
			font-weight: var(--rf-font-weight-500);
			text-align: center;
			margin: 0 auto 1rem;
		}
		& div[id^="panel-"] {
			border-radius: 10px;
			box-shadow: 0px 0px 5px 0px #00000026;
			& .area-header {
				min-height: 5.2rem;
                background-color: #53b4e9;
                color: #fff;
                font-size: 1.8rem;
                font-weight: var(--rf-font-weight-600);
                padding: 0.6rem 1.8rem;
                display: flex;
                align-items: center;
                border-top-left-radius: 10px;
                border-top-right-radius: 10px;
                gap: 0 0.8rem;
			}
			& .area-body {
				padding: 2.4rem 2.0rem 3.0rem;
				& .usrtmpl-areabody1 {
				}
			}
		}
		& .area-pref-list{
			display: flex;
			flex-direction: column;
			& > li{
				border-bottom: 1px solid #D7D7D7;
				&:first-child{
					border-top: 1px solid #D7D7D7;
				}
				& dl {
					display: flex;
					width: 100%;
					flex-direction: column;
					&:last-child{
						margin-bottom: 1.6rem;
					}
					&:has(+ dl){
						& dt{
							&::before{
								content:'';
								position: absolute;
								width: 100%;
								height: 1px;
								display: block;
								background-color: #fff;
								bottom: -2px;
								left: 0;
								z-index: 1;
							}
						}
					}
					& :where(dt,dd){
						width: 100%;
						border: 1px solid #BFCACF;
					}
					& dt {
						background-color: #BFCACF;
						color: #fff;
						font-size: calc(1rem * var(--rf-rem-multiply) * 0.9375);
						font-weight: var(--rf-font-weight-600);
						padding: 0.5rem 1rem 0.2rem;
						position: relative;
					}
					& dd {
						padding: 1rem 1rem 0.9rem;
						font-size: calc(1rem * var(--rf-rem-multiply) * 0.75);
						font-weight: var(--rf-font-weight-300);
						line-height: calc(24 / 12);
						display: none;
					}
				}
			}
			& .js-area-acc-toggle {
				font-size: calc(1rem * var(--rf-rem-multiply) * 1);
				font-weight: var(--rf-font-weight-600);
				padding: 1.6rem 0;
				position: relative;
				display: flex;
				align-items: center;
				&:hover,
				&:link{
					text-decoration: none;
				}
				&::after{
					content:'';
					background-image: url(../../img/usr/reform/common/plus-gray.png);
					background-repeat: no-repeat;
					background-size: contain;
					width: 1.1rem;
					height: 1.1rem;
					display: block;
					position: absolute;
					top: 50%;
					transform: translateY(-50%);
					right: 0;
				}
				&[aria-expanded="true"]{
					&::after{
						background-image: url(../../img/usr/reform/common/minus-gray.png);
					}
				}
			}
			& .js-area-acc-target {
				display: none;
				& dt{
					&::after{
						content:'';
						background-image: url(../../img/usr/reform/common/plus-white.png);
						background-repeat: no-repeat;
						background-size: contain;
						width: 1.1rem;
						height: 1.1rem;
						display: block;
						position: absolute;
						top: 50%;
						transform: translateY(-50%);
						right: calc(10 / 375 * 100vw);
					}
					&[aria-expanded="true"]{
						&::after{
							background-image: url(../../img/usr/reform/common/minus-white.png);
						}
					}
				}
			}
		}
	}
	& #search-possible,
	& .area-category-btn-wrapper{
		&#search-possible{
			& .category-btn {
				margin: 1.6rem auto 0;
			}
		}
		& .category-btn {
			display: flex;
			justify-content: center;
			& a{
				text-align: center;
				display: flex;
				flex-direction: column;
				padding: 0.6rem 4rem;
				min-height: 5rem;
				align-items: center;
				justify-content: center;
				background-color: #165BB2;
				color: white;
				min-width: 100%;
				border-radius: 40px;
				position: relative;
				font-size: calc(1rem * var(--rf-rem-multiply) * 1);
				font-weight: var(--rf-font-weight-600);
				line-height: calc(24 / 16);
				&::after{
					content:'';
					background-image: url(../../img/usr/reform/common/arrow-white-right@2x.png);
					background-repeat: no-repeat;
					background-size: contain;
					width: 1.2rem;
					height: 2rem;
					display: block;
					position: absolute;
					right: 2rem;
					top: 50%;
					transform: translateY(-50%);
				}
			}
		}
	}
}