/* ============================================================
   BLUELAB SOS CHECKER
   Frontend CSS
   ============================================================ */

.bluelab-sos-form-wrap,
.bluelab-sos-results-wrap {
	width: 100%;
}

.bluelab-sos-form {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 24px;
	background: #ffffff;
	border: 1px solid #d9e2ec;
	border-radius: 22px;
	box-shadow: 0 12px 34px rgba(15, 66, 134, 0.08);
}

.bluelab-sos-label {
	font-size: 14px;
	font-weight: 700;
	color: #111827;
	margin: 0;
}

.bluelab-sos-input {
	width: 100%;
	min-height: 56px;
	padding: 0 18px;
	border: 1px solid #cfd8e3;
	border-radius: 16px;
	background: #fff;
	font-size: 16px;
	line-height: 1.4;
	color: #111827;
	outline: none;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
	box-sizing: border-box;
}

.bluelab-sos-input:focus {
	border-color: #0f4286;
	box-shadow: 0 0 0 4px rgba(15, 66, 134, 0.10);
}

.bluelab-sos-input::placeholder {
	color: #98a2b3;
}

.bluelab-sos-mini-note {
	margin: 2px 0 0;
	font-size: 14px;
	line-height: 1.6;
	color: #667085;
}

/* Buttons */

.bluelab-sos-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 18px;
	border-radius: 14px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none;
	border: 0;
	cursor: pointer;
	transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease, background .18s ease;
}

.bluelab-sos-btn:hover {
	transform: translateY(-1px);
}

.bluelab-sos-btn:active {
	transform: translateY(0);
}

.bluelab-sos-btn-primary {
	background: #0f4286;
	color: #fff;
	box-shadow: 0 10px 24px rgba(15, 66, 134, 0.20);
}

.bluelab-sos-btn-primary:hover {
	background: #123f7a;
}

.bluelab-sos-btn-secondary {
	background: #fff;
	color: #0f4286;
	border: 1px solid #cfd8e3;
	box-shadow: 0 6px 18px rgba(15, 66, 134, 0.06);
}

.bluelab-sos-btn-secondary:hover {
	background: #f8fbff;
}

/* Loading */

.bluelab-sos-loading {
	margin-top: 20px;
	padding: 24px;
	background: #ffffff;
	border: 1px solid #d9e2ec;
	border-radius: 22px;
	box-shadow: 0 12px 34px rgba(15, 66, 134, 0.08);
	overflow: hidden;
	transition: all .35s ease;
}

.bluelab-sos-loading-lead {
	margin: 0 0 16px;
	font-size: 18px;
	color: #111827;
}

.bluelab-sos-progress-track {
	position: relative;
	width: 100%;
	height: 12px;
	background: #eaf0f6;
	border-radius: 999px;
	overflow: hidden;
}

.bluelab-sos-progress-bar {
	width: 8%;
	height: 100%;
	background: linear-gradient(90deg, #0f4286 0%, #2d6ac2 100%);
	border-radius: 999px;
	transition: width .35s ease;
}

.bluelab-sos-progress-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 10px;
	font-size: 13px;
	font-weight: 600;
	color: #667085;
}

.bluelab-sos-loading-copy {
	margin-top: 18px;
}

.bluelab-sos-loading-step {
	margin: 0 0 6px;
	font-size: 17px;
	font-weight: 700;
	color: #111827;
}

.bluelab-sos-loading-substep {
	margin: 0;
	font-size: 14px;
	line-height: 1.6;
	color: #667085;
}

/* Result */

.bluelab-sos-result {
	transition: opacity .35s ease, transform .35s ease;
}

.bluelab-sos-result-card {
	margin-top: 20px;
	padding: 26px;
	background: #ffffff;
	border: 1px solid #d9e2ec;
	border-radius: 24px;
	box-shadow: 0 16px 42px rgba(15, 66, 134, 0.10);
}

.bluelab-sos-result-top {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(320px, .9fr);
	gap: 22px;
	align-items: stretch;
}

.bluelab-sos-main-verdict {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 6px 0;
}

