/* Кастомные стили DiiVo Plants */

/* Импорт шрифта Inter */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* Базовые стили */
* {
		margin: 0;
		padding: 0;
		box-sizing: border-box;
}

body {
		font-family: 'Inter', system-ui, -apple-system, sans-serif;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
}

/* Плавный скролл */
html {
		scroll-behavior: smooth;
}

/* Стили для скроллбара */
::-webkit-scrollbar {
		width: 8px;
}

::-webkit-scrollbar-track {
		background: #f0fdf4;
}

::-webkit-scrollbar-thumb {
		background: #86efac;
		border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
		background: #4ade80;
}

/* Анимация появления */
@keyframes fadeInUp {
		from {
				opacity: 0;
				transform: translateY(20px);
		}
		to {
				opacity: 1;
				transform: translateY(0);
		}
}

.fade-in-up {
		animation: fadeInUp 0.6s ease-out;
}

/* Анимация пульсации для уведомлений */
@keyframes pulse {
		0%, 100% {
				transform: scale(1);
		}
		50% {
				transform: scale(1.1);
		}
}

.pulse {
		animation: pulse 2s infinite;
}

/* Стили для активных фильтров */
.filter-active {
		background-color: #16a34a !important;
		color: white !important;
}

/* Улучшенные стили для форм */
input:focus, select:focus, textarea:focus {
		box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.1);
}

/* Стили для карточек деревьев */
.tree-card {
		transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.tree-card:hover {
		transform: translateY(-8px);
		box-shadow: 0 20px 40px rgba(22, 163, 74, 0.15);
}

.tree-card:hover .tree-card-image {
		transform: scale(1.1);
}

.tree-card-image {
		transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Градиентные фоны */
.gradient-hero {
		background: linear-gradient(135deg, #14532d 0%, #166534 50%, #15803d 100%);
		    /* --tw-gradient-stops: var(--tw-gradient-from), #000000 var(--tw-gradient-via-position), var(--tw-gradient-to); */
}

.gradient-card {
		background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
}

/* Стили для прелоадера */
.loader {
		border: 3px solid #f0fdf4;
		border-top: 3px solid #16a34a;
		border-radius: 50%;
		width: 40px;
		height: 40px;
		animation: spin 1s linear infinite;
}

@keyframes spin {
		0% { transform: rotate(0deg); }
		100% { transform: rotate(360deg); }
}

/* Стили для мобильного меню */
.mobile-menu-enter {
		opacity: 0;
		transform: translateY(-10px);
}

.mobile-menu-enter-active {
		opacity: 1;
		transform: translateY(0);
		transition: all 0.3s ease-out;
}

/* Стили для уведомлений админа */
.notification-badge {
		animation: slideIn 0.3s ease-out;
}

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

/* Стили для хлебных крошек */
.breadcrumb-item + .breadcrumb-item::before {
		content: "›";
		margin: 0 0.5rem;
		color: #8c6535;
}

/* Стили для SEO-текстов */
.prose h2 {
		color: #166534;
		margin-top: 2rem;
		margin-bottom: 1rem;
}

.prose p {
		line-height: 1.8;
		margin-bottom: 1rem;
}

.prose ul {
		margin-bottom: 1rem;
}

.prose li {
		margin-bottom: 0.5rem;
}

/* Медиа-запросы для адаптивности */
@media (max-width: 768px) {
		.hero-title {
				font-size: 2.5rem;
				line-height: 1.2;
		}
		
		.card-grid {
				grid-template-columns: 1fr;
		}
		
		.filter-panel {
				position: fixed;
				bottom: 0;
				left: 0;
				right: 0;
				z-index: 40;
				border-radius: 1rem 1rem 0 0;
				max-height: 80vh;
				overflow-y: auto;
		}
}

@media (min-width: 769px) and (max-width: 1024px) {
		.card-grid {
				grid-template-columns: repeat(2, 1fr);
		}
}

/* Утилитарные классы */
.line-clamp-1 {
		display: -webkit-box;
		-webkit-line-clamp: 1;
		-webkit-box-orient: vertical;
		overflow: hidden;
}

.line-clamp-2 {
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
}

.line-clamp-3 {
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
}

/* Эффект размытия для фона */
.backdrop-blur {
		backdrop-filter: blur(10px);
		-webkit-backdrop-filter: blur(10px);
}

/* Стили для toast-уведомлений */
.toast {
		position: fixed;
		bottom: 20px;
		right: 20px;
		padding: 1rem 1.5rem;
		border-radius: 0.75rem;
		background: white;
		box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
		z-index: 1000;
		animation: slideUp 0.3s ease-out;
}

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

.toast-success {
		border-left: 4px solid #22c55e;
}

.toast-error {
		border-left: 4px solid #ef4444;
}

/* Оптимизация для печати */
@media print {
		.no-print {
				display: none;
		}
		
		body {
				background: white;
		}
}