/**
 * Paw Pets — frontend pet management
 */

.paw-pets {
	max-width: var(--hp-container-md, 768px);
	margin: 0 auto;
}

.paw-pets__header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--hp-space-3, 0.75rem);
	margin-bottom: var(--hp-space-5, 1.5rem);
}

.paw-pets__title {
	margin: 0;
	font-size: var(--hp-font-size-2xl, 1.5rem);
}

.paw-pets-notice {
	margin: 0 0 var(--hp-space-4, 1rem);
	padding: var(--hp-space-3, 0.75rem) var(--hp-space-4, 1rem);
	background: var(--hp-pink-50, #fff5f8);
	border: 1px solid var(--hp-pink-200, #ffd0de);
	border-radius: var(--hp-radius-lg, 0.75rem);
}

.paw-pets-notice--error {
	background: #fff5f5;
	border-color: #fecaca;
	color: #991b1b;
}

.paw-pets-empty {
	padding: var(--hp-space-8, 3rem) var(--hp-space-5, 1.5rem);
	text-align: center;
}

.paw-pets-empty p {
	margin: 0 0 var(--hp-space-4, 1rem);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: var(--hp-space-4, 1rem);
}

.paw-pets-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.paw-pets-card__media {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--hp-cream-100, #fff8f0);
}

.paw-pets-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.paw-pets-card__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 3rem;
}

.paw-pets-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: var(--hp-space-2, 0.5rem);
	padding: var(--hp-space-4, 1rem);
}

.paw-pets-card__name {
	margin: 0;
	font-size: var(--hp-font-size-lg, 1.125rem);
}

.paw-pets-card__name a {
	color: inherit;
	text-decoration: none;
}

