/* ============================================================
   CONTACT PAGE — Premium Design
   SB Webmarketing
   ============================================================ */

/* ================================================================
   HERO — Immersive gradient with form overlay
   ================================================================ */
.sb-contact-hero {
	background: linear-gradient(135deg, #0A2540 0%, #0f3460 50%, #0A2540 100%);
	color: #fff;
	padding: clamp(8rem, 14vw, 11rem) 0 clamp(4rem, 8vw, 6rem);
	position: relative;
	overflow: hidden;
}

/* Animated mesh background */
.sb-contact-hero__mesh {
	position: absolute;
	inset: -50%;
	background:
		radial-gradient(ellipse at 20% 50%, rgba(51,91,255,0.2), transparent 50%),
		radial-gradient(ellipse at 80% 20%, rgba(91,127,255,0.12), transparent 50%),
		radial-gradient(ellipse at 50% 90%, rgba(51,91,255,0.15), transparent 50%);
	background-size: 200% 200%;
	animation: sb-mesh-drift 20s ease-in-out infinite;
	pointer-events: none;
}

/* Dot grid */
.sb-contact-hero__dots {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
	background-size: 24px 24px;
	pointer-events: none;
}

/* Floating orbs */
.sb-contact-hero__orb {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.sb-contact-hero__orb--1 {
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(51,91,255,0.12) 0%, transparent 65%);
	top: -200px;
	right: -200px;
	animation: sb-float 8s ease-in-out infinite;
}
.sb-contact-hero__orb--2 {
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(126,180,255,0.06) 0%, transparent 65%);
	bottom: -150px;
	left: -100px;
	animation: sb-float-slow 10s ease-in-out infinite;
}

/* Angled bottom separator */
.sb-contact-hero::after {
	content: "";
	position: absolute;
	bottom: -1px;
	left: 0;
	right: 0;
	height: 80px;
	background: #fff;
	clip-path: polygon(0 60%, 100% 0, 100% 100%, 0 100%);
	z-index: 1;
}

/* Hero layout */
.sb-contact-hero .sb-container {
	position: relative;
	z-index: 2;
}

.sb-contact-hero .sb-breadcrumbs {
	margin-bottom: 2rem;
}
.sb-contact-hero .sb-breadcrumbs a {
	color: rgba(255,255,255,0.4);
}
.sb-contact-hero .sb-breadcrumbs a:hover {
	color: #7EB4FF;
}
.sb-contact-hero .sb-breadcrumbs span {
	color: rgba(255,255,255,0.7);
}

.sb-contact-hero__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: start;
}

@media (min-width: 1024px) {
	.sb-contact-hero__grid {
		grid-template-columns: 1fr 1.1fr;
		gap: 4rem;
	}
}

