/* =============================================================================
   RomCon Inscrições — Form Styles
   Premium design com gradiente roxo-rosa, glassmorphism e micro-animações.
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@600;700&display=swap');

/* ─── Custom Properties ─────────────────────────────────────────────────────── */
.romcon-wrap {
	--rc-primary:       #20395f;
	--rc-primary-light: #a855f7;
	--rc-accent:        #be185d;
	--rc-accent-light:  #ec4899;
	--rc-success:       #059669;
	--rc-error:         #dc2626;
	--rc-warning:       #d97706;
	--rc-bg:            #FFECEA;
	--rc-surface:       #ffffff;
	--rc-border:        #e5e0f0;
	--rc-border-focus:  #7c3aed;
	--rc-text:          #1a1028;
	--rc-text-muted:    #6b6080;
	--rc-text-light:    #9588b0;
	--rc-radius:        12px;
	--rc-radius-sm:     8px;
	--rc-shadow:        0 4px 24px rgba(201, 45, 66, 0.08);
	--rc-shadow-lg:     0 8px 40px rgba(124,58,237,0.15);
	--rc-transition:    0.2s cubic-bezier(0.4, 0, 0.2, 1);

	font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	color: var(--rc-text);
	background: var(--rc-bg);
	max-width: 860px;
	margin: 0 auto;
	padding: 0 16px 60px;
}

/* ─── Cabeçalho do Formulário ────────────────────────────────────────────────── */
.romcon-form-header {
	text-align: center;
	padding: 60px 20px 40px;
	position: relative;
}

.romcon-form-header::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(124,58,237,0.06) 0%, rgba(190,24,93,0.06) 100%);
	border-radius: 0 0 40px 40px;
	z-index: -1;
}

.romcon-form-header__eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--rc-primary);
	background: rgba(124,58,237,0.1);
	padding: 4px 14px;
	border-radius: 999px;
	margin-bottom: 16px;
}

.romcon-form-header__title {
	font-family: Montserrat, sans-serif;
	font-size: clamp(2.5rem, 5vw, 3.5rem);
	font-weight: 700;
	margin: 0 0 12px;
	/* background: linear-gradient(135deg, var(--rc-primary) 0%, var(--rc-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent; */
	/* background-clip: text; */
	line-height: 1.2;
	color: var(--rc-primary);
}

.romcon-form-header__subtitle {
	font-size: 16px;
	color: var(--rc-primary);
	max-width: 720px;
	margin: 0 auto;
	line-height: 1.6;
}

/* ─── Banner de Sucesso ─────────────────────────────────────────────────────── */
.romcon-success-banner {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
	border: 1.5px solid #6ee7b7;
	border-radius: var(--rc-radius);
	padding: 24px 28px;
	margin-bottom: 32px;
	animation: romcon-slide-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.romcon-success-banner[hidden] { display: none; }

.romcon-success-banner__icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	background: var(--rc-success);
	color: white;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 700;
}

.romcon-success-banner strong {
	display: block;
	color: #065f46;
	font-size: 17px;
	margin-bottom: 4px;
}

.romcon-success-banner p {
	margin: 0;
	color: #047857;
	font-size: 14px;
}

/* ─── Fieldsets ─────────────────────────────────────────────────────────────── */
.romcon-fieldset {
	background: var(--rc-surface);
	border: 1.5px solid var(--rc-border);
	border-radius: var(--rc-radius);
	padding: 32px;
	margin-bottom: 24px;
	box-shadow: var(--rc-shadow);
	transition: box-shadow var(--rc-transition);
}

.romcon-fieldset:focus-within {
	box-shadow: var(--rc-shadow-lg);
}

.romcon-fieldset__legend {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 17px;
	font-weight: 700;
	color: var(--rc-text);
	padding: 0 8px;
	margin-bottom: 4px;
	float: none;
	width: 100%;
}

.romcon-fieldset__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: linear-gradient(135deg, var(--rc-primary), var(--rc-accent));
	color: white;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 700;
	flex-shrink: 0;
}

