.jjin-review-form-card {
	padding: 60px;
	border: 1px solid var(--jjin-review-line);
	border-radius: var(--jjin-review-board-radius);
	background: var(--jjin-review-surface);
	overflow: hidden;
	box-shadow: var(--jjin-review-shadow);
}

.jjin-review-notice {
	margin-bottom: 22px;
	padding: 16px 18px;
	border-radius: 18px;
	font-size: var(--jjin-review-form-field-size);
	font-weight: 650;
	line-height: 1.5;
}

.jjin-review-notice.jjin-is-success {
	background: color-mix(in srgb, var(--jjin-review-accent, #0000ff) 8%, white);
	color: var(--jjin-review-accent, #0000ff);
}

.jjin-review-notice.jjin-is-error {
	background: var(--jjin-review-error-bg);
	color: var(--jjin-review-error-text);
}

.jjin-review-complete-toast {
	position: fixed;
	z-index: 100000;
	left: 50%;
	bottom: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 20px;
	border-radius: 999px;
	background: #111;
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.16);
	color: #fff;
	font-family: inherit;
	font-size: var(--jjin-review-button-font-size);
	font-weight: 750;
	line-height: 1;
	opacity: 0;
	pointer-events: none;
	transform: translate(-50%, 12px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.jjin-review-complete-toast.jjin-is-visible {
	opacity: 1;
	transform: translate(-50%, 0);
}

.jjin-review-submit-form {
	display: grid;
	gap: 20px;
}

.jjin-review-form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
	align-items: start;
}

.jjin-review-submit-form label {
	display: grid;
	grid-template-columns: 1fr;
	gap: 11px !important;
	align-items: start;
	color: var(--jjin-review-text-soft);
	font-size: var(--jjin-review-form-label-size);
	font-weight: 650;
	line-height: 1.25;
	margin: 0;
}

.jjin-review-submit-form label > span {
	display: block;
	margin: 0;
	line-height: 1.25;
}

.jjin-review-submit-form > label,
.jjin-review-submit-form .jjin-review-form-grid > label {
	min-width: 0;
}

.jjin-review-submit-form > p,
.jjin-review-submit-form > div:not(.jjin-review-form-grid) {
	margin-top: 0;
	margin-bottom: 0;
}

.jjin-review-submit-form > p:has(select),
.jjin-review-submit-form > div:not(.jjin-review-form-grid):has(select),
.jjin-review-submit-form > div:not(.jjin-review-form-grid):has(input),
.jjin-review-submit-form > div:not(.jjin-review-form-grid):has(textarea) {
	display: grid;
	grid-template-columns: 1fr;
	gap: 11px;
	align-items: start;
}

.jjin-review-submit-form input,
.jjin-review-submit-form select,
.jjin-review-submit-form textarea {
	box-sizing: border-box !important;
	width: 100%;
	min-height: 50px;
	padding: 0 16px;
	border: 1px solid var(--jjin-review-line) !important;
	border-radius: calc(var(--jjin-review-control-radius) + 2px) !important;
	background: var(--jjin-review-surface) !important;
	color: var(--jjin-review-text) !important;
	font-family: inherit !important;
	font-size: var(--jjin-review-form-field-size) !important;
	line-height: 1.2 !important;
	outline: none !important;
	box-shadow: none !important;
	appearance: none;
	-webkit-appearance: none;
}

.jjin-review-submit-form select {
	margin-top: 0 !important;
}

.jjin-review-submit-form input,
.jjin-review-submit-form select {
	height: 50px !important;
}

.jjin-review-submit-form input:focus,
.jjin-review-submit-form select:focus,
.jjin-review-submit-form textarea:focus {
	border-color: color-mix(in srgb, var(--jjin-review-accent, #0000ff) 45%, var(--jjin-review-line)) !important;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--jjin-review-accent, #0000ff) 12%, transparent) !important;
	outline: none !important;
}

.jjin-review-submit-form input[readonly] {
	background: var(--jjin-review-surface-soft) !important;
	color: var(--jjin-review-muted) !important;
	cursor: default;
}

.jjin-review-locked-subject {
	display: flex;
	align-items: center;
	box-sizing: border-box;
	height: 50px;
	min-height: 50px;
	padding: 0 16px;
	border: 1px solid color-mix(in srgb, var(--jjin-review-accent, #0000ff) 18%, transparent);
	border-radius: 16px;
	background: color-mix(in srgb, var(--jjin-review-accent, #0000ff) 7%, white);
	color: var(--jjin-review-accent, #0000ff);
	font-size: var(--jjin-review-form-field-size);
	font-weight: 720;
}

.jjin-review-submit-form textarea {
	min-height: 120px;
	padding: 15px 16px;
	line-height: 1.6;
	resize: vertical;
}

.jjin-review-file-field input[type="file"] {
	height: auto !important;
	min-height: auto;
	padding: 13px 16px;
	cursor: pointer;
}

.jjin-review-field-help,
.jjin-review-file-field em {
	color: var(--jjin-review-subtle);
	font-size: var(--jjin-review-form-help-size);
	font-style: normal;
	font-weight: 480;
	line-height: 1.5;
}

.jjin-review-submit-btn {
	height: 56px;
	border: 0 !important;
	border-radius: calc(var(--jjin-review-control-radius) + 4px);
	background: var(--jjin-review-accent, #111) !important;
	color: var(--jjin-review-inverse-text) !important;
	font-family: inherit;
	font-size: var(--jjin-review-button-font-size);
	font-weight: 700;
	cursor: pointer;
}

.jjin-review-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
}


.jjin-review-submit-btn,
.jjin-review-submit-btn:hover,
.jjin-review-submit-btn:focus-visible,
.jjin-review-submit-btn:active {
	color: var(--jjin-review-inverse-text) !important;
	text-decoration: none !important;
	opacity: 1 !important;
}

.jjin-review-submit-btn {
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.jjin-review-submit-btn:hover,
.jjin-review-submit-btn:focus-visible {
	background: color-mix(in srgb, var(--jjin-review-accent, #111) 86%, black) !important;
	box-shadow: 0 16px 30px color-mix(in srgb, var(--jjin-review-accent, #111) 20%, transparent);
	transform: translateY(-1px);
}

.jjin-review-file-field input[type="file"] {
	padding: 10px 14px;
	border-radius: calc(var(--jjin-review-control-radius) + 4px);
	background: var(--jjin-review-surface);
}

.jjin-review-file-field input[type="file"]::file-selector-button {
	height: 36px;
	margin-right: 12px;
	padding: 0 14px;
	border: 0;
	border-radius: 12px;
	background: var(--jjin-review-surface-soft);
	color: var(--jjin-review-text-soft);
	font-family: inherit;
	font-size: var(--jjin-review-control-font-size);
	font-weight: 650;
	cursor: pointer;
}

.jjin-review-file-field input[type="file"]::-webkit-file-upload-button {
	height: 36px;
	margin-right: 12px;
	padding: 0 14px;
	border: 0;
	border-radius: 12px;
	background: var(--jjin-review-surface-soft);
	color: var(--jjin-review-text-soft);
	font-family: inherit;
	font-size: var(--jjin-review-control-font-size);
	font-weight: 650;
	cursor: pointer;
}


/* === JJIN v1.0.9: submit button hover movement only, no color change === */

/* 후기 제출하기 버튼: hover 시 색상 변화 없이 살짝만 움직임 */
.jjin-review-submit-btn,
.jjin-review-submit-btn:hover,
.jjin-review-submit-btn:focus-visible,
.jjin-review-submit-btn:active {
	background: var(--jjin-review-accent, #111) !important;
	color: var(--jjin-review-inverse-text) !important;
	border: 0 !important;
	box-shadow: none !important;
	opacity: 1 !important;
	text-decoration: none !important;
}

.jjin-review-submit-btn:hover,
.jjin-review-submit-btn:focus-visible {
	transform: translateY(-1px) !important;
}