.bluelab-sos-result-heading {
	margin: 0 0 14px;
	font-size: 30px;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: #111827;
}

.bluelab-sos-result-summary {
	margin: 0;
	font-size: 16px;
	line-height: 1.75;
	color: #5b6472;
	max-width: 760px;
}

.bluelab-sos-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

/* Domain card */

.bluelab-sos-domain-card {
	background: linear-gradient(180deg, #fbfcfe 0%, #f4f8fc 100%);
	border: 1px solid #d9e2ec;
	border-radius: 22px;
	padding: 18px;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}

.bluelab-sos-domain-top {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
}

.bluelab-sos-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	display: inline-block;
}

.bluelab-sos-dot.is-red {
	background: #f04438;
}

.bluelab-sos-dot.is-yellow {
	background: #f4b400;
}

.bluelab-sos-dot.is-green {
	background: #12b76a;
}

.bluelab-sos-domain-pill {
	margin-left: auto;
	max-width: 70%;
	padding: 7px 12px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid #d9e2ec;
	font-size: 12px;
	font-weight: 700;
	color: #0f4286;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.bluelab-sos-domain-body {
	display: block;
}

.bluelab-sos-domain-mini-card {
	padding: 18px;
	border-radius: 18px;
	background: #ffffff;
	border: 1px solid #e3eaf2;
	box-shadow: 0 10px 28px rgba(15, 66, 134, 0.06);
}

.bluelab-sos-domain-title {
	font-size: 18px;
	font-weight: 800;
	line-height: 1.2;
	color: #111827;
	margin-bottom: 4px;
}

.bluelab-sos-domain-sub {
	font-size: 14px;
	color: #667085;
	margin-bottom: 18px;
	word-break: break-word;
}

.bluelab-sos-domain-meta + .bluelab-sos-domain-meta {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid #eef2f6;
}

.bluelab-sos-domain-meta-label {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: #98a2b3;
	margin-bottom: 5px;
}

.bluelab-sos-domain-meta-value {
	font-size: 15px;
	line-height: 1.55;
	font-weight: 700;
	color: #111827;
	word-break: break-word;
}

/* mini info cards */

.bluelab-sos-info-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 14px;
	margin-top: 24px;
}

.bluelab-sos-mini-card {
	padding: 16px;
	background: #fff;
	border: 1px solid #e1e8f0;
	border-radius: 18px;
	box-shadow: 0 8px 22px rgba(15, 66, 134, 0.05);
}

.bluelab-sos-mini-label {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .03em;
	text-transform: uppercase;
	color: #98a2b3;
	margin-bottom: 6px;
}

.bluelab-sos-mini-value {
	font-size: 16px;
	font-weight: 800;
	line-height: 1.35;
	color: #111827;
	word-break: break-word;
}

.bluelab-sos-mini-sub {
	margin-top: 6px;
	font-size: 13px;
	line-height: 1.5;
	color: #667085;
}

/* content grids */

.bluelab-sos-preview-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-top: 18px;
}

.bluelab-sos-preview-card,
.bluelab-sos-section,
.bluelab-sos-next-step-box {
	padding: 20px;
	background: #fff;
	border: 1px solid #e1e8f0;
	border-radius: 20px;
	box-shadow: 0 8px 24px rgba(15, 66, 134, 0.05);
}

.bluelab-sos-preview-card h4,
.bluelab-sos-section h4 {
	margin: 0 0 12px;
	font-size: 19px;
	line-height: 1.25;
	color: #111827;
}

.bluelab-sos-preview-card p,
.bluelab-sos-section p {
	margin: 0;
	font-size: 15px;
	line-height: 1.75;
	color: #5b6472;
}

.bluelab-sos-preview-list,
.bluelab-sos-preview-card ul {
	margin: 0;
	padding-left: 18px;
}

.bluelab-sos-preview-list li,
.bluelab-sos-preview-card li {
	margin: 0 0 8px;
	font-size: 15px;
	line-height: 1.7;
	color: #374151;
}

.bluelab-sos-preview-list li:last-child,
.bluelab-sos-preview-card li:last-child {
	margin-bottom: 0;
}