.romcon-fieldset--declarations {
	background: linear-gradient(135deg, rgba(124,58,237,0.03) 0%, rgba(190,24,93,0.03) 100%);
	border-color: rgba(124,58,237,0.2);
}

/* ─── Grid ───────────────────────────────────────────────────────────────────── */
.romcon-grid {
	display: grid;
	gap: 20px;
	margin-top: 24px;
}

.romcon-grid--2 { grid-template-columns: repeat(2, 1fr); }
.romcon-grid--3 { grid-template-columns: repeat(3, 1fr); }
.romcon-grid--full { grid-column: 1 / -1; }
.romcon-grid--span2 { grid-column: span 2; }

@media (max-width: 640px) {
	.romcon-grid--2,
	.romcon-grid--3 { grid-template-columns: 1fr; }
	.romcon-grid--span2 { grid-column: span 1; }
}

/* ─── Campos ────────────────────────────────────────────────────────────────── */
.romcon-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.romcon-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--rc-text);
}

.romcon-label--sub {
	font-size: 13px;
	font-weight: 500;
	color: var(--rc-text-muted);
	margin-top: 8px;
}

.romcon-required {
	color: var(--rc-error);
	margin-left: 2px;
}

.romcon-optional {
	font-size: 12px;
	font-weight: 400;
	color: var(--rc-text-light);
}

/* ─── Inputs ────────────────────────────────────────────────────────────────── */
.romcon-input,
.romcon-select,
.romcon-textarea {
	width: 100%;
	padding: 12px 16px;
	font-size: 15px;
	font-family: 'Inter', sans-serif;
	color: var(--rc-text);
	background: var(--rc-bg);
	border: 1.5px solid var(--rc-border);
	border-radius: var(--rc-radius-sm);
	outline: none;
	transition: border-color var(--rc-transition), box-shadow var(--rc-transition), background var(--rc-transition);
	box-sizing: border-box;
}

.romcon-input:hover,
.romcon-select:hover,
.romcon-textarea:hover {
	border-color: var(--rc-primary-light);
}

.romcon-input:focus,
.romcon-select:focus,
.romcon-textarea:focus {
	border-color: var(--rc-border-focus);
	box-shadow: 0 0 0 3px rgba(124,58,237,0.15);
	background: #fff;
}

.romcon-input.romcon-has-error,
.romcon-select.romcon-has-error,
.romcon-textarea.romcon-has-error {
	border-color: var(--rc-error);
	box-shadow: 0 0 0 3px rgba(220,38,38,0.12);
}

.romcon-input.romcon-is-valid,
.romcon-select.romcon-is-valid,
.romcon-textarea.romcon-is-valid {
	border-color: var(--rc-success);
}

.romcon-select {
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6080' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 40px;
	cursor: pointer;
}

.romcon-textarea {
	resize: vertical;
	min-height: 140px;
	line-height: 1.6;
}

/* ─── Campo Condicional ──────────────────────────────────────────────────────── */
.romcon-conditional {
	overflow: hidden;
	animation: romcon-expand 0.25s ease;
}

.romcon-conditional[hidden] { display: none; }

/* ─── CEP com loading ────────────────────────────────────────────────────────── */
.romcon-input-icon-wrap {
	position: relative;
}

.romcon-input-icon-wrap .romcon-input {
	padding-right: 44px;
}

.romcon-cep-loading {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
}

.romcon-cep-loading[hidden] { display: none; }

/* ─── Contador de caracteres ─────────────────────────────────────────────────── */
.romcon-textarea-wrap {
	position: relative;
}

.romcon-char-counter {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 12px;
	color: var(--rc-text-muted);
	padding: 6px 12px;
	background: var(--rc-bg);
	border: 1.5px solid var(--rc-border);
	border-top: none;
	border-radius: 0 0 var(--rc-radius-sm) var(--rc-radius-sm);
	transition: color var(--rc-transition), background var(--rc-transition);
}

