:root {
	--bg: #f6f7fb;
	--surface: #ffffff;
	--ink: #111827;
	--muted: #5f6673;
	--line: #e6e8ee;
	--red: #f0332f;
	--green: #17a653;
	--green-soft: #e8f8ee;
	--blue: #1565d8;
	--orange: #f08a00;
	--purple: #7e3ccf;
	--shadow: 0 12px 36px rgba(17, 24, 39, 0.08);
	--radius: 8px;
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	min-height: 100%;
	background: var(--bg);
}

body {
	min-width: 320px;
	margin: 0;
	background: radial-gradient(circle at 50% -10%, #ffffff 0, #f7f8fb 34rem, #eef2f8 100%);
	color: var(--ink);
	font-family: var(--font, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0;
}

button,
input {
	font: inherit;
}

button {
	cursor: pointer;
}

a {
	color: inherit;
	text-decoration: none;
}

.skip-link,
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link:focus {
	z-index: 20;
	top: 1rem;
	left: 1rem;
	width: auto;
	height: auto;
	padding: 0.75rem 1rem;
	clip: auto;
	background: var(--ink);
	color: #fff;
}

.app-header {
	position: sticky;
	top: 0;
	z-index: 10;
	padding: 1rem clamp(1rem, 4vw, 2rem) 0.8rem;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(230, 232, 238, 0.75);
}

.top-bar {
	display: grid;
	grid-template-columns: 3rem 1fr auto;
	align-items: center;
	gap: 0.7rem;
	max-width: 70rem;
	margin: 0 auto 1rem;
}

.icon-button {
	position: relative;
	width: 2.75rem;
	height: 2.75rem;
	border: 0;
	background: transparent;
	color: var(--ink);
}

.menu-button span {
	display: block;
	width: 2rem;
	height: 0.2rem;
	margin: 0.35rem auto;
	background: currentColor;
	border-radius: 999px;
}

.brand {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0.12rem;
	font-size: clamp(2rem, 7vw, 2.6rem);
	font-weight: 850;
	line-height: 1;
	color: #151927;
}

.brand i {
	width: 1.42rem;
	height: 1.42rem;
	margin-top: 0.36rem;
	background:
		radial-gradient(circle at 72% 28%, #fff 0 0.18rem, transparent 0.2rem),
		linear-gradient(135deg, #ffb000, #f08a00);
	border-radius: 0.34rem;
	transform: rotate(45deg);
}

.desktop-nav {
	display: none;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
}

.desktop-nav a {
	padding: 0.55rem 0.8rem;
	border-radius: 999px;
	color: var(--muted);
	font-weight: 850;
}

.desktop-nav a:hover {
	background: #f1f5f9;
	color: var(--ink);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 0.42rem;
}

.bell-button::before {
	content: "";
	position: absolute;
	inset: 0.55rem 0.77rem 0.62rem;
	border: 0.18rem solid currentColor;
	border-bottom-color: transparent;
	border-radius: 1rem 1rem 0.35rem 0.35rem;
}

.bell-button::after {
	content: "";
	position: absolute;
	top: 0.34rem;
	right: 0.55rem;
	width: 0.72rem;
	height: 0.72rem;
	background: var(--red);
	border: 0.12rem solid #fff;
	border-radius: 50%;
}

.country-switcher {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	min-height: 3rem;
	padding: 0.45rem 0.8rem;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: #fff;
	box-shadow: 0 8px 22px rgba(17, 24, 39, 0.08);
	color: var(--ink);
}

.country-switcher::after {
	content: "";
	width: 0.55rem;
	height: 0.55rem;
	border-right: 0.15rem solid currentColor;
	border-bottom: 0.15rem solid currentColor;
	transform: rotate(45deg) translateY(-0.1rem);
}

.flag-us {
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 50%;
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08);
	background:
		radial-gradient(circle at 32% 38%, #17468f 0 0.68rem, transparent 0.7rem),
		repeating-linear-gradient(to bottom, #bf0a30 0 0.18rem, #fff 0.18rem 0.36rem);
}

.site-search {
	position: relative;
	max-width: 70rem;
	margin: 0 auto;
}

.site-search::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 1.35rem;
	width: 1.42rem;
	height: 1.42rem;
	border: 0.2rem solid #6f7480;
	border-radius: 50%;
	transform: translateY(-55%);
}

.site-search::after {
	content: "";
	position: absolute;
	top: 58%;
	left: 2.55rem;
	width: 0.85rem;
	height: 0.2rem;
	background: #6f7480;
	border-radius: 999px;
	transform: rotate(45deg);
}

.site-search input {
	width: 100%;
	height: 4.2rem;
	padding: 0 1.4rem 0 4.2rem;
	border: 1px solid #cbd0d8;
	border-radius: 999px;
	background: #fff;
	color: var(--ink);
	font-size: clamp(1rem, 3.8vw, 1.45rem);
	box-shadow: 0 8px 26px rgba(17, 24, 39, 0.04);
}

.search-results {
	position: absolute;
	z-index: 11;
	top: calc(100% + 0.45rem);
	left: 1rem;
	right: 1rem;
	display: grid;
	gap: 0.25rem;
	padding: 0.55rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
}

.search-results[hidden] {
	display: none;
}

.search-results a {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.65rem 0.75rem;
	border-radius: 0.35rem;
}

.search-results a:hover {
	background: #f3f5f8;
}

.search-results span {
	color: var(--muted);
	font-size: 0.88rem;
}

.site-main {
	width: min(100%, 70rem);
	margin: 0 auto;
	padding: 1rem clamp(1rem, 4vw, 2rem) 7.4rem;
}

.home-layout {
	display: grid;
	gap: 1rem;
}

.store-hero,
.coupon-card,
.content-band {
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(230, 232, 238, 0.8);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.store-hero {
	display: grid;
	grid-template-columns: clamp(5.5rem, 18vw, 9rem) 1fr auto;
	align-items: center;
	gap: clamp(0.8rem, 3vw, 1.4rem);
	padding: clamp(1rem, 4vw, 1.9rem);
	margin-top: 0.3rem;
}

.store-logo {
	display: grid;
	place-items: center;
	aspect-ratio: 1;
	border-radius: 50%;
	background: #fff;
	box-shadow: inset 0 0 0 1px #eef0f4, 0 12px 30px rgba(17, 24, 39, 0.09);
	color: #050505;
}

.store-logo span {
	position: relative;
	font-family: Georgia, serif;
	font-size: clamp(4rem, 13vw, 7rem);
	font-weight: 900;
	line-height: 0.8;
}

.store-logo span::after {
	content: "";
	position: absolute;
	left: 5%;
	right: -18%;
	bottom: -0.2rem;
	height: 1rem;
	border-bottom: 0.35rem solid #ff9900;
	border-radius: 50%;
}

.store-copy h1 {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	margin: 0 0 0.2rem;
	font-size: clamp(1.95rem, 6vw, 3rem);
	line-height: 1.1;
}

.verified-seal {
	position: relative;
	width: 1.55rem;
	height: 1.55rem;
	background: var(--green);
	border-radius: 50%;
}

.verified-seal::after {
	content: "";
	position: absolute;
	left: 0.42rem;
	top: 0.36rem;
	width: 0.55rem;
	height: 0.85rem;
	border-right: 0.18rem solid #fff;
	border-bottom: 0.18rem solid #fff;
	transform: rotate(45deg);
}

.rating-row {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	margin: 0.2rem 0 0.45rem;
	color: var(--muted);
	font-size: clamp(1rem, 3vw, 1.35rem);
}

.star,
.tab-star,
.nav-flame {
	display: inline-block;
}

.star {
	width: 1.3rem;
	height: 1.3rem;
	background: #ffb000;
	clip-path: polygon(50% 0, 62% 34%, 98% 36%, 69% 56%, 79% 91%, 50% 70%, 21% 91%, 31% 56%, 2% 36%, 38% 34%);
}

.hero-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.hero-pills span,
.verified-chip {
	display: inline-flex;
	align-items: center;
	min-height: 2rem;
	padding: 0.18rem 0.65rem;
	border-radius: 0.55rem;
	background: #eaf3ff;
	color: var(--blue);
	font-weight: 800;
}

.hero-pills .verified-pill,
.verified-chip {
	background: var(--green-soft);
	color: #087b2b;
}

.follow-button {
	display: grid;
	place-items: center;
	gap: 0.2rem;
	width: 6rem;
	min-height: 6.6rem;
	border: 0;
	border-radius: var(--radius);
	background: #fdeaea;
	color: #e2221d;
	font-size: 1.15rem;
}

.follow-button span {
	position: relative;
	width: 2.2rem;
	height: 2.2rem;
}

.follow-button span::before,
.follow-button span::after {
	content: "";
	position: absolute;
	top: 0.35rem;
	width: 1.15rem;
	height: 1.75rem;
	border: 0.18rem solid currentColor;
	border-bottom: 0;
	border-radius: 1rem 1rem 0 0;
	background: transparent;
}

.follow-button span::before {
	left: 0.16rem;
	transform: rotate(-45deg);
}

.follow-button span::after {
	right: 0.16rem;
	transform: rotate(45deg);
}

.store-metrics {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.55rem;
	margin: 0.85rem 0 1rem;
}

.store-metrics div {
	padding: 0.75rem 0.45rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	text-align: center;
}

.store-metrics strong,
.store-metrics span {
	display: block;
}

.store-metrics strong {
	font-size: clamp(0.95rem, 3.6vw, 1.3rem);
}

.store-metrics span {
	color: var(--muted);
	font-size: 0.78rem;
}

.offer-tabs {
	position: sticky;
	top: 8.95rem;
	z-index: 8;
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: max-content;
	gap: clamp(1rem, 5vw, 3.4rem);
	overflow-x: auto;
	padding: 0 0.45rem;
	margin: 0 -0.45rem 1rem;
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: 0 10px 26px rgba(17, 24, 39, 0.06);
	scrollbar-width: none;
}

.offer-tabs::-webkit-scrollbar {
	display: none;
}

.offer-tabs a {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	min-height: 4.5rem;
	padding: 0 0.55rem;
	color: var(--ink);
	font-weight: 800;
	white-space: nowrap;
}

.offer-tabs a.active {
	color: var(--red);
}

.offer-tabs a.active::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 0.18rem;
	background: var(--red);
	border-radius: 999px;
}

.tab-ticket,
.tab-code,
.tab-tag,
.tab-star {
	position: relative;
	width: 1.7rem;
	height: 1.7rem;
}

.tab-ticket::before {
	content: "";
	position: absolute;
	inset: 0.18rem;
	background: var(--red);
	border-radius: 0.22rem;
	transform: rotate(-38deg);
}

.tab-code::before {
	content: "";
	position: absolute;
	inset: 0.22rem 0;
	border: 0.16rem solid currentColor;
	border-radius: 0.2rem;
}

.tab-tag::before {
	content: "";
	position: absolute;
	inset: 0.2rem;
	border: 0.16rem solid currentColor;
	border-radius: 0.2rem;
	transform: rotate(-38deg);
}

.tab-star {
	border: 0.15rem solid currentColor;
	clip-path: polygon(50% 0, 62% 34%, 98% 36%, 69% 56%, 79% 91%, 50% 70%, 21% 91%, 31% 56%, 2% 36%, 38% 34%);
}

.coupon-feed {
	display: grid;
	gap: 1rem;
}

.couponic-sentinel {
	min-height: 1px;
}

.coupon-card {
	position: relative;
	display: grid;
	grid-template-columns: minmax(5.4rem, 9rem) 1fr minmax(7.4rem, 15rem);
	gap: clamp(0.8rem, 3vw, 1.45rem);
	align-items: center;
	padding: clamp(0.9rem, 3vw, 1.45rem);
}

.discount-box {
	display: grid;
	place-items: center;
	align-content: center;
	gap: 0.45rem;
	aspect-ratio: 1;
	border-radius: var(--radius);
	background: linear-gradient(135deg, rgba(23, 166, 83, 0.15), rgba(23, 166, 83, 0.04));
	color: var(--green);
	text-align: center;
}

.discount-box strong {
	max-width: 5.6rem;
	font-size: clamp(1.9rem, 6vw, 3.1rem);
	line-height: 0.98;
}

.discount-box span {
	padding: 0.08rem 0.45rem;
	border-radius: 0.4rem;
	background: rgba(255, 255, 255, 0.7);
	font-weight: 850;
}

.coupon-main h2 {
	margin: 0.25rem 0 0.18rem;
	font-size: clamp(1.2rem, 4vw, 1.65rem);
	line-height: 1.18;
}

.coupon-main p {
	margin: 0;
	color: var(--muted);
	font-size: clamp(0.96rem, 3.2vw, 1.2rem);
}

.coupon-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.45rem;
	color: var(--muted);
	font-size: clamp(0.85rem, 3vw, 1.05rem);
}

.coupon-meta > span + span::before {
	content: "";
	display: inline-block;
	width: 0.22rem;
	height: 0.22rem;
	margin-right: 0.45rem;
	background: currentColor;
	border-radius: 50%;
	vertical-align: middle;
}

.verified-chip::before {
	content: "";
	width: 0.44rem;
	height: 0.72rem;
	margin-right: 0.36rem;
	border-right: 0.13rem solid currentColor;
	border-bottom: 0.13rem solid currentColor;
	transform: rotate(45deg) translateY(-0.05rem);
}

.details-button {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin-top: 0.35rem;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--blue);
	font-weight: 800;
}

.details-button::after {
	content: "";
	width: 0.6rem;
	height: 0.6rem;
	border-right: 0.15rem solid currentColor;
	border-bottom: 0.15rem solid currentColor;
	transform: rotate(45deg) translateY(-0.12rem);
}

.details-button[aria-expanded="true"]::after {
	transform: rotate(225deg) translate(-0.1rem, -0.1rem);
}

.coupon-details {
	margin-top: 0.45rem;
}

.coupon-action {
	display: grid;
	gap: 0.75rem;
	align-items: center;
}

.share-button {
	justify-self: end;
	position: relative;
	width: 2rem;
	height: 2rem;
	border: 0;
	background: transparent;
	color: #5d6470;
}

.share-button::before {
	content: "";
	position: absolute;
	inset: 0.35rem;
	background:
		radial-gradient(circle at 0.2rem 0.2rem, currentColor 0 0.2rem, transparent 0.22rem),
		radial-gradient(circle at 1rem 0, currentColor 0 0.2rem, transparent 0.22rem),
		radial-gradient(circle at 1rem 1.05rem, currentColor 0 0.2rem, transparent 0.22rem);
}

.share-button::after {
	content: "";
	position: absolute;
	left: 0.72rem;
	top: 0.72rem;
	width: 0.9rem;
	height: 0.9rem;
	border-top: 0.13rem solid currentColor;
	border-bottom: 0.13rem solid currentColor;
	transform: skewY(-30deg);
}

.coupon-action code {
	display: grid;
	place-items: center;
	min-height: 3.2rem;
	padding: 0.45rem 0.7rem;
	border: 0.12rem dashed rgba(23, 166, 83, 0.65);
	border-radius: var(--radius);
	background: rgba(23, 166, 83, 0.05);
	color: var(--green);
	font-family: inherit;
	font-size: clamp(1.1rem, 4vw, 1.45rem);
	font-weight: 850;
	overflow-wrap: anywhere;
}

.copy-button {
	min-height: 3.2rem;
	padding: 0.55rem 0.85rem;
	border: 0;
	border-radius: var(--radius);
	background: var(--green);
	color: #fff;
	font-size: clamp(1rem, 3.5vw, 1.3rem);
	font-weight: 850;
	box-shadow: inset 0 -0.2rem 0 rgba(0, 0, 0, 0.08);
}

.coupon-card--blue .discount-box {
	background: linear-gradient(135deg, rgba(21, 101, 216, 0.14), rgba(21, 101, 216, 0.04));
	color: var(--blue);
}

.coupon-card--blue .coupon-action code {
	border-color: rgba(21, 101, 216, 0.5);
	background: rgba(21, 101, 216, 0.05);
	color: var(--blue);
}

.coupon-card--blue .copy-button {
	background: var(--blue);
}

.coupon-card--orange .discount-box {
	background: linear-gradient(135deg, rgba(240, 138, 0, 0.14), rgba(240, 138, 0, 0.04));
	color: var(--orange);
}

.coupon-card--orange .copy-button {
	background: var(--orange);
}

.coupon-card--purple .discount-box {
	background: linear-gradient(135deg, rgba(126, 60, 207, 0.14), rgba(126, 60, 207, 0.04));
	color: var(--purple);
}

.coupon-card--purple .copy-button {
	background: var(--purple);
}

.content-band {
	margin-top: 1rem;
	padding: 1.2rem;
}

.content-band h2 {
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
}

.content-band p {
	margin: 0;
	color: var(--muted);
}

.content-band details {
	padding: 0.7rem 0;
	border-top: 1px solid var(--line);
}

.content-band summary {
	font-weight: 800;
	cursor: pointer;
}

.desktop-hero {
	display: grid;
	grid-template-columns: 1fr minmax(18rem, 32rem);
	gap: 2rem;
	align-items: end;
	margin: 1rem 0;
	padding: clamp(1.4rem, 4vw, 3rem);
	border-radius: var(--radius);
	background: linear-gradient(135deg, #0f766e, #152238 62%, #f6b000);
	color: #fff;
	box-shadow: var(--shadow);
}

.home-banner,
.archive-hero,
.account-hero {
	display: grid;
	grid-template-columns: 1fr minmax(18rem, 30rem);
	gap: 1.2rem;
	align-items: end;
	min-height: 17rem;
	margin: 1rem 0;
	padding: clamp(1.2rem, 4vw, 2.6rem);
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(4, 15, 29, 0.92), rgba(20, 32, 48, 0.72)),
		var(--banner-image, linear-gradient(135deg, #0f766e, #152238 62%, #f6b000));
	background-size: cover;
	background-position: center;
	color: #fff;
	box-shadow: var(--shadow);
}

.home-banner p,
.home-banner h1,
.home-banner h2,
.home-banner span,
.archive-hero p,
.archive-hero h1,
.account-hero p,
.account-hero h1 {
	margin: 0;
}

.home-banner p,
.archive-hero p,
.account-hero p {
	font-weight: 850;
	opacity: 0.82;
}

.home-banner h1,
.archive-hero h1,
.account-hero h1 {
	font-size: clamp(2rem, 5vw, 4rem);
	line-height: 1;
}

.home-banner h2 {
	font-size: clamp(1.7rem, 4vw, 3rem);
	line-height: 1.05;
}

.home-banner span {
	display: block;
	max-width: 40rem;
	margin-top: 0.8rem;
	color: rgba(255, 255, 255, 0.86);
}

.banner-button {
	justify-self: end;
	display: inline-flex;
	align-items: center;
	min-height: 3rem;
	padding: 0 1rem;
	border-radius: var(--radius);
	background: #fff;
	color: var(--ink);
	font-weight: 850;
}

.desktop-hero p,
.desktop-hero h1 {
	margin: 0;
}

.desktop-hero p {
	font-weight: 800;
	opacity: 0.84;
}

.desktop-hero h1 {
	font-size: clamp(2rem, 5vw, 4.2rem);
	line-height: 1;
}

.home-hero span {
	display: block;
	max-width: 42rem;
	margin-top: 0.8rem;
	color: rgba(255, 255, 255, 0.86);
	font-size: 1.1rem;
}

.quick-strip {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: max-content;
	gap: 0.65rem;
	overflow-x: auto;
	margin: 1rem 0;
	padding-bottom: 0.2rem;
	scrollbar-width: none;
}

.home-section {
	min-width: 0;
}

.category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
	gap: 0.75rem;
}

.category-grid a {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	min-height: 4rem;
	padding: 0.8rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: 0 8px 20px rgba(17, 24, 39, 0.05);
	font-weight: 850;
}

.category-grid span {
	display: grid;
	place-items: center;
	width: 2.4rem;
	height: 2.4rem;
	border-radius: 50%;
	background: #fff4d6;
	color: #8a5c00;
}

.quick-strip::-webkit-scrollbar {
	display: none;
}

.quick-strip a {
	padding: 0.65rem 0.9rem;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: #fff;
	box-shadow: 0 8px 18px rgba(17, 24, 39, 0.05);
	font-weight: 800;
}

.section-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	margin: 1.3rem 0 0.75rem;
}

.section-head h2 {
	margin: 0;
	font-size: clamp(1.25rem, 4vw, 2rem);
}

.section-head a {
	color: var(--blue);
	font-weight: 800;
}

.compact-grid {
	grid-template-columns: repeat(auto-fill, minmax(10.5rem, 1fr));
}

.collection-band div {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
	gap: 0.7rem;
	margin-top: 0.9rem;
}

.collection-band a {
	padding: 1rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #f8fafc;
	font-weight: 800;
}

.newsletter-band {
	display: grid;
	grid-template-columns: 1fr minmax(18rem, 32rem);
	gap: 1.2rem;
	align-items: center;
	margin-top: 1rem;
	padding: clamp(1.2rem, 4vw, 2rem);
	border-radius: var(--radius);
	background: linear-gradient(135deg, #06111f, #222 54%, #c17a2c);
	color: #fff;
}

.archive-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 17rem;
	gap: 1rem;
	align-items: start;
}

.archive-sidebar {
	position: sticky;
	top: 9.8rem;
	display: grid;
	gap: 0.55rem;
	padding: 1rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
}

.archive-sidebar h2 {
	margin: 0 0 0.3rem;
	font-size: 1.1rem;
}

.archive-sidebar a {
	padding: 0.6rem 0.7rem;
	border-radius: 0.35rem;
	background: #f6f7fb;
	font-weight: 800;
}

.deal-grid,
.blog-grid,
.account-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
	gap: 1rem;
}

.deal-card,
.blog-card,
.account-grid article,
.deal-day-card {
	display: grid;
	gap: 0.65rem;
	padding: 1rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
}

.deal-card span,
.deal-day-card span {
	color: var(--orange);
	font-weight: 850;
}

.deal-card strong,
.blog-card strong,
.deal-day-card h3 {
	font-size: 1.25rem;
	line-height: 1.15;
}

.deal-card p,
.blog-card span,
.deal-day-card p,
.account-grid p {
	margin: 0;
	color: var(--muted);
}

.deal-card b {
	justify-self: start;
	padding: 0.55rem 0.8rem;
	border-radius: var(--radius);
	background: var(--orange);
	color: #fff;
}

.deal-day-card {
	grid-template-columns: 1fr auto;
	align-items: center;
	background: linear-gradient(135deg, #fff7e6, #fff);
}

.account-shell {
	display: grid;
	gap: 1rem;
}

.account-grid span {
	font-size: 2rem;
	font-weight: 850;
}

@media (min-width: 961px) {
	.top-bar {
		grid-template-columns: auto 1fr auto;
	}

	.menu-button {
		display: none;
	}

	.brand {
		justify-content: start;
		font-size: 2rem;
	}

	.desktop-nav {
		display: flex;
	}

	.site-main {
		width: min(100%, 76rem);
	}

	.home-layout {
		grid-template-columns: minmax(0, 1.5fr) minmax(18rem, 0.8fr);
		align-items: start;
	}

	.home-banner,
	.newsletter-band {
		grid-column: 1 / -1;
	}

	.home-section--coupons {
		grid-row: span 3;
	}

	.home-section--stores .store-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.home-section--categories,
	.home-section--deal-day,
	.home-section--blogs {
		padding: 1rem;
		border: 1px solid var(--line);
		border-radius: var(--radius);
		background: rgba(255, 255, 255, 0.72);
		box-shadow: 0 10px 28px rgba(17, 24, 39, 0.05);
	}

	.bottom-nav {
		display: none;
	}

	.site-main {
		padding-bottom: 3rem;
	}
}

.newsletter-band h2,
.newsletter-band p {
	margin: 0;
}

.newsletter-band form {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.55rem;
}

.newsletter-band input,
.newsletter-band button {
	min-height: 3rem;
	border: 0;
	border-radius: 0.35rem;
}

.newsletter-band input {
	padding: 0 1rem;
}

.newsletter-band button {
	padding: 0 1rem;
	background: #000;
	color: #fff;
	font-weight: 850;
}

.archive-filter {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.6rem;
	padding: 0.45rem;
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.18);
}

.archive-filter input,
.archive-filter button {
	min-height: 3rem;
	border: 0;
	border-radius: 0.35rem;
}

.archive-filter input {
	padding: 0 1rem;
}

.archive-filter button {
	padding: 0 1.1rem;
	background: #111827;
	color: #fff;
	font-weight: 800;
}

.store-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(12.5rem, 1fr));
	gap: 1rem;
	margin: 1rem 0;
}

