/* ============================================================
   COMPONENTS.CSS — Cards, Badges, Forms, Testimonials,
   Breadcrumbs, Pagination extras, Service Icons, Accordion
   Citi Guard Services Theme
   ============================================================ */

/* ============================================================
   FORM COMPONENTS
   ============================================================ */
.form-group {
	margin-bottom: 20px;
}

.form-label {
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-dark);
	margin-bottom: 6px;
}

.form-required {
	color: #e53e3e;
	margin-left: 3px;
}

.form-control {
	display: block;
	width: 100%;
	padding: 11px 16px;
	font-family: var(--font-family);
	font-size: 0.9375rem;
	color: var(--color-text);
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-base);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
}

.form-control:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(0,119,182,0.12);
}

.form-control::placeholder {
	color: var(--color-text-muted);
	opacity: 0.7;
}

.form-control.has-error {
	border-color: #e53e3e;
	box-shadow: 0 0 0 3px rgba(229,62,62,0.1);
}

.form-error-msg {
	display: block;
	font-size: 0.8125rem;
	color: #e53e3e;
	margin-top: 5px;
}

textarea.form-control {
	resize: vertical;
	min-height: 120px;
}

select.form-control {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23718096' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 14px;
	padding-right: 42px;
	cursor: pointer;
}

.form-row { display: flex; gap: 16px; }

.form-row--two-col > .form-group { flex: 1; min-width: 0; }

.form-submit {
	margin-top: 8px;
}

/* Contact Form 7 overrides */
.wpcf7-form .wpcf7-text,
.wpcf7-form .wpcf7-email,
.wpcf7-form .wpcf7-tel,
.wpcf7-form .wpcf7-textarea,
.wpcf7-form .wpcf7-select {
	width: 100%;
	padding: 11px 16px;
	font-family: var(--font-family);
	font-size: 0.9375rem;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-base);
	transition: border-color 0.2s ease;
	margin-bottom: 0;
}

.wpcf7-form .wpcf7-text:focus,
.wpcf7-form .wpcf7-email:focus,
.wpcf7-form .wpcf7-tel:focus,
.wpcf7-form .wpcf7-textarea:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(0,119,182,0.12);
}

.wpcf7-form .wpcf7-submit {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	background-color: var(--color-accent);
	color: var(--color-dark);
	border: none;
	border-radius: var(--radius-base);
	font-family: var(--font-family);
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.15s ease;
}

.wpcf7-form .wpcf7-submit:hover {
	background-color: var(--color-accent-dark);
	transform: translateY(-1px);
}

.wpcf7-not-valid-tip {
	font-size: 0.8125rem;
	color: #e53e3e;
	margin-top: 4px;
	display: block;
}

.wpcf7-response-output {
	margin-top: 16px;
	padding: 12px 16px;
	border-radius: var(--radius-base);
	font-size: 0.9375rem;
}

.wpcf7-mail-sent-ok {
	background-color: #f0fff4;
	border: 1px solid #9ae6b4;
	color: #276749;
}

.wpcf7-mail-sent-ng,
.wpcf7-validation-errors {
	background-color: #fff5f5;
	border: 1px solid #feb2b2;
	color: #c53030;
}

@media (max-width: 600px) {
	.form-row { flex-direction: column; }
}

/* ============================================================
   BADGE COMPONENT
   ============================================================ */
.badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px;
	border-radius: 50px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1.2;
}

.badge-primary {
	background-color: rgba(0,119,182,0.1);
	color: var(--color-primary);
}

.badge-accent {
	background-color: rgba(240,165,0,0.15);
	color: var(--color-accent-dark);
}

.badge-success {
	background-color: rgba(72,187,120,0.12);
	color: #276749;
}

.badge-dark {
	background-color: var(--color-dark);
	color: var(--color-white);
}

/* ============================================================
   HERO OVERLAY VARIANTS
   ============================================================ */
