/* -----------------------------------------------------------------------
 * Components
 * -------------------------------------------------------------------- */

/* Buttons */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 44px;
	padding: 10px 24px;
	border-radius: var(--r-md);
	font-family: var(--font-body);
	font-weight: 700;
	font-size: var(--body-md-size);
	line-height: 1;
	transition: all var(--dur) var(--ease);
	white-space: nowrap;
}
.btn:focus-visible { outline-offset: 4px; }

.btn-primary {
	background: var(--primary);
	color: var(--on-primary);
	border: 1px solid transparent;
}
.btn-primary:hover { transform: scale(0.97); box-shadow: var(--shadow-2); }

.btn-secondary {
	background: transparent;
	color: var(--secondary);
	border: 2px solid var(--secondary);
}
html.dark .btn-secondary { color: var(--secondary-fixed); border-color: var(--secondary-fixed); }
.btn-secondary:hover { background: color-mix(in srgb, var(--secondary) 8%, transparent); }

.btn-accent {
	background: var(--secondary);
	color: var(--on-secondary);
}
html.dark .btn-accent { background: var(--secondary-fixed); color: var(--on-secondary); }
.btn-accent:hover { transform: scale(0.97); box-shadow: var(--shadow-2); }

.btn-ghost {
	background: transparent;
	color: var(--on-surface);
}
.btn-ghost:hover { background: var(--surface-container-high); }

/* Generic outlined button. Per-variant accent colour comes from
 * --btn-outline-color, which the modifiers below set. Use:
 *   <a class="btn btn-outline btn-outline--warm">…</a>
 */
.btn-outline {
	background: transparent;
	color: var(--btn-outline-color, var(--on-surface));
	border: 2px solid var(--btn-outline-color, var(--outline-variant));
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.btn-outline:hover {
	background: color-mix(in srgb, var(--btn-outline-color, var(--on-surface)) 10%, transparent);
	transform: translateY(-1px);
	box-shadow: var(--shadow-1);
}

/* Warm coral/amber accent — sits well next to brand teal without clashing.
 * In light mode it's a warm coral-orange; in dark mode it shifts to a
 * brighter peach so it stays legible against the dark surface. */
.btn-outline--warm {
	--btn-outline-color: #e07a5f;
}
html.dark .btn-outline--warm {
	--btn-outline-color: #f4a261;
}

/* Other variants kept available but currently unused on the listing page. */
.btn-outline--success { --btn-outline-color: var(--success); }
.btn-outline--info    { --btn-outline-color: var(--secondary); }

.btn-icon {
	min-height: 40px;
	width: 40px;
	padding: 0;
	justify-content: center;
	border-radius: var(--r-full);
	color: var(--on-surface-variant);
}
.btn-icon:hover { background: var(--surface-container-high); color: var(--on-surface); }

/* Chips */
.chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	border-radius: var(--r-full);
	background: var(--accent-aqua-soft);
	color: var(--secondary);
	font-size: var(--label-md-size);
	font-weight: 600;
	letter-spacing: var(--label-md-tracking);
	line-height: 1;
	text-transform: uppercase;
	border: 1px solid color-mix(in srgb, var(--secondary) 14%, transparent);
}
html.dark .chip { color: var(--secondary-fixed); }

.chip-solid {
	background: var(--secondary);
	color: var(--on-secondary);
	border-color: transparent;
}
html.dark .chip-solid { background: var(--secondary-fixed); color: var(--on-secondary); }

