/* ==========================================================================
   Ganacsigaaga — base styles (step 1 skeleton).
   Final palette + typography land in the design pass (build step 14).
   Inter is referenced for when the web font is loaded later; until then
   the system stack takes over via the fallback list.
   ========================================================================== */

:root {
	/* Spacing scale (4px base). */
	--gs-space-1: 4px;
	--gs-space-2: 8px;
	--gs-space-3: 12px;
	--gs-space-4: 16px;
	--gs-space-5: 24px;
	--gs-space-6: 32px;
	--gs-space-8: 48px;

	/* Type scale. */
	--gs-fs-100: 0.875rem;
	--gs-fs-200: 1rem;
	--gs-fs-300: 1.125rem;
	--gs-fs-400: 1.25rem;
	--gs-fs-500: 1.5rem;
	--gs-fs-600: 2rem;

	/* Helaaye brand palette — sampled from the helaaye.com logo. */
	--gs-color-bg: #ffffff;
	--gs-color-surface: #f9fafb;
	--gs-color-fg: #111827;
	--gs-color-muted: #6b7280;
	--gs-color-border: #e5e7eb;
	--gs-color-primary: #1e40af;      /* brand blue */
	--gs-color-primary-dark: #1e3a8a; /* hover / pressed */
	--gs-color-accent: #f97316;       /* brand orange */
	--gs-color-accent-dark: #ea580c;  /* hover / pressed */

	/* Layout. */
	--gs-container-max: 1200px;
	--gs-tap-target: 44px; /* enforced minimum for buttons + nav links */
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
	font-size: var(--gs-fs-200);
	line-height: 1.55;
	color: var(--gs-color-fg);
	background: var(--gs-color-bg);
}

img, picture, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--gs-color-primary); }
a:hover { color: var(--gs-color-primary-dark); }
a:focus-visible { outline: 2px solid var(--gs-color-accent); outline-offset: 2px; }

.gs-container {
	max-width: var(--gs-container-max);
	margin: 0 auto;
	padding-left: var(--gs-space-4);
	padding-right: var(--gs-space-4);
}

/* Skip link: hidden until focused (keyboard a11y). */
.gs-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100;
	padding: var(--gs-space-3) var(--gs-space-4);
	background: var(--gs-color-fg);
	color: #fff;
	text-decoration: none;
}
.gs-skip-link:focus { left: 8px; top: 8px; }

/* Header. */
.gs-site-header {
	border-bottom: 1px solid var(--gs-color-border);
	padding: var(--gs-space-4) 0;
}
.gs-site-header__inner {
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-3);
}
@media (min-width: 720px) {
	.gs-site-header__inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: var(--gs-space-5);
	}
}

.gs-site-title {
	font-size: var(--gs-fs-500);
	font-weight: 700;
	text-decoration: none;
	color: var(--gs-color-primary);
}
.gs-site-description {
	margin: var(--gs-space-1) 0 0;
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
}

/* Nav menus — flat list, tap targets meet 44px floor. */
.gs-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
}
.gs-menu a {
	display: inline-flex;
	align-items: center;
	min-height: var(--gs-tap-target);
	padding: 0 var(--gs-space-3);
	text-decoration: none;
	color: var(--gs-color-fg);
	border-radius: 6px;
}
.gs-menu a:hover,
.gs-menu a:focus-visible {
	background: var(--gs-color-border);
}

/* Welcome / 404 panels. */
.gs-welcome,
.gs-404 {
	padding: var(--gs-space-8) 0;
}
.gs-welcome__title,
.gs-404__title {
	margin: 0 0 var(--gs-space-3);
	font-size: var(--gs-fs-600);
	line-height: 1.15;
}
.gs-welcome__tagline,
.gs-404__message {
	margin: 0 0 var(--gs-space-4);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-300);
}