.paw-pets-card__meta {
	margin: 0;
	font-size: var(--hp-font-size-sm, 0.875rem);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-card__actions {
	display: flex;
	gap: var(--hp-space-2, 0.5rem);
	margin-top: auto;
	padding-top: var(--hp-space-2, 0.5rem);
}

.paw-pets-card__delete-form {
	margin: 0;
}

.paw-pets-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.25rem;
	padding: 0 var(--hp-space-3, 0.75rem);
	font: inherit;
	font-size: var(--hp-font-size-sm, 0.875rem);
	font-weight: var(--hp-font-weight-semibold, 600);
	text-decoration: none;
	border: 1px solid var(--hp-color-border, #ffe4ec);
	border-radius: var(--hp-radius-full, 999px);
	cursor: pointer;
	background: var(--hp-color-surface, #fff);
	color: var(--hp-color-text, #4a3f47);
}

.paw-pets-card__btn--edit {
	background: var(--hp-pink-50, #fff5f8);
	border-color: var(--hp-pink-200, #ffd0de);
}

.paw-pets-card__btn--delete {
	background: #fff;
	border-color: #fecaca;
	color: #b91c1c;
}

.paw-pets-form {
	padding: var(--hp-space-5, 1.5rem);
}

.paw-pets-form__title {
	margin: 0 0 var(--hp-space-4, 1rem);
	font-size: var(--hp-font-size-xl, 1.25rem);
}

.paw-pets-field {
	margin-bottom: var(--hp-space-4, 1rem);
}

.paw-pets-field__label {
	display: block;
	margin-bottom: var(--hp-space-2, 0.5rem);
	font-size: var(--hp-font-size-sm, 0.875rem);
	font-weight: var(--hp-font-weight-semibold, 600);
}

.paw-pets-field__hint {
	margin: calc(var(--hp-space-2, 0.5rem) * -1) 0 var(--hp-space-3, 0.75rem);
	font-size: var(--hp-font-size-xs, 0.75rem);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-upload-default-preview {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--hp-space-2, 0.5rem);
	margin-top: var(--hp-space-3, 0.75rem);
	font-size: var(--hp-font-size-xs, 0.75rem);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-upload-default-preview img {
	width: 5rem;
	height: 5rem;
	object-fit: contain;
	border-radius: var(--hp-radius-md, 0.5rem);
}

.paw-pets-req {
	color: var(--hp-color-accent, #e891a8);
}

.paw-pets-input {
	display: block;
	width: 100%;
	padding: var(--hp-space-3, 0.75rem);
	font: inherit;
	border: 1px solid var(--hp-color-border, #ffe4ec);
	border-radius: var(--hp-radius-md, 0.5rem);
	background: #fff;
}

.paw-pets-textarea {
	min-height: 7rem;
	resize: vertical;
}

.paw-pets-form__preview {
	margin-bottom: var(--hp-space-3, 0.75rem);
}

.paw-pets-form__preview img {
	width: 7.5rem;
	height: 7.5rem;
	object-fit: cover;
	border: 3px solid var(--hp-color-surface, #fff);
	border-radius: var(--hp-radius-full, 999px);
	box-shadow: var(--hp-shadow-sm, 0 1px 3px rgba(0, 0, 0, 0.08));
}

.paw-pets-form__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--hp-space-3, 0.75rem);
	margin-top: var(--hp-space-5, 1.5rem);
}

.paw-pets-form__submit {
	min-width: 8rem;
}

@media (max-width: 640px) {
	.paw-pets__header {
		flex-direction: column;
		align-items: stretch;
	}

	.paw-pets__add-btn {
		width: 100%;
		text-align: center;
	}
}

/* -------------------------------------------------------------------------
   Profile hub — single page on /profile/?a=edit
   ------------------------------------------------------------------------- */

body.paw-pets-profile-page .hp-container--auth {
	width: min(960px, calc(100vw - var(--hp-container-padding) * 2));
	max-width: 960px;
}

.hp-wpmem-shell--profile-pets {
	max-width: 960px;
}

.paw-pets-profile-hub {
	padding: 0 var(--hp-space-5, 1.5rem) var(--hp-space-5, 1.5rem);
}

.paw-pets-profile-main .div_text,
.paw-pets-profile-main .div_multicheckbox,
.paw-pets-profile-main .div_checkbox,
.paw-pets-profile-main .div_select,
.paw-pets-profile-main .div_textarea {
	margin-bottom: var(--hp-space-4, 1rem);
}

.paw-pets-profile-actions {
	display: flex;
	flex-wrap: nowrap;
	gap: var(--hp-space-3, 0.75rem);
	width: 100%;
	margin: var(--hp-space-4, 1rem) 0;
	padding-top: var(--hp-space-4, 1rem);
	border-top: 1px solid var(--hp-color-border, #ffe4ec);
}

.paw-pets-profile-actions__btn {
	flex: 1 1 0;
	width: 50%;
	min-width: 0;
	justify-content: center;
	text-align: center;
}

.paw-pets-profile-drawer {
	margin-bottom: var(--hp-space-4, 1rem);
	padding: var(--hp-space-4, 1rem);
	background: var(--hp-pink-50, #fff5f8);
	border: 1px solid var(--hp-color-border, #ffe4ec);
	border-radius: var(--hp-radius-lg, 0.75rem);
}

.paw-pets-profile-drawer.is-open {
	display: block;
}

.paw-pets-profile-bottom {
	margin-top: var(--hp-space-6, 2rem);
	padding-top: var(--hp-space-5, 1.5rem);
	border-top: 1px solid var(--hp-color-border, #ffe4ec);
}

.paw-pets-profile-section__title {
	margin: 0 0 var(--hp-space-4, 1rem);
	font-size: var(--hp-font-size-lg, 1.125rem);
}

.paw-pets-notice--success {
	background: #f0fdf4;
	border-color: #bbf7d0;
	color: #166534;
}

.paw-pets-notice--warning {
	background: #fffbeb;
	border-color: #fde68a;
	color: #92400e;
}

.paw-pets-card__media--placeholder img {
	object-fit: contain;
	padding: var(--hp-space-4, 1rem);
}

.paw-pets-char-counter {
	margin-left: var(--hp-space-2, 0.5rem);
	font-size: var(--hp-font-size-xs, 0.75rem);
	font-weight: var(--hp-font-weight-normal, 400);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-card__details {
	display: grid;
	gap: var(--hp-space-2, 0.5rem);
	margin: 0;
}

.paw-pets-card__detail {
	display: grid;
	gap: 0.15rem;
}

.paw-pets-card__detail dt {
	margin: 0;
	font-size: var(--hp-font-size-xs, 0.75rem);
	font-weight: var(--hp-font-weight-semibold, 600);
	color: var(--hp-color-text-muted, #8a7b82);
}

.paw-pets-card__detail dd {
	margin: 0;
	font-size: var(--hp-font-size-sm, 0.875rem);
}

.paw-pets-card__detail--about dd {
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}

.paw-pets-upload-preview__image {
	width: 100%;
	max-width: 240px;
	aspect-ratio: 1;
	border-radius: var(--hp-radius-lg, 0.75rem);
	background-size: cover;
	background-position: center;
}

.paw-pets-field--gallery-url .paw-pets-gallery-url-pick {
	margin-bottom: var(--hp-space-2, 0.5rem);
}

.paw-pets-gallery-pick__preview {
	margin: 0 0 var(--hp-space-3, 0.75rem);
}

.paw-pets-gallery-pick__preview img {
	display: block;
	width: 7.5rem;
	height: 7.5rem;
	object-fit: cover;
	border: 2px solid var(--hp-pink-200, #ffd0de);
	border-radius: var(--hp-radius-lg, 0.75rem);
	background: var(--hp-cream-100, #fff8f0);
}

.paw-pets-field--upload .paw-upload--profile-pet {
	margin-top: var(--hp-space-2, 0.5rem);
}

.paw-pets-field--upload .paw-pets-upload-input {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