.hero-overlay--dark {
	background: linear-gradient(180deg, rgba(6,13,20,0.85) 0%, rgba(6,13,20,0.7) 100%);
}

.hero-overlay--gradient {
	background: linear-gradient(135deg, rgba(0,119,182,0.85) 0%, rgba(6,13,20,0.9) 60%);
}

.hero-overlay--blue {
	background: linear-gradient(135deg, rgba(0,90,142,0.9) 0%, rgba(0,119,182,0.75) 100%);
}

/* ============================================================
   SERVICE ICON VARIANTS
   ============================================================ */
.service-icon-wrapper {
	width: 60px;
	height: 60px;
	border-radius: var(--radius-base);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.625rem;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.service-icon-wrapper--blue {
	background-color: rgba(0,119,182,0.1);
	color: var(--color-primary);
}

.service-icon-wrapper--gold {
	background-color: rgba(240,165,0,0.12);
	color: var(--color-accent-dark);
}

.service-icon-wrapper--dark {
	background-color: var(--color-dark);
	color: var(--color-white);
}

.service-icon-wrapper:hover {
	transform: scale(1.08);
	box-shadow: var(--shadow-md);
}

/* ============================================================
   TESTIMONIAL CARD
   ============================================================ */
.testimonial-card {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	padding: 32px;
	position: relative;
	box-shadow: var(--shadow-sm);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.testimonial-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.testimonial-card__quote {
	position: absolute;
	top: 20px;
	right: 24px;
	font-size: 4rem;
	color: var(--color-primary);
	opacity: 0.1;
	line-height: 1;
	font-family: Georgia, serif;
}

.testimonial-card__stars {
	display: flex;
	gap: 3px;
	margin-bottom: 14px;
}

.testimonial-card__star {
	color: var(--color-accent);
	font-size: 1rem;
}

.testimonial-card__text {
	font-size: 1rem;
	color: var(--color-text);
	line-height: 1.75;
	margin-bottom: 20px;
	font-style: italic;
}

.testimonial-card__author {
	display: flex;
	align-items: center;
	gap: 12px;
}

.testimonial-card__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background-color: var(--color-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-white);
	font-weight: 700;
	font-size: 1rem;
	flex-shrink: 0;
	overflow: hidden;
}

.testimonial-card__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.testimonial-card__name {
	font-weight: 700;
	color: var(--color-dark);
	font-size: 0.9375rem;
}

.testimonial-card__role {
	font-size: 0.8125rem;
	color: var(--color-text-muted);
	margin-top: 2px;
}

/* ============================================================
   INFO CARD COMPONENT
   ============================================================ */
.info-card {
	background-color: var(--color-white);
	border-left: 4px solid var(--color-primary);
	border-radius: 0 var(--radius-base) var(--radius-base) 0;
	padding: 20px 24px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.info-card--warning {
	border-left-color: var(--color-accent);
	background-color: rgba(240,165,0,0.04);
}

.info-card--success {
	border-left-color: #48bb78;
	background-color: rgba(72,187,120,0.05);
}

.info-card__icon {
	flex-shrink: 0;
	color: var(--color-primary);
}

.info-card--warning .info-card__icon { color: var(--color-accent-dark); }
.info-card--success .info-card__icon { color: #276749; }

.info-card__title {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-dark);
	margin-bottom: 4px;
}

.info-card__text {
	font-size: 0.9rem;
	color: var(--color-text-muted);
	line-height: 1.6;
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumbs {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.875rem;
}

.breadcrumbs a {
	color: rgba(255,255,255,0.6);
	text-decoration: none;
	transition: color 0.2s ease;
}

.breadcrumbs a:hover {
	color: var(--color-accent);
}

.breadcrumbs .separator {
	color: rgba(255,255,255,0.3);
}

.breadcrumbs .current {
	color: rgba(255,255,255,0.4);
}

/* Yoast SEO breadcrumbs */
.breadcrumb_last {
	color: rgba(255,255,255,0.4);
}

/* ============================================================
   STAT COUNTER CARD
   ============================================================ */
.stat-counter-card {
	text-align: center;
	padding: 24px;
	background-color: var(--color-white);
	border-radius: var(--radius-card);
	border: 1px solid var(--color-border);
}

.stat-counter-card__number {
	font-size: 2.75rem;
	font-weight: 800;
	color: var(--color-primary);
	line-height: 1;
	margin-bottom: 8px;
}

.stat-counter-card__label {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--color-text-muted);
}

/* ============================================================
   ACCORDION / FAQ
   ============================================================ */
.accordion {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	overflow: hidden;
}

.accordion-item {
	border-bottom: 1px solid var(--color-border);
}

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

.accordion-header {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 24px;
	background-color: var(--color-white);
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: var(--font-family);
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-dark);
	transition: background-color 0.2s ease;
}

.accordion-header:hover {
	background-color: rgba(0,119,182,0.04);
}

.accordion-header[aria-expanded="true"] {
	background-color: rgba(0,119,182,0.06);
	color: var(--color-primary);
}

.accordion-icon {
	width: 24px;
	height: 24px;
	flex-shrink: 0;
	color: var(--color-primary);
	transition: transform 0.3s ease;
}

.accordion-header[aria-expanded="true"] .accordion-icon {
	transform: rotate(180deg);
}

.accordion-body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.35s ease;
}

