/*
----------------------------------------

form

----------------------------------------
*/

/* input
---------------------------------------- */

.editor-styles-wrapper input[type=checkbox],
.editor-styles-wrapper  input[type=radio] {
	margin-top: 0 !important;
}

.efo-form input[type=text],
.efo-form input[type=email],
.efo-form input[type=tel],
.efo-form input[type=url],
.efo-form input[type=number],
.efo-form input[type=search],
.efo-form input[type=password],
.efo-form input[type=date] {
	display: block;
	width: 100%;
	font-size: 16px;
	line-height: 1.5;
	padding: var(--wp--preset--spacing--30) !important;
	border-radius: 0 !important;
	border: solid 1px var(--wp--preset--color--gray) !important;
}

.efo-form input[name=date],
.efo-form input[name=zip],
.efo-form input[name=calendar] {
	width: inherit;
}

/* select
---------------------------------------- */

.efo-form select {
	font-size: var(--wp--preset--font-size--16-px);
	line-height: 1.5;
	padding: var(--wp--preset--spacing--30);
	padding-right: 3em;
	border-radius: 0;
	border: solid 1px var(--wp--preset--color--gray);
	position: relative;
}

.efo-form div:has( > select ) {
	position: relative;
}

.efo-form div:has( > select )::after {
	font-family: 'Material Symbols Outlined';
	content: '\e5cf';
	display: block;
	text-align: center;
	line-height: 20px;
	color: var(--wp--preset--color--primary);
	position: absolute;
	right: 15px;
	top: calc( 50% - 10px );
	transition: all .2s;
}

/* datepicker
---------------------------------------- */

.efo-form .datepicker {
	font-size: var(--wp--preset--font-size--16-px);
	line-height: 1.5;
	padding: var(--wp--preset--spacing--30);
	padding-right: 3em;
	border-radius: 0;
	border: solid 1px var(--wp--preset--color--gray);
	position: relative;
}

.efo-form div:has( > .datepicker ) {
	display: inline-block;
	position: relative;
}

.efo-form div:has( > .datepicker )::after {
	font-family: 'Material Symbols Outlined';
	content: '\e935';
	display: block;
	text-align: center;
	line-height: 20px;
	color: var(--wp--preset--color--primary);
	position: absolute;
	right: 15px;
	top: calc( 50% - 10px );
	transition: all .2s;
}

/* radio / checkbox
---------------------------------------- */

.efo-form input[type=radio],
.efo-form input[type=checkbox] {
	position: absolute !important;
	left: -10rem;
	pointer-events: none;
}

.efo-form label:has( input[type=radio] ),
.efo-form label:has( input[type=checkbox] ) {
	display: inline-block;
	font-size: var(--wp--preset--font-size--16-px);
	line-height: 1.5;
	padding: 0 1em 0 2em;
	margin: var(--wp--preset--spacing--30) 0;
	position: relative;
	overflow: hidden;
}

.efo-form label:has( input[type=radio] )::before,
.efo-form label:has( input[type=checkbox] )::before {
	content: '';
	width: 20px;
	height: 20px;
	border: solid 2px var(--wp--preset--color--gray);
	background: var(--wp--preset--color--base);
	position: absolute;
	top: calc( 50% - 10px );
	left: 0;
}

.efo-form label:has( input[type=radio] )::before {
	border-radius: 50%;
}

.efo-form label:has( input[type=checkbox] )::before {
	border-radius: 4px;
}

.efo-form label:has( input[type=radio] )::after {
	content: '';
	width: 10px;
	height: 10px;
	background: var(--wp--preset--color--primary);
	border-radius: 50%;
	position: absolute;
	top: calc( 50% - 5px );
	left: 5px;
	opacity: 0;
	visibility: hidden;
	transition: all .2s;
}

.efo-form label:has( input[type=radio]:checked )::after {
	opacity: 1;
	visibility: visible;
}

.efo-form label:has( input[type=checkbox] )::after {
	content: '';
	width: 8px;
	height: 16px;
	border-right: solid 3px var(--wp--preset--color--primary);
	border-bottom: solid 3px var(--wp--preset--color--primary);
	transform: rotate( 45deg );
	position: absolute;
	top: calc( 50% - 12px );
	left: 8px;
	opacity: 0;
	visibility: hidden;
	transition: all .2s;
}

/* textarea
---------------------------------------- */

.efo-form textarea {
	display: block;
	width: 100%;
	font-size: var(--wp--preset--font-size--16-px);
	padding: var(--wp--preset--spacing--30);
	border-radius: 0;
	border: solid 1px var(--wp--preset--color--gray);
}