/* Hero content (left) */
.sb-contact-hero__label {
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	background: linear-gradient(90deg, #7EB4FF, #335BFF);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin-bottom: 1rem;
}

.sb-contact-hero__content h1 {
	font-size: clamp(1.85rem, 4.5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.12;
	margin: 0 0 1.25rem;
	color: #fff;
}

.sb-contact-hero__subtitle {
	font-size: clamp(1rem, 1.5vw, 1.15rem);
	line-height: 1.7;
	color: rgba(255,255,255,0.55);
	margin: 0 0 2.5rem;
	max-width: 500px;
}

/* Trust indicators */
.sb-contact-trust {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.sb-contact-trust__item {
	display: flex;
	align-items: center;
	gap: 0.85rem;
}

.sb-contact-trust__icon {
	width: 44px;
	height: 44px;
	min-width: 44px;
	border-radius: 12px;
	background: rgba(51,91,255,0.12);
	border: 1px solid rgba(51,91,255,0.2);
	display: flex;
	align-items: center;
	justify-content: center;
}

.sb-contact-trust__icon svg {
	width: 20px;
	height: 20px;
	color: #7EB4FF;
}

.sb-contact-trust__item strong {
	display: block;
	font-size: 0.95rem;
	font-weight: 600;
	color: #fff;
	line-height: 1.3;
}

.sb-contact-trust__item span {
	font-size: 0.8rem;
	color: rgba(255,255,255,0.4);
}

/* ================================================================
   FORM CARD — Glass morphism
   ================================================================ */
.sb-contact-form-card {
	position: relative;
	background: rgba(255,255,255,0.07);
	backdrop-filter: blur(24px);
	-webkit-backdrop-filter: blur(24px);
	border: 1px solid rgba(255,255,255,0.14);
	border-radius: 20px;
	padding: 2.5rem;
	overflow: hidden;
	box-shadow:
		0 8px 32px rgba(0,0,0,0.3),
		inset 0 1px 0 rgba(255,255,255,0.08);
}

/* Subtle glow behind card */
.sb-contact-form-card__glow {
	position: absolute;
	top: -100px;
	right: -100px;
	width: 300px;
	height: 300px;
	background: radial-gradient(circle, rgba(51,91,255,0.15), transparent 70%);
	pointer-events: none;
	border-radius: 50%;
}

.sb-contact-form__title {
	font-size: 1.35rem;
	font-weight: 700;
	color: #fff;
	margin: 0 0 1.75rem;
	position: relative;
}

/* Form rows */
.sb-contact-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin-bottom: 1rem;
}

@media (max-width: 600px) {
	.sb-contact-form__row {
		grid-template-columns: 1fr;
	}
}

.sb-contact-form__group {
	position: relative;
}

.sb-contact-form__group--full {
	margin-bottom: 1.5rem;
}

.sb-contact-form__group label {
	display: block;
	font-size: 0.82rem;
	font-weight: 500;
	color: rgba(255,255,255,0.6);
	margin-bottom: 0.4rem;
	transition: color 0.2s;
}

.sb-contact-form__group--focused label {
	color: #7EB4FF;
}

.sb-required {
	color: #7EB4FF;
}

.sb-contact-form__group input,
.sb-contact-form__group select,
.sb-contact-form__group textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	font-family: var(--wp--preset--font-family--primary);
	font-size: 0.95rem;
	color: #fff;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 10px;
	transition: border-color 0.3s, box-shadow 0.3s, background 0.3s;
	outline: none;
}

.sb-contact-form__group input::placeholder,
.sb-contact-form__group textarea::placeholder {
	color: rgba(255,255,255,0.25);
}

.sb-contact-form__group input:focus,
.sb-contact-form__group select:focus,
.sb-contact-form__group textarea:focus {
	border-color: rgba(51,91,255,0.5);
	box-shadow: 0 0 0 3px rgba(51,91,255,0.15);
	background: rgba(255,255,255,0.08);
}

.sb-contact-form__group select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
	cursor: pointer;
}

.sb-contact-form__group select option {
	background: #0A2540;
	color: #fff;
}

.sb-contact-form__group textarea {
	min-height: 120px;
	resize: vertical;
}

/* Submit button */
.sb-contact-form__submit {
	width: 100%;
	margin-top: 0.5rem;
	font-size: 1.05rem !important;
}

/* Privacy note */
.sb-contact-form__privacy {
	font-size: 0.75rem;
	color: rgba(255,255,255,0.3);
	text-align: center;
	margin: 1rem 0 0;
	line-height: 1.5;
}

/* Status messages */
.sb-contact-form__status {
	margin-top: 1rem;
	padding: 1rem 1.25rem;
	border-radius: 10px;
	font-size: 0.9rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.sb-contact-form__status svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

.sb-contact-form__status--success {
	background: rgba(39,174,96,0.15);
	color: #4ade80;
	border: 1px solid rgba(39,174,96,0.2);
}

.sb-contact-form__status--error {
	background: rgba(231,76,60,0.15);
	color: #ff6b6b;
	border: 1px solid rgba(231,76,60,0.2);
}

/* ================================================================
   PROCESS SECTION — 3 Steps
   ================================================================ */
.sb-contact-process {
	padding: clamp(4rem, 8vw, 7rem) 0;
	background: #fff;
}

.sb-contact-process__header {
	text-align: center;
	margin-bottom: 4rem;
}

.sb-contact-process__label {
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #335BFF;
	margin-bottom: 0.75rem;
}

.sb-contact-process__header h2 {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 800;
	color: #0A2540;
	letter-spacing: -0.02em;
	margin: 0 0 0.75rem;
}

.sb-contact-process__subtitle {
	font-size: 1.05rem;
	color: #6b7b8d;
	max-width: 520px;
	margin: 0 auto;
	line-height: 1.7;
}

.sb-contact-process__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 1000px;
	margin: 0 auto;
}

@media (max-width: 768px) {
	.sb-contact-process__grid {
		grid-template-columns: 1fr;
		max-width: 420px;
	}
}

.sb-contact-process__step {
	position: relative;
	background: #fff;
	border: 1px solid rgba(10,37,64,0.06);
	border-radius: 20px;
	padding: 2.25rem;
	text-align: center;
	box-shadow: 0 2px 12px rgba(10,37,64,0.04);
	transition: transform 0.4s cubic-bezier(0.25,0.1,0.25,1), box-shadow 0.4s, border-color 0.4s;
}