.romcon-char-counter.romcon-counter--ok { color: var(--rc-success); background: #f0fdf4; }
.romcon-char-counter.romcon-counter--low { color: var(--rc-warning); background: #fffbeb; }
.romcon-char-counter.romcon-counter--over { color: var(--rc-error); background: #fef2f2; }

.romcon-char-min-note {
	color: var(--rc-text-light);
	margin-left: 4px;
}

.romcon-textarea-wrap .romcon-textarea {
	border-radius: var(--rc-radius-sm) var(--rc-radius-sm) 0 0;
	margin-bottom: 0;
}

/* ─── Dropzone ───────────────────────────────────────────────────────────────── */
.romcon-dropzone {
	position: relative;
	border: 2px dashed var(--rc-border);
	border-radius: var(--rc-radius);
	padding: 40px 24px;
	text-align: center;
	cursor: pointer;
	transition: border-color var(--rc-transition), background var(--rc-transition), transform var(--rc-transition);
	background: var(--rc-bg);
}

.romcon-dropzone:hover,
.romcon-dropzone.romcon-drag-over {
	border-color: var(--rc-primary);
	background: rgba(124,58,237,0.04);
}

.romcon-dropzone.romcon-drag-over {
	transform: scale(1.01);
	box-shadow: var(--rc-shadow-lg);
}

.romcon-dropzone.romcon-has-error {
	border-color: var(--rc-error);
}

.romcon-dropzone__icon {
	font-size: 40px;
	margin-bottom: 12px;
	display: block;
}

.romcon-dropzone__text {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	font-size: 15px;
	color: var(--rc-text-muted);
}

.romcon-dropzone__text strong {
	color: var(--rc-text);
}

.romcon-dropzone__btn {
	display: inline-block;
	background: var(--rc-primary);
	color: white;
	padding: 10px 20px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: opacity var(--rc-transition), transform var(--rc-transition);
	margin-top: 8px;
}

.romcon-dropzone__btn:hover {
	opacity: 0.9;
	transform: translateY(-1px);
}

.romcon-dropzone__hint {
	font-size: 12px;
	color: var(--rc-text-light);
	margin-top: 10px;
}

.romcon-file-input {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
	width: 100%;
	height: 100%;
	z-index: 1;
}

/* ─── File Preview ───────────────────────────────────────────────────────────── */
.romcon-file-preview {
	display: flex;
	align-items: center;
	gap: 10px;
	background: rgba(124,58,237,0.06);
	border: 1.5px solid rgba(124,58,237,0.2);
	border-radius: var(--rc-radius-sm);
	padding: 12px 16px;
	margin-top: 10px;
	animation: romcon-slide-in 0.3s ease;
}

.romcon-file-preview[hidden] { display: none; }

.romcon-file-preview__icon { font-size: 20px; }

.romcon-file-preview__name {
	flex: 1;
	font-size: 14px;
	font-weight: 600;
	color: var(--rc-primary);
	word-break: break-all;
}

.romcon-file-preview__size {
	font-size: 12px;
	color: var(--rc-text-muted);
	white-space: nowrap;
}

.romcon-file-preview__remove {
	background: none;
	border: none;
	color: var(--rc-error);
	cursor: pointer;
	font-size: 16px;
	padding: 4px 6px;
	border-radius: 4px;
	transition: background var(--rc-transition);
	line-height: 1;
}

.romcon-file-preview__remove:hover {
	background: rgba(220,38,38,0.1);
}

/* ─── Progress Bar ───────────────────────────────────────────────────────────── */
.romcon-progress-wrap {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 8px;
}

.romcon-progress-wrap[hidden] { display: none; }

.romcon-progress-bar {
	flex: 1;
	height: 8px;
	background: var(--rc-border);
	border-radius: 999px;
	overflow: hidden;
}

.romcon-progress-fill {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, var(--rc-primary), var(--rc-accent));
	border-radius: 999px;
	transition: width 0.3s ease;
}

.romcon-progress-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--rc-primary);
	min-width: 38px;
	text-align: right;
}

