/* ChangeFluent Job Verifier — frontend styles
 * Scoped to .cfjv- prefix. Inherits typography from the host theme.
 * Override any variable in your theme's CSS to retheme.
 */

.cfjv-app {
	--cfjv-bg:           #ffffff;
	--cfjv-fg:           #0f172a;
	--cfjv-muted:        #475569;
	--cfjv-border:       #e2e8f0;
	--cfjv-border-strong:#cbd5e1;
	--cfjv-surface:      #f8fafc;
	--cfjv-accent:       #0f766e;
	--cfjv-accent-fg:    #ffffff;
	--cfjv-radius:       10px;
	--cfjv-radius-sm:    6px;
	--cfjv-shadow:       0 1px 2px rgba(15,23,42,.04), 0 4px 12px rgba(15,23,42,.06);

	--cfjv-green:        #15803d;
	--cfjv-green-bg:     #dcfce7;
	--cfjv-amber:        #b45309;
	--cfjv-amber-bg:     #fef3c7;
	--cfjv-red:          #b91c1c;
	--cfjv-red-bg:       #fee2e2;
	--cfjv-grey:         #475569;
	--cfjv-grey-bg:      #e2e8f0;

	color: var(--cfjv-fg);
	font-size: 1rem;
	line-height: 1.55;
	max-width: 720px;
	margin: 0 auto;
}

.cfjv-form {
	background: var(--cfjv-bg);
	border: 1px solid var(--cfjv-border);
	border-radius: var(--cfjv-radius);
	box-shadow: var(--cfjv-shadow);
	padding: 1.5rem;
}

.cfjv-form__heading {
	margin: 0 0 .25rem;
	font-size: 1.5rem;
	line-height: 1.2;
}

.cfjv-form__label {
	display: block;
	font-weight: 600;
	margin: 1rem 0 .5rem;
	font-size: .95rem;
}

.cfjv-form__textarea {
	width: 100%;
	min-height: 240px;
	font: inherit;
	font-size: .95rem;
	line-height: 1.5;
	padding: .75rem .9rem;
	border: 1px solid var(--cfjv-border-strong);
	border-radius: var(--cfjv-radius-sm);
	background: var(--cfjv-surface);
	color: var(--cfjv-fg);
	resize: vertical;
	box-sizing: border-box;
}

.cfjv-form__textarea:focus {
	outline: 2px solid var(--cfjv-accent);
	outline-offset: 1px;
	background: var(--cfjv-bg);
}

.cfjv-form__meta {
	display: flex;
	justify-content: flex-end;
	margin-top: .35rem;
	font-size: .825rem;
	color: var(--cfjv-muted);
}

.cfjv-form__counter.is-warn { color: var(--cfjv-amber); }
.cfjv-form__counter.is-over { color: var(--cfjv-red); font-weight: 600; }

.cfjv-honeypot {
	position: absolute;
	left: -10000px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.cfjv-form__actions {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: .75rem;
	margin-top: 1rem;
}

.cfjv-form__notice {
	margin: 0;
	color: var(--cfjv-muted);
	font-size: .825rem;
}

.cfjv-button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	padding: .7rem 1.25rem;
	background: var(--cfjv-accent);
	color: var(--cfjv-accent-fg);
	border: 0;
	border-radius: var(--cfjv-radius-sm);
	font: inherit;
	font-weight: 600;
	cursor: pointer;
	transition: filter .15s ease, transform .05s ease;
}
.cfjv-button:hover:not(:disabled)   { filter: brightness(1.06); }
.cfjv-button:active:not(:disabled)  { transform: translateY(1px); }
.cfjv-button:disabled               { opacity: .65; cursor: progress; }

.cfjv-button__spinner {
	display: none;
	width: 1em;
	height: 1em;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	animation: cfjv-spin .7s linear infinite;
}
.cfjv-button.is-loading .cfjv-button__spinner { display: inline-block; }
@keyframes cfjv-spin { to { transform: rotate(360deg); } }

/* RESULT */

.cfjv-result {
	margin-top: 1.25rem;
	background: var(--cfjv-bg);
	border: 1px solid var(--cfjv-border);
	border-radius: var(--cfjv-radius);
	box-shadow: var(--cfjv-shadow);
	overflow: hidden;
}

.cfjv-result__header {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.25rem;
	align-items: center;
	padding: 1.5rem;
	border-bottom: 1px solid var(--cfjv-border);
}

.cfjv-gauge {
	--size: 96px;
	width: var(--size);
	height: var(--size);
	border-radius: 50%;
	display: grid;
	place-items: center;
	background:
		conic-gradient(var(--cfjv-gauge-color, var(--cfjv-grey)) calc(var(--cfjv-gauge-pct, 0) * 1%), var(--cfjv-grey-bg) 0);
	position: relative;
}
.cfjv-gauge::after {
	content: "";
	position: absolute;
	inset: 8px;
	background: var(--cfjv-bg);
	border-radius: 50%;
}
.cfjv-gauge__num {
	position: relative;
	font-size: 1.55rem;
	font-weight: 700;
	color: var(--cfjv-fg);
	line-height: 1;
}
.cfjv-gauge__label {
	position: relative;
	font-size: .65rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--cfjv-muted);
	margin-top: 2px;
}

.cfjv-verdict__category {
	display: inline-block;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase;
	padding: .25rem .55rem;
	border-radius: 999px;
	background: var(--cfjv-cat-bg, var(--cfjv-grey-bg));
	color: var(--cfjv-cat-fg, var(--cfjv-grey));
}

