.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;
	scrollbar-gutter: stable both-edges
}



.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)
}


.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;
    aspect-ratio: 1 / 1;
}

.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 {
	display: flex;
	flex-direction: column;
	align-items: center;
	min-width: 120px;
	align-self: stretch;
	background: linear-gradient(145deg, #ffffff 0%, #fff8f0 30%, #ffe9d6 70%, #ffd4a8 100%);
	border: 4px solid #FCA9C9;
	border-radius: 24px;
	padding: 20px;
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.8),
		0 8px 0 #e379a1,
		0 12px 30px -8px rgba(0, 0, 0, 0.3);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.pack-info-block:hover {
	transform: translateY(-2px);
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.9),
		0 10px 0 #e379a1,
		0 16px 35px -8px rgba(0, 0, 0, 0.4);
}

.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(145deg, #ffffff 0%, #fff8f0 30%, #ffe9d6 70%, #ffd4a8 100%);
	border: 4px solid #FCA9C9;
	border-radius: 24px;
	padding: 24px;
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.8),
		0 8px 0 #e379a1,
		0 12px 30px -8px rgba(0, 0, 0, 0.3);
}

.progress-bar {
	width: 100%;
	height: 28px;
	background: rgba(252, 169, 201, 0.2);
	border: 3px solid #FCA9C9;
	border-radius: 14px;
	overflow: hidden;
	margin-bottom: 12px;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.progress-fill {
	height: 100%;
	background: linear-gradient(to right, #00b894, #00d1a7);
	width: 0%;
	box-shadow: 0 0 10px rgba(0, 184, 148, 0.5);
	transition: width 0.3s ease;
}

.progress-text {
	color: #00b894;
	font-size: 18px;
	font-weight: bold;
	text-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);
	text-align: center;
}


.status-text {
	color: #e64a19;
	font-size: 20px;
	margin-bottom: 20px;
	text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.8);
	font-weight: 800;
	text-align: center;
	padding: 10px;
	background: rgba(252, 169, 201, 0.1);
	border-radius: 12px;
	border: 2px solid #FCA9C9;
}

.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;
}

.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;
}

.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;
}

.offer-desc {
	color: #bdc3c7;
	font-size: 14px;
	line-height: 1.4;
	margin-bottom: 12px;
	text-align: left;
}

.offer-reward {
	color: #ff5722;
	font-size: 16px;
	font-weight: 800;
	text-align: left;
}

.offer-complete-btn,
.toast {
	background: linear-gradient(180deg, #27ae60, #229954);
	font-size: 14px;
	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;
	padding: 5px 8px;
	transition: .2s cubic-bezier(.68, -.55, .265, 1.55);
	color: #fff;
}

.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);
	text-align: center;
}

.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:active {
	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: Insaniburger, sans-serif
}

.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: Insaniburger, sans-serif;
	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
}

/* Enhanced Offer Cards & Generation Page - Modern Responsive Design */
.offers-grid {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
	padding: 20px !important;
	max-width: 800px !important;
	margin: 0 auto !important;
}

/* Responsive Grid for larger screens */
@media (min-width: 768px) {
	.offers-grid {
		/* display: grid !important;
		grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)) !important; */
		gap: 20px !important;
	}
	
	.offer-card {
		margin-bottom: 0 !important;
	}
}

.offer-card {
	background: linear-gradient(145deg, #fff, #fff8f0 30%, #ffe9d6 70%, #ffd4a8) !important;
	border: 4px solid #fca9c9 !important;
	border-radius: 24px !important;
	padding: 20px !important;
	transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55) !important;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8), 0 8px 0 #e379a1, 0 12px 30px -8px rgba(0, 0, 0, 0.3) !important;
	display: flex !important;
	align-items: center !important;
	gap: 20px !important;
	width: 100%;
	margin-bottom: 16px;
	font-family: Insaniburger, sans-serif !important;
}

.offer-card:hover {
	transform: translateY(-6px) scale(1.02) !important;
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9), 0 6px 0 #e67e22, 0 18px 40px -8px rgba(0, 0, 0, 0.4) !important;
	border-color: #e67e22 !important;
}

.offer-card.featured {
	border-color: #00b894 !important;
	box-shadow: 0 0 0 4px #fff, 0 0 0 8px #00b894, 0 8px 0 #00a085, 0 16px 35px -8px rgba(0, 0, 0, 0.4) !important;
	transform: scale(1.02) !important;
}