/* Cards */
.card {
	background: var(--surface-container-lowest);
	border: 1px solid var(--outline-variant);
	border-radius: var(--r-xl);
	box-shadow: var(--shadow-1);
	overflow: hidden;
	transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
html.dark .card { background: var(--surface-container); border-color: var(--outline-variant); }
.card:hover { box-shadow: var(--shadow-2); }

/* Glass panel (search bar, sticky header) */
.glass {
	background: var(--glass-bg);
	backdrop-filter: var(--glass-blur);
	-webkit-backdrop-filter: var(--glass-blur);
	border: 1px solid var(--glass-border);
	border-radius: var(--r-2xl);
}

/* Inputs */
.field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.field label {
	font-size: var(--label-md-size);
	font-weight: 600;
	letter-spacing: var(--label-md-tracking);
	text-transform: uppercase;
	color: var(--on-surface-variant);
}
.field input,
.field textarea,
.field select {
	width: 100%;
	min-height: 44px;
	padding: 10px 14px;
	background: var(--surface-container-lowest);
	color: var(--on-surface);
	border: 1px solid var(--outline-variant);
	border-radius: var(--r-md);
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.field input:focus,
.field textarea:focus,
.field select:focus {
	outline: none;
	border-color: var(--secondary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--secondary) 18%, transparent);
}

/* Listing card */
.listing-card { display: flex; flex-direction: column; height: 100%; }
.listing-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--surface-container-high);
	overflow: hidden;
}
.listing-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease);
}
.listing-card:hover .listing-card__media img { transform: scale(1.04); }
.listing-card__badges {
	position: absolute;
	top: 12px;
	left: 12px;
	right: 12px;
	display: flex;
	justify-content: space-between;
	gap: 8px;
}
.listing-card__body { padding: var(--md); display: flex; flex-direction: column; gap: 8px; }
.listing-card__category {
	font-size: var(--label-md-size);
	font-weight: 600;
	letter-spacing: var(--label-md-tracking);
	text-transform: uppercase;
	color: var(--secondary);
}
html.dark .listing-card__category { color: var(--secondary-fixed); }
.listing-card__title {
	font-family: var(--font-display);
	font-size: var(--headline-md-size);
	font-weight: 700;
	line-height: 1.2;
	color: var(--on-surface);
}
.listing-card__excerpt {
	color: var(--on-surface-variant);
	font-size: var(--body-md-size);
	line-height: var(--body-md-line);
}
.listing-card__meta {
	margin-top: auto;
	padding-top: var(--md);
	display: flex;
	align-items: center;
	gap: 12px;
	color: var(--on-surface-variant);
	font-size: var(--caption-size);
	border-top: 1px solid var(--outline-variant);
}
.listing-card__meta .material-symbols-outlined { font-size: 16px; }

/* Logo ticker */
.ticker {
	border-top: 1px solid var(--outline-variant);
	border-bottom: 1px solid var(--outline-variant);
	background: var(--surface-container-low);
	overflow: hidden;
	padding-block: var(--lg);
}
html.dark .ticker { background: var(--surface-container); }
.ticker__track {
	display: flex;
	width: max-content;
	gap: var(--xxl);
	animation: ticker-scroll 50s linear infinite;
}
.ticker__row {
	display: flex;
	gap: var(--xxl);
	padding-inline: var(--xxl);
	flex-shrink: 0;
}
.ticker__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 4px 8px;
	border-radius: var(--r-md);
	color: inherit;
	text-decoration: none;
	filter: grayscale(1);
	opacity: 0.75;
	transition: all var(--dur) var(--ease);
	cursor: pointer;
}
.ticker__item:hover,
.ticker__item:focus-visible {
	filter: none;
	opacity: 1;
	background: color-mix(in srgb, var(--secondary) 8%, transparent);
}
.ticker__icon {
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	border-radius: var(--r-md);
	background: var(--surface-container-high);
	color: var(--on-surface-variant);
	overflow: hidden;
	flex-shrink: 0;
}
.ticker__icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ticker__name {
	font-size: var(--label-md-size);
	font-weight: 600;
	letter-spacing: var(--label-md-tracking);
	color: var(--on-surface-variant);
	text-transform: uppercase;
	white-space: nowrap;
}
@keyframes ticker-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.ticker__track { animation: none; }
}