/* Buttons. */
.gs-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: var(--gs-tap-target);
	padding: 0 var(--gs-space-5);
	background: var(--gs-color-primary);
	color: #fff;
	text-decoration: none;
	border: 0;
	border-radius: 8px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.12s ease;
}
.gs-btn:hover,
.gs-btn:focus-visible { background: var(--gs-color-primary-dark); color: #fff; }

/* Footer. */
.gs-site-footer {
	margin-top: var(--gs-space-8);
	padding: var(--gs-space-5) 0;
	border-top: 1px solid var(--gs-color-border);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
}
.gs-footer-nav { margin-bottom: var(--gs-space-3); }
.gs-menu--footer a { padding: 0 var(--gs-space-2); }
.gs-site-info { margin: 0; }

/* ==========================================================================
   Single product page (step 3).
   ========================================================================== */

.gs-product { padding: var(--gs-space-5) 0; }

.gs-product__header { margin-bottom: var(--gs-space-5); }
.gs-product__title {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-fs-600);
	line-height: 1.15;
	word-wrap: break-word;
}
.gs-product__meta-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-3);
	align-items: center;
}
.gs-product__price {
	font-size: var(--gs-fs-500);
	font-weight: 700;
	color: var(--gs-color-accent);
}
.gs-product__condition {
	font-size: var(--gs-fs-100);
	color: var(--gs-color-muted);
}

/* Sold/expired listings get a subtle gallery treatment so the state
   reads even when the status pill is scrolled past. */
.gs-product--sold    .gs-gallery__main-img,
.gs-product--expired .gs-gallery__main-img {
	filter: grayscale(0.4) opacity(0.85);
}

/* Status pill — re-used on archives in step 5. */
.gs-status-pill {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: var(--gs-fs-100);
	font-weight: 600;
}
.gs-status-active  { background: #dcfce7; color: #166534; }
.gs-status-sold    { background: #fef3c7; color: #854d0e; }
.gs-status-expired { background: #fee2e2; color: #991b1b; }

/* Mobile-first stack; 2-column from 900px. */
.gs-product__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-5);
}
@media (min-width: 900px) {
	.gs-product__layout {
		grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
		align-items: start;
	}
}

/* Gallery */
.gs-gallery__main {
	aspect-ratio: 4 / 3;
	background: #f5f5f5;
	border-radius: 8px;
	overflow: hidden;
}
.gs-gallery__main-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}
.gs-gallery__thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	list-style: none;
	margin: var(--gs-space-3) 0 0;
	padding: 0;
}
.gs-gallery__thumb-wrap { margin: 0; }
.gs-gallery__thumb {
	border: 2px solid transparent;
	background: none;
	padding: 0;
	cursor: pointer;
	border-radius: 4px;
	overflow: hidden;
	display: block;
	line-height: 0;
}
.gs-gallery__thumb img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	display: block;
}
.gs-gallery__thumb:hover,
.gs-gallery__thumb:focus-visible,
.gs-gallery__thumb.is-active {
	border-color: var(--gs-color-primary);
}

/* Sidebar facts. */
.gs-product__facts {
	margin: 0 0 var(--gs-space-4);
	padding: 0;
}
.gs-product__fact {
	display: grid;
	grid-template-columns: minmax(120px, auto) 1fr;
	gap: var(--gs-space-3);
	padding: var(--gs-space-2) 0;
	border-bottom: 1px solid var(--gs-color-border);
}
.gs-product__fact dt {
	font-weight: 600;
	color: var(--gs-color-muted);
	margin: 0;
}
.gs-product__fact dd {
	margin: 0;
}
.gs-product__fact a {
	color: var(--gs-color-fg);
	text-decoration: underline;
}

/* WhatsApp button — uses brand green deliberately, not the theme accent. */
.gs-whatsapp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--gs-space-2);
	width: 100%;
	min-height: 52px;
	padding: 0 var(--gs-space-5);
	background: #25d366;
	color: #fff;
	text-decoration: none;
	border-radius: 10px;
	font-weight: 700;
	font-size: var(--gs-fs-300);
	margin-bottom: var(--gs-space-4);
	box-shadow: 0 2px 0 #128c7e;
	transition: filter 0.12s ease;
}
.gs-whatsapp-btn:hover,
.gs-whatsapp-btn:focus-visible {
	filter: brightness(0.95);
	color: #fff;
}
.gs-whatsapp-btn__icon { display: inline-flex; }

