.game-btn,
.game-input,
body {
	font-family: Insaniburger, sans-serif
}

*,
.blog-post * {
	box-sizing: border-box
}

.adoptme-card,
.game-btn,
.modal-close,
.nav-btn,
.offer-card,
.shop-close {
	cursor: pointer
}

.adoptme-theme .blox-fruits-btn {
	background: url('img/bloxfruit.jpg') center/cover no-repeat !important;
	color: transparent !important
}

.adoptme-theme .grow-garden-btn {
	background: url('img/GrowAGarden.jpg') center/cover no-repeat !important;
	color: transparent !important
}

* {
	margin: 0;
	padding: 0
}

:root {
	--color-primary: #fd9abe;
	--color-secondary: #ffbad5;
	--color-tertiary: #f7dce7;
	--color-accent: #ffe5f0;
	--color-background: #fff4fa;
	--color-gradient: linear-gradient(135deg, #fdc8df, #fdc8df 35%, #ffe5f0 70%, #ffe5f0)
}

body {
	background-attachment: fixed;
	background: var(--color-tertiary);
	background-image: linear-gradient(hsla(0, 0%, 100%, .7) .1em, transparent 0), linear-gradient(90deg, hsla(0, 0%, 100%, .7) .1em, transparent 0);
	background-size: 2em 2em;
	min-height: 100vh;
	min-height: 100dvh;
	overflow-x: hidden;
	-webkit-tap-highlight-color: transparent;
	flex-direction: column;
	height: 100vh !important;
	height: 100dvh !important;
	letter-spacing: 1px;
	overflow: hidden !important;
	position: fixed !important;
	width: 100vw !important;
	width: 100dvw !important
}

.loading-screen,
.pet-icon,
.selected-pet-info,
.user-avatar,
.user-info-container,
.user-info-display,
.user-info-display .user-avatar,
body {
	align-items: center;
	display: flex;
	justify-content: center
}

.loading-screen {
	background: linear-gradient(135deg, var(--color-primary) 0, var(--color-secondary) 50%, var(--color-accent) 100%);
	height: 100%;
	left: 0;
	position: fixed;
	top: 0;
	transition: opacity .5s;
	width: 100%;
	z-index: 10000
}

.loading-content {
	color: #fff;
	text-align: center;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, .8)
}

.loading-logo {
	animation: 2s ease-in-out infinite pulse;
	font-size: 80px;
	margin-bottom: 20px
}

.loading-text {
	color: #fff;
	font-size: 24px;
	font-weight: 800;
	margin-bottom: 30px;
	text-shadow: 3px 3px 8px rgba(0, 0, 0, .8)
}

.loading-bar {
	background: hsla(0, 0%, 100%, .3);
	border-radius: 4px;
	height: 8px;
	overflow: hidden;
	width: 300px
}

