/**
 * EARA Address Survey Tool — Styles
 * Professional surveying tool for field workers
 */

/* ── Wrapper ─────────────────────────────────────────────────────────────── */

.eara-survey {
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	max-width: 680px;
	margin: 0 auto;
	padding-bottom: 80px;
}

/* ── Header ──────────────────────────────────────────────────────────────── */

.eara-survey__header {
	background: linear-gradient(135deg, #1e3a5f 0%, #2563eb 100%);
	border-radius: 16px;
	padding: 24px 20px;
	margin-bottom: 20px;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
}

/* ── Sync queue badge ────────────────────────────────────────────────────── */

.eara-survey__sync-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: rgba(255,255,255,.15);
	border: 1px solid rgba(255,255,255,.3);
	border-radius: 20px;
	padding: 5px 12px;
	font-size: 12px;
	font-weight: 600;
	color: #fff;
	white-space: nowrap;
	backdrop-filter: blur(4px);
	transition: opacity .3s;
}
.eara-survey__sync-badge--syncing {
	background: rgba(253,224,98,.2);
	border-color: rgba(253,224,98,.5);
	color: #fde262;
}
.eara-survey__sync-badge-icon {
	font-size: 14px;
}

/* ── Offline banner (survey-specific positioning) ────────────────────────── */

#eara-survey-offline-banner {
	position: sticky;
	top: 0;
	z-index: 200;
	margin-bottom: 12px;
	border-radius: 10px;
	font-size: 13px;
}

.eara-survey__header-content {
	display: flex;
	align-items: center;
	gap: 16px;
}

.eara-survey__icon {
	font-size: 40px;
	flex-shrink: 0;
}

.eara-survey__title {
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 4px;
	color: #fff;
}

.eara-survey__subtitle {
	font-size: 13px;
	margin: 0;
	opacity: 0.85;
	color: #fff;
}

/* ── Setup card ──────────────────────────────────────────────────────────── */

.eara-survey__setup-card {
	background: #fff;
	border: 2px solid #e2e8f0;
	border-radius: 12px;
	padding: 24px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.eara-survey__setup-title {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 16px;
	color: #1a1a2e;
}

.eara-survey__step-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: #2563eb;
	color: #fff;
	border-radius: 50%;
	font-size: 13px;
	font-weight: 700;
	flex-shrink: 0;
}

.eara-survey__select-row {
	display: flex;
	gap: 10px;
	align-items: stretch;
	flex-wrap: wrap;
}

.eara-survey__street-select {
	flex: 1;
	min-width: 200px;
	height: 46px;
	font-size: 15px;
}

.eara-survey__start-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, #1e3a5f, #2563eb);
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 12px 22px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: opacity 0.2s, transform 0.1s;
	white-space: nowrap;
}

.eara-survey__start-btn:hover  { opacity: 0.9; transform: translateY(-1px); }
.eara-survey__start-btn:active { transform: translateY(0); }
.eara-survey__start-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

.eara-survey__start-icon { font-size: 18px; }

.eara-survey__setup-hint {
	font-size: 12px;
	color: #64748b;
	margin: 12px 0 0;
}

/* ── Sticky progress bar ─────────────────────────────────────────────────── */