/* findings */

.bluelab-sos-findings-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px;
}

.bluelab-sos-findings-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 14px;
	border-radius: 14px;
	font-size: 15px;
	line-height: 1.6;
}

.bluelab-sos-findings-item.is-positive {
	background: #ecfdf3;
	border: 1px solid #ccebd8;
	color: #166534;
}

.bluelab-sos-findings-item.is-negative {
	background: #fff4f2;
	border: 1px solid #ffd6d1;
	color: #b42318;
}

.bluelab-sos-findings-icon {
	flex: 0 0 auto;
	font-weight: 800;
	line-height: 1.2;
	margin-top: 1px;
}

/* next step */

.bluelab-sos-next-step-box {
	margin-top: 18px;
	background: linear-gradient(180deg, #fbfcfe 0%, #f5f8fc 100%);
	border-color: #d9e2ec;
}

.bluelab-sos-next-step-box strong {
	display: block;
	margin: 0 0 8px;
	font-size: 18px;
	color: #111827;
}

.bluelab-sos-next-step-box p {
	margin: 0;
	font-size: 15px;
	line-height: 1.75;
	color: #5b6472;
}

.bluelab-sos-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 18px;
}

/* extra forms */

.bluelab-sos-extra-form {
	animation: bluelabSosFadeUp .28s ease;
}

@keyframes bluelabSosFadeUp {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* error */

.bluelab-sos-error-box {
	margin-top: 20px;
	padding: 18px 20px;
	background: #fff4f2;
	border: 1px solid #ffd6d1;
	border-radius: 18px;
	color: #b42318;
	font-size: 15px;
	line-height: 1.65;
	box-shadow: 0 10px 26px rgba(180, 35, 24, 0.06);
}

/* signature */

.bluelab-sos-signature {
	margin-top: 14px;
	text-align: right;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #98a2b3;
}

/* fluent forms inside */

.bluelab-sos-extra-form .ff-el-form-control,
.bluelab-sos-extra-form input[type="text"],
.bluelab-sos-extra-form input[type="email"],
.bluelab-sos-extra-form input[type="tel"],
.bluelab-sos-extra-form textarea,
.bluelab-sos-extra-form select {
	border-radius: 14px !important;
	border-color: #cfd8e3 !important;
	min-height: 48px;
}

.bluelab-sos-extra-form textarea {
	min-height: 140px !important;
}

.bluelab-sos-extra-form .ff-btn-submit,
.bluelab-sos-extra-form button[type="submit"] {
	border-radius: 14px !important;
	background: #0f4286 !important;
	border-color: #0f4286 !important;
	padding: 12px 20px !important;
	font-weight: 700 !important;
	box-shadow: 0 10px 24px rgba(15, 66, 134, 0.18);
}

/* responsive */

@media (max-width: 1200px) {
	.bluelab-sos-info-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 960px) {
	.bluelab-sos-result-top {
		grid-template-columns: 1fr;
	}

	.bluelab-sos-preview-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 680px) {
	.bluelab-sos-form,
	.bluelab-sos-loading,
	.bluelab-sos-result-card,
	.bluelab-sos-preview-card,
	.bluelab-sos-section,
	.bluelab-sos-next-step-box {
		padding: 18px;
		border-radius: 18px;
	}

	.bluelab-sos-result-heading {
		font-size: 24px;
	}

	.bluelab-sos-info-grid {
		grid-template-columns: 1fr 1fr;
	}

	.bluelab-sos-actions {
		flex-direction: column;
	}

	.bluelab-sos-btn {
		width: 100%;
	}
}

@media (max-width: 480px) {
	.bluelab-sos-info-grid {
		grid-template-columns: 1fr;
	}

	.bluelab-sos-domain-pill {
		max-width: 58%;
	}

	.bluelab-sos-result-heading {
		font-size: 22px;
	}

	.bluelab-sos-result-summary,
	.bluelab-sos-preview-card p,
	.bluelab-sos-section p,
	.bluelab-sos-preview-list li,
	.bluelab-sos-findings-item {
		font-size: 14px;
	}
}