.loading-progress {
	animation: 3s ease-in-out loadingProgress;
	background: linear-gradient(90deg, #27ae60, #2ecc71);
	height: 100%
}

@keyframes loadingProgress {
	0% {
		width: 0
	}

	to {
		width: 100%
	}
}

.top-nav {
	justify-content: space-evenly;
	padding-bottom: 20px
}

.nav-btn {
	background: linear-gradient(145deg, var(--color-primary), var(--color-secondary));
	border: 3px solid var(--color-primary);
	box-shadow: 0 4px 0 #e379a1, 0 8px 20px -6px rgba(0, 0, 0, .3);
	color: #fff;
	overflow: hidden;
	position: relative;
	user-select: none
}

.adoptme-theme .game-btn:before,
.adoptme-theme .info-step:before,
.adoptme-theme .nav-btn:before,
.adoptme-theme .rarity-tier:before,
.adoptme-theme .safety-item:before,
.nav-btn:before {
	background: linear-gradient(90deg, transparent, hsla(0, 0%, 100%, .4), transparent);
	content: "";
	height: 100%;
	left: -100%;
	position: absolute;
	top: 0;
	transition: left .5s;
	width: 100%
}

.nav-btn.garden,
.nav-btn.seeds,
.nav-btn.sell {
	background: linear-gradient(145deg, var(--color-primary), var(--color-secondary))
}

.adoptme-theme .game-btn:hover:before,
.adoptme-theme .info-step:hover:before,
.adoptme-theme .nav-btn:hover:before,
.adoptme-theme .rarity-tier:hover:before,
.adoptme-theme .safety-item:hover:before,
.nav-btn:hover:before {
	left: 100%
}

.nav-btn.garden,
.nav-btn.sell {
	border-color: var(--color-primary)
}

.nav-btn.active {
	background: linear-gradient(145deg, #ff8a65, #ff7043);
	box-shadow: 0 2px 0 #d84315, 0 6px 15px -4px rgba(0, 0, 0, .4);
	transform: translateY(2px)
}

.nav-btn:hover:not(.active) {
	box-shadow: 0 6px 0 #e379a1, 0 12px 25px -6px rgba(0, 0, 0, .4);
	transform: translateY(-3px)
}

.shop-window {
	align-self: center;
	background: linear-gradient(145deg, #fff 0, #fff8f0 25%, var(--color-accent) 60%, var(--color-tertiary) 100%);
	border: 6px solid #fca9c9;
	box-shadow: 0 0 0 3px #fdbdd5, 0 0 0 8px #fca9c9, 0 16px 40px -8px rgba(0, 0, 0, .4), inset 0 2px 0 hsla(0, 0%, 100%, .8);
	display: flex;
	display: grid;
	flex-direction: column;
	grid-template-rows: auto 1fr;
	height: 90vh;
	justify-self: center;
	max-width: 900px;
	width: 90%
}

.shop-header,
.shop-window {
	overflow: hidden;
	position: relative
}

.shop-header {
	align-items: center;
	background: linear-gradient(135deg, #fdc8df, #fdc8df 35%, #ffe5f0 70%, #ffe5f0);
	border-bottom: 5px solid #fdbdd5;
	border-top-left-radius: 26px;
	border-top-right-radius: 26px;
	display: flex;
	justify-content: space-between;
	padding: 20px 28px;
	z-index: 210
}

.adoptme-theme .shop-header:before,
.shop-header:before {
	background: linear-gradient(180deg, hsla(0, 0%, 100%, .3), transparent);
	content: "";
	height: 50%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0
}

.adoptme-theme .shop-title,
.shop-title {
	color: #fff;
	font-size: 1.9rem;
	font-weight: 800;
	letter-spacing: .5px;
	text-shadow: 2px 2px 0 #d84315, 0 0 10px hsla(0, 0%, 100%, .5)
}

.shop-close {
	align-items: center;
	background: linear-gradient(145deg, #ff4757, #ff3742);
	border: 3px solid #ff1744;
	box-shadow: 0 4px 0 #d50000, 0 6px 12px rgba(0, 0, 0, .3);
	color: #fff;
	display: flex;
	font-size: 20px;
	font-weight: 900;
	height: 44px;
	justify-content: center;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .5);
	width: 44px
}

.adoptme-theme .shop-close:hover,
.shop-close:hover {
	box-shadow: 0 6px 0 #d50000, 0 8px 16px rgba(0, 0, 0, .4);
	transform: scale(1.15) rotate(90deg)
}

.shop-content {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	padding: 5px 15px 20px
}

.shop-content.hidden,
.shop-section.hidden {
	display: none
}

.blog-article-section,
.shop-section {
	backdrop-filter: blur(10px);
	background: linear-gradient(160deg, hsla(0, 0%, 100%, .95), rgba(255, 248, 240, .9) 50%, rgba(255, 233, 214, .85));
	border: 4px solid #fca9c9;
	border-radius: 28px;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 12px 30px -6px rgba(0, 0, 0, .25), inset 0 1px 0 hsla(0, 0%, 100%, .9);
	margin-bottom: 20px;
	overflow: hidden;
	position: relative;
	transition: .3s
}

.blog-section a,
.game-input {
	transition: border-color .3s
}

.adoptme-theme .info-section:before,
.blog-article-section:before,
.info-section:before,
.shop-section:before {
	background: linear-gradient(180deg, hsla(0, 0%, 100%, .25), transparent);
	border-radius: 24px 24px 0 0;
	content: "";
	height: 30%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0
}

.section-header {
	align-items: center;
	background: var(--color-gradient);
	border-top-left-radius: 24px;
	border-top-right-radius: 24px;
	display: flex;
	gap: 12px;
	overflow: hidden;
	padding: 14px 22px;
	position: relative
}

.adoptme-theme .section-header:before,
.blog-header-section:before,
.section-header:before {
	background: linear-gradient(180deg, hsla(0, 0%, 100%, .25), transparent);
	content: "";
	height: 40%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0
}

.section-badge {
	border: 3px solid #fff;
	border-radius: 20px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
	font-size: 13px;
	font-weight: 800;
	padding: 6px 14px
}

.section-badge.new {
	background: linear-gradient(45deg, #ff4757, #ff6b6b, #ff8e53);
	color: #fff;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .3)
}

.section-badge.prismatic {
	animation: 3s ease-in-out infinite rainbow;
	background: linear-gradient(45deg, #fca9c9, #fdbdd5, #ffe5f0, #fff4fa);
	color: #ff5722;
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .8)
}

.section-badge.legendary,
.section-badge.mythical,
.section-badge.rare,
.section-badge.uncommon {
	color: #fff;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .3)
}

.section-badge.mythical {
	background: linear-gradient(145deg, #a29bfe, #6c5ce7)
}

.section-badge.legendary {
	background: linear-gradient(145deg, gold, #ffb347, #ff8f00)
}

.section-badge.rare {
	background: linear-gradient(145deg, #64b5f6, #2196f3)
}

.section-badge.uncommon {
	background: linear-gradient(145deg, #81c784, #4caf50)
}

.section-badge.common,
.section-timer {
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .8)
}

.section-badge.common {
	background: linear-gradient(145deg, #e0e0e0, #bdbdbd);
	color: #424242
}

.section-badge.unknown {
	background: linear-gradient(145deg, #9e9e9e, #757575);
	color: #fff;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .3)
}

@keyframes rainbow {

	0%,
	to {
		filter: hue-rotate(0deg)
	}

	50% {
		filter: hue-rotate(180deg)
	}
}

.section-title {
	flex: 1;
	font-size: 1.15rem;
	font-weight: 800
}

.section-timer {
	color: #ff5722;
	font-size: 13px;
	font-weight: 800
}

.info-title,
.timer-text {
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .3), 0 0 8px hsla(0, 0%, 100%, .6);
	color: #ff5722;
	font-weight: 800
}

.items-row {
	display: flex;
	gap: 16px
}

.item-preview {
	flex: 1
}

.preview-pets {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
	justify-content: center;
	padding: 16px;
	row-gap: 16px !important
}

.pet-icon {
	margin-bottom: 8px;
	min-height: 60px
}

.pet-icon img {
	background: hsla(0, 0%, 100%, .1);
	border-radius: 6px;
	max-width: 100%;
	object-fit: contain;
	padding: 4px
}

.timer-text {
	font-size: 20px
}

.adoptme-theme .info-container,
.info-container {
	margin: 0 auto;
	max-width: 800px;
	padding: 20px
}

.adoptme-theme .info-section,
.info-section {
	backdrop-filter: blur(10px);
	background: linear-gradient(160deg, hsla(0, 0%, 100%, .95), rgba(255, 248, 240, .9) 50%, rgba(255, 233, 214, .85));
	border: 4px solid #fca9c9;
	border-radius: 28px;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 12px 30px -6px rgba(0, 0, 0, .25), inset 0 1px 0 hsla(0, 0%, 100%, .9);
	margin-bottom: 30px;
	overflow: hidden;
	padding: 20px;
	position: relative
}

.info-title {
	font-size: 24px;
	text-align: center
}

.info-text,
.info-title {
	margin-bottom: 15px;
	position: relative;
	z-index: 1
}

.info-text {
	color: #2d3436;
	font-size: 16px;
	line-height: 1.6;
	text-shadow: 0 1px 2px hsla(0, 0%, 100%, .8)
}

.adoptme-theme .info-steps,
.info-steps {
	display: flex;
	flex-direction: column;
	gap: 15px
}

.info-step {
	align-items: flex-start;
	background: hsla(0, 0%, 100%, .05);
	border-radius: 8px;
	display: flex;
	gap: 15px;
	padding: 15px
}

.step-number {
	align-items: center;
	background: linear-gradient(180deg, gold, #ffb347);
	border-radius: 50%;
	box-shadow: 0 2px 8px rgba(255, 215, 0, .3);
	color: #333;
	display: flex;
	flex-shrink: 0;
	font-size: 18px;
	font-weight: 700;
	height: 40px;
	justify-content: center;
	width: 40px
}

.rarity-tier,
.safety-item {
	background: hsla(0, 0%, 100%, .05);
	border-radius: 8px;
	padding: 15px
}

.adoptme-theme .step-content h3,
.step-content h3 {
	color: #ff5722;
	font-size: 18px;
	font-weight: 800;
	margin-bottom: 5px;
	position: relative;
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .8);
	z-index: 2
}

.adoptme-theme .rarity-info p,
.adoptme-theme .safety-content p,
.adoptme-theme .step-content p,
.safety-content p,
.step-content p {
	color: #636e72;
	font-size: 14px;
	line-height: 1.4;
	margin: 0;
	position: relative;
	text-shadow: 0 1px 1px hsla(0, 0%, 100%, .6);
	z-index: 2
}

.adoptme-theme .safety-features,
.safety-features {
	display: grid;
	gap: 15px;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr))
}

.safety-item {
	align-items: flex-start;
	display: flex;
	gap: 12px
}

.rarity-icon,
.safety-icon {
	flex-shrink: 0;
	font-size: 24px
}

.adoptme-theme .rarity-info h3,
.adoptme-theme .safety-content h3,
.safety-content h3 {
	color: #ff5722;
	font-size: 16px;
	font-weight: 800;
	margin-bottom: 5px;
	position: relative;
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .8);
	z-index: 2
}

.adoptme-theme .rarity-tiers,
.rarity-tiers {
	display: grid;
	gap: 15px;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))
}

.rarity-tier {
	align-items: center;
	border-left: 4px solid;
	display: flex;
	gap: 12px
}

.modal-header,
.modal-overlay {
	align-items: center;
	display: flex
}

.rarity-tier.divine {
	border-left-color: gold
}

.rarity-tier.legendary {
	border-left-color: #ff6b6b
}

.rarity-tier.mythical {
	border-left-color: #a855f7
}

.rarity-tier.prismatic {
	border-left-color: #06b6d4
}

.rarity-tier.rare {
	border-left-color: #3b82f6
}

.rarity-tier.uncommon {
	border-left-color: #10b981
}

.rarity-tier.common {
	border-left-color: #6b7280
}

.rarity-info h3 {
	color: gold;
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 5px
}

.rarity-info h3,
.rarity-info p {
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8)
}

.rarity-info p {
	color: #f0f8ff;
	font-size: 14px;
	line-height: 1.4;
	margin: 0
}

.forever-pack {
	background: linear-gradient(180deg, #8e44ad, #7d3c98);
	border: 3px solid #6c3483;
	border-radius: 8px;
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2);
	margin-top: 16px;
	padding: 20px;
	text-align: center
}

.forever-title {
	color: #f0f8ff;
	font-size: 20px;
	text-shadow: 3px 3px 6px rgba(0, 0, 0, .8)
}

.forever-timer,
.forever-title {
	font-weight: 700;
	margin-bottom: 8px
}

.forever-timer {
	color: gold;
	font-size: 18px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8)
}

.forever-description {
	color: #2d3436;
	font-size: 14px;
	text-shadow: 0 1px 2px hsla(0, 0%, 100%, .8)
}

.modal-overlay {
	backdrop-filter: blur(5px);
	height: 100%;
	justify-content: center;
	left: 0;
	padding: 20px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1000
}

.game-modal {
	background: linear-gradient(180deg, #8b4513, #654321);
	border: 4px solid #543415;
	box-shadow: inset 2px 2px 0 rgba(139, 69, 19, .6), 0 8px 32px rgba(0, 0, 0, .5);
	max-height: 90vh;
	max-height: 90dvh;
	max-width: 450px;
	overflow-y: auto;
	width: 100%
}

.modal-header {
	background: linear-gradient(180deg, #5dade2, #3498db);
	border-bottom: 2px solid #2980b9;
	justify-content: space-between;
	padding: 12px 16px
}

.modal-title {
	font-size: 18px;
	font-weight: 800
}

.modal-close {
	box-shadow: 0 4px 0 #d50000, 0 6px 12px rgba(0, 0, 0, .3);
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .5)
}

.modal-close:hover {
	box-shadow: 0 6px 0 #d50000, 0 8px 16px rgba(0, 0, 0, .4);
	transform: scale(1.1) rotate(90deg)
}

.modal-content {
	padding: 24px
}

.selected-pack-info {
	align-items: center;
	background: linear-gradient(180deg, #7d5a3f, #654321);
	border: 2px solid #543415;
	border-radius: 8px;
	display: flex;
	gap: 16px;
	margin-bottom: 10px;
	padding: 10px
}

.pack-icon {
	filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, .5));
	gap: 10px
}

.arrow-animate {
	display: inline-block;
	filter: drop-shadow(0 2px 6px #54341555)
}

@keyframes arrowWiggle {

	0%,
	to {
		transform: translateX(0) scale(1)
	}

	20% {
		transform: translateX(-6px) scale(1.08)
	}

	40% {
		transform: translateX(6px) scale(1.08)
	}

	60% {
		transform: translateX(-4px) scale(1.04)
	}

	80% {
		transform: translateX(4px) scale(1.04)
	}
}

.pack-name {
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 4px;
	max-width: 120px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap
}

.pack-quantity {
	color: gold
}

.input-label,
.pack-quantity {
	font-size: 14px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8)
}

.input-label {
	color: #f0f8ff;
	margin-bottom: 12px
}

.game-input {
	background: #fff;
	border: 3px solid #654321;
	border-radius: 6px;
	color: #2c3e50;
	font-size: 16px;
	margin-bottom: 12px;
	padding: 12px 16px;
	width: 100%
}

.game-input:focus {
	border-color: #3498db;
	box-shadow: 0 0 12px rgba(52, 152, 219, .5);
	outline: 0
}

.progress-container,
.username-tips {
	margin-bottom: 20px
}

.tip {
	color: #ff5722;
	font-size: 12px;
	font-weight: 600;
	margin-bottom: 4px;
	text-shadow: 0 1px 1px hsla(0, 0%, 100%, .8)
}

.modal-buttons {
	display: flex;
	gap: 12px;
	justify-content: center
}

.game-btn {
	border: 3px solid;
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2);
	font-size: 16px;
	font-weight: 700;
	padding: 12px 24px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8);
	user-select: none
}