.store-card {
	display: grid;
	place-items: center;
	gap: 0.45rem;
	min-height: 11rem;
	padding: 1rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: 0 8px 22px rgba(17, 24, 39, 0.06);
	text-align: center;
}

.store-card-logo {
	display: grid;
	place-items: center;
	width: 100%;
	min-height: 4.2rem;
}

.store-card-logo img {
	max-width: 8.5rem;
	max-height: 3.4rem;
	object-fit: contain;
}

.store-card-logo span {
	display: grid;
	place-items: center;
	width: 4.2rem;
	height: 4.2rem;
	border-radius: 50%;
	background: #eaf3ff;
	color: var(--blue);
	font-size: 2rem;
	font-weight: 850;
}

.store-card strong {
	color: #00738b;
}

.store-card span {
	color: var(--muted);
}

.prose-band {
	max-width: 52rem;
	margin-inline: auto;
}

.bottom-nav {
	position: fixed;
	z-index: 12;
	left: 50%;
	bottom: max(0.65rem, env(safe-area-inset-bottom));
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
	align-items: center;
	width: min(calc(100% - 2rem), 60rem);
	min-height: 5.1rem;
	padding: 0.4rem 0.5rem;
	border: 1px solid var(--line);
	border-radius: 2rem;
	background: rgba(255, 255, 255, 0.95);
	box-shadow: 0 16px 44px rgba(17, 24, 39, 0.14);
	transform: translateX(-50%);
	backdrop-filter: blur(20px);
}