.accordion-body.is-open {
	max-height: 500px;
}

.accordion-body__inner {
	padding: 8px 24px 20px;
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	line-height: 1.7;
}

/* ============================================================
   PROGRESS / LOADING STATES
   ============================================================ */
.skeleton {
	background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
	background-size: 200% 100%;
	animation: skeletonShimmer 1.4s infinite;
	border-radius: var(--radius-base);
}

@keyframes skeletonShimmer {
	0% { background-position: -200% 0; }
	100% { background-position: 200% 0; }
}

/* ============================================================
   NOTICE / ALERT COMPONENTS
   ============================================================ */
.alert {
	padding: 14px 20px;
	border-radius: var(--radius-base);
	font-size: 0.9375rem;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 16px;
}

.alert-info {
	background-color: rgba(0,119,182,0.08);
	border: 1px solid rgba(0,119,182,0.2);
	color: var(--color-primary-dark);
}

.alert-success {
	background-color: rgba(72,187,120,0.1);
	border: 1px solid rgba(72,187,120,0.3);
	color: #276749;
}

.alert-warning {
	background-color: rgba(240,165,0,0.1);
	border: 1px solid rgba(240,165,0,0.3);
	color: #744210;
}

.alert-error {
	background-color: rgba(229,62,62,0.08);
	border: 1px solid rgba(229,62,62,0.25);
	color: #c53030;
}

/* ============================================================
   HOVER CARD (lift effect)
   ============================================================ */
.hover-lift {
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.hover-lift:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-lg);
}

/* ============================================================
   MEDIA CARD
   ============================================================ */
.media-card {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

.media-card__icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border-radius: var(--radius-base);
	background-color: rgba(0,119,182,0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-primary);
}

.media-card__body { flex: 1; min-width: 0; }

.media-card__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-dark);
	margin-bottom: 6px;
}

.media-card__text {
	font-size: 0.9rem;
	color: var(--color-text-muted);
	line-height: 1.6;
}

/* ============================================================
   DIVIDERS
   ============================================================ */
.section-divider {
	width: 100%;
	height: 1px;
	background-color: var(--color-border);
	margin: 48px 0;
}

.section-divider--accent {
	height: 3px;
	background: linear-gradient(to right, var(--color-primary), var(--color-accent));
	border-radius: 3px;
}

/* ============================================================
   PILL TAGS
   ============================================================ */