.game-btn.cancel {
	background: linear-gradient(145deg, #fff, #f8f9fa 50%, #e9ecef);
	border-color: #ff5722;
	box-shadow: 0 4px 0 #e55347, 0 8px 20px -6px rgba(255, 99, 72, .3);
	color: #ff5722
}

.game-btn.confirm {
	background: linear-gradient(180deg, #27ae60, #229954);
	border-color: #1e8449;
	color: #ffe4e1
}

.game-btn:hover {
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2), 0 4px 8px rgba(0, 0, 0, .3);
	transform: translateY(-2px)
}

.game-btn:active {
	transform: translateY(0)
}

.generation-container {
	margin: 0 auto;
	max-width: 600px;
	text-align: center
}

.generating-pack-info {
	align-items: flex-end;
	backdrop-filter: blur(18px) saturate(1.2);
	background: hsla(0, 0%, 100%, .18);
	border: 2.5px solid hsla(0, 0%, 100%, .28);
	border-radius: 24px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, .18);
	display: flex;
	gap: 40px;
	justify-content: center;
	margin-bottom: 30px;
	padding: 28px 32px
}

.generation-progress,
.offer-card {
	box-shadow: inset 2px 2px 0 rgba(139, 69, 19, .6)
}

.pack-info-block {
	align-self: stretch;
	flex-direction: column;
	min-width: 120px
}

.pack-icon,
.pack-info-block {
	align-items: center;
	display: flex
}

.pack-icon {
	background: hsla(0, 0%, 100%, .13);
	border-radius: 16px;
	filter: drop-shadow(4px 4px 12px rgba(0, 0, 0, .5));
	font-size: 64px;
	justify-content: center;
	margin-bottom: 10px;
	min-height: 80px;
	min-width: 80px
}

.pack-label {
	color: #f0f8ff;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: .5px;
	margin-top: 4px;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, .8)
}

.arrow-animate {
	align-items: flex-end;
	animation: 1.2s cubic-bezier(.4, 0, .2, 1) infinite arrowWiggle;
	color: gold;
	display: flex;
	filter: drop-shadow(0 4px 12px #54341555);
	font-size: 56px;
	margin: 0 32px 12px;
	text-shadow: 2px 2px 12px #54341588, 0 0 10px #fff6
}

@keyframes bounce {

	0%,
	to {
		transform: translateY(0)
	}

	50% {
		transform: translateY(-10px)
	}
}

.pack-name-large {
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 8px
}

.pack-quantity-large,
.progress-text {
	color: gold;
	font-size: 16px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8)
}

.generation-progress {
	background: linear-gradient(180deg, #7d5a3f, #654321);
	border: 3px solid #543415;
	border-radius: 8px;
	padding: 24px
}

.progress-bar {
	background: #543415;
	border: 3px solid #3d2a15;
	border-radius: 12px;
	height: 24px;
	margin-bottom: 12px;
	overflow: hidden;
	width: 100%
}

.progress-fill {
	background: linear-gradient(90deg, #27ae60, #2ecc71);
	height: 100%;
	width: 0
}

.progress-text {
	font-weight: 700
}

.status-text {
	color: #2d3436;
	font-size: 18px;
	font-weight: 600;
	margin-bottom: 20px;
	text-shadow: 0 1px 2px hsla(0, 0%, 100%, .8)
}

.generation-steps {
	text-align: left
}

.step {
	border-radius: 6px;
	color: #ff5722;
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 12px;
	padding: 8px 12px;
	text-shadow: 0 1px 1px hsla(0, 0%, 100%, .8);
	transition: .3s
}

.step.active {
	background: rgba(135, 206, 235, .15);
	color: #87ceeb;
	font-weight: 700;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8)
}

.step.completed {
	background: rgba(39, 174, 96, .1);
	color: #27ae60
}

.offers-header {
	margin-bottom: 24px;
	text-align: center
}

.offers-title {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 12px
}

.offers-subtitle {
	color: #e8f8f5;
	font-size: 16px;
	margin-bottom: 16px;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .5)
}

.security-badge {
	background: rgba(39, 174, 96, .2);
	border: 2px solid #27ae60;
	border-radius: 20px;
	color: #27ae60;
	display: inline-block;
	font-size: 14px;
	font-weight: 700;
	padding: 8px 16px;
	text-shadow: 1px 1px 1px rgba(0, 0, 0, .5)
}

.offers-grid {
	display: flex;
	flex-direction: column;
	gap: 16px
}

.offer-card {
	align-items: center;
	background: linear-gradient(180deg, #7d5a3f, #654321);
	border: 3px solid #543415;
	display: flex;
	gap: 20px;
	padding: 20px;
	position: relative
}

.offer-card.featured {
	border-color: gold;
	box-shadow: 0 0 16px rgba(255, 215, 0, .4), inset 2px 2px 0 rgba(139, 69, 19, .6)
}

.offer-card:hover {
	box-shadow: inset 2px 2px 0 rgba(139, 69, 19, .6), 0 8px 16px rgba(0, 0, 0, .3);
	transform: translateY(-4px)
}

.offer-badge {
	border: 2px solid #d68910;
	border-radius: 12px;
	color: #8b4513;
	font-size: 10px;
	font-weight: 700;
	left: 50%;
	padding: 4px 12px;
	position: absolute;
	top: -18px;
	transform: translateX(-50%)
}

.offer-icon {
	display: flex;
	filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, .5));
	flex-shrink: 0;
	font-size: 40px
}

.offer-info {
	align-items: flex-start;
	display: flex;
	flex: 1;
	flex-direction: column;
	justify-content: center
}

.offer-name {
	color: #fff;
	font-size: 18px;
	font-weight: 700;
	margin-bottom: 8px;
	text-align: left;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .7)
}

.offer-desc {
	color: #bdc3c7;
	font-size: 14px;
	line-height: 1.4;
	margin-bottom: 12px;
	text-align: left;
	text-shadow: 1px 1px 1px rgba(0, 0, 0, .5)
}

.offer-reward {
	color: #ff5722;
	font-size: 16px;
	font-weight: 800;
	text-align: left;
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .8)
}

.offer-complete-btn,
.toast {
	background: linear-gradient(180deg, #27ae60, #229954);
	font-size: 14px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .8);
	font-weight: 700;
	font-family: Insaniburger, sans-serif
}

.offer-complete-btn {
	border: 2px solid #1e8449;
	border-radius: 6px;
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2);
	color: #ffe4e1;
	cursor: pointer;
	margin-top: 8px;
	padding: 8px 16px;
	transition: .2s;
	user-select: none
}

.offer-complete-btn:hover {
	background: linear-gradient(180deg, #229954, #27ae60);
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2), 0 4px 8px rgba(0, 0, 0, .3);
	transform: translateY(-1px)
}

