/**
 * Component Styles
 *
 * Reusable UI components (buttons, cards, forms, badges)
 */

/* ========================================
   BUTTONS
   ======================================== */
.bp-btn {
	display: inline-block;
	padding: var(--space-md) var(--space-xl);
	font-size: var(--text-body);
	font-weight: var(--font-weight-semibold);
	text-align: center;
	text-decoration: none;
	border-radius: var(--radius-full);
	border: none;
	cursor: pointer;
	transition: all var(--transition-speed) var(--transition-easing);
	min-height: 44px;
	min-width: 44px;
	line-height: 1.5;
}

.bp-btn-primary {
	background: var(--gradient-billie);
	color: var(--color-white);
	box-shadow: var(--shadow-md);
}

.bp-btn-primary:hover,
.bp-btn-primary:focus {
	transform: translateY(-2px);
	box-shadow: var(--shadow-hover);
	color: var(--color-white);
}

.bp-btn-secondary {
	background: var(--gradient-papi);
	color: var(--color-white);
	box-shadow: var(--shadow-md);
}

.bp-btn-secondary:hover,
.bp-btn-secondary:focus {
	transform: translateY(-2px);
	box-shadow: var(--shadow-hover);
	color: var(--color-white);
}

.bp-btn-outline {
	background: transparent;
	color: var(--color-charcoal);
	border: 2px solid var(--color-charcoal);
}

.bp-btn-outline:hover,
.bp-btn-outline:focus {
	background: var(--color-charcoal);
	color: var(--color-white);
}

.bp-btn:focus-visible {
	outline: 3px solid var(--color-teal-fresh);
	outline-offset: 3px;
}

/* ========================================
   BADGES
   ======================================== */
.bp-badge {
	display: inline-block;
	padding: 6px 16px;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	background: var(--color-cream);
	color: var(--color-charcoal);
	border-radius: var(--radius-full);
	text-decoration: none;
	transition: all var(--transition-speed) var(--transition-easing);
}

.bp-badge:hover {
	background: var(--color-pink-primary);
	color: var(--color-white);
}

.bp-badge.active {
	background: var(--gradient-billie);
	color: var(--color-white);
}

.bp-category-badge {
	background: var(--color-pink-primary);
	color: var(--color-white);
	position: absolute;
	top: var(--space-md);
	left: var(--space-md);
	z-index: var(--z-base);
}

/* ========================================
   FORMS
   ======================================== */
.bp-form-group {
	margin-bottom: var(--space-lg);
}

.bp-label {
	display: block;
	margin-bottom: var(--space-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-charcoal);
}

.bp-input,
.bp-textarea,
.bp-select {
	width: 100%;
	padding: var(--space-md);
	font-size: var(--text-body);
	font-family: var(--font-primary);
	color: var(--color-charcoal);
	background: var(--color-white);
	border: 2px solid var(--color-cream);
	border-radius: var(--radius-sm);
	transition: border-color var(--transition-speed) var(--transition-easing);
	min-height: 44px;
}

.bp-input:focus,
.bp-textarea:focus,
.bp-select:focus {
	outline: none;
	border-color: var(--color-teal-fresh);
	box-shadow: 0 0 0 3px rgba(78, 205, 196, 0.1);
}

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

.bp-input::placeholder,
.bp-textarea::placeholder {
	color: var(--color-gray);
}

/* Search Form */
.search-form {
	display: flex;
	gap: var(--space-sm);
	max-width: 500px;
	margin: 0 auto;
}

.search-field {
	flex: 1;
	padding: var(--space-md);
	font-size: var(--text-body);
	border: 2px solid var(--color-cream);
	border-radius: var(--radius-sm);
}

.search-submit {
	padding: var(--space-md) var(--space-lg);
	background: var(--gradient-billie);
	color: var(--color-white);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	font-size: var(--text-body-lg);
	min-height: 44px;
	min-width: 44px;
}

/* ========================================
   CARDS
   ======================================== */
.bp-card {
	background: var(--color-white);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
	transition: all var(--transition-speed) var(--transition-easing);
	height: 100%;
}

.bp-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-hover);
}