.sb-contact-process__step:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 48px rgba(51,91,255,0.12);
	border-color: rgba(51,91,255,0.15);
}

/* Step number badge */
.sb-contact-process__number {
	position: absolute;
	top: -16px;
	left: 50%;
	transform: translateX(-50%);
	width: 32px;
	height: 32px;
	border-radius: 10px;
	background: linear-gradient(135deg, #335BFF, #5B7FFF);
	box-shadow: 0 4px 12px rgba(51,91,255,0.3);
	display: flex;
	align-items: center;
	justify-content: center;
}

.sb-contact-process__number span {
	font-size: 0.75rem;
	font-weight: 800;
	color: #fff;
}

.sb-contact-process__icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(51,91,255,0.08), rgba(51,91,255,0.03));
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 1rem auto 1.25rem;
}

.sb-contact-process__icon svg {
	width: 26px;
	height: 26px;
	color: #335BFF;
}

.sb-contact-process__step h3 {
	font-size: 1.15rem;
	font-weight: 700;
	color: #0A2540;
	margin: 0 0 0.6rem;
}

.sb-contact-process__step p {
	font-size: 0.92rem;
	color: #6b7b8d;
	line-height: 1.65;
	margin: 0;
}

/* Connector line between steps (desktop) */
@media (min-width: 769px) {
	.sb-contact-process__grid {
		gap: 3rem;
	}
	.sb-contact-process__step:not(:last-child)::after {
		content: "";
		position: absolute;
		top: 0;
		right: -1.75rem;
		width: 3.5rem;
		height: 2px;
		background: linear-gradient(90deg, #335BFF, rgba(91,127,255,0.15));
		border-radius: 2px;
	}
}

/* ================================================================
   CONTACT INFO SECTION — Cards grid
   ================================================================ */
.sb-contact-info-section {
	padding: clamp(4rem, 8vw, 6rem) 0;
	background: #F5F5F7;
}

.sb-contact-info-section__header {
	text-align: center;
	margin-bottom: 3rem;
}

.sb-contact-info-section__label {
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #335BFF;
	margin-bottom: 0.75rem;
}

.sb-contact-info-section__header h2 {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 800;
	color: #0A2540;
	letter-spacing: -0.02em;
	margin: 0;
}

.sb-contact-info__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	max-width: 1000px;
	margin: 0 auto;
}

/* 3-column variant for fewer cards */
.sb-contact-info__grid--3 {
	grid-template-columns: repeat(3, 1fr);
	max-width: 800px;
}

@media (max-width: 1023px) {
	.sb-contact-info__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.sb-contact-info__grid--3 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.sb-contact-info__grid,
	.sb-contact-info__grid--3 {
		grid-template-columns: 1fr;
		max-width: 400px;
	}
}

.sb-contact-info-card {
	background: #fff;
	border: 1px solid rgba(10,37,64,0.06);
	border-radius: 16px;
	padding: 2rem;
	text-decoration: none;
	color: inherit;
	text-align: center;
	position: relative;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(10,37,64,0.03);
	transition: transform 0.4s cubic-bezier(0.25,0.1,0.25,1), box-shadow 0.4s, border-color 0.4s;
}

.sb-contact-info-card:not(.sb-contact-info-card--static):hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(51,91,255,0.1);
	border-color: rgba(51,91,255,0.15);
}

/* Top accent line on hover */
.sb-contact-info-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, #335BFF, #7EB4FF, transparent);
	opacity: 0;
	transition: opacity 0.4s;
}

.sb-contact-info-card:hover::before {
	opacity: 1;
}

.sb-contact-info-card__icon {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(51,91,255,0.08), rgba(51,91,255,0.03));
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
}

.sb-contact-info-card__icon svg {
	width: 24px;
	height: 24px;
	color: #335BFF;
}

.sb-contact-info-card h3 {
	font-size: 1rem;
	font-weight: 700;
	color: #0A2540;
	margin: 0 0 0.4rem;
}

.sb-contact-info-card p {
	font-size: 0.88rem;
	color: #6b7b8d;
	margin: 0;
	line-height: 1.5;
}

.sb-contact-info-card__arrow {
	display: inline-block;
	margin-top: 0.75rem;
	font-size: 1.2rem;
	color: #335BFF;
	transition: transform 0.3s;
}