.eara-survey__progress-wrap {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	padding: 12px 16px;
	margin-bottom: 16px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* Honour the HTML hidden attribute — some themes override it */
.eara-survey__progress-wrap[hidden],
.eara-survey__results[hidden],
.eara-survey__success[hidden] {
	display: none !important;
}

.eara-survey__progress-street {
	font-size: 13px;
	font-weight: 700;
	color: #1e3a5f;
	margin-bottom: 6px;
}

.eara-survey__progress-track {
	height: 10px;
	background: #e5e7eb;
	border-radius: 6px;
	overflow: hidden;
	margin-bottom: 6px;
}

.eara-survey__progress-fill {
	height: 100%;
	background: linear-gradient(90deg, #1e3a5f, #2563eb);
	border-radius: 6px;
	transition: width 0.4s ease;
	width: 0%;
}

.eara-survey__progress-label {
	font-size: 12px;
	color: #374151;
	font-weight: 600;
	text-align: right;
}

.eara-survey__progress-legend {
	display: flex;
	gap: 12px;
	margin-top: 6px;
	flex-wrap: wrap;
}

.eara-survey__legend-item {
	font-size: 11px;
	font-weight: 600;
}

.eara-survey__legend-item--confirmed { color: #065f46; }
.eara-survey__legend-item--issue     { color: #b91c1c; }
.eara-survey__legend-item--pending   { color: #9ca3af; }

/* ── Survey cards ────────────────────────────────────────────────────────── */

/*
 * Virtual scroll mode:  JS sets position:relative + explicit height.
 * Flat mode (fallback): display:flex + gap works as before.
 * Both modes coexist — JS switches between them via initCardList().
 */
.eara-survey__cards {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: 24px;
}

/* When virtual scroll is active, JS adds position:relative and an explicit
   height. Cards are position:absolute inside. The gap is baked into slotHeight
   in JS (SLOT = card height + 8px gap). */
.eara-survey__cards--virtual {
	display: block; /* override flex so absolute children position correctly */
}

.eara-survey-card {
	background: #fff;
	border: 2px solid #e2e8f0;
	border-radius: 12px;
	padding: 14px 16px;
	transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
	position: relative; /* needed by virtual scroll absolute positioning */
	/* Ensure consistent card height for virtual slot measurement */
	box-sizing: border-box;
}

.eara-survey-card--confirmed {
	border-color: #86efac;
	background: #f0fdf4;
}

.eara-survey-card--issue {
	border-color: #fca5a5;
	background: #fff5f5;
}

.eara-survey-card__top {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.eara-survey-card__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: #f1f5f9;
	border-radius: 8px;
	font-size: 12px;
	font-weight: 700;
	color: #374151;
	flex-shrink: 0;
}

.eara-survey-card--confirmed .eara-survey-card__num { background: #dcfce7; color: #15803d; }
.eara-survey-card--issue     .eara-survey-card__num { background: #fee2e2; color: #dc2626; }

.eara-survey-card__address {
	flex: 1;
}

.eara-survey-card__house {
	font-size: 15px;
	font-weight: 700;
	color: #1a1a2e;
	display: block;
}

.eara-survey-card__postcode {
	font-size: 12px;
	color: #64748b;
}

.eara-survey-card__status-badge {
	font-size: 11px;
	font-weight: 700;
	padding: 3px 10px;
	border-radius: 12px;
	display: none;
}

.eara-survey-card--confirmed .eara-survey-card__status-badge {
	display: inline-block;
	background: #dcfce7;
	color: #15803d;
}

.eara-survey-card--issue .eara-survey-card__status-badge {
	display: inline-block;
	background: #fee2e2;
	color: #b91c1c;
}

/* Action buttons */

.eara-survey-card__actions {
	display: flex;
	gap: 8px;
	margin-top: 12px;
	flex-wrap: wrap;
}

.eara-survey-card--confirmed .eara-survey-card__actions,
.eara-survey-card--issue     .eara-survey-card__actions {
	/* keep actions visible so user can change their mind */
}

.eara-survey-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 600;
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 0.15s;
	white-space: nowrap;
}

.eara-survey-btn--confirm {
	background: #f0fdf4;
	color: #15803d;
	border-color: #86efac;
}

.eara-survey-btn--confirm:hover,
.eara-survey-card--confirmed .eara-survey-btn--confirm {
	background: #15803d;
	color: #fff;
	border-color: #15803d;
}

.eara-survey-btn--issue {
	background: #fff5f5;
	color: #b91c1c;
	border-color: #fca5a5;
}

.eara-survey-btn--issue:hover,
.eara-survey-card--issue .eara-survey-btn--issue {
	background: #b91c1c;
	color: #fff;
	border-color: #b91c1c;
}

/* Note area */

.eara-survey-card__note-wrap {
	margin-top: 10px;
}

.eara-survey-card__note {
	width: 100%;
	box-sizing: border-box;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	padding: 8px 12px;
	font-size: 13px;
	resize: vertical;
	min-height: 60px;
	font-family: inherit;
}

.eara-survey-card__note:focus {
	outline: none;
	border-color: #2563eb;
	box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}

.eara-survey-card__note-save {
	margin-top: 6px;
	background: #2563eb;
	color: #fff;
	border: none;
	border-radius: 6px;
	padding: 6px 14px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
}

.eara-survey-card__note-saved {
	font-size: 11px;
	color: #15803d;
	margin-left: 8px;
	font-weight: 600;
}

/* ── Missing property section ────────────────────────────────────────────── */

.eara-survey__missing-section {
	background: #fffbeb;
	border: 2px dashed #f59e0b;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 24px;
}

.eara-survey__missing-header {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 16px;
	font-weight: 700;
	color: #92400e;
	margin-bottom: 8px;
}

.eara-survey__missing-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	background: #f59e0b;
	color: #fff;
	border-radius: 50%;
	font-size: 18px;
	font-weight: 700;
}

.eara-survey__missing-hint {
	font-size: 13px;
	color: #78350f;
	margin: 0 0 14px;
}

.eara-survey__missing-fields {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

.eara-survey__missing-fields .eara-field {
	flex: 1;
	min-width: 200px;
}

.eara-survey__missing-add-btn {
	background: #f59e0b;
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 10px 20px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s;
}

.eara-survey__missing-add-btn:hover { background: #d97706; }

.eara-survey__missing-list {
	list-style: none;
	margin: 12px 0 0;
	padding: 0;
}

.eara-survey__missing-item {
	background: #fff;
	border: 1px solid #fde68a;
	border-radius: 8px;
	padding: 10px 14px;
	margin-bottom: 6px;
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
}

.eara-survey__missing-item-icon {
	font-size: 16px;
}

.eara-survey__missing-item-text {
	flex: 1;
}

.eara-survey__missing-item-name {
	font-weight: 700;
	color: #92400e;
}

.eara-survey__missing-item-note {
	color: #78350f;
	font-size: 12px;
}

/* ── Submit section ──────────────────────────────────────────────────────── */

.eara-survey__submit-wrap {
	background: #f8fafc;
	border: 2px solid #e2e8f0;
	border-radius: 12px;
	padding: 24px;
	text-align: center;
}

.eara-survey__submit-summary {
	font-size: 14px;
	color: #374151;
	margin-bottom: 16px;
	line-height: 1.6;
}

.eara-survey__submit-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: linear-gradient(135deg, #065f46, #16a34a);
	color: #fff;
	border: none;
	border-radius: 10px;
	padding: 14px 32px;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity 0.2s, transform 0.1s;
}

.eara-survey__submit-btn:hover:not(:disabled)  { opacity: 0.9; transform: translateY(-1px); }
.eara-survey__submit-btn:disabled {
	background: #9ca3af;
	cursor: not-allowed;
	transform: none;
}

.eara-survey__submit-icon { font-size: 18px; }

.eara-survey__submit-hint {
	font-size: 12px;
	color: #9ca3af;
	margin: 10px 0 0;
}

/* ── Success screen ──────────────────────────────────────────────────────── */

.eara-survey__success {
	text-align: center;
	padding: 48px 24px;
	background: #f0fdf4;
	border: 2px solid #86efac;
	border-radius: 16px;
}

.eara-survey__success-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	background: #16a34a;
	color: #fff;
	border-radius: 50%;
	font-size: 36px;
	margin-bottom: 16px;
}

.eara-survey__success h3 {
	font-size: 22px;
	color: #065f46;
	margin: 0 0 10px;
}

.eara-survey__success p {
	color: #374151;
	margin: 0 0 24px;
}

/* ── Saving indicator ────────────────────────────────────────────────────── */

.eara-survey-card--saving {
	opacity: 0.7;
}

.eara-survey__saving-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: #2563eb;
	border-radius: 50%;
	animation: eara-pulse 1s infinite;
}

@keyframes eara-pulse {
	0%, 100% { opacity: 1; }
	50%       { opacity: 0.3; }
}

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 480px) {
	.eara-survey__header { padding: 18px 16px; }
	.eara-survey__title  { font-size: 18px; }
	.eara-survey-card__actions { gap: 6px; }
	.eara-survey-btn { padding: 7px 11px; font-size: 12px; }
	.eara-survey__submit-btn { width: 100%; justify-content: center; }
}

/* ── Pause button & progress actions ─────────────────────────────────────── */

.eara-survey__progress-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 8px;
}

.eara-survey__pause-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: #1e3a5f;
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s, transform .1s;
	flex-shrink: 0;
	line-height: 1.3;
}

.eara-survey__pause-btn:hover  { background: #2563eb; transform: translateY(-1px); }
.eara-survey__pause-btn:active { transform: translateY(0); }
.eara-survey__pause-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* ── Saved / paused surveys panel ────────────────────────────────────────── */

.eara-survey__saved-wrap {
	background: #fff;
	border: 2px solid #fde68a;
	border-radius: 12px;
	overflow: hidden;
}

.eara-survey__saved-header {
	background: #fffbeb;
	padding: 12px 16px;
	font-size: 14px;
	font-weight: 700;
	color: #92400e;
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid #fde68a;
}

.eara-survey__saved-count {
	background: #f59e0b;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.eara-survey__saved-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 16px;
	border-bottom: 1px solid #fef3c7;
	flex-wrap: wrap;
}

.eara-survey__saved-item:last-child { border-bottom: none; }

.eara-survey__saved-info {
	flex: 1;
	min-width: 0;
}

.eara-survey__saved-info strong {
	display: block;
	font-size: 14px;
	color: #1a1a2e;
}

.eara-survey__saved-meta {
	font-size: 12px;
	color: #64748b;
	margin-top: 2px;
	display: block;
}

.eara-survey__saved-actions {
	display: flex;
	gap: 8px;
	align-items: center;
	flex-shrink: 0;
}

.eara-survey__resume-btn {
	background: #1e3a5f;
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s;
}

.eara-survey__resume-btn:hover { background: #2563eb; }

.eara-survey__discard-btn {
	background: #fee2e2;
	color: #b91c1c;
	border: 1px solid #fca5a5;
	border-radius: 8px;
	padding: 8px 12px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s;
}

.eara-survey__discard-btn:hover { background: #fecaca; }

/* ── Note saved tick (fix: was empty span) ───────────────────────────────── */

.eara-survey-card__note-saved {
	font-size: 12px;
	color: #15803d;
	font-weight: 600;
}