/* Mobile money */
.gs-mobile-money {
	background: #fafaf7;
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	padding: var(--gs-space-4);
	margin-bottom: var(--gs-space-4);
}
.gs-mobile-money__heading {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-fs-300);
}
.gs-mobile-money__note {
	margin: 0 0 var(--gs-space-3);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
}
.gs-mobile-money__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
}
.gs-mobile-money__item {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	align-items: center;
	gap: var(--gs-space-3);
	padding: var(--gs-space-2) var(--gs-space-3);
	background: #fff;
	border: 1px solid var(--gs-color-border);
	border-radius: 8px;
}
.gs-mobile-money__label {
	font-weight: 700;
	font-size: var(--gs-fs-100);
}
.gs-mobile-money__number {
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.02em;
	word-break: break-all;
}
.gs-mobile-money__copy {
	min-height: var(--gs-tap-target);
	min-width: 64px;
	padding: 0 var(--gs-space-3);
	background: var(--gs-color-fg);
	color: #fff;
	border: 0;
	border-radius: 6px;
	cursor: pointer;
	font-weight: 600;
	font-size: var(--gs-fs-100);
}
.gs-mobile-money__copy.is-copied { background: #166534; }

/* Description block. */
.gs-product__description {
	margin-top: var(--gs-space-6);
	padding-top: var(--gs-space-5);
	border-top: 1px solid var(--gs-color-border);
}
.gs-product__section-heading {
	margin: 0 0 var(--gs-space-3);
	font-size: var(--gs-fs-500);
}
.gs-product__content { max-width: 75ch; }
.gs-product__content p { margin: 0 0 var(--gs-space-3); }

/* ==========================================================================
   Archives, taxonomy, search (step 4): header + filter form + card grid + pagination.
   ========================================================================== */

.gs-archive-header {
	padding: var(--gs-space-5) 0 var(--gs-space-4);
	border-bottom: 1px solid var(--gs-color-border);
}
.gs-archive-header__title {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-fs-600);
	line-height: 1.15;
}
.gs-archive-header__description {
	margin: 0 0 var(--gs-space-3);
	color: var(--gs-color-muted);
}
.gs-archive-header__count {
	margin: 0 0 var(--gs-space-4);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
}

/* Filter form — mobile-first stack, then widen. */
.gs-filters {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-3);
	align-items: end;
}
@media (min-width: 640px) {
	.gs-filters { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
	.gs-filters { grid-template-columns: 2fr repeat(4, 1fr) auto; }
}
.gs-filters__field {
	display: flex;
	flex-direction: column;
	margin: 0;
}
.gs-filters__label {
	font-size: var(--gs-fs-100);
	font-weight: 600;
	margin-bottom: 4px;
	color: var(--gs-color-muted);
}
.gs-filters__field input,
.gs-filters__field select {
	width: 100%;
	min-height: var(--gs-tap-target);
	padding: 0 12px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	background: #fff;
	font: inherit;
	color: var(--gs-color-fg);
}
.gs-filters__submit { justify-self: start; }
@media (min-width: 960px) {
	.gs-filters__submit { justify-self: stretch; }
}

/* Archive area + responsive card grid. */
.gs-archive { padding: var(--gs-space-5) 0; }
.gs-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--gs-space-3);
}
@media (min-width: 640px) {
	.gs-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 960px) {
	.gs-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: var(--gs-space-4);
	}
}