.sb-contact-info-card:hover .sb-contact-info-card__arrow {
	transform: translateX(4px);
}

/* ================================================================
   CITY TAGS — CTA Section
   ================================================================ */
.sb-contact-cities {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	justify-content: center;
	margin-top: 1.5rem;
}

.sb-contact-city-tag {
	display: inline-block;
	padding: 0.45rem 1.15rem;
	font-size: 0.85rem;
	font-weight: 500;
	color: rgba(255,255,255,0.7);
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 980px;
	text-decoration: none;
	transition: all 0.3s;
}

.sb-contact-city-tag:hover {
	background: rgba(51,91,255,0.2);
	border-color: rgba(51,91,255,0.4);
	color: #fff;
	transform: translateY(-1px);
}

/* Active nav link */
.sb-header__nav--active {
	color: var(--wp--preset--color--accent) !important;
}
.sb-header__nav--active::after {
	width: 100% !important;
}

/* ================================================================
   ANIMATIONS — Contact-specific keyframes
   ================================================================ */

/* Gradient text shimmer on hero label */
.sb-contact-hero__label {
	background-size: 200% auto;
	animation: sb-gradient-shift 4s ease-in-out infinite;
}

@keyframes sb-gradient-shift {
	0%, 100% { background-position: 0% center; }
	50% { background-position: 200% center; }
}

/* Step number subtle glow pulse */
.sb-contact-process__number {
	animation: sb-number-glow 3s ease-in-out infinite;
}

@keyframes sb-number-glow {
	0%, 100% { box-shadow: 0 4px 12px rgba(51,91,255,0.3); }
	50% { box-shadow: 0 4px 20px rgba(51,91,255,0.5); }
}

/* Stagger delay for process steps */
.sb-contact-process__step:nth-child(2) .sb-contact-process__number {
	animation-delay: 0.5s;
}
.sb-contact-process__step:nth-child(3) .sb-contact-process__number {
	animation-delay: 1s;
}

/* Smooth form card entrance */
.sb-contact-form-card {
	animation: sb-card-float 6s ease-in-out infinite;
}

@keyframes sb-card-float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-6px); }
}

/* Trust items stagger entrance from scroll-triggered animations */
.sb-contact-trust__item {
	opacity: 0;
	animation: sb-fade-up 0.6s ease-out forwards;
}
.sb-contact-trust__item:nth-child(1) { animation-delay: 0.3s; }
.sb-contact-trust__item:nth-child(2) { animation-delay: 0.5s; }
.sb-contact-trust__item:nth-child(3) { animation-delay: 0.7s; }

@keyframes sb-fade-up {
	from { opacity: 0; transform: translateY(12px); }
	to { opacity: 1; transform: translateY(0); }
}

/* Contact info card hover icon color shift */
.sb-contact-info-card:not(.sb-contact-info-card--static):hover .sb-contact-info-card__icon {
	background: linear-gradient(135deg, rgba(51,91,255,0.15), rgba(51,91,255,0.06));
}
.sb-contact-info-card:not(.sb-contact-info-card--static):hover .sb-contact-info-card__icon svg {
	color: #5B7FFF;
}

/* City tag active state highlight */
.sb-contact-city-tag--active,
.sb-contact-city-tag--active:hover {
	background: rgba(51,91,255,0.2);
	border-color: rgba(51,91,255,0.45);
	color: #fff;
}

/* ================================================================
   LIGHT VARIANT — Form on white/light background
   Used on: audit page, any form outside the dark hero
   Apply class .sb-contact-form--light on the <form> element
   ================================================================ */

/* Labels */
.sb-contact-form--light .sb-contact-form__group label {
	color: #425466;
}

.sb-contact-form--light .sb-contact-form__group--focused label {
	color: #335BFF;
}

.sb-contact-form--light .sb-required {
	color: #335BFF;
}

/* Inputs, selects, textareas */
.sb-contact-form--light .sb-contact-form__group input,
.sb-contact-form--light .sb-contact-form__group select,
.sb-contact-form--light .sb-contact-form__group textarea {
	color: #0A2540;
	background: #fff;
	border: 1px solid rgba(10, 37, 64, 0.15);
}

.sb-contact-form--light .sb-contact-form__group input::placeholder,
.sb-contact-form--light .sb-contact-form__group textarea::placeholder {
	color: rgba(10, 37, 64, 0.35);
}