/* ─── Checkboxes ─────────────────────────────────────────────────────────────── */
.romcon-field--checkbox {
	padding: 20px;
	background: rgba(255,255,255,0.6);
	border-radius: var(--rc-radius-sm);
	border: 1.5px solid var(--rc-border);
	margin-bottom: 12px;
	transition: border-color var(--rc-transition), background var(--rc-transition);
}

.romcon-field--checkbox:last-of-type {
	margin-bottom: 0;
}

.romcon-field--checkbox:has(.romcon-checkbox:checked) {
	border-color: rgba(124,58,237,0.3);
	background: rgba(124,58,237,0.03);
}

.romcon-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	cursor: pointer;
}

.romcon-checkbox {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.romcon-checkbox-custom {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border: 2px solid var(--rc-border);
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: border-color var(--rc-transition), background var(--rc-transition), transform var(--rc-transition);
	background: var(--rc-surface);
	margin-top: 1px;
}

.romcon-checkbox:checked + .romcon-checkbox-custom {
	background: linear-gradient(135deg, var(--rc-primary), var(--rc-accent));
	border-color: transparent;
	transform: scale(1.05);
}

.romcon-checkbox:checked + .romcon-checkbox-custom::after {
	content: '✓';
	color: white;
	font-size: 13px;
	font-weight: 700;
}

.romcon-checkbox:focus-visible + .romcon-checkbox-custom {
	box-shadow: 0 0 0 3px rgba(124,58,237,0.3);
}

.romcon-checkbox-text {
	font-size: 14px;
	color: var(--rc-text-muted);
	line-height: 1.6;
}

.romcon-link {
	color: var(--rc-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ─── Mensagens de erro ──────────────────────────────────────────────────────── */
.romcon-error {
	font-size: 13px;
	color: var(--rc-error);
	font-weight: 500;
	min-height: 18px;
	display: block;
	animation: romcon-slide-in 0.2s ease;
}

.romcon-error:empty { display: none; }

/* ─── Botão de envio ─────────────────────────────────────────────────────────── */
.romcon-submit-wrap {
	text-align: center;
	padding: 8px 0 0;
}

.romcon-submit-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background: var(--rc-primary);
	color: white;
	font-family: 'Inter', sans-serif;
	font-size: 18px;
	font-weight: 700;
	padding: 16px 48px;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: opacity var(--rc-transition), transform var(--rc-transition), box-shadow var(--rc-transition);
	box-shadow: 0 4px 20px rgba(124,58,237,0.35);
	letter-spacing: 0.3px;
	min-width: 240px;
}

.romcon-submit-btn:hover:not(:disabled) {
	opacity: 0.92;
	transform: translateY(-2px);
	box-shadow: 0 8px 28px rgba(124,58,237,0.45);
}

.romcon-submit-btn:active:not(:disabled) {
	transform: translateY(0);
}

.romcon-submit-btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.romcon-submit-btn__loading[hidden] { display: none; }

.romcon-submit-hint {
	font-size: 13px;
	color: var(--rc-text-light);
	margin-top: 12px;
}

/* ─── Spinner ────────────────────────────────────────────────────────────────── */
.romcon-spinner {
	display: inline-block;
	width: 16px;
	height: 16px;
	border: 2.5px solid rgba(124,58,237,0.25);
	border-top-color: var(--rc-primary);
	border-radius: 50%;
	animation: romcon-spin 0.7s linear infinite;
}

.romcon-spinner--white {
	border-color: rgba(255,255,255,0.35);
	border-top-color: white;
}

/* ─── Animações ──────────────────────────────────────────────────────────────── */
@keyframes romcon-spin {
	to { transform: rotate(360deg); }
}

@keyframes romcon-slide-in {
	from { opacity: 0; transform: translateY(-6px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes romcon-expand {
	from { max-height: 0; opacity: 0; }
	to   { max-height: 200px; opacity: 1; }
}

/* ─── Responsivo ─────────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
	.romcon-fieldset {
		padding: 24px 18px;
	}

	.romcon-form-header {
		padding: 40px 16px 28px;
	}

	.romcon-submit-btn {
		width: 100%;
		padding: 16px 32px;
	}
}