.efo-form label:has( input[type=checkbox]:checked )::after {
	opacity: 1;
	visibility: visible;
}

/* submit
---------------------------------------- */

.efo-form input[type=submit],
.efo-form button[type=submit] {
	font-size: var(--wp--preset--font-size--20-px);
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	padding: 15px 50px;
	display: inline-block;
	min-width: 240px;
	text-align: center;
	line-height: 1.5;
	border: none;
	border-radius: 30px;
	position: relative;
	transition: all .4s;
}

.efo-form input[type=submit]::after,
.efo-form button[type=submit]::after {
	font-family: 'Material Symbols Outlined';
	content: '\e5cc';
	line-height: 20px;
	position: absolute;
	top: calc( 50% - 10px );
	right: 10px;
	transition: all .4s;
}

.efo-form .smf-button-control {
	display: inline-block;
	cursor: pointer;
}

.efo-form input[type=submit].disabled,
.efo-form button[type=submit].disabled {
	background: var(--wp--preset--color--dark-gray);
	pointer-events: none;
}

.efo-form input[type=submit].disabled::after,
.efo-form button[type=submit].disabled::after {
	display: none;
}

.ui-widget-header {
	background: var(--wp--preset--color--light-gray);
	color: var( --wp--preset--color--contrast );
	font-weight: normal;
}

.ui-widget-header .ui-icon {
	background: none;
	text-indent: 0;
	color: transparent;
}

@media ( min-width: 751px ) {

	.efo-form input[type=submit]:not(.disabled):hover,
	.efo-form button[type=submit]:not(.disabled):hover {
		transform: scale( 1.05 );
		box-shadow: 0 4px 10px rgba( 0, 0, 0, .2 );
	}

	.efo-form input[type=submit]:not(.disabled):hover::after,
	.efo-form button[type=submit]:not(.disabled):hover::after {
		right: 6px;
	}

}


/*
----------------------------------------

date-picker

----------------------------------------
*/

.ui-widget.ui-widget-content {
	border-color: var(--wp--preset--color--gray);
	border-radius: 0;
}

.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
	background: transparent !important;
	border: none !important;
	top: 0 !important;
	transition: all .2s;
}

.ui-datepicker .ui-datepicker-prev span::before,
.ui-datepicker .ui-datepicker-next span::before {
	font-family: 'Material Symbols Outlined';
	color: var( --wp--preset--color--primary );
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transition: all .2s;
}

.ui-datepicker .ui-datepicker-prev span::before {
	content: '\e5cb';
}

.ui-datepicker .ui-datepicker-next span::before {
	content: '\e5cc';
}

.ui-corner-all,
.ui-corner-top,
.ui-corner-right,
.ui-corner-tr {
	border-radius: 0;
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button,
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
	border-color: var(--wp--preset--color--gray);
	background: var(--wp--preset--color--light-gray);
	color: var( --wp--preset--color--contrast );
}

.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
	border-color: var( --wp--preset--color--primary );
	background: var( --wp--preset--color--primary );
	color: var( --wp--preset--color--base );
}

@media ( min-width: 751px ) {

	.ui-datepicker .ui-datepicker-prev:hover {
		left: 0 !important;
	}

	.ui-datepicker .ui-datepicker-next:hover {
		right: 0 !important;
	}

}


/*
----------------------------------------

efo-form

----------------------------------------
*/

.form-step {
	margin-bottom: var(--wp--preset--spacing--30);
}

.form-step .step {
	position: relative;
}


/* form-step-01
---------------------------------------- */

.form-step-01 .step {
	flex: 1;
}

.form-step-01 .step + .step::before {
	font-family: 'Material Symbols Outlined';
	content: '\e5cc';
	line-height: 20px;
	position: absolute;
	top: calc( 50% - 10px );
	left: calc( var(--wp--preset--spacing--50) / 2 * -1 - 8px );
	transition: all .2s;
}

.form-step-01 .step:first-child {
	background: var( --wp--preset--color--primary );
}

.form-step-01 .step:first-child * {
	color: var( --wp--preset--color--base );
}

form[data-screen=confirm] .form-step-01 .step:first-child {
	background: transparent;
}

form[data-screen=confirm] .form-step-01 .step:first-child * {
	color: var( --wp--preset--color--primary );
}

form[data-screen=confirm] .form-step-01 .step:nth-child( 2 ) {
	background: var( --wp--preset--color--primary );
}