.sb-contact-form--light .sb-contact-form__group input:focus,
.sb-contact-form--light .sb-contact-form__group select:focus,
.sb-contact-form--light .sb-contact-form__group textarea:focus {
	border-color: rgba(51, 91, 255, 0.5);
	box-shadow: 0 0 0 3px rgba(51, 91, 255, 0.1);
	background: #fff;
}

/* Select dropdown arrow — dark variant */
.sb-contact-form--light .sb-contact-form__group select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='rgba(10,37,64,0.4)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-color: #fff;
}

/* Select options (dropdown menu) */
.sb-contact-form--light .sb-contact-form__group select option {
	background: #fff;
	color: #0A2540;
}

/* Status messages on light bg */
.sb-contact-form--light .sb-contact-form__status--success {
	background: rgba(39, 174, 96, 0.08);
	color: #27ae60;
	border: 1px solid rgba(39, 174, 96, 0.2);
}

.sb-contact-form--light .sb-contact-form__status--error {
	background: rgba(231, 76, 60, 0.06);
	color: #e74c3c;
	border: 1px solid rgba(231, 76, 60, 0.15);
}

/* Submit button stays the same (primary blue) */
.sb-contact-form--light .sb-contact-form__submit {
	width: auto;
}

/* Form card title on light background */
.sb-contact-form--light .sb-contact-form__title {
	color: #0A2540;
}

/* Privacy note on light bg */
.sb-contact-form--light .sb-contact-form__privacy {
	color: #6b7b8d;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.sb-contact-hero__label,
	.sb-contact-process__number,
	.sb-contact-form-card,
	.sb-contact-trust__item,
	.sb-contact-hero__mesh,
	.sb-contact-hero__orb {
		animation: none !important;
	}
	.sb-contact-trust__item {
		opacity: 1 !important;
	}
}

/* ================================================================
   AUDIT FORM — Step Titles & Custom Controls
   Moved from inline styles in page-audit.html
   ================================================================ */

/* Step titles */
.sb-audit-step-title {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--wp--preset--color--text-primary, #0A2540);
	display: flex;
	align-items: center;
}

.sb-audit-step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent, #335BFF);
	color: #fff;
	font-size: 0.8rem;
	font-weight: 700;
	margin-right: 0.75rem;
	flex-shrink: 0;
}

