/* ===========================================
   Single Listing - Premium Boutique Design
   Luxury feel with elegant animations
   =========================================== */

/* ===========================================
   Ad Status Notice - Pending/Rejected
   =========================================== */
.ad-status-notice {
	display: flex;
	gap: 16px;
	padding: 20px;
	border-radius: var(--radius-lg);
	margin-bottom: 24px;
	animation: itemReveal 0.5s ease backwards;
}

.ad-status-notice.pending-notice {
	background: linear-gradient(135deg, #fff9e6 0%, #fff5d6 100%);
	border: 1px solid #f0d78c;
}

.ad-status-notice .notice-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-size: 1.25rem;
}

.pending-notice .notice-icon {
	background: linear-gradient(135deg, #f0d78c 0%, #e6c56c 100%);
	color: #8b6914;
}

.ad-status-notice .notice-content {
	flex: 1;
}

.ad-status-notice .notice-content h3 {
	margin: 0 0 8px 0;
	font-size: 1.1rem;
	font-weight: 600;
	font-family: var(--font-heading);
}

.pending-notice .notice-content h3 {
	color: #8b6914;
}

.ad-status-notice .notice-content > p {
	margin: 0 0 16px 0;
	font-size: 0.9rem;
	line-height: 1.5;
	color: #6b5a1e;
}

.ad-status-notice .notice-steps {
	list-style: none;
	margin: 0 0 16px 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ad-status-notice .notice-steps li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.85rem;
	color: #6b5a1e;
}

.ad-status-notice .notice-steps li i {
	width: 18px;
	text-align: center;
}

.ad-status-notice .notice-steps li .fa-check {
	color: #4caf50;
}

.ad-status-notice .notice-steps li.current {
	font-weight: 600;
	color: #8b6914;
}

.ad-status-notice .notice-steps li.current i {
	color: #e6a700;
}

.ad-status-notice .notice-steps li.upcoming {
	color: #a89b6c;
}

.ad-status-notice .notice-steps li.upcoming i {
	color: #c4b896;
}

.ad-status-notice .notice-info {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 12px 16px;
	background: rgba(255, 255, 255, 0.6);
	border-radius: var(--radius-md);
	font-size: 0.85rem;
	color: #6b5a1e;
}

.ad-status-notice .notice-info i {
	color: #8b6914;
}

/* Mobile responsive */
@media (max-width: 768px) {
	.ad-status-notice {
		flex-direction: column;
		gap: 12px;
		padding: 16px;
	}

	.ad-status-notice .notice-icon {
		width: 40px;
		height: 40px;
		font-size: 1rem;
	}

	.ad-status-notice .notice-content h3 {
		font-size: 1rem;
	}

	.ad-status-notice .notice-content > p {
		font-size: 0.85rem;
	}

	.ad-status-notice .notice-steps li {
		font-size: 0.8rem;
	}

	.ad-status-notice .notice-info {
		padding: 10px 12px;
		font-size: 0.8rem;
	}
}

@keyframes itemReveal {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes slideInLeft {
	from {
		opacity: 0;
		transform: translateX(-20px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(20px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes thumbReveal {
	from {
		opacity: 0;
		transform: scale(0.9);
	}
	to {
		opacity: 0.6;
		transform: scale(1);
	}
}

.single-listing-container {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 64px;
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 20px 60px;
}

/* ===========================================
   Gallery - Elegant Image Display
   =========================================== */
.listing-gallery {
	position: relative;
	animation: slideInLeft 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
}

.main-image {
	width: 100%;
	aspect-ratio: 2/3;
	background: linear-gradient(135deg, var(--color-surface) 0%, #f5f5f5 100%);
	margin-bottom: 20px;
	overflow: hidden;
	border-radius: var(--radius-lg);
	box-shadow:
		0 8px 32px rgba(86, 66, 51, 0.1),
		0 2px 8px rgba(86, 66, 51, 0.05);
}

.main-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition:
		transform var(--transition-slow),
		filter var(--transition-base);
}

.main-image:hover img {
	transform: scale(1.02);
	filter: brightness(1.02);
}

.gallery-thumbnails {
	display: flex;
	gap: 12px;
	overflow-x: auto;
	padding-bottom: 10px;
	scrollbar-width: thin;
	scrollbar-color: var(--color-accent) transparent;
}

.gallery-thumbnails::-webkit-scrollbar {
	height: 4px;
}

.gallery-thumbnails::-webkit-scrollbar-track {
	background: var(--color-surface);
	border-radius: 2px;
}

.gallery-thumbnails::-webkit-scrollbar-thumb {
	background: var(--color-accent);
	border-radius: 2px;
}

.gallery-thumb {
	width: 75px;
	height: 110px;
	cursor: pointer;
	opacity: 0.6;
	transition:
		opacity var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
	flex-shrink: 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	animation: thumbReveal 0.4s ease backwards;
}

/* Staggered thumbnail animations */
.gallery-thumb:nth-child(1) { animation-delay: 0.1s; }
.gallery-thumb:nth-child(2) { animation-delay: 0.15s; }
.gallery-thumb:nth-child(3) { animation-delay: 0.2s; }
.gallery-thumb:nth-child(4) { animation-delay: 0.25s; }
.gallery-thumb:nth-child(5) { animation-delay: 0.3s; }

.gallery-thumb:hover {
	opacity: 0.9;
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(86, 66, 51, 0.15);
}

.gallery-thumb.active {
	opacity: 1;
	box-shadow:
		0 0 0 2px var(--color-accent),
		0 4px 12px rgba(212, 163, 115, 0.3);
}

.gallery-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ===========================================
   Product Info - Premium Typography
   =========================================== */
.listing-info,
.krpice-info {
	padding-top: 0;
	position: sticky;
	top: 100px;
	height: fit-content;
	animation: slideInRight 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) 0.1s backwards;
}

/* Listing Stats Row */
.krpice-listing-stats {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
	flex-wrap: wrap;
}

/* Published Date */
.krpice-published-date {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.8rem;
	color: var(--color-text-light);
	padding: 6px 14px;
	background: linear-gradient(135deg, var(--color-surface) 0%, #fff 100%);
	border-radius: var(--radius-full);
	border: 1px solid var(--color-border);
}

.krpice-published-date::before {
	content: '✦';
	font-size: 0.5rem;
	color: var(--color-accent);
}

.krpice-published-date i {
	font-size: 0.75rem;
}

/* Favorites Info - Simple elegant style */
.krpice-favorites-info {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	color: var(--color-text-light);
	font-size: 0.9rem;
}

.krpice-favorites-info i {
	color: var(--color-accent);
	font-size: 0.85rem;
}

.listing-title,
.krpice-title {
	font-family: var(--font-heading);
	font-size: 1.9rem;
	font-weight: 500;
	margin-bottom: 14px;
	color: var(--color-text);
	line-height: 1.2;
	letter-spacing: -0.02em;
	animation: itemReveal 0.5s ease 0.2s backwards;
}

.listing-price,
.krpice-info .krpice-price,
.single-listing-container .krpice-price {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	color: var(--color-primary);
	margin-bottom: 24px;
	font-weight: 600;
	letter-spacing: -0.02em;
	position: static !important;
	background: none !important;
	padding: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	bottom: auto !important;
	right: auto !important;
	animation: itemReveal 0.5s ease 0.25s backwards;
}

/* ===========================================
   Meta Info Card - Elevated Design
   =========================================== */
.krpice-meta-info {
	margin-bottom: 28px;
	padding: 20px;
	background: linear-gradient(135deg, var(--color-surface) 0%, #fff 100%);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	position: relative;
	animation: itemReveal 0.5s ease 0.3s backwards;
}

/* Decorative corner */
.krpice-meta-info::before {
	content: '◆';
	position: absolute;
	top: -6px;
	left: 20px;
	font-size: 0.5rem;
	color: var(--color-accent);
	background: #fff;
	padding: 0 8px;
}

.krpice-meta-info .krpice-meta-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	font-size: 0.9rem;
	border-bottom: 1px solid var(--color-border);
}

.krpice-meta-info .krpice-meta-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.krpice-meta-info .krpice-meta-item:first-child {
	padding-top: 0;
}

.krpice-meta-info .krpice-meta-item strong {
	color: var(--color-text-light);
	font-weight: 500;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

/* ===========================================
   Color Indicator - Visual Color Display
   =========================================== */
.krpice-color-item,
.color-detail-item {
	display: flex !important;
	align-items: center;
	gap: 10px;
}

.color-indicator {
	display: inline-block;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	border: 2px solid var(--color-border);
	flex-shrink: 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
	transition: transform var(--transition-fast);
}

.krpice-color-item:hover .color-indicator,
.color-detail-item:hover .color-indicator {
	transform: scale(1.15);
}

/* Multicolor gradient for "Više boja" */
.color-indicator.is-multicolor {
	background: conic-gradient(
		#FF0000 0deg,
		#FF8000 45deg,
		#FFFF00 90deg,
		#00FF00 135deg,
		#00FFFF 180deg,
		#0000FF 225deg,
		#8000FF 270deg,
		#FF00FF 315deg,
		#FF0000 360deg
	) !important;
}

/* White color needs visible border */
.color-indicator[style*="background-color: #FFFFFF"],
.color-indicator[style*="background-color: #ffffff"] {
	border-color: #ddd;
}

/* ===========================================
   Actions - Premium CTA Buttons
   =========================================== */
.listing-actions,
.krpice-actions {
	margin-bottom: 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	animation: itemReveal 0.5s ease 0.35s backwards;
}

.button-action {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	padding: 16px 24px;
	text-align: center;
	text-transform: uppercase;
	font-size: 0.8rem;
	letter-spacing: 0.1em;
	border: 2px solid transparent;
	border-radius: var(--radius-md);
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition:
		background var(--transition-base),
		color var(--transition-fast),
		border-color var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
	text-decoration: none;
	font-family: var(--font-heading);
	font-weight: 600;
}

.button-primary-action {
	background: linear-gradient(135deg, var(--color-primary) 0%, #4a3729 100%);
	color: #ffffff;
	border-color: transparent;
}

/* Shimmer effect */
.button-primary-action::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left 0.5s ease;
}

.button-primary-action:hover {
	background: linear-gradient(135deg, #4a3729 0%, var(--color-primary) 100%);
	color: #ffffff;
	transform: translateY(-3px);
	box-shadow:
		0 8px 20px rgba(86, 66, 51, 0.25),
		0 4px 8px rgba(86, 66, 51, 0.15);
}

.button-primary-action:hover::before {
	left: 100%;
}

.button-primary-action:active {
	transform: translateY(-1px);
}

.button-secondary-action {
	background: transparent;
	color: var(--color-text);
	border: 2px solid var(--color-border);
}

.button-secondary-action::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--color-primary);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition-base);
	z-index: -1;
}

.button-secondary-action:hover {
	border-color: var(--color-primary);
	color: #ffffff;
	transform: translateY(-3px);
}

.button-secondary-action:hover::before {
	transform: scaleX(1);
}

.sold-badge {
	padding: 18px;
	text-align: center;
	background: linear-gradient(135deg, #f0f0f0 0%, #e8e8e8 100%);
	color: #999;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 0.85rem;
	border-radius: var(--radius-md);
	font-family: var(--font-heading);
	position: relative;
}

.sold-badge::before {
	content: '✦';
	margin-right: 8px;
	font-size: 0.6rem;
}

/* ===========================================
   Accordion / Details - Elegant Expansion
   =========================================== */
.listing-details-accordion,
.krpice-details-accordion {
	border-top: 1px solid var(--color-border);
	margin-top: 16px;
	position: relative;
	animation: itemReveal 0.5s ease 0.4s backwards;
}

/* Decorative accent */
.listing-details-accordion::before,
.krpice-details-accordion::before {
	content: '';
	position: absolute;
	top: -1px;
	left: 0;
	width: 30px;
	height: 2px;
	background: linear-gradient(90deg, var(--color-accent), transparent);
}

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

.accordion-header {
	padding: 18px 0;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--font-heading);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text);
	font-weight: 600;
	transition: color var(--transition-fast);
}

.accordion-header:hover {
	color: var(--color-accent);
}

.toggle-icon {
	font-size: 1.1rem;
	font-weight: 300;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--color-surface);
	color: var(--color-text-light);
	transition:
		transform var(--transition-bounce),
		background var(--transition-fast),
		color var(--transition-fast);
}

.accordion-header:hover .toggle-icon {
	background: rgba(212, 163, 115, 0.15);
	color: var(--color-accent);
}

.accordion-item.active .toggle-icon {
	transform: rotate(45deg);
	background: var(--color-accent);
	color: #fff;
}

.listing-meta-item {
	display: block;
	margin-bottom: 10px;
	font-size: 0.95rem;
}

.listing-tags,
.krpice-tags {
	margin-top: 14px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.tag {
	font-size: 0.8rem;
	color: var(--color-accent);
	background: rgba(212, 163, 115, 0.1);
	padding: 6px 14px;
	border-radius: var(--radius-full);
	border: 1px solid rgba(212, 163, 115, 0.2);
	transition:
		background var(--transition-fast),
		border-color var(--transition-fast);
}

.tag:hover {
	background: rgba(212, 163, 115, 0.2);
	border-color: var(--color-accent);
}

.accordion-content {
	display: none;
	padding-bottom: 24px;
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--color-text-light);
}

.detail-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.detail-list li {
	margin-bottom: 10px;
	display: flex;
	justify-content: space-between;
	padding: 6px 0;
	border-bottom: 1px dashed var(--color-border);
}

.detail-list li:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

.text-link {
	color: var(--color-primary);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--transition-fast);
}

.text-link:hover {
	border-color: var(--color-primary);
}

/* ===========================================
   Accessibility - Reduced Motion
   =========================================== */
@media (prefers-reduced-motion: reduce) {
	.listing-gallery,
	.listing-info,
	.krpice-info,
	.listing-title,
	.krpice-title,
	.listing-price,
	.krpice-meta-info,
	.listing-actions,
	.krpice-actions,
	.listing-details-accordion,
	.krpice-details-accordion,
	.gallery-thumb {
		animation: none !important;
	}

	.button-primary-action::before {
		display: none;
	}

	.main-image:hover img {
		transform: none;
	}
}

/* ===========================================
   Responsive - Tablet
   =========================================== */
@media (max-width: 992px) {
	.single-listing-container {
		grid-template-columns: 1fr;
		gap: 40px;
		padding: 20px;
	}

	.listing-gallery,
	.listing-info,
	.krpice-info {
		animation: none;
	}

	.listing-info,
	.krpice-info {
		position: static;
	}

	.main-image {
		border-radius: var(--radius-md);
	}

	/* Simplified animations on tablet */
	.gallery-thumb {
		animation: none;
		opacity: 0.6;
	}
}

/* Modal Styles */
.modal {
	display: none;
	position: fixed;
	z-index: 1000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(5px);
	opacity: 0;
	transition: opacity var(--transition-base);
	justify-content: center;
	align-items: center;
}

.modal.show {
	opacity: 1;
}

.modal-content {
	background-color: #fdf8f0;
	margin: 0;
	padding: 40px;
	border: 1px solid #e6e1d8;
	width: 90%;
	max-width: 500px;
	position: relative;
	box-shadow: var(--shadow-xl);
	border-radius: var(--radius-md);
	transform: translateY(-20px) scale(0.95);
	transition: transform var(--transition-bounce);
}

.modal.show .modal-content {
	transform: translateY(0) scale(1);
}

.close-modal {
	color: #aaa;
	float: right;
	font-size: 28px;
	font-weight: bold;
	cursor: pointer;
	line-height: 1;
	transition:
		color var(--transition-fast),
		transform var(--transition-bounce);
}

.close-modal:hover,
.close-modal:focus {
	color: #564233;
	text-decoration: none;
	cursor: pointer;
	transform: scale(1.1);
}

.modal h2 {
	font-family: var(--font-heading);
	font-size: 1.8rem;
	color: #564233;
	margin-bottom: 20px;
	text-align: center;
}

.modal p {
	text-align: center;
	margin-bottom: 30px;
	color: #8c7b70;
}

.modal textarea {
	width: 100%;
	padding: 15px;
	border: 1px solid #e6e1d8;
	background: #fff;
	font-family: var(--font-primary);
	margin-bottom: 20px;
	resize: vertical;
}

.button-full {
	width: 100%;
}

/* =========================================
   Breadcrumbs - Elegant Navigation Path
   ========================================= */
.breadcrumbs {
	padding: 16px 0;
	margin-bottom: 0;
	animation: itemReveal 0.4s ease backwards;
}

.breadcrumbs ol {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0;
	font-size: 0.85rem;
	line-height: 1.5;
}

.breadcrumbs li {
	display: inline-flex;
	align-items: center;
	color: var(--color-text-light);
}

.breadcrumbs li:first-child::before {
	content: '✦';
	font-size: 0.5rem;
	color: var(--color-accent);
	margin-right: 8px;
}

.breadcrumbs li:not(:last-child)::after {
	content: '›';
	margin: 0 12px;
	color: var(--color-border);
	font-weight: 300;
	font-size: 1rem;
}

.breadcrumbs a {
	color: var(--color-text-light);
	text-decoration: none;
	transition: color var(--transition-fast);
	padding: 2px 0;
}

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

.breadcrumbs li:last-child {
	color: var(--color-text);
	font-weight: 500;
	max-width: 250px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* =========================================
   Share Buttons - Premium Social Grid
   ========================================= */
.share-section {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 20px 24px;
	background: linear-gradient(135deg, var(--color-surface) 0%, #fff 100%);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	margin-bottom: 24px;
	animation: itemReveal 0.5s ease 0.45s backwards;
}

.share-header {
	display: flex;
	align-items: center;
	gap: 10px;
}

.share-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: rgba(212, 163, 115, 0.1);
	border-radius: 50%;
	color: var(--color-accent);
}

.share-label {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-text);
	font-family: var(--font-heading);
	letter-spacing: 0.02em;
}

.share-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.share-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	border-radius: 50%;
	background: #ffffff;
	border: 1px solid var(--color-border);
	color: var(--color-text-light);
	cursor: pointer;
	transition:
		transform var(--transition-bounce),
		box-shadow var(--transition-base),
		background var(--transition-fast),
		border-color var(--transition-fast),
		color var(--transition-fast);
	text-decoration: none;
	box-shadow: none;
}

.share-btn svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	transition: transform var(--transition-bounce);
}

