@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+Malayalam:wght@400;600;700&display=swap');

/* Kerala Election Poll — front styles */
.kepol-wrap {
	--kepol-bg: #faf8f5;
	--kepol-card: #fff;
	--kepol-accent: #0f4c3a;
	--kepol-gold: #b8860b;
	--kepol-text: #1a1a1a;
	--kepol-muted: #5c5348;
	max-width: 42rem;
	margin: 1.5rem auto;
	padding: 0 1rem 2rem;
	font-family: "Noto Sans Malayalam", "Manjari", "Nirmala UI", sans-serif;
	color: var(--kepol-text);
	line-height: 1.65;
	background: var(--kepol-bg);
	border-radius: 4px;
	box-sizing: border-box;
}

.kepol-header,
.kepol-results-header {
	text-align: center;
	padding: 1.75rem 1rem 0.5rem;
	border-bottom: 2px solid var(--kepol-accent);
	margin-bottom: 1.5rem;
}

.kepol-brand {
	font-size: 0.8rem;
	letter-spacing: 0.06em;
	color: var(--kepol-gold);
	text-transform: uppercase;
	margin: 0 0 0.5rem;
}

.kepol-main-title {
	font-size: clamp(1.35rem, 4vw, 1.85rem);
	font-weight: 700;
	margin: 0 0 0.75rem;
	color: var(--kepol-accent);
}

.kepol-poll-subject {
	font-size: 1.1rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
	color: var(--kepol-muted);
	line-height: 1.4;
}

.kepol-poll-description {
	margin: 0 auto 0.5rem;
	max-width: 38rem;
	text-align: left;
	font-size: 0.98rem;
	color: var(--kepol-text);
}

.kepol-results-header .kepol-poll-description,
.kepol-header .kepol-poll-description {
	text-align: center;
}

.kepol-header--compact .kepol-main-title {
	font-size: 1.25rem;
}

.kepol-msg-note {
	font-weight: 600;
	margin: 1rem 0 0.5rem;
}

.kepol-msg-hint {
	font-size: 0.9rem;
	color: var(--kepol-muted);
	margin: 0;
}

.kepol-waiting-results .kepol-waiting-card {
	text-align: center;
	padding: 2rem 1.5rem;
	margin-top: 0.5rem;
}

.kepol-waiting-lead {
	font-size: 1.05rem;
	margin: 0.75rem 0;
}

.kepol-waiting-hint {
	font-size: 0.9rem;
	color: var(--kepol-muted);
	margin: 1rem 0 0;
}

.kepol-rule {
	border: none;
	border-top: 1px solid #ddd;
	margin: 1rem auto;
	max-width: 12rem;
}

.kepol-lead {
	font-size: 1.35rem;
	margin: 0.5rem 0;
}

.kepol-intro {
	color: var(--kepol-muted);
	margin: 0 0 1rem;
}

.kepol-section {
	margin-bottom: 2rem;
}

.kepol-section-title {
	font-size: 1.05rem;
	color: var(--kepol-accent);
	border-left: 4px solid var(--kepol-gold);
	padding-left: 0.65rem;
	margin: 0 0 1.25rem;
}

.kepol-fieldset {
	border: none;
	margin: 0 0 1.5rem;
	padding: 0;
}

.kepol-question {
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: 0.65rem;
	padding: 0;
	line-height: 1.45;
}

.kepol-select {
	width: 100%;
	max-width: 100%;
	padding: 0.65rem 0.75rem;
	font-size: 1rem;
	font-family: inherit;
	border: 1px solid #ccc;
	border-radius: 6px;
	background: var(--kepol-card);
}

.kepol-radio-group {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.kepol-radio-label {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
	padding: 0.4rem 0.5rem;
	border-radius: 6px;
	transition: background 0.15s;
}

.kepol-radio-label:hover {
	background: rgba(15, 76, 58, 0.06);
}

.kepol-radio-label input {
	margin-top: 0.35rem;
	flex-shrink: 0;
	accent-color: var(--kepol-accent);
}

.kepol-actions {
	margin-top: 2rem;
	text-align: center;
}

.kepol-submit {
	background: var(--kepol-accent);
	color: #fff;
	border: none;
	padding: 0.85rem 2rem;
	font-size: 1.05rem;
	font-family: inherit;
	font-weight: 600;
	border-radius: 8px;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(15, 76, 58, 0.25);
}

.kepol-submit:hover {
	filter: brightness(1.08);
}

.kepol-submit:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.kepol-form-msg {
	text-align: center;
	margin-top: 1rem;
	min-height: 1.5em;
}

.kepol-form-msg.kepol-ok {
	color: var(--kepol-accent);
	font-weight: 600;
}

.kepol-form-msg.kepol-err {
	color: #b32d2e;
}

.kepol-msg,
.kepol-closed .kepol-card {
	text-align: center;
	padding: 2rem;
	background: var(--kepol-card);
	border-radius: 8px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.kepol-results-wrap {
	max-width: 52rem;
}

.kepol-results-header {
	border-bottom-color: var(--kepol-gold);
}

.kepol-sub {
	color: var(--kepol-muted);
	margin: 0;
}

.kepol-total {
	font-size: 1.15rem;
	font-weight: 700;
	text-align: center;
	color: var(--kepol-accent);
	margin: 0 0 2rem;
}

.kepol-res-sec {
	font-size: 1.2rem;
	color: var(--kepol-accent);
	margin: 2rem 0 1rem;
	padding-bottom: 0.35rem;
	border-bottom: 1px solid #e0dcd4;
}

.kepol-chart-block {
	background: var(--kepol-card);
	padding: 1rem 1rem 1.5rem;
	margin-bottom: 1.25rem;
	border-radius: 8px;
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);
}

.kepol-chart-block h3 {
	font-size: 0.95rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
	line-height: 1.4;
}

.kepol-chart-block canvas {
	max-height: 420px;
}

.kepol-loading {
	text-align: center;
	color: var(--kepol-muted);
}

.kepol-results-root[aria-busy="true"] {
	min-height: 120px;
}