.offer-complete-btn:active {
	box-shadow: inset 1px 1px 0 hsla(0, 0%, 100%, .2);
	transform: translateY(0)
}

.toast-container {
	display: flex;
	flex-direction: column;
	gap: 10px;
	position: fixed;
	right: 20px;
	top: 20px;
	z-index: 10000
}

.toast {
	animation: .3s slideInRight;
	border: 2px solid #1e8449;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
	color: #f0f8ff;
	max-width: 300px;
	padding: 12px 20px
}

.toast.error {
	background: linear-gradient(180deg, #e74c3c, #c0392b);
	border-color: #a93226
}

@keyframes slideInRight {
	0% {
		opacity: 0;
		transform: translateX(100%)
	}

	to {
		opacity: 1;
		transform: translateX(0)
	}
}

.hidden,
.shop-section.empty {
	display: none !important
}

.shop-content::-webkit-scrollbar {
	width: 8px
}

.shop-content::-webkit-scrollbar-track {
	background: #543415;
	border-radius: 4px
}

.shop-content::-webkit-scrollbar-thumb {
	background: #fff;
	border-radius: 4px
}

.shop-content::-webkit-scrollbar-thumb:hover {
	background: sienna
}

@media (max-width:768px) {

	.offer-card,
	.offer-desc,
	.offer-name,
	.offer-reward {
		text-align: center
	}

	body {
		display: block;
		min-height: 100vh;
		min-height: 100dvh;
		overflow: auto !important
	}

	.shop-window {
		display: flex;
		flex-direction: column;
		height: calc(100dvh - 16px);
		margin: 8px auto
	}

	.shop-content {
		flex: 1;
		min-height: 0;
		overflow-y: auto;
		padding: 12px
	}

	.shop-header {
		position: relative;
		z-index: 210
	}

	.modal-overlay {
		align-items: flex-start;
		padding: 10px
	}

	.game-modal {
		margin: 10px 0;
		max-height: 85dvh
	}

	.modal-content {
		padding: 16px
	}

	.modal-buttons,
	.search-filter-bar {
		flex-direction: column;
		gap: 8px
	}

	.preview-fruits,
	.preview-pets {
		gap: 8px;
		grid-template-columns: repeat(2, 1fr)
	}

	.pet-item {
		min-height: 100px;
		padding: 8px 4px
	}

	.pet-icon {
		min-height: 50px
	}

	.fruit-chance,
	.pet-chance {
		font-size: 10px
	}

	.fruit-item {
		min-height: 100px;
		padding: 8px 6px
	}

	.info-container,
	.info-section {
		padding: 15px
	}

	.generating-title,
	.info-title,
	.offers-title {
		font-size: 20px
	}

	.offers-grid,
	.rarity-tiers,
	.safety-features {
		grid-template-columns: 1fr
	}

	.offers-grid {
		gap: 12px
	}

	.offer-card {
		flex-direction: column;
		gap: 15px
	}

	.offer-info {
		align-items: center
	}

	.selected-pack-display {
		flex-direction: column;
		gap: 12px;
		text-align: center
	}

	.pack-icon-large {
		font-size: 48px
	}

	.offers-subtitle {
		font-size: 14px
	}

	.toast-container {
		left: 10px;
		right: 10px;
		top: 70px
	}

	.toast {
		max-width: none
	}
}

@media (max-width:480px) {
	.shop-window {
		display: flex;
		flex-direction: column;
		height: calc(100dvh - 16px);
		margin: 8px auto
	}

	.shop-content {
		flex: 1;
		min-height: 0;
		overflow-y: auto;
		padding: 12px
	}

	.modal-overlay {
		align-items: flex-start;
		padding: 5px
	}

	.game-modal {
		margin: 5px 0;
		max-height: 80dvh
	}

	.preview-fruits,
	.preview-pets {
		flex-wrap: wrap;
		gap: 6px
	}

	.pet-item {
		flex: 0 0 48%;
		max-width: 48%;
		min-height: 80px;
		padding: 6px 4px
	}

	.fruit-item {
		flex: 0 0 48%;
		max-width: 48%
	}

	.pet-icon {
		min-height: 40px
	}

	.pet-chance {
		font-size: 9px
	}

	.section-title {
		font-size: 14px
	}

	.section-timer {
		font-size: 10px
	}

	.modal-content {
		padding: 16px
	}

	.game-btn {
		font-size: 14px;
		padding: 10px 16px
	}
}

@media (hover:none) and (pointer:coarse) {

	.fruit-item:hover,
	.game-btn:hover,
	.nav-btn:hover,
	.offer-card:hover,
	.pet-item:hover {
		transform: none
	}

	.fruit-item:active,
	.pet-item:active {
		transform: scale(.95)
	}

	.game-btn:active,
	.nav-btn:active,
	.offer-card:active {
		transform: scale(.98)
	}
}

@media (max-width:768px) and (orientation:landscape) {

	.preview-fruits,
	.preview-pets {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media (-webkit-min-device-pixel-ratio:2),
(min-resolution:192dpi) {

	.fruit-icon img,
	.pet-icon img {
		image-rendering: -webkit-optimize-contrast;
		image-rendering: crisp-edges
	}
}

:focus {
	outline: gold solid 3px;
	outline-offset: 2px;
	z-index: 10001
}

.fruit-item:focus,
.game-btn:focus,
.modal-close:focus,
.nav-btn:focus,
.offer-card:focus,
.pet-item:focus,
.shop-close:focus,
button:focus {
	box-shadow: 0 0 0 4px rgba(255, 215, 0, .2);
	outline: gold solid 3px;
	outline-offset: 2px
}

.fruit-item,
.game-btn,
.modal-close,
.nav-btn,
.offer-card,
.pet-item,
.shop-close {
	box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
	transition: background .2s, color .2s, box-shadow .3s, transform .2s
}

.fruit-item:hover,
.game-btn:hover,
.modal-close:hover,
.nav-btn:hover,
.offer-card:hover,
.pet-item:hover,
.shop-close:hover {
	box-shadow: 0 6px 24px rgba(255, 215, 0, .18), 0 2px 8px rgba(0, 0, 0, .12);
	color: #543415;
	transform: translateY(-2px) scale(1.03)
}

.fruit-item:active,
.game-btn:active,
.modal-close:active,
.nav-btn:active,
.offer-card:active,
.pet-item:active,
.shop-close:active {
	background: linear-gradient(180deg, #f1c40f, gold);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .18);
	color: #543415;
	transform: scale(.97)
}

.modal-overlay {
	backdrop-filter: blur(7px);
	background: rgba(0, 0, 0, .85);
	transition: background .3s, backdrop-filter .3s
}

@media (max-height:600px) and (orientation:landscape) {
	.modal-overlay {
		align-items: flex-start;
		padding: 5px
	}

	.game-modal {
		margin: 5px 0;
		max-height: 75dvh
	}

	.modal-content {
		padding: 10px
	}

	.game-input,
	.modal-header {
		padding: 8px 12px
	}

	.modal-title {
		font-size: 16px
	}

	.game-input {
		font-size: 14px
	}

	.game-btn {
		font-size: 14px;
		padding: 8px 16px
	}
}

.game-modal {
	box-shadow: 0 8px 40px rgba(0, 0, 0, .45), 0 2px 8px rgba(255, 215, 0, .08)
}

.modal-close {
	align-items: center;
	background: #e74c3c;
	border: 2px solid #c0392b;
	color: #fff;
	display: flex;
	font-size: 20px;
	font-weight: 700;
	height: 32px;
	justify-content: center;
	transition: background .2s, color .2s, box-shadow .2s;
	width: 32px
}

.modal-close:focus,
.modal-close:hover {
	background: #c0392b;
	box-shadow: 0 0 0 4px rgba(255, 215, 0, .15);
	color: gold
}

.mobile-menu-overlay {
	backdrop-filter: blur(2px);
	background: rgba(0, 0, 0, .45);
	transition: background .3s, backdrop-filter .3s
}

.mobile-menu-overlay.open {
	backdrop-filter: blur(4px);
	background: rgba(0, 0, 0, .65)
}

.fruit-icon img,
.offer-icon img,
.pack-icon img,
.pack-icon-large img,
.pet-icon img {
	animation: .7s forwards imgFadeIn;
	opacity: 0
}

@keyframes imgFadeIn {
	to {
		opacity: 1
	}
}

::-webkit-scrollbar {
	background: #543415;
	width: 10px
}

::-webkit-scrollbar-thumb {
	background: linear-gradient(180deg, #8b4513, gold);
	border-radius: 6px
}

::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(180deg, gold, #8b4513)
}

.fruit-item,
.game-btn,
.game-modal,
.modal-close,
.nav-btn,
.offer-card,
.pet-item,
.shop-close,
.shop-window {
	border-radius: 12px
}

.generating-title,
.modal-title,
.offers-title,
.pack-name,
.pack-name-large,
.section-title {
	color: #fff;
	text-shadow: 1px 1px 2px #543415, 0 0 2px #000
}

.toast:focus {
	box-shadow: 0 0 0 4px rgba(255, 215, 0, .15);
	outline: gold solid 2px
}

input:focus,
select:focus {
	box-shadow: 0 0 0 4px rgba(52, 152, 219, .12);
	outline: #3498db solid 2px
}

.selected-pet-info,
.user-info-container,
.user-info-display {
	background: linear-gradient(135deg, hsla(0, 0%, 100%, .1), hsla(0, 0%, 100%, .05));
	border: 2px solid rgba(255, 215, 0, .3);
	border-radius: 16px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .2);
	gap: 20px;
	margin-bottom: 25px;
	padding: 20px
}

.pet-details,
.user-details,
.user-info-display .user-details {
	display: flex;
	flex-direction: column;
	gap: 8px
}

.username {
	color: gold;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .7)
}

.pet-rarity,
.user-id,
.user-info-display .user-id {
	color: #bdc3c7;
	font-size: 14px;
	text-align: center;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .5)
}

.pet-name,
.user-info-display .username {
	color: gold;
	font-size: 20px;
	font-weight: 700;
	text-align: center;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .7)
}

.confirmation-text {
	background: linear-gradient(135deg, rgba(39, 174, 96, .2), rgba(46, 204, 113, .2));
	border: 2px solid rgba(39, 174, 96, .3);
	border-radius: 12px;
	color: #fff;
	font-size: 18px;
	margin-bottom: 25px;
	padding: 15px;
	text-align: center;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .7)
}