.share-btn:hover {
	transform: translateY(-4px) scale(1.05);
	box-shadow: var(--shadow-md);
}

.share-btn:hover svg {
	transform: scale(1.15);
}

/* Viber */
.share-viber:hover {
	background: #7360f2;
	border-color: #7360f2;
	color: #fff;
}

/* WhatsApp */
.share-whatsapp:hover {
	background: #25d366;
	border-color: #25d366;
	color: #fff;
}

/* Facebook */
.share-facebook:hover {
	background: #1877f2;
	border-color: #1877f2;
	color: #fff;
}

/* Telegram */
.share-telegram:hover {
	background: #0088cc;
	border-color: #0088cc;
	color: #fff;
}

/* Pinterest */
.share-pinterest:hover {
	background: #e60023;
	border-color: #e60023;
	color: #fff;
}

/* Email */
.share-email:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

/* Copy Link */
.share-copy:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: #fff;
}

/* =========================================
   Similar Listings Section
   ========================================= */
.similar-listings-section {
	background: var(--color-surface);
	padding: 50px 0;
	margin-top: 40px;
}

.similar-listings-section .container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
}

.similar-listings-section h2 {
	font-size: 1.4rem;
	margin-bottom: 24px;
	font-weight: 400;
	text-align: center;
}

.similar-listings-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