.offer-badge {
	position: absolute !important;
	top: -8px !important;
	right: 20px !important;
	background: linear-gradient(135deg, #00b894, #00a085) !important;
	color: white !important;
	padding: 8px 16px !important;
	border-radius: 0 0 16px 16px !important;
	font-size: 12px !important;
	font-weight: 800 !important;
	font-family: Insaniburger, sans-serif !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	box-shadow: 0 4px 0 #00a085, 0 8px 16px rgba(0, 0, 0, 0.3) !important;
	z-index: 2 !important;
}

.offer-icon {
	font-size: 48px !important;
	margin: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 80px !important;
	height: 80px !important;
	background: rgba(252, 169, 201, 0.2) !important;
	border-radius: 20px !important;
	flex-shrink: 0 !important;
	filter: drop-shadow(4px 4px 12px rgba(0, 0, 0, 0.3)) !important;
	border: 3px solid #fca9c9 !important;
	box-shadow: inset 0 2px 4px rgba(255, 255, 255, 0.8) !important;
}

.offer-content {
	display: flex !important;
	flex: 1 !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 20px !important;
}

.offer-info {
	text-align: left !important;
	position: relative;
	z-index: 1;
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
}

.offer-cta {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	flex-shrink: 0 !important;
}

.offer-name {
	font-size: 20px !important;
	font-weight: 800 !important;
	font-family: Insaniburger, sans-serif !important;
	color: #E81F76 !important;
	margin-bottom: 8px !important;
	line-height: 1.2 !important;
	letter-spacing: 1px !important;
}

.offer-desc {
	font-size: 14px !important;
	font-family: Insaniburger, sans-serif !important;
	color: #363636 !important;
	margin-bottom: 0 !important;
	line-height: 1.4 !important;
	font-weight: 600 !important;
	letter-spacing: 0.5px !important;
}

.offer-reward {
	font-size: 14px !important;
	color: white !important;
	font-weight: 800 !important;
	font-family: Insaniburger, sans-serif !important;
	background: linear-gradient(135deg, #e67e22, #d35400) !important;
	padding: 12px 18px !important;
	border-radius: 20px !important;
	border: 3px solid #d35400 !important;
	cursor: pointer !important;
	transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	white-space: nowrap !important;
	box-shadow: 0 4px 0 #bf6516, 0 8px 16px rgba(0, 0, 0, 0.3) !important;
}


.offer-arrow {
	font-size: 22px !important;
	color: #e67e22 !important;
	font-weight: bold !important;
	transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) !important;
	opacity: 0.8 !important;
}

.offer-reward:hover {
	transform: translateY(-2px) !important;
	background: linear-gradient(135deg, #f39c12, #e67e22) !important;
	box-shadow: 0 6px 0 #bf6516, 0 12px 20px rgba(0, 0, 0, 0.4) !important;
}

.offer-card:hover .offer-arrow {
	transform: translateX(6px) scale(1.1) !important;
	opacity: 1 !important;
	color: #f39c12 !important;
}

/* Mobile Responsive Styles */
@media (max-width: 767px) {
	.offer-card {
		padding: 16px !important;
		flex-direction: column !important;
		text-align: center !important;
		gap: 16px !important;
		border-radius: 20px !important;
		border-width: 3px !important;
	}
	
	.offer-content {
		flex-direction: column !important;
		gap: 16px !important;
		width: 100% !important;
	}
	
	.offer-cta {
		justify-content: center !important;
		width: 100% !important;
	}
	
	.offer-icon {
		width: 64px !important;
		height: 64px !important;
		font-size: 40px !important;
		align-self: center !important;
		border-radius: 16px !important;
		border-width: 2px !important;
	}
	
	.offer-info {
		text-align: center !important;
	}
	
	.offer-name {
		font-size: 18px !important;
	}
	
	.offer-desc {
		font-size: 13px !important;
	}
	
	.offer-reward {
		padding: 10px 16px !important;
		font-size: 12px !important;
		border-radius: 16px !important;
		border-width: 2px !important;
	}
	
	.offers-grid {
		padding: 16px !important;
		gap: 12px !important;
	}
	
	.offers-header {
		padding: 20px 16px !important;
		border-radius: 20px !important;
		border-width: 3px !important;
	}
	
	.offers-title {
		font-size: 28px !important;
	}
}

/* Small mobile screens */
@media (max-width: 480px) {
	.offer-card {
		padding: 12px !important;
		border-radius: 16px !important;
		gap: 12px !important;
	}
	
	.offer-icon {
		width: 56px !important;
		height: 56px !important;
		font-size: 32px !important;
		border-radius: 12px !important;
	}
	
	.offer-name {
		font-size: 16px !important;
	}
	
	.offer-desc {
		font-size: 12px !important;
	}
	
	.offer-reward {
		font-size: 11px !important;
		padding: 8px 12px !important;
	}
	
	.offers-title {
		font-size: 24px !important;
	}
	
	.offers-header {
		padding: 16px 12px !important;
		border-radius: 16px !important;
	}
}

/* Accessibility - Focus States */
.offer-card:focus {
	outline: 3px solid #ff6b9d !important;
	outline-offset: 2px !important;
}

.offer-reward:focus {
	outline: 2px solid #ffffff !important;
	outline-offset: 2px !important;
}

/* Touch device improvements */
@media (hover: none) and (pointer: coarse) {
	.offer-card:hover {
		transform: none !important;
	}
	
	.offer-card:active {
		transform: scale(0.98) !important;
		transition: transform 0.1s ease !important;
	}
	
	.offer-reward:hover {
		transform: none !important;
	}
}

.offers-header {
	text-align: center !important;
	margin-bottom: 32px !important;
	padding: 28px 24px !important;
	background: linear-gradient(145deg, #fff, #fff8f0 30%, #ffe9d6 70%, #ffd4a8) !important;
	border-radius: 28px !important;
	border: 4px solid #fca9c9 !important;
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8), 0 8px 0 #e379a1, 0 12px 30px -8px rgba(0, 0, 0, 0.3) !important;
}

.offers-title {
	font-size: 32px !important;
	font-weight: 800 !important;
	font-family: Insaniburger, sans-serif !important;
	color: #2c3e50 !important;
	margin-bottom: 16px !important;
	letter-spacing: 1px !important;
}

.offers-subtitle {
	font-size: 16px !important;
	font-family: Insaniburger, sans-serif !important;
	color: #363636 !important;
	margin-bottom: 20px !important;
	line-height: 1.4 !important;
	font-weight: 600 !important;
	letter-spacing: 0.5px !important;
}

.security-badge {
	display: inline-block !important;
	background: rgba(34, 197, 94, 0.1) !important;
	color: #22c55e !important;
	padding: 8px 16px !important;
	border-radius: 20px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	border: 1px solid rgba(34, 197, 94, 0.2) !important
}

.generation-container {
	max-width: 600px !important;
	margin: 0 auto !important;
	padding: 24px 16px !important;
	text-align: center !important
}

.generating-pack-info {
	margin-bottom: 24px !important
}

.pack-info-block {
	background: linear-gradient(145deg, #ffffff 0%, #f8f9ff 100%) !important;
	border-radius: 16px !important;
	padding: 20px !important;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08) !important;
	/* margin-bottom: 20px !important */
}

.pack-icon {
	font-size: 48px !important;
	margin-bottom: 8px !important;
	/* animation: float 3s ease-in-out infinite */
}

@keyframes float {

	0%,
	100% {
		transform: translateY(0px)
	}

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

.generation-progress {
	margin-bottom: 20px !important
}

.progress-container {
	background: #f0f0f0 !important;
	border-radius: 10px !important;
	height: 14px !important;
	overflow: hidden !important;
	margin-bottom: 12px !important;
	position: relative !important;
	box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1) !important
}

.progress-bar {
	width: 100% !important;
	height: 100% !important;
	background: #f0f0f0 !important;
	border-radius: 10px !important;
	overflow: hidden !important;
	position: relative !important
}

.progress-fill {
	height: 100% !important;
	background: linear-gradient(90deg, #ff6b9d, #ff8fab, #ffd93d) !important;
	border-radius: 10px !important;
	transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
	position: relative !important;
	overflow: hidden !important
}

.progress-fill::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
	animation: shimmer 2s infinite
}

@keyframes shimmer {
	0% {
		transform: translateX(-100%)
	}

	100% {
		transform: translateX(100%)
	}
}

.progress-text {
	font-size: 16px !important;
	font-weight: 600 !important;
	color: #ff6b9d !important;
	margin-bottom: 10px !important
}

.status-text {
	font-size: 14px !important;
	color: #666666 !important;
	margin-bottom: 20px !important;
	font-weight: 500 !important
}

.generation-steps {
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
	max-width: 380px !important;
	margin: 0 auto !important
}

.step {
	background: #f8f9ff !important;
	padding: 12px 16px !important;
	border-radius: 10px !important;
	font-size: 13px !important;
	color: #666666 !important;
	border-left: 3px solid #e0e0e0 !important;
	transition: all 0.3s ease !important;
	position: relative !important;
	text-align: left !important
}

.step.active {
	background: rgba(255, 107, 157, 0.1) !important;
	border-left-color: #ff6b9d !important;
	color: #ff6b9d !important;
	font-weight: 500 !important;
	padding-left: 32px !important
}

.step.completed {
	background: rgba(34, 197, 94, 0.1) !important;
	border-left-color: #22c55e !important;
	color: #22c55e !important;
	padding-left: 32px !important
}

.step.completed::before {
	content: '✓';
	position: absolute;
	left: 16px;
	font-weight: bold;
	color: #22c55e
}

.step.active::before {
	content: '';
	position: absolute;
	left: 16px;
	width: 10px;
	height: 10px;
	border: 2px solid #ff6b9d;
	border-top: 2px solid transparent;
	border-radius: 50%;
	animation: spin 1s linear infinite
}

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

	100% {
		transform: rotate(360deg)
	}
}

@media (max-width:768px) {
	.offers-grid {
		/* grid-template-columns: 1fr !important; */
		gap: 8px !important;
		padding: 8px !important
	}

	.offer-card {
		grid-template-columns: 60px 1fr;
        grid-template-rows: auto auto;
        gap: 12px;
        padding: 12px;
	}
	

	.offer-icon {
		width: 48px !important;
		height: 48px !important;
		font-size: 24px !important;
		flex-shrink: 0 !important
	}

	.offer-info {
		text-align: left !important;
		flex: 1 !important
	}

	.offer-name {
		font-size: 14px !important;
		margin-bottom: 2px !important
	}

	.offer-desc {
		font-size: 11px !important;
		margin-bottom: 6px !important;
		line-height: 1.3 !important
	}

	.offer-reward {
		grid-column: 1 / -1;
		font-size: 10px !important;
		padding: 6px 10px !important;
		border-radius: 16px !important
	}

	.offer-card.featured {
		transform: none !important
	}

	.offer-card:hover {
		transform: none !important
	}

	.offer-card:active {
		transform: scale(0.98) !important;
		transition: transform 0.1s ease !important
	}

	.generation-container {
		padding: 12px 8px !important
	}

	.pack-info-block {
		padding: 12px !important;
		border-radius: 12px !important
	}

	.pack-icon {
		font-size: 32px !important;
		margin-bottom: 6px !important
	}

	.progress-container {
		height: 12px !important;
		border-radius: 8px !important
	}

	.progress-text {
		font-size: 14px !important;
		margin-bottom: 8px !important
	}

	.status-text {
		font-size: 12px !important;
		margin-bottom: 16px !important
	}

	.generation-steps {
		gap: 4px !important;
		max-width: 100% !important
	}

	.step {
		padding: 8px 12px !important;
		font-size: 11px !important;
		border-radius: 8px !important;
		min-height: 40px !important;
		display: flex !important;
		align-items: center !important
	}

	.step.active,
	.step.completed {
		padding-left: 28px !important
	}

	.step.active::before,
	.step.completed::before {
		left: 10px;
		top: 50%;
		transform: translateY(-50%)
	}
}

@media (max-width:480px) {
	.offers-header {
		padding: 6px !important;
		margin-bottom: 12px !important
	}

	.offers-title {
		font-size: 18px !important;
		margin-bottom: 6px !important
	}

	.offers-subtitle {
		font-size: 12px !important;
		margin-bottom: 8px !important
	}

	.security-badge {
		font-size: 11px !important;
		padding: 4px 10px !important
	}

	.offers-grid {
		gap: 6px !important;
		padding: 6px !important
	}

	.offer-card {
		grid-template-columns: 50px 1fr;
		grid-template-rows: auto auto;
		padding: 10px !important;
		gap: 10px !important;
		min-height: 70px !important;
		border-radius: 10px !important
	}
	

	.offer-icon {
		font-size: 20px !important;
		width: 40px !important;
		height: 40px !important;
		border-radius: 8px !important
	}

	.offer-name {
		font-size: 13px !important;
		font-weight: 600 !important
	}

	.offer-desc {
		font-size: 10px !important;
		margin-bottom: 4px !important
	}

	.offer-reward {
		grid-column: 1 / -1;
		font-size: 9px !important;
		padding: 4px 8px !important;
		border-radius: 12px !important
	}

	.offer-reward::after {
		display: none
	}

	.pack-icon {
		font-size: 28px !important;
		margin-bottom: 4px !important
	}

	.generation-container {
		padding: 8px 6px !important
	}

	.pack-info-block {
		padding: 10px !important;
		border-radius: 10px !important
	}

	.progress-container {
		height: 10px !important;
		margin-bottom: 8px !important
	}

	.progress-text {
		font-size: 12px !important;
		margin-bottom: 6px !important
	}

	.status-text {
		font-size: 11px !important;
		margin-bottom: 12px !important
	}

	.generation-steps {
		gap: 3px !important
	}

	.step {
		padding: 6px 10px !important;
		font-size: 10px !important;
		min-height: 36px !important;
		border-radius: 6px !important
	}

	.step.active,
	.step.completed {
		padding-left: 24px !important
	}

	.step.active::before,
	.step.completed::before {
		left: 8px;
		width: 8px !important;
		height: 8px !important
	}

	.step.active::before {
		border-width: 1px !important
	}
}

/* Additional Mobile Enhancements */
@media (hover:none) and (pointer:coarse) {
	.offer-card:hover {
		transform: none !important;
		box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06) !important
	}

	.offer-card:active {
		transform: scale(0.97) !important;
		transition: transform 0.1s ease !important
	}

	.offer-reward:hover {
		transform: none !important;
		background: linear-gradient(135deg, #ff6b9d, #ff8fab) !important
	}

	.offer-reward:active {
		transform: scale(0.95) !important
	}
}

/* Improved Touch Targets */
@media (max-width:768px) {
	.offer-card {
		min-height: 60px !important
	}

	.offer-reward {
		grid-column: 1 / -1;
		padding: 10px;
		
		align-items: center !important;
		justify-content: center !important
	}
}

/* Ultra-compact for very small screens */
@media (max-width:360px) {
	.offers-grid {
		padding: 4px !important;
		gap: 4px !important
	}

	.offer-card {
		grid-template-columns: 40px 1fr;
		grid-template-rows: auto auto;
		padding: 8px !important;
		gap: 8px !important;
		min-height: 60px !important
	}

	.offer-icon {
		width: 32px !important;
		height: 32px !important;
		font-size: 16px !important
	}

	.offer-name {
		font-size: 12px !important
	}

	.offer-desc {
		font-size: 9px !important
	}

	.offer-reward {
		grid-column: 1 / -1;
		font-size: 8px !important;
		padding: 3px 6px !important;
		min-width: 60px !important;
		min-height: 28px !important
	}

	.generation-container {
		padding: 6px 4px !important
	}

	.pack-info-block {
		padding: 8px !important
	}

	.pack-icon {
		font-size: 24px !important
	}

	.progress-container {
		height: 8px !important
	}

	.progress-text {
		font-size: 11px !important
	}

	.status-text {
		font-size: 10px !important
	}

	.step {
		padding: 5px 8px !important;
		font-size: 9px !important;
		min-height: 32px !important
	}

	.step.active,
	.step.completed {
		padding-left: 20px !important
	}

	.step.active::before,
	.step.completed::before {
		left: 6px;
		width: 6px !important;
		height: 6px !important
	}
}

/* Smooth animations for mobile */
* {
	-webkit-tap-highlight-color: transparent !important
}

.offer-card,
.step,
.offer-reward {
	-webkit-transform: translateZ(0);
	transform: translateZ(0)
}

/* ===== Section Header Accents (migrated from inline <style>) ===== */
/* Tier accent variables per section */
.shop-section.legendary-tier { --accent: #b91c1c; --accent-soft: rgba(185, 28, 28, 0.12); --accent-border: rgba(185, 28, 28, 0.28); }
.shop-section.ultra-rare-tier { --accent: #7c3aed; --accent-soft: rgba(124, 58, 237, 0.12); --accent-border: rgba(124, 58, 237, 0.28); }
.shop-section.rare-tier { --accent: #2563eb; --accent-soft: rgba(37, 99, 235, 0.12); --accent-border: rgba(37, 99, 235, 0.28); }

/* Scoped title color by tier to avoid global collisions */
.shop-section.legendary-tier .section-header .section-title,
.shop-section.ultra-rare-tier .section-header .section-title,
.shop-section.rare-tier .section-header .section-title {
	color: var(--accent) !important;
}

/* Scoped timer pill styling by tier */
.shop-section.legendary-tier .section-header .section-timer,
.shop-section.ultra-rare-tier .section-header .section-timer,
.shop-section.rare-tier .section-header .section-timer {
	background: var(--accent-soft);
	border: 1px solid var(--accent-border);
	color: var(--accent);
	font-weight: 800;
	line-height: 1;
}
.shop-section.legendary-tier .section-header .section-timer .timer-text,
.shop-section.ultra-rare-tier .section-header .section-timer .timer-text,
.shop-section.rare-tier .section-header .section-timer .timer-text {
	color: var(--accent);
}

/* Mobile layout: keep title+badge inline and timer below */
@media (max-width: 600px) {
	.section-header { flex-wrap: wrap; }
	.section-header .section-badge { order: 1; }
	.section-header .section-title { order: 1; }
	.section-header .section-timer { order: 2; flex-basis: 100%; margin-top: 4px; margin-left: 0; }
}

/* ===== Performance & CLS guards (appended) ===== */
/* Avoid CLS from async font swap and give browser better legibility hints */
html { font-synthesis-weight: none; text-rendering: optimizeLegibility; }

/* Reserve space for sections and grids while JS populates */
.shop-section { min-height: 180px; }
.preview-pets { min-height: 120px; }

/* Stabilize pet card internals */
.adoptme-card .pet-img, .pet-icon { min-height: 80px; }
.pet-name { min-height: 22px; line-height: 1.2; }

/* Hint the compositor to avoid layout thrash on interactive elements */
.pet-item, .offer-card, .game-btn, .nav-btn, .shop-close, .modal-close { will-change: transform; contain: layout paint; }

/* Ensure images never cause reflow while loading */
img[loading="lazy"] { aspect-ratio: attr(width number) / attr(height number); }



/* Offers Progress Bar */
.offers-progress-container {
	margin: 20px 0;
	padding: 0 20px;
}

.progress-text {
	text-align: center;
	color: #666;
	font-family: 'Insaniburger', cursive;
	font-size: 16px;
	margin-bottom: 10px;
}

.progress-bar {
	background: rgba(255, 255, 255, 0.3);
	border-radius: 25px;
	height: 8px;
	overflow: hidden;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.progress-bar-fill {
	background: linear-gradient(90deg, #4CAF50, #45a049);
	height: 100%;
	border-radius: 25px;
	transition: width 0.5s ease;
	box-shadow: 0 2px 4px rgba(76, 175, 80, 0.3);
}

/* Enhanced Offer Cards */
.offers-grid .offer-card {
	display: flex;
	flex-direction: column;
	background: rgba(255, 255, 255, 0.98);
	border-radius: 12px;
	padding: 0;
	margin: 8px 0;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.08);
	cursor: pointer;
	transition: all 0.25s ease;
	position: relative;
	overflow: hidden;
}

.offers-grid .offer-card:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
	border-color: var(--color-primary);
}

.offers-grid .offer-card.featured {
	background: rgba(255, 229, 240, 0.6);
	border: 1.5px solid var(--color-primary);
	box-shadow: 0 3px 15px rgba(253, 154, 190, 0.15);
}



.offer-card-main {
	display: flex;
	align-items: center;
	padding: 12px 14px;
	flex: 1;
	width: 100%;
}

.offer-card-icon {
	flex-shrink: 0;
	width: 60px;
	height: 60px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(248, 249, 250, 0.8);
	margin-right: 12px;
	font-size: 20px;
	border: 1px solid rgba(0, 0, 0, 0.04);
}

.offer-card-icon img {
	width: 40px;
	height: 40px;
	object-fit: contain;
	border-radius: 8px;
}

.offer-card-content {
	display: flex;
	flex-direction: column;
	min-width: 0;
	flex: 1;
	text-align: left;
}

.offer-card-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 6px;
}

.offer-card-title {
	font-family: 'insaniburger', sans-serif;
	font-size: 16px;
	color: #2c3e50;
	margin: 0;
	line-height: 1.3;
	font-weight: 600;
}



.offer-card-description {
	color: #64748b;
	font-size: 13px;
	line-height: 1.4;
	margin-bottom: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	line-clamp: 2;
	overflow: hidden;
	font-weight: 400;
}

.offer-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	padding: 8px 14px 12px;
	margin-top: auto;
	width: 100%;
	box-sizing: border-box;
	
}

.offer-card-badges {
	display: flex;
	align-items: center;
	gap: 6px;
	flex: 1;
}

.verified-badge {
	background: linear-gradient(135deg, #4CAF50, #45a049);
	color: white;
	font-size: 11px;
	font-weight: bold;
	padding: 3px 8px;
	border-radius: 12px;
	font-family: 'Insaniburger', cursive;
	display: flex;
	align-items: center;
	gap: 2px;
}

.estimated-time {
	color: #64748b;
	font-size: 10px;
	font-weight: 500;
	background: rgba(148, 163, 184, 0.15);
	padding: 2px 6px;
	border-radius: 8px;
}

.offer-card-arrow {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 30%;
	background: var(--color-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 16px;
	font-weight: bold;
	transition: all 0.2s ease;
	box-shadow: 0 2px 6px rgba(253, 154, 190, 0.3);
}

.offers-grid .offer-card:hover .offer-card-arrow {
	transform: translateX(4px);
}

/* Offers Instructions */
.offers-instructions {
	margin: 30px 20px 20px;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.9) 100%);
	border-radius: 16px;
	padding: 24px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.instructions-header h3 {
	font-family: 'Insaniburger', cursive;
	color: #333;
	text-align: center;
	margin-bottom: 20px;
	font-size: 20px;
}

.instructions-steps {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.instruction-step {
	display: flex;
	align-items: center;
	gap: 16px;
}

.step-number {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Insaniburger', cursive;
	font-size: 18px;
	font-weight: bold;
}

.step-content {
	flex: 1;
}

.step-title {
	font-family: 'Insaniburger', cursive;
	font-size: 16px;
	color: #333;
	margin-bottom: 4px;
}

.step-description {
	color: #666;
	font-size: 14px;
	line-height: 1.4;
}

/* Responsive Design */
@media (max-width: 768px) {
	.offers-grid .offer-card {
		margin: 6px 0;
	}

	.offer-card-main {
		padding: 10px 12px;
	}

	.offer-card-footer {
		padding: 6px 12px 10px;
	}

	.offer-card-icon {
		width: 42px;
		height: 42px;
		margin-right: 10px;
		font-size: 18px;
	}

	.offer-card-title {
		font-size: clamp(14px, 3.5vw, 16px);
	}

	.offer-card-description {
		font-size: clamp(11px, 3vw, 13px);
	}

	.offer-card-rating {
		font-size: clamp(10px, 2.5vw, 12px);
	}

	.verified-badge {
		font-size: clamp(8px, 2vw, 10px);
		padding: 1px 4px;
	}

	.estimated-time {
		font-size: clamp(8px, 2vw, 10px);
		padding: 1px 4px;
	}

	.offer-card-arrow {
		width: 24px;
		height: 24px;
		font-size: 12px;
	}

	.offers-instructions {
		margin: 20px 10px;
		padding: 16px;
	}

	.instructions-header h3 {
		font-size: clamp(16px, 4vw, 18px);
	}

	.instruction-step {
		gap: 12px;
	}

	.step-number {
		width: 32px;
		height: 32px;
		font-size: 14px;
	}

	.step-title {
		font-size: clamp(14px, 3vw, 16px);
	}

	.step-description {
		font-size: clamp(12px, 2.5vw, 14px);
	}
}

#tiktok-logo {
    width: 250px;
    margin-bottom: 20px;
}
#tiktok-logo-container {
	display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100vh;
    margin: 0;
}