.sb-audit-step-desc {
	color: var(--wp--preset--color--text-secondary, #425466);
	font-size: 0.9rem;
	margin-bottom: 1.5rem;
	padding-left: calc(28px + 0.75rem);
}

/* Service checkbox cards */
.sb-checkbox-card {
	cursor: pointer;
}

.sb-checkbox-card input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.sb-checkbox-card__inner {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem;
	border: 1px solid rgba(10, 37, 64, 0.1);
	border-radius: 10px;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--wp--preset--color--text-secondary, #425466);
	transition: all 0.2s ease;
	background: transparent;
}

.sb-checkbox-card__inner svg {
	opacity: 0.4;
	transition: opacity 0.2s;
}

.sb-checkbox-card:hover .sb-checkbox-card__inner {
	border-color: rgba(51, 91, 255, 0.3);
	background: rgba(51, 91, 255, 0.03);
}

.sb-checkbox-card input:checked + .sb-checkbox-card__inner {
	border-color: var(--wp--preset--color--accent, #335BFF);
	background: rgba(51, 91, 255, 0.06);
	color: var(--wp--preset--color--text-primary, #0A2540);
}

.sb-checkbox-card input:checked + .sb-checkbox-card__inner svg {
	opacity: 1;
	stroke: var(--wp--preset--color--accent, #335BFF);
}

/* Tag-style checkboxes */
.sb-checkbox-tag {
	cursor: pointer;
}

.sb-checkbox-tag input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.sb-checkbox-tag span {
	display: inline-block;
	padding: 0.45rem 0.85rem;
	border: 1px solid rgba(10, 37, 64, 0.1);
	border-radius: 980px;
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--wp--preset--color--text-secondary, #425466);
	transition: all 0.2s ease;
	background: transparent;
	white-space: nowrap;
}

.sb-checkbox-tag:hover span {
	border-color: rgba(51, 91, 255, 0.3);
	background: rgba(51, 91, 255, 0.03);
}

.sb-checkbox-tag input:checked + span {
	border-color: var(--wp--preset--color--accent, #335BFF);
	background: rgba(51, 91, 255, 0.08);
	color: var(--wp--preset--color--accent, #335BFF);
	font-weight: 600;
}

/* Checkbox grid responsive */
.sb-checkbox-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 0.6rem;
	margin-top: 0.5rem;
}

@media (max-width: 767px) {
	.sb-checkbox-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 480px) {
	.sb-checkbox-grid {
		grid-template-columns: 1fr;
	}
}

/* Audit layout responsive */
@media (min-width: 768px) {
	.sb-audit-layout {
		grid-template-columns: 1.4fr 0.6fr !important;
	}
}

@media (max-width: 767px) {
	.sb-audit-layout [style*="grid-template-columns: 1fr 1fr"] {
		grid-template-columns: 1fr !important;
	}
	.sb-audit-sidebar {
		order: -1;
	}
}

/* ================================================================
   BREVO FORMS — Compatibility Layer
   Style Brevo (Sendinblue) embedded forms to match theme design
   Plugin: Brevo – WooCommerce Email Marketing
   Shortcode: [sibwp_form id="X"]
   ================================================================ */

/* Brevo form container */
.sib-form {
	font-family: var(--wp--preset--font-family--primary, 'Inter', sans-serif) !important;
}

/* Brevo form fields → match .sb-form__input style */
.sib-form .input,
.sib-form input[type="text"],
.sib-form input[type="email"],
.sib-form input[type="tel"],
.sib-form input[type="url"],
.sib-form select,
.sib-form textarea {
	width: 100% !important;
	padding: 0.85rem 1rem !important;
	font-family: var(--wp--preset--font-family--primary, 'Inter', sans-serif) !important;
	font-size: 0.95rem !important;
	color: var(--wp--preset--color--text-primary, #0A2540) !important;
	background-color: #fff !important;
	border: 1px solid rgba(10, 37, 64, 0.15) !important;
	border-radius: 10px !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	outline: none !important;
	box-sizing: border-box !important;
}

.sib-form input:focus,
.sib-form select:focus,
.sib-form textarea:focus {
	border-color: rgba(51, 91, 255, 0.5) !important;
	box-shadow: 0 0 0 3px rgba(51, 91, 255, 0.1) !important;
}

.sib-form input::placeholder,
.sib-form textarea::placeholder {
	color: rgba(10, 37, 64, 0.35) !important;
}

/* Brevo form labels → match .sb-form__label style */
.sib-form .entry__label,
.sib-form label {
	display: block !important;
	font-size: 0.875rem !important;
	font-weight: 500 !important;
	color: var(--wp--preset--color--text-primary, #0A2540) !important;
	margin-bottom: 0.5rem !important;
}

/* Brevo submit button → match .sb-btn--primary style */
.sib-form .sib-form-block__button,
.sib-form button[type="submit"],
.sib-form input[type="submit"] {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0.9rem 2rem !important;
	font-family: var(--wp--preset--font-family--primary, 'Inter', sans-serif) !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	color: #fff !important;
	background: var(--wp--preset--color--accent, #335BFF) !important;
	border: none !important;
	border-radius: 12px !important;
	cursor: pointer !important;
	transition: background 0.2s ease, transform 0.15s ease !important;
	text-decoration: none !important;
}

.sib-form .sib-form-block__button:hover,
.sib-form button[type="submit"]:hover,
.sib-form input[type="submit"]:hover {
	background: #2849CC !important;
	transform: translateY(-1px) !important;
}

/* Brevo success/error messages */
.sib-form .sib-form-message-panel {
	padding: 1rem 1.25rem !important;
	border-radius: 10px !important;
	font-size: 0.9rem !important;
	margin-top: 1rem !important;
}

.sib-form .sib-form-message-panel--success {
	background: rgba(39, 174, 96, 0.08) !important;
	color: #27ae60 !important;
	border: 1px solid rgba(39, 174, 96, 0.2) !important;
}

.sib-form .sib-form-message-panel--error {
	background: rgba(231, 76, 60, 0.06) !important;
	color: #e74c3c !important;
	border: 1px solid rgba(231, 76, 60, 0.15) !important;
}

/* Hide Brevo branding */
.sib-form .sib-form__declaration {
	font-size: 0.75rem !important;
	color: var(--wp--preset--color--text-secondary, #6b7b8d) !important;
}

/* Brevo checkbox styling → match .sb-checkbox-tag */
.sib-form .sib-optin {
	display: flex !important;
	align-items: flex-start !important;
	gap: 0.5rem !important;
}

.sib-form .sib-optin input[type="checkbox"] {
	width: auto !important;
	accent-color: var(--wp--preset--color--accent, #335BFF) !important;
}

/* Remove Brevo default shadows */
.sib-form .sib-form-block {
	box-shadow: none !important;
}