@media (max-width: 992px) {
	.similar-listings-section {
		padding: 40px 0;
	}
	
	.similar-listings-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.similar-listings-section {
		padding: 30px 0;
	}
	
	.similar-listings-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 12px;
	}
}

/* =========================================
   Image Zoom
   ========================================= */
.main-image {
	cursor: zoom-in;
	position: relative;
	overflow: hidden;
}

.main-image.zoomed {
	cursor: zoom-out;
}

.main-image.zoomed img {
	transform: scale(2);
	cursor: zoom-out;
}

.zoomable-image {
	transition: transform 0.3s ease;
}

/* Image Zoom Overlay */
.image-zoom-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.9);
	z-index: 2000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
}

.image-zoom-overlay.active {
	opacity: 1;
	pointer-events: auto;
}

.image-zoom-overlay img {
	max-width: 90%;
	max-height: 90%;
	object-fit: contain;
	cursor: zoom-out;
}

.image-zoom-overlay .close-zoom {
	position: absolute;
	top: 20px;
	right: 20px;
	color: #fff;
	font-size: 2rem;
	cursor: pointer;
	background: none;
	border: none;
	padding: 10px;
}

/* Copy success toast */
.copy-toast {
	position: fixed;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%) translateY(100px);
	background: var(--color-primary);
	color: #fff;
	padding: 12px 24px;
	border-radius: var(--radius-full);
	font-size: 0.9rem;
	z-index: 3000;
	transition: transform 0.3s ease;
	box-shadow: var(--shadow-lg);
}