.bottom-nav a {
	display: grid;
	place-items: center;
	gap: 0.2rem;
	min-width: 0;
	color: var(--ink);
	font-size: clamp(0.78rem, 3vw, 1rem);
	font-weight: 700;
}

.bottom-nav a.active {
	color: var(--red);
}

.bottom-nav a.primary {
	position: relative;
	top: -1.25rem;
	color: var(--ink);
}

.bottom-nav a.primary span {
	display: grid;
	place-items: center;
	width: 4.3rem;
	height: 4.3rem;
	border-radius: 50%;
	background: var(--red);
	box-shadow: 0 10px 24px rgba(240, 51, 47, 0.34);
}

.bottom-nav span {
	position: relative;
	width: 1.85rem;
	height: 1.85rem;
}

.couponic-loader {
	position: fixed;
	z-index: 9999;
	inset: 0;
	display: grid;
	place-items: center;
	background: var(--couponic-loading-bg, #fff);
	transition: opacity var(--couponic-loading-duration, 900ms) ease, visibility var(--couponic-loading-duration, 900ms) ease;
}

.couponic-loader span {
	font-size: 2rem;
	font-weight: 850;
	color: var(--ink);
}

.couponic-loader img {
	max-width: 7rem;
	max-height: 7rem;
}

.couponic-loader.is-hidden {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.couponic-popup {
	position: fixed;
	z-index: 30;
	inset: 0;
	display: grid;
	place-items: center;
	padding: 1rem;
	background: rgba(17, 24, 39, 0.55);
}

.couponic-popup[hidden] {
	display: none;
}

.couponic-popup__panel {
	position: relative;
	display: grid;
	gap: 0.8rem;
	width: min(100%, 30rem);
	padding: 1.25rem;
	border-radius: var(--radius);
	background: #fff;
	box-shadow: 0 22px 70px rgba(0, 0, 0, 0.22);
}

.couponic-popup__panel img {
	width: 100%;
	max-height: 14rem;
	object-fit: cover;
	border-radius: var(--radius);
}

.couponic-popup__panel h2,
.couponic-popup__panel p {
	margin: 0;
}

.couponic-popup__close {
	position: absolute;
	top: 0.6rem;
	right: 0.6rem;
	width: 2rem;
	height: 2rem;
	border: 0;
	border-radius: 50%;
	background: #111827;
	color: #fff;
}

.nav-home::before {
	content: "";
	position: absolute;
	inset: 0.4rem 0.2rem 0.18rem;
	background: currentColor;
	clip-path: polygon(50% 0, 100% 42%, 86% 42%, 86% 100%, 18% 100%, 18% 42%, 0 42%);
}

.nav-store::before {
	content: "";
	position: absolute;
	inset: 0.38rem 0.18rem 0.15rem;
	border: 0.16rem solid currentColor;
	border-top-width: 0.45rem;
	border-radius: 0.18rem;
}

.nav-ticket::before {
	content: "";
	position: absolute;
	inset: 1.05rem;
	width: 1.65rem;
	height: 1.65rem;
	margin: -0.82rem;
	border: 0.18rem solid #fff;
	border-radius: 0.25rem;
	transform: rotate(38deg);
}

.nav-flame::before {
	content: "";
	position: absolute;
	inset: 0.18rem 0.35rem;
	border: 0.17rem solid currentColor;
	border-radius: 55% 45% 55% 45%;
	transform: rotate(35deg);
}

.nav-account::before {
	content: "";
	position: absolute;
	top: 0.2rem;
	left: 0.55rem;
	width: 0.75rem;
	height: 0.75rem;
	border: 0.16rem solid currentColor;
	border-radius: 50%;
}

.nav-account::after {
	content: "";
	position: absolute;
	left: 0.28rem;
	bottom: 0.2rem;
	width: 1.25rem;
	height: 0.75rem;
	border: 0.16rem solid currentColor;
	border-radius: 1rem 1rem 0.3rem 0.3rem;
}

@media (max-width: 720px) {
	.header-actions {
		gap: 0.1rem;
	}

	.country-switcher {
		padding-right: 0.62rem;
	}

	.store-hero {
		grid-template-columns: 5.8rem 1fr auto;
	}

	.store-copy h1 {
		font-size: clamp(1.75rem, 6vw, 2.2rem);
	}

	.follow-button {
		width: 4.5rem;
		min-height: 5.2rem;
		font-size: 0.95rem;
	}

	.coupon-card {
		grid-template-columns: 5.9rem 1fr;
		align-items: start;
	}

	.coupon-action {
		grid-column: 2;
		grid-template-columns: 1fr;
	}

	.desktop-hero {
		grid-template-columns: 1fr;
	}

	.home-banner,
	.archive-hero,
	.account-hero {
		grid-template-columns: 1fr;
		min-height: 13rem;
	}

	.home-banner h1,
	.archive-hero h1,
	.account-hero h1 {
		font-size: 2rem;
	}

	.newsletter-band {
		grid-template-columns: 1fr;
	}

	.archive-layout {
		grid-template-columns: 1fr;
	}

	.archive-sidebar {
		position: static;
		grid-template-columns: repeat(2, 1fr);
	}

	.archive-sidebar h2 {
		grid-column: 1 / -1;
	}

	.deal-day-card {
		grid-template-columns: 1fr;
	}

	.share-button {
		position: absolute;
		top: 0.95rem;
		right: 0.95rem;
	}
}

@media (max-width: 520px) {
	.app-header {
		padding-inline: 0.85rem;
	}

	.top-bar {
		grid-template-columns: 2.5rem 1fr auto;
		gap: 0.35rem;
	}

	.icon-button {
		width: 2.35rem;
		height: 2.35rem;
	}

	.menu-button span {
		width: 1.7rem;
	}

	.brand {
		font-size: 1.9rem;
	}

	.bell-button {
		display: none;
	}

	.country-switcher {
		min-height: 2.55rem;
		gap: 0.35rem;
	}

	.flag-us {
		width: 1.9rem;
		height: 1.9rem;
	}

	.site-search input {
		height: 3.65rem;
	}

	.site-main {
		padding-inline: 0.85rem;
	}

	.store-hero {
		grid-template-columns: 4.9rem 1fr 3.8rem;
		gap: 0.7rem;
	}

	.store-logo span {
		font-size: 3.7rem;
	}

	.hero-pills span,
	.verified-chip {
		min-height: 1.65rem;
		font-size: 0.86rem;
	}

	.follow-button {
		width: 3.6rem;
		min-height: 4.4rem;
		font-size: 0.76rem;
	}

	.follow-button span {
		width: 1.7rem;
		height: 1.7rem;
	}

	.store-metrics {
		grid-template-columns: repeat(2, 1fr);
	}

	.offer-tabs {
		top: 8.25rem;
	}

	.coupon-card {
		grid-template-columns: 5.2rem 1fr;
		padding: 0.78rem;
	}

	.discount-box strong {
		font-size: 1.62rem;
	}

	.coupon-main {
		padding-right: 1.65rem;
	}

	.coupon-action {
		grid-column: 1 / -1;
		grid-template-columns: 1fr 1fr;
	}

	.coupon-action code {
		min-height: 2.85rem;
	}

	.copy-button {
		min-height: 2.85rem;
	}
}