/* Card. */
.gs-card {
	background: #fff;
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	overflow: hidden;
	transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.gs-card:hover {
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
	transform: translateY(-1px);
}
.gs-card__link {
	display: flex;
	flex-direction: column;
	color: inherit;
	text-decoration: none;
	height: 100%;
}
.gs-card__media {
	position: relative;
	aspect-ratio: 1 / 1;
	background: #f5f5f5;
	overflow: hidden;
}
.gs-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.gs-card__img--empty {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #eee, #f5f5f5);
}
.gs-card__status {
	position: absolute;
	top: 8px;
	left: 8px;
}
.gs-card--sold    .gs-card__img,
.gs-card--expired .gs-card__img {
	filter: grayscale(0.4) opacity(0.85);
}
.gs-card__body {
	padding: var(--gs-space-3);
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1;
}
.gs-card__title {
	margin: 0;
	font-size: var(--gs-fs-200);
	font-weight: 600;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.gs-card__price {
	font-weight: 700;
	color: var(--gs-color-accent);
	font-size: var(--gs-fs-300);
}
.gs-card__meta {
	margin-top: auto;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	font-size: var(--gs-fs-100);
	color: var(--gs-color-muted);
}
.gs-card__city::after {
	content: '·';
	margin-left: var(--gs-space-2);
	color: var(--gs-color-border);
}

/* Empty state. */
.gs-archive__empty {
	text-align: center;
	padding: var(--gs-space-8) var(--gs-space-4);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-300);
}

/* Pagination (WP's paginate_links output). */
.gs-pagination {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 4px;
	margin-top: var(--gs-space-5);
}
.gs-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: var(--gs-tap-target);
	min-height: var(--gs-tap-target);
	padding: 0 var(--gs-space-3);
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	text-decoration: none;
	color: var(--gs-color-fg);
	font-weight: 600;
	background: #fff;
}
.gs-pagination .page-numbers:hover {
	background: var(--gs-color-border);
}
.gs-pagination .page-numbers.current {
	background: var(--gs-color-primary);
	color: #fff;
	border-color: var(--gs-color-primary);
}
.gs-pagination .page-numbers.dots {
	border: 0;
	background: transparent;
}

/* ==========================================================================
   Auth pages — login + register (step 6).
   Centered card, mobile-first. The Google button drops in via GSI's own
   markup which we don't restyle (Google forbids it in their terms).
   ========================================================================== */

.gs-auth {
	padding: var(--gs-space-6) 0 var(--gs-space-8);
}
.gs-auth__wrap {
	max-width: 420px;
	margin: 0 auto;
}
.gs-auth__title {
	margin: 0 0 var(--gs-space-5);
	font-size: var(--gs-fs-500);
	text-align: center;
}
.gs-google-signin {
	display: flex;
	justify-content: center;
	margin-bottom: var(--gs-space-4);
	min-height: 44px; /* avoid layout shift before GSI renders */
}
.gs-auth__divider {
	display: flex;
	align-items: center;
	gap: var(--gs-space-3);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
	margin: var(--gs-space-3) 0 var(--gs-space-4);
}
.gs-auth__divider::before,
.gs-auth__divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--gs-color-border);
}
.gs-auth__error {
	background: #fee2e2;
	color: #991b1b;
	padding: var(--gs-space-3);
	border-radius: 8px;
	margin: 0 0 var(--gs-space-4);
}
.gs-auth__form {
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-3);
	margin-bottom: var(--gs-space-4);
}
.gs-auth__field {
	margin: 0;
	display: flex;
	flex-direction: column;
}
.gs-auth__field label {
	font-size: var(--gs-fs-100);
	font-weight: 600;
	margin-bottom: 4px;
}
.gs-auth__field input[type="email"],
.gs-auth__field input[type="password"],
.gs-auth__field input[type="text"] {
	width: 100%;
	min-height: var(--gs-tap-target);
	padding: 0 12px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	background: #fff;
	font: inherit;
	color: var(--gs-color-fg);
}
.gs-auth__field input:focus-visible {
	outline: 2px solid var(--gs-color-accent);
	outline-offset: 1px;
	border-color: var(--gs-color-accent);
}
.gs-auth__remember label {
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	font-weight: 400;
	font-size: var(--gs-fs-100);
}
.gs-auth__submit {
	width: 100%;
}
.gs-auth__alt {
	text-align: center;
	font-size: var(--gs-fs-100);
	color: var(--gs-color-muted);
	margin: 0 0 var(--gs-space-2);
}
.gs-auth__alt a {
	color: var(--gs-color-fg);
	font-weight: 600;
	text-decoration: underline;
}