.cfjv-verdict__summary {
	margin: .5rem 0 0;
	font-size: 1.05rem;
	line-height: 1.45;
}

.cfjv-verdict__confidence {
	margin: .35rem 0 0;
	font-size: .825rem;
	color: var(--cfjv-muted);
}

.cfjv-section {
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--cfjv-border);
}
.cfjv-section:last-child { border-bottom: 0; }

.cfjv-section__title {
	font-size: .75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--cfjv-muted);
	margin: 0 0 .75rem;
}

.cfjv-flags {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: .65rem;
}
.cfjv-flag {
	border: 1px solid var(--cfjv-border);
	border-left: 4px solid var(--cfjv-flag-color, var(--cfjv-grey));
	border-radius: var(--cfjv-radius-sm);
	padding: .75rem .9rem;
	background: var(--cfjv-flag-bg, var(--cfjv-surface));
}
.cfjv-flag--high   { --cfjv-flag-color: var(--cfjv-red);    --cfjv-flag-bg: #fdebec; }
.cfjv-flag--medium { --cfjv-flag-color: var(--cfjv-amber);  --cfjv-flag-bg: #fdf4e2; }
.cfjv-flag--low    { --cfjv-flag-color: #a16207;            --cfjv-flag-bg: #fdf9e2; }
.cfjv-flag--green  { --cfjv-flag-color: var(--cfjv-green);  --cfjv-flag-bg: #e8f6ec; }

@media (prefers-color-scheme: dark) {
	.cfjv-app:not(.cfjv-app--force-light) .cfjv-flag--high   { --cfjv-flag-bg: #3b1414; }
	.cfjv-app:not(.cfjv-app--force-light) .cfjv-flag--medium { --cfjv-flag-bg: #3a2710; }
	.cfjv-app:not(.cfjv-app--force-light) .cfjv-flag--low    { --cfjv-flag-bg: #2c2410; }
	.cfjv-app:not(.cfjv-app--force-light) .cfjv-flag--green  { --cfjv-flag-bg: #11321b; }
}

.cfjv-flag__head {
	display: flex;
	align-items: center;
	gap: .5rem;
	flex-wrap: wrap;
}
.cfjv-flag__label {
	font-weight: 600;
}
.cfjv-flag__sev {
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	padding: .12rem .4rem;
	border-radius: 999px;
	background: var(--cfjv-grey-bg);
	color: var(--cfjv-grey);
}
.cfjv-flag--high   .cfjv-flag__sev { background: var(--cfjv-red-bg);   color: var(--cfjv-red); }
.cfjv-flag--medium .cfjv-flag__sev { background: var(--cfjv-amber-bg); color: var(--cfjv-amber); }
.cfjv-flag--low    .cfjv-flag__sev { background: var(--cfjv-grey-bg);  color: var(--cfjv-grey); }

.cfjv-flag__quote {
	margin: .5rem 0 .35rem;
	padding: .4rem .65rem;
	background: rgba(255, 255, 255, 0.55);
	border-left: 2px solid var(--cfjv-flag-color, var(--cfjv-border-strong));
	font-style: italic;
	color: var(--cfjv-fg);
	font-size: .9rem;
}

@media (prefers-color-scheme: dark) {
	.cfjv-app:not(.cfjv-app--force-light) .cfjv-flag__quote {
		background: rgba(0, 0, 0, 0.25);
	}
}

.cfjv-flag__explain {
	margin: .35rem 0 0;
	font-size: .92rem;
	line-height: 1.45;
}

.cfjv-extracted {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: .5rem .9rem;
	margin: 0;
	padding: 0;
}
.cfjv-extracted dt {
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--cfjv-muted);
}
.cfjv-extracted dd {
	margin: 0 0 .25rem;
	font-size: .92rem;
	overflow-wrap: anywhere;
}

.cfjv-relationship {
	display: inline-block;
	margin: 0 0 .85rem;
	padding: .35rem .7rem;
	font-size: .85rem;
	font-weight: 500;
	border-radius: 999px;
	background: var(--cfjv-grey-bg);
	color: var(--cfjv-fg);
}
.cfjv-relationship--note {
	background: var(--cfjv-amber-bg);
	color: var(--cfjv-amber);
	font-weight: 600;
}

.cfjv-checks {
	margin: 0;
	padding: 0 0 0 1.1rem;
}
.cfjv-checks li { margin: .25rem 0; }

.cfjv-error {
	margin-top: 1rem;
	padding: .85rem 1rem;
	border: 1px solid var(--cfjv-red-bg);
	background: #fff5f5;
	color: var(--cfjv-red);
	border-radius: var(--cfjv-radius-sm);
	font-size: .92rem;
}

@media (prefers-color-scheme: dark) {
	.cfjv-app:not(.cfjv-app--force-light) {
		--cfjv-bg:           #0f172a;
		--cfjv-fg:           #e2e8f0;
		--cfjv-muted:        #94a3b8;
		--cfjv-border:       #1e293b;
		--cfjv-border-strong:#334155;
		--cfjv-surface:      #1e293b;
		--cfjv-grey-bg:      #334155;
		--cfjv-green-bg:     #14532d;
		--cfjv-amber-bg:     #78350f;
		--cfjv-red-bg:       #7f1d1d;
	}
}
