/* ============================================================================================
	WALL PAINTING INQUIRY FORM / BLOCK
============================================================================================ */
.kasai-wall-painting-form {
    max-width: 900px !important;
    margin: 50px auto !important;
}
.kasai-form-row {
	margin: 0 0 1em
}
.kasai-form-row label {
	display: block;
	margin: 0 0 .5em;
	font-size: 13px
}
.kasai-form-row input,
.kasai-form-row textarea {
	display: block;
	width: 100%;
	padding: .8em;
	border-radius: 2px;
	border: 1px solid var(--wp--preset--color--translucent-b);
	background: rgb(250,250,250);
	font-size: 16px;
	line-height: 1.5    
}
.kasai-form-row textarea {
	min-height: 160px;
	resize: vertical
}
.kasai-form-row input:focus,
.kasai-form-row textarea:focus {
	outline: none;
	border-color: currentColor;
	background: var(--wp--preset--color--white)
}
.kasai-checkbox-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1em 2em
}
.kasai-checkbox-group input {
	display: none
}
.kasai-checkbox-group label {
	display: flex;
	align-items: center;
	position: relative;
	margin: 0;
	font-size: 16px;
	cursor: pointer
}
.kasai-checkbox-group label::before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 30px;
	border-radius: 2px;
	border: 1px solid var(--wp--preset--color--translucent-b);
	background: var(--wp--preset--color--white);
	margin-right: .5em
}
.kasai-checkbox-group label::after {
	opacity: 0;
	content: "";
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 11px;
	width: 8px;
	height: 18px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-right: .5em;
	transition: opacity .3s
}
.kasai-form-note {
	font-size: 12px;
	color: rgb(102,102,102);
	margin-top: .5em
}
.required {
	color: rgb(255,0,0);
	margin-left: .2em
}
.kasai-checkbox-group input:checked + label::after {
	opacity: 1
}

/* submit button */
.kasai-form-row-submit {
	text-align: center
}
.kasai-form-row-submit .submit-button {
	display: inline-block;
	min-width: 240px;
	margin: 30px auto;
	padding: 1em 2em;
	border-radius: 2px;
	border: 0;
	background: rgb(56, 119, 1);
	color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: var(--wp--preset--font-size--small);
	cursor: pointer;
	transition: box-shadow .3s ease-in-out, background .3s ease-in-out
}
.kasai-form-row-submit .submit-button[disabled] {
	opacity: .4;
	background-color: rgb(180,180,180);
	cursor: not-allowed
}
.kasai-form-row-submit .submit-button:not(:disabled):hover {
	box-shadow: 0 0 10px rgba(0,0,0,.3)
}

/* note below form */
.kasai-inquiry-form-note-wrapper {
	margin: 2em 0;
	padding: 1em;
	border-left: 5px solid rgb(211,205,181);
	background: var(--wp--preset--color--cream);
}
.kasai-inquiry-form-note {
	margin: 0 !important;
	font-size: var(--wp--preset--font-size--x-small);
	color: var(--wp--preset--color--sub-text)
}
.change-info-link {
	display: inline-block;
	margin: 0 .3em;
    padding: .3em 1em;
    border-radius: 100px;
    background: rgba(0, 0, 0, .1);
    color: currentColor;
    text-decoration: none
}

.editor-styles-wrapper .wp-block-kasai-wall-painting-form {
	max-width: 600px;
	margin: 2em auto;
	padding: 2em;
	background: rgb(240,240,240);
	font-size: 13px;
	text-align: center
}


/* ============================================================================================
	COMPLETE MESSAGE OVERLAY
============================================================================================ */
.kasai-inquiry-overlay {
	display: flex;
	align-items: center;
	justify-content: center;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1000;
	background: rgba(0,0,0,.7)
}
.kasai-inquiry-message {
	background: var(--wp--preset--color--white);
	padding: 2rem;
	border-radius: 8px;
	text-align: center;
	max-width: 90%;
	width: 600px
}
.kasai-inquiry-close {
	margin-top: 1.5rem;
	padding: 0.5rem 2rem;
	background: rgb(20,20,20);
	color: var(--wp--preset--color--white);
	border: none;
	border-radius: 4px;
	cursor: pointer
}

/* 電話番号バリデーション用のスタイル */
.validation-message {
    font-size: 0.85em;
    margin-top: 5px;
    min-height: 1.2em;
}

.validation-message.error {
    color: #e74c3c;
}

.validation-message.success {
    color: #2ecc71;
}

/* ユーザーが操作した後のみ無効スタイルを適用 */
input.touched:invalid {
    border-color: #e74c3c;
}

.form-hint {
    font-size: 0.85em;
    color: #666;
    margin-top: 3px;
    display: block;
}