.copy-toast.show {
	transform: translateX(-50%) translateY(0);
}

/* =========================================
   Mobile Responsive Styles
   ========================================= */
@media (max-width: 768px) {
	.single-listing-container {
		padding: 20px 15px;
		gap: 25px;
	}

	/* Breadcrumbs mobile - simplified single line */
	.breadcrumbs {
		padding: 12px 0;
		margin-bottom: 0;
		overflow: hidden;
	}

	.breadcrumbs ol {
		display: block !important;
		font-size: 0.75rem;
		margin: 0;
		padding: 0;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		white-space: nowrap;
		line-height: 1.5;
	}

	.breadcrumbs ol::-webkit-scrollbar {
		display: none;
	}

	.breadcrumbs li {
		display: inline !important;
		white-space: nowrap;
	}

	.breadcrumbs li:first-child::before {
		margin-right: 6px;
	}

	.breadcrumbs li:not(:last-child)::after {
		margin: 0 6px;
	}

	.breadcrumbs li:last-child {
		max-width: 160px;
		overflow: hidden;
		text-overflow: ellipsis;
		display: inline-block !important;
		vertical-align: bottom;
	}

	/* Gallery mobile */
	.main-image {
		aspect-ratio: 1/1;
		margin-bottom: 12px;
	}

	.gallery-thumbnails {
		gap: 8px;
	}

	.gallery-thumb {
		width: 50px;
		height: 70px;
	}

	/* Product info mobile */
	.krpice-info,
	.listing-info {
		position: static;
	}

	/* Listing stats row mobile */
	.krpice-listing-stats {
		gap: 8px;
		margin-bottom: 10px;
	}

	.krpice-published-date {
		font-size: 0.75rem;
		padding: 3px 8px;
	}

	.krpice-favorites-count {
		font-size: 0.7rem;
		padding: 3px 10px;
		gap: 4px;
	}

	/* Social Proof Mobile */
	.krpice-social-proof {
		padding: 12px 16px;
		gap: 12px;
		margin-bottom: 16px;
		border-radius: 12px;
	}

	.social-proof-icon {
		width: 38px;
		height: 38px;
		border-radius: 10px;
	}

	.social-proof-icon svg {
		width: 18px;
		height: 18px;
	}

	.social-proof-count {
		font-size: 1.25rem;
	}

	.social-proof-text {
		font-size: 0.78rem;
	}

	.social-proof-sparkle {
		font-size: 1rem;
		right: 14px;
	}

	.listing-title,
	.krpice-title {
		font-size: 1.5rem;
		margin-bottom: 8px;
		line-height: 1.2;
	}

	.listing-price,
	.krpice-info .krpice-price,
	.single-listing-container .krpice-price {
		font-size: 1.1rem;
		margin-bottom: 15px;
	}

	.krpice-meta-info {
		margin-bottom: 20px;
		font-size: 0.9rem;
	}

	.krpice-meta-info .krpice-meta-item {
		margin-bottom: 6px;
	}

	/* Actions mobile */
	.listing-actions,
	.krpice-actions {
		margin-top: 20px;
		margin-bottom: 25px;
		gap: 10px;
	}

	.button-action {
		padding: 14px;
		font-size: 0.75rem;
		letter-spacing: 1.5px;
	}

	/* Share section mobile */
	.share-section {
		padding: 16px;
		margin-bottom: 15px;
		gap: 10px;
	}

	.share-label {
		font-size: 0.85rem;
	}

	.share-buttons {
		gap: 8px;
	}

	.share-btn {
		width: 42px;
		height: 42px;
	}
	
	.share-btn svg {
		width: 18px;
		height: 18px;
	}

	/* Accordion mobile */
	.accordion-header {
		padding: 15px 0;
		font-size: 0.75rem;
	}

	.accordion-content {
		padding-bottom: 15px;
		font-size: 0.9rem;
		line-height: 1.6;
	}

	.detail-list li {
		font-size: 0.9rem;
		margin-bottom: 6px;
	}

	/* Similar listings mobile */
	.similar-listings-section {
		margin-top: 30px;
		padding-top: 25px;
	}

	.similar-listings-section h2 {
		font-size: 1.2rem;
		margin-bottom: 15px;
	}

	.similar-listings-grid {
		gap: 10px;
	}

	/* Modal mobile */
	.modal-content {
		margin: 5% auto;
		padding: 25px 20px;
		width: 95%;
	}

	.modal h2 {
		font-size: 1.4rem;
		margin-bottom: 15px;
	}

	.modal p {
		margin-bottom: 20px;
		font-size: 0.9rem;
	}

	.modal textarea {
		padding: 12px;
		font-size: 16px; /* Prevents iOS zoom */
	}

	/* Image zoom mobile */
	.image-zoom-overlay img {
		max-width: 100%;
		max-height: 80%;
	}

	.image-zoom-overlay .close-zoom {
		top: 10px;
		right: 10px;
		font-size: 1.5rem;
	}

	/* Copy toast mobile */
	.copy-toast {
		bottom: 80px;
		padding: 10px 20px;
		font-size: 0.85rem;
	}
}