/**
 * KRPP Contact Popup – structural styles (colors/sizes via Elementor selectors).
 */

.krpp-cp {
	--krpp-cp-duration: 0.35s;
	position: relative;
	width: 100%;
}

/* Visually hidden checkbox (keyboard focusable) */
.krpp-cp__state {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.krpp-cp__state:focus-visible + .krpp-cp__trigger-wrap .krpp-cp__btn {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

/* Trigger alignment wrapper */
.krpp-cp__trigger-wrap {
	display: flex;
	width: 100%;
}

/* Open button */
.krpp-cp__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	cursor: pointer;
	text-decoration: none;
	border: none;
	box-sizing: border-box;
	transition: color var(--krpp-cp-duration) ease,
		background-color var(--krpp-cp-duration) ease,
		border-color var(--krpp-cp-duration) ease,
		box-shadow var(--krpp-cp-duration) ease,
		transform var(--krpp-cp-duration) ease;
	-webkit-tap-highlight-color: transparent;
}

/* Button icon position variants */
.krpp-cp__btn--icon-left {
	flex-direction: row;
}

.krpp-cp__btn--icon-above {
	flex-direction: column;
}

.krpp-cp__btn--icon-right {
	flex-direction: row-reverse;
}

.krpp-cp__btn-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 0;
	width: 1.25em;
	height: 1.25em;
	color: inherit;
	font-size: inherit;
}

.krpp-cp__btn-icon svg {
	display: block;
	width: 100%;
	height: 100%;
}

.krpp-cp__btn-icon img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: contain;
}

/* Preserve SVG colors - only use currentColor for black strokes/outlines */
.krpp-cp__btn-icon svg [stroke]:not([stroke="none"]) {
	stroke: currentColor;
}

.krpp-cp__btn-icon svg [fill="none"],
.krpp-cp__btn-icon svg [fill=""] {
	fill: currentColor;
}

.krpp-cp__btn-text {
	display: inline-block;
}

/* Backdrop */
.krpp-cp__backdrop {
	position: fixed;
	inset: 0;
	z-index: 9998;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--krpp-cp-duration) ease,
		visibility var(--krpp-cp-duration) ease;
}

.krpp-cp__state:checked ~ .krpp-cp__backdrop {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

/* Modal panel */
.krpp-cp__modal {
	position: fixed;
	z-index: 9999;
	box-sizing: border-box;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: scale(0.96) translateY(8px);
	transition: opacity var(--krpp-cp-duration) ease,
		visibility var(--krpp-cp-duration) ease,
		transform var(--krpp-cp-duration) ease;
	overflow: auto;
	max-height: calc(100vh - 2rem);
}

.krpp-cp__state:checked ~ .krpp-cp__modal {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: scale(1) translateY(0);
}

/* Center modal by default; Elementor may override position */
.krpp-cp__modal {
	top: 50%;
	left: 50%;
	transform: scale(0.96) translate(-50%, calc(-50% + 8px));
}

.krpp-cp__state:checked ~ .krpp-cp__modal {
	transform: scale(1) translate(-50%, -50%);
}

/* Close control */
.krpp-cp__close {
	position: absolute;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	line-height: 1;
	text-decoration: none;
	border: none;
	background: transparent;
	padding: 0;
	transition: color var(--krpp-cp-duration) ease;
	-webkit-tap-highlight-color: transparent;
}

.krpp-cp__close:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

.krpp-cp__close-icon {
	display: block;
	line-height: 1;
}

.krpp-cp__close-icon svg {
	display: block;
	fill: currentColor;
}

/* Contact grid */
.krpp-cp__grid {
	display: grid;
	width: 100%;
	box-sizing: border-box;
}

/* Contact card – vertical layout (mandatory) */
.krpp-cp__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	text-decoration: none;
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	transition: background-color var(--krpp-cp-duration) ease,
		border-color var(--krpp-cp-duration) ease,
		box-shadow var(--krpp-cp-duration) ease,
		color var(--krpp-cp-duration) ease;
}

/* Icon position variants */
.krpp-cp__card--icon-above {
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.krpp-cp__card--icon-left {
	flex-direction: row;
	align-items: flex-start;
	text-align: left;
	gap: 1rem;
}

.krpp-cp__card--icon-right {
	flex-direction: row-reverse;
	align-items: flex-start;
	text-align: right;
	gap: 1rem;
}

/* Content wrapper for title and description */
.krpp-cp__card-content {
	display: flex;
	flex-direction: column;
	width: 100%;
}

.krpp-cp__card--icon-left .krpp-cp__card-content,
.krpp-cp__card--icon-right .krpp-cp__card-content {
	flex: 1;
}

.krpp-cp__card:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

/* Icon above title */
.krpp-cp__icon {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 0;
	box-sizing: border-box;
	width: 48px;
	height: 48px;
	color: var(--krpp-cp-icon-color, currentColor);
}

/* Icon spacing for different positions */
.krpp-cp__card--icon-above .krpp-cp__icon {
	margin-bottom: 0.5rem;
}

.krpp-cp__card--icon-left .krpp-cp__icon,
.krpp-cp__card--icon-right .krpp-cp__icon {
	margin-bottom: 0;
	flex-shrink: 0;
}

.krpp-cp__icon svg {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	overflow: visible;
}

/* Preserve SVG original colors by default - don't override fill/stroke */
.krpp-cp__icon svg path,
.krpp-cp__icon svg circle,
.krpp-cp__icon svg rect,
.krpp-cp__icon svg line,
.krpp-cp__icon svg polyline,
.krpp-cp__icon svg polygon,
.krpp-cp__icon svg ellipse {
	/* Keep original fill and stroke values */
}

/* Only apply currentColor for strokes when fill="none" */
.krpp-cp__icon svg [fill="none"] {
	stroke: currentColor;
}

/* For SVGs without any fill, use currentColor */
.krpp-cp__icon svg:not([viewBox]) *:not([fill]):not([stroke]),
.krpp-cp__icon svg [fill=""] {
	fill: currentColor;
}

.krpp-cp__icon img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: contain;
}

.krpp-cp__card-title {
	display: block;
	width: 100%;
}

.krpp-cp__card--icon-above .krpp-cp__card-title {
	text-align: center;
}

.krpp-cp__card--icon-left .krpp-cp__card-title {
	text-align: left;
}

.krpp-cp__card--icon-right .krpp-cp__card-title {
	text-align: right;
}

.krpp-cp__card-desc {
	display: block;
	width: 100%;
}

.krpp-cp__card--icon-above .krpp-cp__card-desc {
	text-align: center;
}

.krpp-cp__card--icon-left .krpp-cp__card-desc {
	text-align: left;
}

.krpp-cp__card--icon-right .krpp-cp__card-desc {
	text-align: right;
}

/* Default responsive grid (overridden by Elementor) */
@media (max-width: 1024px) {
	.krpp-cp .krpp-cp__grid.krpp-cp__grid--default-tablet {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.krpp-cp .krpp-cp__grid.krpp-cp__grid--default-mobile {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.krpp-cp,
	.krpp-cp__btn,
	.krpp-cp__backdrop,
	.krpp-cp__modal,
	.krpp-cp__card,
	.krpp-cp__close {
		--krpp-cp-duration: 0.01ms;
	}
}