.pill-group {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.pill {
	display: inline-block;
	padding: 5px 14px;
	border-radius: 50px;
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.pill--outline {
	border: 1px solid var(--color-border);
	color: var(--color-text-muted);
	background-color: transparent;
}

.pill--outline:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.pill--primary {
	background-color: rgba(0,119,182,0.1);
	color: var(--color-primary);
}

.pill--accent {
	background-color: rgba(240,165,0,0.12);
	color: var(--color-accent-dark);
}

/* ============================================================
   ICON TEXT LIST
   ============================================================ */
.icon-text-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.icon-text-list__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	font-size: 0.9375rem;
	color: var(--color-text);
	line-height: 1.6;
}

.icon-text-list__icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	color: var(--color-primary);
	margin-top: 1px;
}

.icon-text-list--check .icon-text-list__icon {
	color: #48bb78;
}

/* ============================================================
   RESPONSIVE IMAGE RATIOS
   ============================================================ */
.aspect-ratio-16-9 {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.aspect-ratio-16-9 > * {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.aspect-ratio-4-3 {
	position: relative;
	padding-bottom: 75%;
	height: 0;
	overflow: hidden;
}

.aspect-ratio-4-3 > * {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ============================================================
   STICKY CTA BAR (mobile)
   ============================================================ */
.sticky-cta-bar {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 90;
	background-color: var(--color-dark);
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 12px 16px;
	gap: 12px;
	align-items: center;
	justify-content: center;
}

@media (max-width: 768px) {
	.sticky-cta-bar { display: flex; }
	body { padding-bottom: 70px; }
}

.sticky-cta-bar .btn {
	flex: 1;
	justify-content: center;
	font-size: 0.875rem;
	padding: 11px 16px;
}

/* ============================================================
   COOKIE NOTICE (base styles)
   ============================================================ */
.cookie-notice {
	position: fixed;
	bottom: 16px;
	left: 16px;
	right: 16px;
	max-width: 480px;
	background-color: var(--color-dark);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: var(--radius-card);
	padding: 20px 24px;
	z-index: 9000;
	box-shadow: var(--shadow-lg);
	display: none;
}

.cookie-notice.is-visible {
	display: block;
}

.cookie-notice__text {
	font-size: 0.9rem;
	color: rgba(255,255,255,0.75);
	margin-bottom: 14px;
	line-height: 1.6;
}

.cookie-notice__actions {
	display: flex;
	gap: 10px;
}

/* ============================================================
   PRINT STYLES
   ============================================================ */
@media print {
	.site-header,
	.site-footer,
	.nav-toggle,
	.cta-banner,
	.hero-phone-cta,
	.sticky-cta-bar {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
		background: #fff;
	}

	.container {
		max-width: 100%;
		padding: 0;
	}

	a { color: #000; text-decoration: underline; }

	.btn {
		border: 1px solid #000;
		background: transparent;
		color: #000;
	}
}

/* ── Testimonials ─────────────────────────────────────────────────────────── */
.testimonials-section {
	padding: 80px 0;
	background: var(--color-light);
}

.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 32px;
	margin-top: 48px;
}

.testimonial-card {
	background: var(--color-white);
	border-radius: 12px;
	padding: 32px;
	box-shadow: var(--shadow-md);
	display: flex;
	flex-direction: column;
	gap: 16px;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.testimonial-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.testimonial-stars {
	display: flex;
	gap: 4px;
}

.star {
	font-size: 1.1rem;
	color: var(--color-border);
}

.star.filled {
	color: var(--color-accent);
}

.testimonial-quote {
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--color-text);
	margin: 0;
	font-style: italic;
	flex: 1;
}

.testimonial-author {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding-top: 16px;
	border-top: 1px solid var(--color-border);
}

.testimonial-name {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--color-dark);
}

.testimonial-role {
	font-size: 0.82rem;
	color: var(--color-text-muted);
}

@media (max-width: 640px) {
	.testimonials-grid {
		grid-template-columns: 1fr;
	}
}