form[data-screen=confirm] .form-step-01 .step:nth-child( 2 ) * {
	color: var( --wp--preset--color--base );
}

form[data-screen=confirm] .smf-item::after {
	display: none;
}


/* form-step-02
---------------------------------------- */

.form-step-02 {
	width: 800px;
	max-width: 100%;
	margin-right: auto;
	margin-bottom: var(--wp--preset--spacing--30);
	margin-left: auto;
	position: relative;
}

.form-step-02::before {
	content: '';
	position: absolute;
	top: 15px;
	right: 30px;
	left: 30px;
	border-bottom: dotted 2px var(--wp--preset--color--gray);	
}

.form-step-02 .step {
	padding-top: 40px;
	line-height: 1.5;
}

.form-step-02 .step:first-child {
	border-color: var( --wp--preset--color--primary );
}

.form-step-02 .step::before {
	content: '';
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: solid 8px var(--wp--preset--color--gray);
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: calc( 50% - 16px );
	background: var( --wp--preset--color--base );
}

.form-step-02 .step:first-child::before {
	border-color: var( --wp--preset--color--primary );
}

form[data-screen=confirm] .form-step-02 .step:first-child::before {
	border-color: var(--wp--preset--color--gray);
}

form[data-screen=confirm] .form-step-02 .step:nth-child( 2 )::before {
	border-color: var( --wp--preset--color--primary );
}

/* remaining
---------------------------------------- */

.editor-styles-wrapper .remaining {
	position: relative !important;
	right: 0 !important;
	bottom: 0 !important;
	opacity: 1 !important;
	visibility: visible !important;
	z-index: 1 !important;
}

.wp-block-group:has( > .remaining ) {
	position: fixed;
	right: 20px;
	bottom: 40px;
	display: inline-block;
	background: var( --wp--preset--color--base );
	border: solid 1px var( --wp--preset--color--primary );
	text-align: center;
	margin: 0 !important;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transition: all .2s;
}

.wp-block-group:has( > .remaining.active ) {
	opacity: 1;
	visibility: visible;
	z-index: 999;
}

.remaining .read {
	padding: 15px 20px;
	line-height: 1.8;
}

.remaining .num {
	width: 100%;
	background: var( --wp--preset--color--primary );
	color: var( --wp--preset--color--base );
	padding: 5px 20px;
}

/* err
---------------------------------------- */

.err {
	font-size: var(--wp--preset--font-size--14-px);
	color: var( --wp--preset--color--primary );
	margin-top: 5px;
}

/*
----------------------------------------

snow-monkey-forms

----------------------------------------
*/

.smf-form .smf-item .smf-file-control {
	justify-content: flex-start;
}

.smf-form .smf-item .smf-file-control__clear {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	border-bottom: solid 1px transparent;
	line-height: 1.5;
	transition: all .2s;
}

.p-country-name {
	display: none;
}

.smf-error-messages {
	font-size: var(--wp--preset--font-size--14-px);
	color: var(--wp--preset--color--primary);
}

.smf-item__controls:has( input[type=radio]) .smf-error-messages,
.smf-item__controls:has( input[type=checkbox]) .smf-error-messages {
	margin-top: -10px;
}

.smf-select-control__toggle {
	display: none !important;
}

.smf-form .smf-item .smf-file-control {
	padding: var(--wp--preset--spacing--20) 0;
}

.smf-form .smf-item .smf-file-control > label > .smf-file-control__label {
	background: var(--wp--preset--color--light-gray);
	border: solid 1px var(--wp--preset--color--gray);
	border-radius: 25px;
	line-height: 1.5;
	padding: var(--wp--preset--spacing--20) 20px;
	transition: all .2s;
}

.smf-item {
	display: flex;
	align-items: flex-start;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--50) var(--wp--preset--spacing--30) 0;
	position: relative;
}

.smf-item::after {
	font-family: 'Material Symbols Outlined';
	content: '\e876';
	font-size: var(--wp--preset--font-size--24-px);
	color: var(--wp--preset--color--primary);
	line-height: 20px;
	position: absolute;
	top: calc( var(--wp--preset--spacing--30) + var(--wp--preset--spacing--30) );
	right: 0;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transition: all .2x;
}

.smf-item.ok::after {
	opacity: 1;
	visibility: visible;
	z-index: 1;
}

.smf-item.agree {
	padding: var(--wp--preset--spacing--20) 0 var(--wp--preset--spacing--30);
}