@media (max-width:768px) {

	.selected-pet-info,
	.user-info-container,
	.user-info-display {
		flex-direction: column;
		gap: 15px;
		padding: 15px
	}

	.username {
		font-size: 20px
	}

	.pet-name,
	.user-info-display .username {
		font-size: 18px
	}

	.confirmation-text {
		font-size: 16px;
		padding: 12px
	}
}

@media (max-width:480px) {

	.selected-pet-info,
	.user-info-container,
	.user-info-display {
		padding: 12px
	}

	.username {
		font-size: 18px
	}

	.pet-name,
	.user-info-display .username {
		font-size: 16px
	}

	.confirmation-text {
		font-size: 14px;
		padding: 10px
	}
}

@media (max-width:600px) {
	.generating-pack-info {
		flex-direction: column;
		gap: 18px;
		padding: 18px 8px
	}

	.arrow-animate {
		margin: 0 0 12px
	}

	.pack-info-block {
		min-width: 0
	}

	.pack-icon {
		font-size: 44px;
		min-height: 56px;
		min-width: 56px
	}

	.pack-label {
		font-size: 15px
	}
}

.adoptme-theme .shop-window {
	background: linear-gradient(145deg, #fff 0, #fff8f0 25%, var(--color-accent) 60%, var(--color-tertiary) 100%);
	border: 6px solid #fca9c9;
	border-radius: 32px;
	box-shadow: 0 0 0 3px #fdbdd5, 0 0 0 8px #fca9c9, 0 16px 40px -8px rgba(0, 0, 0, .4), inset 0 2px 0 hsla(0, 0%, 100%, .8);
	position: relative
}

.adoptme-theme .shop-header {
	background: linear-gradient(135deg, #fdc8df, #fdc8df 35%, #ffe5f0 70%, #ffe5f0);
	border-bottom: 5px solid #fdbdd5;
	border-top-left-radius: 26px;
	border-top-right-radius: 26px;
	overflow: hidden;
	padding: 20px 28px;
	position: relative
}

.adoptme-theme .shop-close {
	background: linear-gradient(145deg, #ff4757, #ff3742);
	border: 3px solid #ff1744;
	border-radius: 50%;
	box-shadow: 0 4px 0 #d50000, 0 6px 12px rgba(0, 0, 0, .3);
	font-size: 20px;
	font-weight: 900;
	height: 44px;
	transition: .2s cubic-bezier(.68, -.55, .265, 1.55);
	width: 44px
}

.adoptme-theme .top-nav {
	gap: 18px;
	justify-content: center
}

.adoptme-theme .nav-btn {
	background: linear-gradient(145deg, #fff, #fff3e0 50%, #ffe0b2);
	border: 4px solid #fca9c9;
	border-radius: 22px;
	box-shadow: 0 6px 0 #e379a1, 0 10px 25px -8px rgba(0, 0, 0, .3);
	color: #ff5722;
	font-size: 16px;
	font-weight: 700;
	overflow: hidden;
	padding: 14px 30px;
	position: relative;
	text-shadow: none;
	transition: .3s cubic-bezier(.68, -.55, .265, 1.55)
}

.adoptme-theme .nav-btn.active {
	background: linear-gradient(145deg, #ff8a65, #ff7043 50%, #ff5722);
	box-shadow: 0 4px 0 #d84315, 0 8px 20px -6px rgba(0, 0, 0, .4);
	color: #fff;
	transform: translateY(2px)
}

.adoptme-theme .nav-btn:hover:not(.active) {
	box-shadow: 0 8px 0 #e379a1, 0 14px 30px -8px rgba(0, 0, 0, .4);
	transform: translateY(-4px)
}

.adoptme-theme .shop-section {
	backdrop-filter: blur(10px);
	background: linear-gradient(160deg, hsla(0, 0%, 100%, .95), rgba(255, 248, 240, .9) 50%, rgba(255, 233, 214, .85));
	border: 4px solid #fca9c9;
	border-radius: 28px;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 12px 30px -6px rgba(0, 0, 0, .25), inset 0 1px 0 hsla(0, 0%, 100%, .9);
	margin-bottom: 20px
}

.adoptme-theme .section-header {
	background: var(--color-gradient);
	border: none;
	border-top-left-radius: 24px;
	border-top-right-radius: 24px;
	overflow: hidden;
	padding: 14px 22px;
	position: relative
}

.adoptme-theme .section-title {
	font-size: 1.15rem;
	font-weight: 800;
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .3), 0 0 8px hsla(0, 0%, 100%, .6)
}

.adoptme-theme .section-badge {
	animation: 2s ease-in-out infinite pulse;
	background: linear-gradient(45deg, #ff4757, #ff6b6b, #ff8e53);
	border: 3px solid #fff;
	border-radius: 20px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	padding: 6px 14px;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .3)
}

@keyframes pulse {

	0%,
	to {
		transform: scale(1)
	}

	50% {
		transform: scale(1.05)
	}
}

.adoptme-theme .section-timer {
	background: hsla(0, 0%, 100%, .2);
	border-radius: 15px;
	color: #fff;
	font-weight: 700;
	padding: 4px 12px;
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .4)
}

.adoptme-card {
	background: linear-gradient(145deg, #fff, #fefefe 30%, #fff8f0 70%, #ffeaa7);
	border: 4px solid #fdcb6e;
	border-radius: 24px;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 8px 0 #e17055, 0 12px 30px -8px rgba(0, 0, 0, .4);
	isolation: isolate;
	min-height: 160px;
	min-width: 140px;
	overflow: hidden;
	padding: 18px 14px;
	position: relative;
	transition: .4s cubic-bezier(.68, -.55, .265, 1.55);
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: center
}

.adoptme-card .pet-img,
.cta-button,
.tip-card {
	transition: transform .3s
}

.adoptme-card:before {
	background: linear-gradient(180deg, hsla(0, 0%, 100%, .4), transparent);
	border-radius: 20px 20px 0 0;
	content: "";
	height: 30%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0
}

.adoptme-card:hover {
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .9), 0 6px 0 #d63031, 0 18px 40px -8px rgba(0, 0, 0, .5);
	transform: translateY(-8px) scale(1.02)
}

.adoptme-card.selected {
	animation: 1.5s ease-in-out infinite selectedGlow;
	border-color: #00b894;
	box-shadow: 0 0 0 4px #fff, 0 0 0 8px #00b894, 0 8px 0 #00a085, 0 16px 35px -6px rgba(0, 0, 0, .5);
	transform: translateY(-4px) scale(1.05)
}

.cta-button:hover,
.nav-btn:hover,
.tip-card:hover {
	transform: translateY(-2px)
}

@keyframes selectedGlow {

	0%,
	to {
		box-shadow: 0 0 0 4px #fff, 0 0 0 8px #00b894, 0 8px 0 #00a085, 0 16px 35px -6px rgba(0, 0, 0, .5)
	}

	50% {
		box-shadow: 0 0 0 4px #fff, 0 0 0 8px #55efc4, 0 8px 0 #00a085, 0 16px 35px -6px rgba(0, 0, 0, .5)
	}
}

.pet-img {
	border-radius: 12px !important;
	overflow: hidden
}

.adoptme-card .pet-img {
	border-radius: 12px;
	filter: drop-shadow(0 8px 16px rgba(0, 0, 0, .3));
	max-width: 110px;
	object-fit: contain;
	width: 100%;
	max-height:120px;
}

.adoptme-card:hover .pet-img {
	transform: scale(1.1) rotate(5deg)
}

.pet-name-label {
	color: #2d3436;
	font-size: .9rem;
	font-weight: 800;
	line-height: 1.2;
	margin-top: 8px;
	text-align: center;
	text-shadow: 0 1px 2px hsla(0, 0%, 100%, .8)
}

.cta-section,
.faq-container,
.tips-grid {
	margin: 20px 0
}

.rarity-legendary {
	background: linear-gradient(145deg, #fff9e6, #fff3cd 30%, #ffe066 70%, #f39c12);
	border-color: #f39c12;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 8px 0 #e67e22, 0 12px 30px -8px rgba(243, 156, 18, .4)
}

.rarity-ultrarare {
	background: linear-gradient(145deg, #fff0f6, #fce4ec 30%, #f48fb1 70%, #e91e63);
	border-color: #e91e63;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 8px 0 #c2185b, 0 12px 30px -8px rgba(233, 30, 99, .4)
}

.rarity-rare {
	background: linear-gradient(145deg, #e3f2fd, #bbdefb 30%, #64b5f6 70%, #2196f3);
	border-color: #2196f3;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 8px 0 #1976d2, 0 12px 30px -8px rgba(33, 150, 243, .4)
}

.pet-tiers-table,
.tip-card {
	box-shadow: 0 4px 15px rgba(0, 0, 0, .1)
}

.adoptme-theme .game-btn {
	border: 4px solid;
	border-radius: 18px;
	box-shadow: 0 6px 0, 0 10px 25px -8px rgba(0, 0, 0, .3);
	font-size: 16px;
	font-weight: 700;
	overflow: hidden;
	padding: 14px 28px;
	position: relative;
	transition: .3s cubic-bezier(.68, -.55, .265, 1.55)
}

.adoptme-theme .game-btn.confirm {
	background: linear-gradient(145deg, #00b894, #00a085 50%, #00856f);
	border-color: #00856f;
	box-shadow: 0 6px 0 #006d56, 0 10px 25px -8px rgba(0, 184, 148, .4);
	color: #fff
}

.adoptme-theme .game-btn.confirm:hover {
	box-shadow: 0 9px 0 #006d56, 0 15px 30px -8px rgba(0, 184, 148, .5);
	transform: translateY(-3px)
}

.adoptme-theme .game-btn.cancel {
	background: linear-gradient(145deg, #fff, #f8f9fa 50%, #e9ecef);
	border-color: #ff6348;
	box-shadow: 0 6px 0 #e55347, 0 10px 25px -8px rgba(255, 99, 72, .3);
	color: #ff6348
}

.adoptme-theme .game-btn.cancel:hover {
	box-shadow: 0 9px 0 #e55347, 0 15px 30px -8px rgba(255, 99, 72, .4);
	transform: translateY(-3px)
}

.adoptme-theme .game-modal {
	background: linear-gradient(145deg, #fff, #fff8f0 30%, #ffe9d6 70%, #ffd4a8);
	border: 6px solid #ff9a5e;
	border-radius: 32px;
	box-shadow: 0 0 0 3px #fff, 0 0 0 8px #ffb36b, 0 20px 50px -10px rgba(0, 0, 0, .5)
}

.adoptme-theme .modal-header {
	background: var(--color-gradient);
	border-bottom: 4px solid #e64a19;
	border-top-left-radius: 26px;
	border-top-right-radius: 26px;
	padding: 18px 24px
}

.adoptme-theme .modal-title {
	font-size: 1.4rem;
	font-weight: 800
}

.adoptme-theme .game-input {
	background: linear-gradient(145deg, #fff, #f8f9fa);
	border: 4px solid #fca9c9;
	border-radius: 16px;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, .1);
	font-family: Insaniburger, sans-serif;
	font-size: 16px;
	font-weight: 600;
	padding: 16px 20px;
	transition: .3s
}

.adoptme-theme .game-input:focus {
	border-color: #00b894;
	box-shadow: 0 0 0 4px rgba(0, 184, 148, .2), inset 0 2px 4px rgba(0, 0, 0, .1)
}

.adoptme-theme .offer-card {
	background: linear-gradient(145deg, #fff, #fff8f0 30%, #ffe9d6 70%, #ffd4a8);
	border: 4px solid #fca9c9;
	border-radius: 28px;
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .8), 0 8px 0 #e379a1, 0 12px 30px -8px rgba(0, 0, 0, .3);
	transition: .4s cubic-bezier(.68, -.55, .265, 1.55)
}

.adoptme-theme .search-input,
.adoptme-theme .tier-filter {
	background: linear-gradient(145deg, #fff, #fff8f0 50%, #ffe9d6)
}

.adoptme-theme .search-input,
.adoptme-theme .selected-pack-info,
.adoptme-theme .tier-filter {
	border: 3px solid #fca9c9;
	box-shadow: 0 4px 0 #e379a1, 0 8px 20px -6px rgba(0, 0, 0, .2)
}

.adoptme-theme .offer-card.featured {
	border-color: #00b894;
	box-shadow: 0 0 0 4px #fff, 0 0 0 8px #00b894, 0 8px 0 #00a085, 0 16px 35px -8px rgba(0, 0, 0, .4)
}

.adoptme-theme .offer-card:hover {
	box-shadow: 0 0 0 2px hsla(0, 0%, 100%, .9), 0 6px 0 #e67e22, 0 18px 40px -8px rgba(0, 0, 0, .4);
	transform: translateY(-6px) scale(1.02)
}

.adoptme-theme .search-input:focus {
	border-color: #00b894;
	box-shadow: 0 0 12px rgba(0, 184, 148, .5)
}

.adoptme-theme .generation-progress,
.adoptme-theme .mobile-stats-panel,
.adoptme-theme .selected-pack-info {
	background: linear-gradient(145deg, #fff, #fff8f0 30%, #ffe9d6 70%, #ffd4a8)
}

.adoptme-theme .generation-progress {
	border: 4px solid #fca9c9;
	box-shadow: 0 6px 0 #e379a1, 0 12px 25px -6px rgba(0, 0, 0, .3)
}

.adoptme-theme .mobile-stats-panel {
	border-left: 4px solid #fca9c9;
	box-shadow: -5px 0 15px rgba(0, 0, 0, .2)
}

.adoptme-theme ::-webkit-scrollbar {
	background: #fca9c9;
	width: 10px
}

.adoptme-theme ::-webkit-scrollbar-thumb {
	background: linear-gradient(to bottom, #e379a1, var(--color-primary));
	border-radius: 6px
}

.adoptme-theme ::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(to bottom, var(--color-primary), #e379a1)
}

.adoptme-theme .shop-content::-webkit-scrollbar-track {
	background: #fca9c9;
	border-radius: 4px
}

.adoptme-theme .shop-content::-webkit-scrollbar-thumb {
	background: linear-gradient(to bottom, #e379a1, var(--color-primary));
	border-radius: 4px
}

.adoptme-theme .shop-content::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(to bottom, var(--color-primary), #e379a1)
}

.adoptme-theme .progress-bar {
	background: linear-gradient(145deg, #f8f9fa, #e9ecef);
	border: 4px solid #fca9c9;
	border-radius: 20px;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, .2);
	overflow: hidden
}

.adoptme-theme .progress-fill {
	background: linear-gradient(135deg, #00b894, #00a085 50%, #55efc4);
	border-radius: 16px;
	box-shadow: inset 0 0 0 2px #fff, 0 2px 8px rgba(0, 184, 148, .5)
}

.adoptme-theme .forever-pack {
	background: linear-gradient(145deg, #a29bfe, #6c5ce7 50%, #5f3dc4);
	border: 5px solid #fff;
	border-radius: 24px;
	box-shadow: 0 0 0 4px #6c5ce7, 0 12px 30px -6px rgba(108, 92, 231, .4);
	overflow: hidden;
	padding: 24px;
	position: relative
}

.adoptme-theme .forever-pack:before {
	background: linear-gradient(180deg, hsla(0, 0%, 100%, .3), transparent);
	border-radius: 19px 19px 0 0;
	content: "";
	height: 40%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0
}

.adoptme-theme .forever-title {
	font-size: 1.4rem;
	font-weight: 800;
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .3)
}

.adoptme-theme .info-title {
	color: #ff5722;
	font-size: 24px;
	font-weight: 800;
	margin-bottom: 15px;
	position: relative;
	text-align: center;
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .3), 0 0 8px hsla(0, 0%, 100%, .6);
	z-index: 1
}

.adoptme-theme .info-text {
	color: #2d3436;
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 15px;
	position: relative;
	text-shadow: 0 1px 2px hsla(0, 0%, 100%, .8);
	z-index: 1
}

.adoptme-theme .info-step {
	align-items: flex-start;
	background: linear-gradient(145deg, hsla(0, 0%, 100%, .9), rgba(255, 248, 240, .8) 50%, rgba(255, 233, 214, .7));
	border: 3px solid #fca9c9;
	border-radius: 20px;
	box-shadow: 0 6px 0 #e379a1, 0 10px 25px -8px rgba(0, 0, 0, .2);
	display: flex;
	gap: 15px;
	overflow: hidden;
	padding: 15px;
	position: relative;
	transition: .3s cubic-bezier(.68, -.55, .265, 1.55)
}

.adoptme-theme .info-step:hover,
.adoptme-theme .rarity-tier:hover,
.adoptme-theme .safety-item:hover {
	box-shadow: 0 9px 0 #e379a1, 0 15px 30px -8px rgba(0, 0, 0, .3);
	transform: translateY(-3px)
}

.adoptme-theme .step-number {
	align-items: center;
	background: linear-gradient(145deg, gold, #ffb347 50%, #ff8f00);
	border: 3px solid #fff;
	border-radius: 50%;
	box-shadow: 0 4px 0 #e67e22, 0 6px 12px rgba(255, 215, 0, .4);
	color: #fff;
	display: flex;
	flex-shrink: 0;
	font-size: 18px;
	font-weight: 800;
	height: 40px;
	justify-content: center;
	position: relative;
	width: 40px;
	z-index: 2
}

.adoptme-theme .rarity-tier,
.adoptme-theme .safety-item {
	background: linear-gradient(145deg, hsla(0, 0%, 100%, .9), rgba(255, 248, 240, .8) 50%, rgba(255, 233, 214, .7));
	box-shadow: 0 6px 0 #e379a1, 0 10px 25px -8px rgba(0, 0, 0, .2);
	padding: 15px;
	transition: .3s cubic-bezier(.68, -.55, .265, 1.55);
	overflow: hidden;
	position: relative
}

.adoptme-theme .safety-item {
	align-items: flex-start;
	border: 3px solid #fca9c9;
	border-radius: 20px;
	display: flex;
	gap: 12px
}

.adoptme-theme .safety-icon {
	flex-shrink: 0;
	font-size: 24px;
	position: relative;
	z-index: 2
}

.adoptme-theme .rarity-tier {
	border: 3px solid #fca9c9;
	border-radius: 20px;
	text-align: center
}

.adoptme-theme .rarity-icon {
	font-size: 32px;
	margin-bottom: 10px;
	position: relative;
	z-index: 2
}

@media (max-width:640px) {
	.adoptme-card {
		min-height: 140px;
		min-width: 120px;
		padding: 14px 10px
	}

	.adoptme-theme .shop-title {
		font-size: 1.4rem
	}

	.adoptme-theme .nav-btn {
		font-size: 14px;
		padding: 10px 20px
	}

	.adoptme-theme .section-title {
		font-size: 1rem
	}

	.pet-name-label {
		font-size: .8rem
	}
}

.blog-header-section {
	background: var(--color-gradient);
	border-top-left-radius: 24px;
	border-top-right-radius: 24px;
	overflow: hidden;
	padding: 20px 28px;
	position: relative
}

.blog-header-section h1 {
	color: #fff;
	font-size: 1.8rem;
	font-weight: 800;
	letter-spacing: .5px;
	line-height: 1.2;
	margin-bottom: 10px;
	text-shadow: 2px 2px 0 #d84315, 0 0 10px hsla(0, 0%, 100%, .5)
}

.blog-section h2,
.nav-btn {
	text-shadow: 1px 1px 0 hsla(0, 0%, 100%, .5)
}

.blog-meta {
	color: hsla(0, 0%, 100%, .9);
	font-weight: 600;
	gap: 15px
}

.blog-section {
	border-bottom: 1px solid rgba(252, 169, 201, .2);
	padding: 20px 28px
}

.key-takeaways,
.pet-tiers-table {
	border: 2px solid var(--color-primary)
}

.blog-section:last-child,
.key-takeaways li:last-child {
	border-bottom: none
}

.blog-section h2 {
	border-bottom: 2px solid var(--color-secondary);
	color: var(--color-primary);
	display: inline-block;
	font-size: 1.4rem;
	font-weight: 800;
	margin-bottom: 15px;
	padding-bottom: 8px
}

.blog-section h3 {
	color: #333;
	font-size: 1.1rem;
	font-weight: 700;
	margin: 20px 0 10px
}

.blog-section p {
	color: #555;
	line-height: 1.6;
	margin-bottom: 15px
}

.blog-section ol,
.blog-section ul {
	margin: 15px 0;
	padding-left: 25px
}

.blog-section li {
	color: #555;
	line-height: 1.5;
	margin-bottom: 8px
}

.blog-section strong,
.tip-card h4 {
	color: var(--color-primary);
	font-weight: 700
}

.key-takeaways {
	background: linear-gradient(135deg, rgba(253, 154, 190, .1), rgba(255, 187, 213, .1))
}

.key-takeaways h2 {
	font-size: 1.3rem
}

.key-takeaways ul {
	margin: 0
}

.key-takeaways li:before {
	content: "🐾";
	left: 0;
	position: absolute;
	top: 8px
}

.pet-table-container {
	margin: 20px 0;
	overflow-x: auto
}

.pet-tiers-table th {
	text-shadow: 1px 1px 0 rgba(0, 0, 0, .2)
}

.pet-tiers-table tr:nth-child(2n) {
	background: rgba(255, 229, 240, .5)
}

.tips-grid {
	display: grid;
	gap: 15px;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr))
}

.tip-card {
	background: linear-gradient(135deg, hsla(0, 0%, 100%, .9), rgba(253, 218, 231, .8));
	border: 2px solid var(--color-secondary);
	border-radius: 15px;
	padding: 20px
}

.tip-card h4 {
	font-size: 1.1rem;
	margin-bottom: 10px
}

.faq-item {
	border: 2px solid var(--color-accent);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .05)
}

.faq-item h3 {
	font-weight: 700
}

.blog-section a,
.nav-links a {
	font-weight: 600;
	text-decoration: none
}

.cta-section {
	background: linear-gradient(135deg, var(--color-primary) 0, var(--color-secondary) 100%);
	border-radius: 15px;
	color: #fff;
	text-align: center
}

.cta-section h2 {
	color: #fff;
	margin-bottom: 10px;
	text-shadow: 2px 2px 0 rgba(0, 0, 0, .3)
}

.cta-button {
	box-shadow: 0 4px 15px rgba(0, 0, 0, .2);
	font-size: 1.1rem;
	margin-top: 15px
}

.cta-button:hover {
	box-shadow: 0 6px 20px rgba(0, 0, 0, .3);
	box-shadow: 0 5px 15px rgba(0, 0, 0, .2)
}

.blog-section a {
	border-bottom: 1px solid transparent;
	color: var(--color-primary)
}

.blog-section a:hover {
	border-bottom-color: var(--color-primary)
}

@media (max-width:768px) {
	.blog-header-section h1 {
		font-size: 1.5rem
	}

	.blog-meta {
		flex-direction: column;
		gap: 8px
	}

	.blog-section {
		padding: 15px 20px
	}

	.tips-grid {
		grid-template-columns: 1fr
	}

	.pet-tiers-table {
		font-size: .9rem
	}

	.pet-tiers-table td,
	.pet-tiers-table th {
		padding: 8px 10px
	}
}

.blog-meta,
.nav-links {
	display: flex;
	gap: 2rem
}

.blog-post {
	background: #fff !important;
	font-family: Baloo\ 2, Nunito, sans-serif !important;
	height: auto !important;
	letter-spacing: normal !important;
	min-height: 100vh !important;
	overflow: auto !important;
	position: static !important;
	width: 100% !important
}

.blog-nav,
.pet-tiers-table th {
	background: var(--color-primary)
}

.blog-header h1,
.content-section h2,
.key-takeaways h2,
.nav-logo {
	font-family: Fredoka One, cursive
}

.blog-nav {
	box-shadow: 0 2px 10px rgba(0, 0, 0, .1);
	padding: 1rem 0;
	position: sticky;
	top: 0;
	z-index: 1000
}

.nav-container {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1200px;
	padding: 0 2rem
}

.nav-logo {
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	text-decoration: none
}

.blog-meta,
.caption,
.nav-btn {
	font-size: .9rem
}

.nav-links a {
	border-radius: 20px;
	color: #fff;
	padding: .5rem 1rem;
	transition: background-color .3s
}

.nav-links a.active,
.nav-links a:hover {
	background-color: hsla(0, 0%, 100%, .2)
}

.blog-header {
	background: linear-gradient(135deg, var(--color-primary) 0, var(--color-secondary) 100%);
	color: #fff;
	padding: 4rem 2rem 3rem;
	text-align: center
}

.blog-container {
	margin: 0 auto;
	max-width: 800px
}

.blog-header h1 {
	font-size: 2.5rem;
	line-height: 1.2;
	margin-bottom: 1rem
}

.blog-meta {
	justify-content: center;
	opacity: .9
}

.blog-content {
	display: grid;
	gap: 3rem;
	grid-template-columns: 1fr 300px;
	margin: 0 auto;
	max-width: 1200px;
	padding: 2rem
}

.blog-article {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 5px 20px rgba(0, 0, 0, .1);
	padding: 2rem
}

.key-takeaways,
.pet-tiers-table tr:nth-child(2n) {
	background: var(--color-accent)
}

.content-section {
	margin-bottom: 3rem
}

.content-section h2 {
	border-bottom: 3px solid var(--color-secondary);
	color: var(--color-primary);
	font-size: 1.8rem;
	margin-bottom: 1rem;
	padding-bottom: .5rem
}

.content-section h3 {
	color: #333;
	font-size: 1.3rem;
	margin: 1.5rem 0 1rem
}

.content-section p {
	color: #555;
	line-height: 1.7;
	margin-bottom: 1rem
}

.content-section ol,
.content-section ul {
	margin: 1rem 0;
	padding-left: 2rem
}

.content-section li {
	color: #555;
	line-height: 1.6;
	margin-bottom: .5rem
}

.key-takeaways {
	border-left: 5px solid var(--color-primary);
	border-radius: 10px;
	margin: 2rem 0;
	padding: 2rem
}

.key-takeaways h2 {
	color: var(--color-primary);
	margin-bottom: 1rem
}

.key-takeaways ul,
.sidebar-widget ul {
	list-style: none;
	padding: 0
}

.key-takeaways li {
	position: relative;
	border-bottom: 1px solid rgba(253, 154, 190, .2);
	padding: .5rem 0
}

.pet-tiers-table {
	background: #fff;
	border-collapse: collapse;
	border-radius: 8px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, .1);
	margin: 2rem 0;
	overflow: hidden;
	width: 100%
}

.pet-tiers-table td,
.pet-tiers-table th {
	border-bottom: 1px solid #eee;
	padding: 1rem;
	text-align: left
}

.pet-tiers-table th {
	color: #fff;
	font-weight: 700
}

.featured-image,
.generator-preview {
	margin: 2rem 0;
	text-align: center
}

.featured-image img {
	border-radius: 10px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, .2);
	height: auto;
	max-width: 100%
}

.generator-preview img {
	border-radius: 10px;
	box-shadow: 0 3px 10px rgba(0, 0, 0, .15);
	height: auto;
	max-width: 300px
}

.caption {
	color: #666;
	font-style: italic;
	margin-top: .5rem
}

.tip-box {
	background: #e8f4fd;
	border: 1px solid #2196f3;
	border-radius: 8px;
	margin: 2rem 0;
	padding: 1.5rem
}

.tip-box h4 {
	color: #2196f3;
	margin-bottom: .5rem
}

.faq-section {
	margin: 3rem 0
}

.faq-item {
	background: #f9f9f9;
	border-left: 4px solid var(--color-primary);
	border-radius: 8px;
	margin-bottom: 1rem;
	padding: 1.5rem
}

.faq-item h3 {
	color: var(--color-primary);
	font-size: 1.2rem;
	margin-bottom: .5rem
}

.cta-box h3,
.sidebar-widget h3 {
	font-family: Fredoka One, cursive;
	margin-bottom: 1rem
}

.cta-box {
	background: linear-gradient(135deg, var(--color-primary) 0, var(--color-secondary) 100%);
	border-radius: 10px;
	color: #fff;
	margin: 2rem 0;
	padding: 2rem;
	text-align: center
}

.cta-button,
.sidebar-widget a:hover,
.sidebar-widget h3 {
	color: var(--color-primary)
}

.cta-button {
	background: #fff;
	border-radius: 25px;
	display: inline-block;
	font-weight: 700;
	padding: 1rem 2rem;
	text-decoration: none
}

.blog-sidebar {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 5px 20px rgba(0, 0, 0, .1);
	height: fit-content;
	padding: 2rem;
	position: sticky;
	top: 2rem
}

.sidebar-widget {
	margin-bottom: 2rem
}

.sidebar-widget h3 {
	font-size: 1.3rem
}

.sidebar-widget li {
	margin-bottom: .5rem
}

.sidebar-widget a {
	color: #555;
	text-decoration: none;
	transition: color .3s
}

.blog-footer {
	background: #333;
	color: #fff;
	margin-top: 3rem;
	padding: 2rem 0
}

.footer-container {
	margin: 0 auto;
	max-width: 1200px;
	padding: 0 2rem;
	text-align: center
}

.footer-content a {
	color: var(--color-secondary);
	text-decoration: none
}

.footer-content a:hover {
	text-decoration: underline
}

@media (max-width:768px) {
	.blog-content {
		gap: 2rem;
		grid-template-columns: 1fr
	}

	.blog-header h1 {
		font-size: 2rem
	}

	.blog-meta {
		flex-direction: column;
		gap: .5rem
	}

	.nav-container {
		flex-direction: column;
		gap: 1rem
	}

	.nav-links {
		gap: 1rem
	}

	.blog-article {
		padding: 1rem
	}

	.pet-tiers-table {
		font-size: .9rem
	}

	.pet-tiers-table td,
	.pet-tiers-table th {
		padding: .5rem
	}
}

.top-nav {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-bottom: 20px
}

.nav-btn {
	text-decoration: none;
	background: hsla(0, 0%, 100%, .8);
	border: 2px solid transparent;
	border-radius: 20px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
	color: var(--color-primary);
	font-weight: 700;
	min-width: 80px;
	padding: 10px 16px;
	text-align: center;
	transition: .3s
}

.nav-btn:hover {
	background: hsla(0, 0%, 100%, .9);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .2)
}

.nav-btn.active {
	background: var(--color-primary);
	border-color: var(--color-secondary);
	box-shadow: 0 4px 15px rgba(253, 154, 190, .4);
	color: #fff
}

.nav-btn.home {
	background: linear-gradient(135deg, var(--color-primary) 0, var(--color-secondary) 100%);
	color: #fff;
	font-weight: 800
}

.nav-btn.home:hover {
	background: linear-gradient(135deg, var(--color-secondary) 0, var(--color-primary) 100%)
}

.blog-image-container {
	display: grid;
	gap: 15px;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	justify-items: center;
	margin: 20px 0
}

.blog-image-container.single {
	grid-template-columns: 1fr;
	margin: 20px auto;
	max-width: 300px
}

.blog-image-container img {
	border: 3px solid var(--color-secondary);
	border-radius: 15px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, .2);
	height: auto;
	max-width: 150px;
	transition: transform .3s;
	width: 100%
}

.blog-image-container.single img {
	max-width: 250px
}

.blog-image-container img:hover {
	transform: scale(1.05)
}

.image-caption {
	color: #666;
	font-style: italic;
	margin-top: 10px;
	text-align: center
}

.back-link,
.image-caption {
	font-size: .9rem;
	font-weight: 600
}

.back-link {
	color: hsla(0, 0%, 100%, .8);
	display: block;
	margin-bottom: 5px;
	text-decoration: none;
	transition: color .3s
}

.back-link:hover {
	color: #fff
}

.shop-title span {
	display: block;
	font-size: 1.4rem
}
