/**
 * Geo Pincode - Use My Location button styles
 * Fully responsive with auto-calculated sizing
 *
 * @package AmitraFlex_Plug
 */

.afp-geopincode-btn {
	--afp-gp-size: clamp(36px, 11vw, 52px);
	--afp-gp-border: clamp(1px, 0.4vw, 2px);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-left: clamp(6px, 1.5vw, 10px);
	padding: 0;
	background: none;
	border: var(--afp-gp-border) solid #ff8057;
	border-radius: 50%;
	overflow: hidden;
	width: var(--afp-gp-size);
	height: var(--afp-gp-size);
	min-width: var(--afp-gp-size);
	min-height: var(--afp-gp-size);
	color: inherit;
	font-weight: inherit;
	font-family: inherit;
	cursor: pointer;
	transition: opacity 0.2s ease, transform 0.2s ease;
	vertical-align: middle;
}

.afp-geopincode-btn svg,
.afp-geopincode-btn img {
	display: block;
	width: calc(var(--afp-gp-size) - (var(--afp-gp-border) * 4));
	height: calc(var(--afp-gp-size) - (var(--afp-gp-border) * 4));
	max-width: 100%;
	max-height: 100%;
}

.afp-geopincode-btn img {
	object-fit: cover;
	border-radius: 50%;
}

.afp-geopincode-btn svg {
	object-fit: contain;
}

.afp-geopincode-btn:focus-visible {
	outline: 2px solid #ff8057;
	outline-offset: 2px;
}

.afp-geopincode-btn:hover:not(:disabled) {
	opacity: 0.9;
	transform: scale(1.05);
}

.afp-geopincode-btn:active:not(:disabled) {
	transform: scale(0.98);
}

.afp-geopincode-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

/* Loading state: spinner instead of clipped text */
.afp-geopincode-btn--loading .afp-geopincode-spinner {
	display: block;
	width: 60%;
	height: 60%;
	border: 2px solid rgba(255, 128, 87, 0.3);
	border-top-color: #ff8057;
	border-radius: 50%;
	animation: afp-geopincode-spin 0.7s linear infinite;
}

@keyframes afp-geopincode-spin {
	to {
		transform: rotate(360deg);
	}
}