/* Modal (suggest a business) */
.modal {
	position: fixed;
	inset: 0;
	z-index: 100;
	display: none;
	align-items: center;
	justify-content: center;
	padding: var(--md);
	background: color-mix(in srgb, var(--inverse-surface) 60%, transparent);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.modal[open],
.modal.is-open { display: flex; }
.modal__panel {
	width: min(720px, 100%);
	max-height: calc(100vh - 64px);
	overflow: auto;
	background: var(--surface-container-lowest);
	border-radius: var(--r-2xl);
	box-shadow: var(--shadow-3);
	padding: var(--xl);
	position: relative;
}
.modal__close {
	position: absolute;
	top: var(--md);
	right: var(--md);
}

/* Bento card variants */
.bento { display: flex; flex-direction: column; }
.bento--feature {
	position: relative;
	color: #fff;
	min-height: 480px;
}
.bento--feature .bento__bg,
.bento--feature .bento__bg img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.bento--feature .bento__body {
	position: relative;
	margin-top: auto;
	padding: var(--xl);
	background: linear-gradient(to top, rgba(2, 6, 23, 0.92), rgba(2, 6, 23, 0));
}
.bento--accent {
	background: color-mix(in srgb, var(--secondary) 12%, transparent);
	border-color: color-mix(in srgb, var(--secondary) 26%, transparent);
}
html.dark .bento--accent {
	background: color-mix(in srgb, var(--secondary-fixed) 14%, transparent);
	border-color: color-mix(in srgb, var(--secondary-fixed) 30%, transparent);
}
.bento--invert {
	background: var(--primary-container);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.08);
}
.bento--invert h2,
.bento--invert h3 { color: #fff; }

/* Status badges */
.badge-open {
	background: var(--secondary);
	color: var(--on-secondary);
}
html.dark .badge-open { background: var(--secondary-fixed); color: var(--on-secondary); }
.badge-claimed {
	background: var(--primary);
	color: var(--on-primary);
}
.badge-trusted {
	background: var(--tertiary-fixed);
	color: var(--on-tertiary-container);
}

/* Footer */
.site-footer {
	margin-top: auto;
	padding-block: var(--xl);
	background: var(--surface-container-highest);
	border-top: 1px solid var(--outline-variant);
}
html.dark .site-footer { background: var(--surface-container-low); }
/* Specificity bumped via chained `.site-footer .site-footer__inner` so
 * Hummingbird Critical CSS can't prune these centering rules and leave
 * us with the row-layout defaults bleeding into mobile. */
.site-footer .site-footer__inner {
	display: flex;
	flex-direction: column;
	gap: var(--lg);
	align-items: center;
	text-align: center;
}
@media (min-width: 768px) {
	.site-footer .site-footer__inner {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
		text-align: left;
	}
}
.site-footer .site-footer__brand { align-items: center; }
@media (min-width: 768px) {
	.site-footer .site-footer__brand { align-items: flex-start; }
}
.site-footer .site-footer__nav { display: flex; flex-wrap: wrap; gap: var(--md) var(--lg); justify-content: center; }
.site-footer .footer-list { display: flex; flex-wrap: wrap; gap: var(--md) var(--lg); justify-content: center; list-style: none; margin: 0; padding: 0; }
.site-footer__nav a {
	font-size: var(--label-md-size);
	font-weight: 600;
	letter-spacing: var(--label-md-tracking);
	text-transform: uppercase;
	color: var(--on-surface-variant);
}
@media (hover: hover) {
	.site-footer__nav a:hover { color: var(--secondary); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 4px; }
	html.dark .site-footer__nav a:hover { color: var(--secondary-fixed); }
}

/* Utilities */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-sm { gap: var(--sm); } .gap-md { gap: var(--md); } .gap-lg { gap: var(--lg); }
.mt-md { margin-top: var(--md); } .mt-lg { margin-top: var(--lg); } .mt-xl { margin-top: var(--xl); } .mt-xxl { margin-top: var(--xxl); }
.text-muted { color: var(--on-surface-variant); }
.relative { position: relative; }
.is-hidden { display: none !important; }
.no-scroll { overflow: hidden; }