.smf-item.agree::after {
	display: none;
}

.smf-item__col--label {
	width: 16em;
	font-size: var(--wp--preset--font-size--16-px);
	line-height: 1.5;
	padding: var(--wp--preset--spacing--30) 0;
	padding-right: 5em;
	position: relative;
}

.smf-item.req-label .smf-item__col--label::after,
.smf-item:has( .req ) .smf-item__col--label::after {
	content: '必須';
	display: inline-block;
	font-size: var(--wp--preset--font-size--14-px);
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	padding: .2em .8em;
	position: absolute;
	top: 50%;
	right: var(--wp--preset--spacing--30);
	transform: translateY( -50% );
}

.smf-item__col--label +.smf-item__col--controls {
	width: calc( 100% - 16em );
}

.smf-radio-buttons-control__control,
.smf-checkboxes-control__control {
	line-height: .5;
}

.smf-placeholder + .smf-placeholder {
	margin-top: var(--wp--preset--spacing--30);
}

form.snow-monkey-form:not( [data-screen=confirm] ) .agree {
	justify-content: center;
	align-items: center;
}

form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--label {
	display: none;
}

form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--controls {
	width: auto;
	padding-right: 0;
	padding-left: 4.5em;
	position: relative;
}

form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--controls::before {
	content: '必須';
	display: inline-block;
	font-size: var(--wp--preset--font-size--14-px);
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	padding: .2em .8em;
	position: absolute;
	top:1.1em;
	left: 0;
}

form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--controls a {
	display: inline-block;
	border-bottom: solid 1px var(--wp--preset--color--primary);
}

.privacy-policy p,
.privacy-policy ul {
	margin-block-start: 1em;
}

.smf-action {
	text-align: center;
}


/* confirm
---------------------------------------- */

body:has( form.snow-monkey-form[data-screen=confirm] ) .remaining {
	display: none !important;
}

form.snow-monkey-form[data-screen=confirm] .privacy-policy {
	display: none;
	order: 1;
}

form.snow-monkey-form[data-screen=confirm] .smf-item__col--label {
	padding: 0 var(--wp--preset--spacing--50);
}

form.snow-monkey-form[data-screen=confirm] .smf-item__col--controls {
	font-size: var(--wp--preset--font-size--16-px);
	line-height: 1.5;
	padding: 0;
}

form.snow-monkey-form[data-screen=confirm] .smf-item:nth-child( even ) {
	background: var(--wp--preset--color--light-gray);
}

form.snow-monkey-form[data-screen=confirm] .smf-item.agree {
	background: transparent;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--50) var(--wp--preset--spacing--30) 0;
	background: var(--wp--preset--color--light-gray);
}

form.snow-monkey-form[data-screen=confirm] .smf-item.req-label .smf-item__col--label::after,
form.snow-monkey-form[data-screen=confirm] .smf-item:has( .req ) .smf-item__col--label::after {
	display: none;
}


form.snow-monkey-form[data-screen=confirm] div[data-name=address-01],
form.snow-monkey-form[data-screen=confirm] div[data-name=address-02],
form.snow-monkey-form[data-screen=confirm] div[data-name=address-03] {
	display: inline-block;
	margin: 0;
}

form.snow-monkey-form[data-screen=confirm] .date-flex {
	gap: var(--wp--preset--spacing--20);
}

form.snow-monkey-form[data-screen=confirm] .date-flex > .wp-block-group {
	gap: 0;
}

form.snow-monkey-form[data-screen=confirm] .smf-action {
	margin: var(--wp--preset--spacing--50) 0 var(--wp--preset--spacing--40);
	display: flex;
	flex-direction: column-reverse;
	gap: var(--wp--preset--spacing--20);
}

form.snow-monkey-form[data-screen=confirm] .smf-action .smf-button-control+.smf-button-control {
	margin: 0;
}

.efo-form form.snow-monkey-form[data-screen=confirm] button[data-action=back] {
	font-size: var(--wp--preset--font-size--16-px);
	background: transparent;
	color: var(--wp--preset--color--contrast);
	padding: 10px 20px;
	min-width: initial;
	text-align: center;
	line-height: 1.5;
	border-bottom: solid 2px var( --wp--preset--color--contrast );
	border-radius: 0;
	transform: none !important;
	box-shadow: none !important;
}

.efo-form form.snow-monkey-form[data-screen=confirm] button[data-action=back]::after {
	display: none;
}


/*
----------------------------------------

1000

----------------------------------------
*/