/* Pet Card */
.bp-pet-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-md);
	text-align: center;
	transition: all var(--transition-speed) var(--transition-easing);
}

.bp-pet-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-hover);
}

.bp-pet-avatar {
	width: 200px;
	height: 200px;
	border-radius: 50%;
	margin: 0 auto var(--space-lg);
	padding: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.bp-pet-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50%;
}

.bp-pet-name {
	font-size: var(--text-h3);
	margin-bottom: var(--space-sm);
}

.bp-pet-meta {
	color: var(--color-gray);
	margin-bottom: var(--space-md);
	font-size: var(--text-sm);
}

.bp-pet-traits {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: center;
	margin-bottom: var(--space-md);
}

.bp-pet-bio {
	font-size: var(--text-body);
	color: var(--color-gray);
	line-height: var(--line-height-relaxed);
}

/* ========================================
   PAGINATION
   ======================================== */
.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-sm);
	margin-top: var(--space-2xl);
}

.pagination a,
.pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: var(--space-sm) var(--space-md);
	font-size: var(--text-body);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
	color: var(--color-charcoal);
	background: var(--color-white);
	border: 2px solid var(--color-cream);
	border-radius: var(--radius-sm);
	transition: all var(--transition-speed) var(--transition-easing);
}

.pagination a:hover,
.pagination a:focus {
	background: var(--gradient-billie);
	color: var(--color-white);
	border-color: transparent;
}

.pagination .current {
	background: var(--gradient-billie);
	color: var(--color-white);
	border-color: transparent;
}

.pagination .dots {
	border: none;
	background: transparent;
}

/* ========================================
   SOCIAL LINKS
   ======================================== */
.social-links {
	display: flex;
	gap: var(--space-md);
	justify-content: center;
	flex-wrap: wrap;
}

.social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	font-size: 24px;
	background: var(--color-cream);
	border-radius: 50%;
	transition: all var(--transition-speed) var(--transition-easing);
}

.social-link:hover {
	transform: translateY(-4px) scale(1.1);
	box-shadow: var(--shadow-md);
}

/* ========================================
   SOCIAL SHARE BUTTONS
   ======================================== */
.bp-social-share {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
	justify-content: center;
}

.bp-share-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-lg);
	background: var(--color-cream);
	color: var(--color-charcoal);
	border: none;
	border-radius: var(--radius-full);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-speed) var(--transition-easing);
	min-height: 44px;
}

.bp-share-btn:hover {
	background: var(--color-pink-primary);
	color: var(--color-white);
	transform: translateY(-2px);
}

.social-share-section {
	margin-top: var(--space-2xl);
	padding-top: var(--space-2xl);
	border-top: 2px solid var(--color-cream);
}

.social-share-section h3 {
	text-align: center;
	margin-bottom: var(--space-lg);
}

/* ========================================
   WIDGETS
   ======================================== */
.widget {
	margin-bottom: var(--space-xl);
}

.widget-title {
	font-size: var(--text-h4);
	margin-bottom: var(--space-md);
}

.footer-widget-title {
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

/* ========================================
   NEWSLETTER FORM
   ======================================== */
.newsletter-form {
	max-width: 500px;
	margin: 0 auto;
}

.newsletter-form .bp-flex {
	display: flex;
	gap: var(--space-sm);
}

.newsletter-form input[type="email"] {
	flex: 1;
}

.newsletter-privacy {
	font-size: var(--text-sm);
	color: var(--color-gray);
	margin-top: var(--space-sm);
	text-align: center;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */
@media (max-width: 768px) {
	.bp-btn {
		padding: var(--space-sm) var(--space-lg);
		font-size: var(--text-sm);
	}

	.bp-pet-avatar {
		width: 150px;
		height: 150px;
	}

	.pagination {
		gap: 4px;
	}

	.pagination a,
	.pagination span {
		min-width: 40px;
		padding: 8px 12px;
		font-size: var(--text-sm);
	}

	.bp-social-share {
		justify-content: flex-start;
	}

	.bp-share-text {
		display: none;
	}

	.bp-share-btn {
		width: 44px;
		justify-content: center;
		padding: var(--space-sm);
	}
}