/* ==========================================================================
   Dashboard (step 7).
   ========================================================================== */

.gs-dashboard { padding: var(--gs-space-5) 0 var(--gs-space-8); }
.gs-dashboard__header { margin-bottom: var(--gs-space-5); }
.gs-dashboard__title {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-fs-600);
	color: var(--gs-color-primary);
}
.gs-dashboard__welcome { margin: 0; color: var(--gs-color-muted); }

.gs-dashboard__flash {
	padding: var(--gs-space-3) var(--gs-space-4);
	border-radius: 8px;
	margin-bottom: var(--gs-space-4);
}
.gs-dashboard__flash--ok { background: #dcfce7; color: #166534; }

.gs-dashboard__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--gs-space-3);
	margin-bottom: var(--gs-space-5);
}
.gs-dashboard__stat {
	background: var(--gs-color-surface);
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	padding: var(--gs-space-4);
	text-align: center;
}
.gs-dashboard__stat-num {
	display: block;
	font-size: var(--gs-fs-600);
	font-weight: 700;
	line-height: 1.1;
	color: var(--gs-color-fg);
}
.gs-dashboard__stat-label {
	display: block;
	margin-top: var(--gs-space-1);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
	font-weight: 600;
}
.gs-dashboard__stat--active  .gs-dashboard__stat-num { color: #166534; }
.gs-dashboard__stat--sold    .gs-dashboard__stat-num { color: #854d0e; }
.gs-dashboard__stat--expired .gs-dashboard__stat-num { color: #991b1b; }

.gs-dashboard__cta-row { margin: 0 0 var(--gs-space-6); }
.gs-dashboard__cta {
	min-height: 52px;
	padding: 0 var(--gs-space-6);
	font-size: var(--gs-fs-300);
}

.gs-dashboard__section { margin-bottom: var(--gs-space-6); }
.gs-dashboard__section-title {
	margin: 0 0 var(--gs-space-3);
	font-size: var(--gs-fs-500);
}
.gs-dashboard__empty {
	padding: var(--gs-space-5);
	text-align: center;
	color: var(--gs-color-muted);
	background: var(--gs-color-surface);
	border: 1px dashed var(--gs-color-border);
	border-radius: 10px;
}

/* My listings table. */
.gs-my-listings {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
}
.gs-my-listings__item {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: var(--gs-space-3);
	padding: var(--gs-space-3);
	background: #fff;
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	align-items: center;
}
@media (min-width: 720px) {
	.gs-my-listings__item {
		grid-template-columns: 80px 1fr auto;
	}
}
.gs-my-listings__media { line-height: 0; display: block; }
.gs-my-listings__img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 8px;
	display: block;
}
.gs-my-listings__img--empty { background: linear-gradient(135deg, #eee, #f5f5f5); }
.gs-my-listings__body { display: flex; flex-direction: column; gap: var(--gs-space-1); min-width: 0; }
.gs-my-listings__title {
	font-weight: 600;
	color: var(--gs-color-fg);
	text-decoration: none;
	word-break: break-word;
}
.gs-my-listings__title:hover { color: var(--gs-color-primary); }
.gs-my-listings__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	align-items: center;
	font-size: var(--gs-fs-100);
}
.gs-my-listings__price { font-weight: 700; color: var(--gs-color-accent); }
.gs-my-listings__item--expired { opacity: 0.7; }

.gs-my-listings__actions {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	margin-top: var(--gs-space-2);
}
@media (min-width: 720px) {
	.gs-my-listings__actions {
		grid-column: auto;
		margin-top: 0;
	}
}
.gs-my-listings__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0 var(--gs-space-3);
	font-size: var(--gs-fs-100);
	font-weight: 600;
	text-decoration: none;
	color: var(--gs-color-fg);
	background: var(--gs-color-surface);
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	cursor: pointer;
}
.gs-my-listings__action:hover { background: var(--gs-color-border); color: var(--gs-color-fg); }
.gs-my-listings__action--danger { color: #991b1b; }
.gs-my-listings__action--danger:hover { background: #fee2e2; color: #991b1b; }
.gs-my-listings__delete-form { margin: 0; display: inline-block; }

/* Referral block + copy bar. */
.gs-dashboard__referral {
	background: var(--gs-color-surface);
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	padding: var(--gs-space-4);
}
.gs-dashboard__referral-count { margin: 0 0 var(--gs-space-3); color: var(--gs-color-muted); }
.gs-copy-bar {
	display: flex;
	gap: var(--gs-space-2);
	margin-bottom: var(--gs-space-2);
}
.gs-copy-bar__input {
	flex: 1;
	min-height: var(--gs-tap-target);
	padding: 0 12px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	background: #fff;
	color: var(--gs-color-fg);
	font: inherit;
	font-variant-numeric: tabular-nums;
}
.gs-copy-bar__btn {
	min-height: var(--gs-tap-target);
	padding: 0 var(--gs-space-4);
	background: var(--gs-color-fg);
	color: #fff;
	border: 0;
	border-radius: 6px;
	font-weight: 600;
	cursor: pointer;
}
.gs-copy-bar__btn.is-copied { background: #166534; }

.gs-dashboard__footer {
	margin-top: var(--gs-space-6);
	padding-top: var(--gs-space-4);
	border-top: 1px solid var(--gs-color-border);
	text-align: center;
}
.gs-dashboard__signout {
	display: inline-block;
	color: var(--gs-color-muted);
	text-decoration: underline;
}

/* ==========================================================================
   Listing form (step 7).
   ========================================================================== */

.gs-form-page { padding: var(--gs-space-5) 0 var(--gs-space-8); }
.gs-form-page__header { margin-bottom: var(--gs-space-5); }
.gs-form-page__title {
	margin: 0;
	font-size: var(--gs-fs-600);
	color: var(--gs-color-primary);
}

.gs-form {
	max-width: 720px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-5);
}
.gs-form__error {
	background: #fee2e2;
	color: #991b1b;
	padding: var(--gs-space-3) var(--gs-space-4);
	border-radius: 8px;
}
.gs-form__section {
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
	padding: var(--gs-space-4);
	margin: 0;
}
.gs-form__legend {
	font-weight: 700;
	font-size: var(--gs-fs-300);
	padding: 0 var(--gs-space-2);
	color: var(--gs-color-fg);
}
.gs-form__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-3);
}
@media (min-width: 640px) {
	.gs-form__row { grid-template-columns: 1fr 1fr; }
	.gs-form__row--mm { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
	.gs-form__row--mm { grid-template-columns: repeat(4, 1fr); }
}
.gs-form__field {
	margin: 0 0 var(--gs-space-3);
	display: flex;
	flex-direction: column;
}
.gs-form__field:last-child { margin-bottom: 0; }
.gs-form__field label {
	font-size: var(--gs-fs-100);
	font-weight: 600;
	margin-bottom: 4px;
}
.gs-form__req { color: #991b1b; }
.gs-form__field input[type="text"],
.gs-form__field input[type="email"],
.gs-form__field input[type="tel"],
.gs-form__field input[type="number"],
.gs-form__field input[type="date"],
.gs-form__field select,
.gs-form__field textarea {
	width: 100%;
	min-height: var(--gs-tap-target);
	padding: 8px 12px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	background: #fff;
	color: var(--gs-color-fg);
	font: inherit;
}
.gs-form__field textarea { min-height: 120px; padding: 12px; }
.gs-form__field input:focus-visible,
.gs-form__field select:focus-visible,
.gs-form__field textarea:focus-visible {
	outline: 2px solid var(--gs-color-accent);
	outline-offset: 1px;
	border-color: var(--gs-color-accent);
}
.gs-form__field input[type="file"] {
	min-height: var(--gs-tap-target);
	padding: 8px;
}

.gs-img-previews {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	margin-bottom: var(--gs-space-3);
}
.gs-img-preview {
	position: relative;
	width: 100px;
	height: 100px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	overflow: hidden;
	background: var(--gs-color-surface);
}
.gs-img-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gs-img-preview__remove {
	position: absolute;
	top: 4px;
	right: 4px;
	border: 0;
	background: rgba(0, 0, 0, 0.7);
	color: #fff;
	font-size: 11px;
	padding: 3px 7px;
	border-radius: 4px;
	cursor: pointer;
}
.gs-img-preview__new-badge {
	position: absolute;
	bottom: 4px;
	left: 4px;
	background: var(--gs-color-accent);
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 6px;
	border-radius: 4px;
	text-transform: uppercase;
}

.gs-form__submit-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-3);
	align-items: center;
	margin-top: var(--gs-space-3);
}
.gs-form__submit { min-height: 52px; padding: 0 var(--gs-space-6); font-size: var(--gs-fs-300); }
.gs-form__cancel { color: var(--gs-color-muted); text-decoration: underline; }

/* ==========================================================================
   Transaction-reference form on single product (step 10 stub).
   ========================================================================== */

.gs-tx-form {
	margin: var(--gs-space-6) 0;
	padding: var(--gs-space-5);
	background: var(--gs-color-surface);
	border: 1px solid var(--gs-color-border);
	border-radius: 10px;
}
.gs-tx-form__heading {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-fs-400);
	color: var(--gs-color-primary);
}
.gs-tx-form__intro {
	margin: 0 0 var(--gs-space-4);
	color: var(--gs-color-muted);
	font-size: var(--gs-fs-100);
	max-width: 65ch;
}
.gs-tx-form__success {
	background: #dcfce7;
	color: #166534;
	padding: var(--gs-space-3) var(--gs-space-4);
	border-radius: 8px;
	margin: 0 0 var(--gs-space-4);
}
.gs-tx-form__error {
	background: #fee2e2;
	color: #991b1b;
	padding: var(--gs-space-3) var(--gs-space-4);
	border-radius: 8px;
	margin: 0 0 var(--gs-space-4);
}
.gs-tx-form__form {
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-3);
	max-width: 640px;
}
.gs-tx-form__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-3);
}
@media (min-width: 640px) {
	.gs-tx-form__row { grid-template-columns: 1fr 1fr; }
}
.gs-tx-form__field {
	margin: 0;
	display: flex;
	flex-direction: column;
}
.gs-tx-form__field label {
	font-size: var(--gs-fs-100);
	font-weight: 600;
	margin-bottom: 4px;
}
.gs-tx-form__field input,
.gs-tx-form__field select,
.gs-tx-form__field textarea {
	width: 100%;
	min-height: var(--gs-tap-target);
	padding: 8px 12px;
	border: 1px solid var(--gs-color-border);
	border-radius: 6px;
	background: #fff;
	color: var(--gs-color-fg);
	font: inherit;
}
.gs-tx-form__field textarea { min-height: 80px; padding: 12px; }
.gs-tx-form__field input:focus-visible,
.gs-tx-form__field select:focus-visible,
.gs-tx-form__field textarea:focus-visible {
	outline: 2px solid var(--gs-color-accent);
	outline-offset: 1px;
	border-color: var(--gs-color-accent);
}
.gs-tx-form__submit-row { margin: var(--gs-space-2) 0 0; }
.gs-tx-form__submit { min-height: 48px; padding: 0 var(--gs-space-5); }

/* Honeypot — invisible to humans, present to bots. */
.gs-tx-form__honeypot {
	position: absolute;
	left: -9999px;
	top: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Respect user motion preference. */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}
}