@media screen and ( max-width: 1000px ) {

	.smf-item__col--label {
		width: 14em;
	}

	.smf-item__col--label +.smf-item__col--controls {
		width: calc( 100% - 14em );
	}

}


/*
----------------------------------------

750

----------------------------------------
*/

@media ( max-width: 750px ) {

	body:has( form ) #sp-fix {
		display: none !important;
	}

	body:has( form ) .copyright {
		padding-bottom: var(--wp--preset--spacing--20) !important;
	}

	.smf-select-control {
		width: 100%;
	}

	.wp-block-group:has( > .remaining ) {
		right: 0;
		bottom: 0;
		left: 0;
	}

	.remaining .read {
		display: none;
	}

	.remaining .num {
		justify-content: center;
	}

	.efo-form select {
		width: 100%;
		padding-right: 2em;
	}

	.efo-form div:has( > select )::after {
		right: 10px;
	}

	.efo-form div:has( > input[type=date] ),
	.efo-form div:has( > .datepicker ) {
		display: block;
	}

	.efo-form input[type=date],
	.efo-form .datepicker {
		width: 100%;
	}

	.smf-item {
		flex-direction: column;
		padding: 5px 0;
	}

	.smf-item::after {
		font-size: var(--wp--preset--font-size--40-px);
		line-height: 30px;
		top: calc( var(--wp--preset--spacing--20) + 5px );
	}

	.smf-item__col--label {
		width: 100%;
		display: flex;
		align-items: center;
		gap: 10px;
		padding: var(--wp--preset--spacing--20) 30px var(--wp--preset--spacing--20) 0;
	}

	.smf-item__col--label +.smf-item__col--controls {
		width: 100%;
	}

	.smf-item__label {
		display: inline-block;
		line-height: 30px;
	}

	.smf-item.req-label .smf-item__col--label::after,
	.smf-item:has( .req ) .smf-item__col--label::after {
		position: relative;
		top: 0;
		right: auto;
		transform: none;
	}

	.annotation {
		flex-direction: column;
		gap: var(--wp--preset--spacing--30) !important;
	}

	.annotation .ttl {
		width: 100%;
	}

	#efo-form {
		padding: var(--wp--preset--spacing--30) !important;
	}

	.form-step {
		gap: var(--wp--preset--spacing--40) !important;
	}

	.form-step .step {
		flex-direction: column;
		gap: 0;
		line-height: 1.5;
	}

	.form-step .step .en {
		font-weight: bold;
		font-size: var(--wp--preset--font-size--14-px);
	}

	.form-step-01 .step + .step::before {
		left: calc( var(--wp--preset--spacing--40) / 2 * -1 - 8px );
	}

	form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--controls {
		padding: var(--wp--preset--spacing--50) 0 0;
	}

	form.snow-monkey-form:not( [data-screen=confirm] ) .agree .smf-item__col--controls::before {
		top: 0;
		left: 50%;
		transform: translateX( -50% );
	}

	form.snow-monkey-form:not( [data-screen=confirm] ) .agree label {
		padding-right: 0 !important;
	}

	.privacy-policy {
		max-height: 20rem;
		padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--30) !important;
		font-size: var(--wp--preset--font-size--14-px);
	}

	.smf-action {
		margin: 0 0 var(--wp--preset--spacing--40);
	}

	form.snow-monkey-form[data-screen=confirm] .smf-item {
		background: transparent !important;
		padding: 0 0 10px;
	}

	form.snow-monkey-form[data-screen=confirm] .smf-item__col--label {
		padding: 5px var(--wp--preset--spacing--40);
		background: var(--wp--preset--color--light-gray);
	}

	form.snow-monkey-form[data-screen=confirm] .smf-item__col--controls {
		padding: 10px var(--wp--preset--spacing--40);
	}

	.efo-form input[name=date],
	.efo-form input[name=zip],
	.efo-form input[name=calendar] {
		width: 100%;
	}

}


/*
----------------------------------------

hover

----------------------------------------
*/

@media screen and ( min-width: 780px ) {

	.smf-form .smf-item .smf-file-control__clear:hover {
		border-color: var(--wp--preset--color--primary);
	}

	.smf-form .smf-item .smf-file-control > label:hover > .smf-file-control__label {
		background: var(--wp--preset--color--primary);
		color: var(--wp--preset--color--base);
	}

	.efo-form form.snow-monkey-form[data-screen=confirm] button[data-action=back]:hover {
		background: var(--wp--preset--color--light-gray);
	}

}
