/* Buskery — main stylesheet
 * Mobile-first, plain CSS, custom properties for theming.
 */

:root {
	color-scheme: dark;

	/* Neutral grayscale only. Artist work supplies all the color on the page. */
	--c-bg:        #0e0f10;  /* page */
	--c-surface:   #16181a;  /* cards, panels */
	--c-surface-2: #1d1f22;  /* hover, raised */
	--c-fg:        #e8e8e8;  /* primary text */
	--c-fg-soft:   #cccccc;  /* secondary text */
	--c-muted:     #8a8d92;  /* tertiary, captions */
	--c-rule:      #2a2c30;  /* hairlines */
	--c-rule-2:    #3a3d42;  /* hover hairlines */
	--c-link:      var(--c-fg);
	--c-link-hover:#ffffff;

	/* Single neutral accent, used sparingly. No chroma. */
	--c-accent:        #f2f2f2;
	--c-accent-fg:     #0e0f10;
	--c-accent-soft:   #2a2c30;

	--ff-text: ui-serif, Georgia, "Iowan Old Style", "Charter", serif;
	--ff-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

	--measure: 38rem;
	--gutter: 1.25rem;
	--radius: 4px;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	background: var(--c-bg);
	color: var(--c-fg);
	font-family: var(--ff-ui);
	font-size: 1.0625rem;
	line-height: 1.55;
}

a { color: var(--c-link); text-underline-offset: 2px; }
a:hover, a:focus { color: var(--c-link-hover); }

img, video { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ff-text);
	line-height: 1.2;
	margin: 1.5em 0 0.5em;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.15rem; }

/* Long-form reading contexts get the serif. UI/lists/buttons stay sans (body default). */
.artist-bio, .case-content, .page-content, .entry-content {
	font-family: var(--ff-text);
}

.muted { color: var(--c-muted); }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px; overflow: hidden;
	white-space: nowrap;
}
.skip-link:focus {
	clip: auto; width: auto; height: auto;
	background: #fff; color: #000;
	padding: 0.5rem 1rem;
	position: fixed; top: 0.5rem; left: 0.5rem;
	z-index: 100;
}

/* Layout */
.site-header, .site-footer, main {
	padding-left: var(--gutter);
	padding-right: var(--gutter);
}
main { max-width: 72rem; margin: 0 auto; padding-top: 2rem; padding-bottom: 4rem; }

/* Header: 3-column grid — brand left, nav centered, user widget right. */
.site-header {
	border-bottom: 1px solid var(--c-rule);
}
.site-header-inner {
	max-width: 72rem;
	margin: 0 auto;
	padding: 1rem 0;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1rem;
}
.site-brand { text-decoration: none; justify-self: start; }
.site-title { font-family: var(--ff-text); font-size: 1.5rem; font-weight: 600; }

.site-nav { justify-self: center; }
.site-nav .menu, .site-footer-nav .menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; gap: 1.25rem; flex-wrap: wrap; align-items: center; justify-content: center;
}
.site-nav a { text-decoration: none; }

.site-user { justify-self: end; }

@media (max-width: 40rem) {
	.site-header-inner {
		grid-template-columns: auto auto;
		row-gap: 0.5rem;
	}
	.site-brand   { grid-column: 1; grid-row: 1; }
	.site-user    { grid-column: 2; grid-row: 1; }
	.site-nav     { grid-column: 1 / -1; grid-row: 2; justify-self: center; }
}

.user-widget { font-family: var(--ff-ui); }
.user-widget-out { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.user-widget-alt {
	font-size: 0.85rem;
	color: var(--c-muted);
	text-decoration: none;
	border-bottom: 1px dotted var(--c-rule);
}
.user-widget-alt:hover { color: var(--c-fg); border-bottom-color: var(--c-rule-2); }

/* Google button */
.btn-google {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: #ffffff;
	color: #1f1f1f;
	border: 1px solid #dadce0;
	border-radius: var(--radius);
	padding: 0.5rem 0.875rem;
	font-family: 'Roboto', var(--ff-ui);
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: background 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}
.btn-google:hover {
	background: #f8f9fa;
	border-color: #d2d5d9;
	box-shadow: 0 1px 2px rgba(0,0,0,0.18), 0 1px 3px rgba(0,0,0,0.12);
	color: #1f1f1f;
}
.btn-google-icon { display: block; flex-shrink: 0; }

/* Logged-in disclosure menu */
.user-widget-in {
	position: relative;
}
.user-widget-trigger {
	list-style: none;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.25rem 0.5rem 0.25rem 0.25rem;
	border: 1px solid transparent;
	border-radius: 999px;
	cursor: pointer;
	color: var(--c-fg);
	background: var(--c-surface);
}
.user-widget-trigger::-webkit-details-marker { display: none; }
.user-widget-trigger:hover { border-color: var(--c-rule); }
.user-widget-in[open] .user-widget-trigger { border-color: var(--c-rule-2); }
.user-widget-avatar {
	width: 28px; height: 28px;
	border-radius: 50%;
	display: block;
}
.user-widget-name {
	font-size: 0.9rem;
	font-weight: 500;
}
.user-widget-caret { color: var(--c-muted); transition: transform 120ms ease; }
.user-widget-in[open] .user-widget-caret { transform: rotate(180deg); }

.user-widget-menu {
	position: absolute;
	right: 0;
	top: calc(100% + 0.5rem);
	min-width: 12rem;
	display: flex;
	flex-direction: column;
	background: var(--c-surface);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	box-shadow: 0 8px 24px rgba(0,0,0,0.4);
	padding: 0.25rem;
	z-index: 50;
}
.user-widget-menu a {
	display: block;
	padding: 0.5rem 0.75rem;
	color: var(--c-fg);
	text-decoration: none;
	border-radius: 3px;
	font-size: 0.9rem;
}
.user-widget-menu a:hover { background: var(--c-surface-2); color: var(--c-link-hover); }
.user-widget-menu .user-widget-logout {
	border-top: 1px solid var(--c-rule);
	margin-top: 0.25rem;
	padding-top: 0.625rem;
	color: var(--c-muted);
}
.user-widget-menu .user-widget-logout:hover { color: var(--c-fg); }

/* Footer */
.site-footer {
	border-top: 1px solid var(--c-rule);
	margin-top: 4rem;
	font-family: var(--ff-ui);
	font-size: 0.95rem;
}
.site-footer-inner {
	max-width: 72rem; margin: 0 auto;
	padding: 2rem 0;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1rem;
}
.site-footer-host {
	margin: 0;
	text-align: left;
	justify-self: start;
}
.site-footer-meta {
	margin: 0;
	color: var(--c-muted);
	text-align: center;
	justify-self: center;
}
.site-footer-version {
	margin: 0;
	color: var(--c-muted);
	font-size: 0.8rem;
	font-family: var(--ff-ui);
	opacity: 0.7;
	text-align: right;
	justify-self: end;
}
@media (max-width: 40rem) {
	.site-footer-inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.site-footer-version, .site-footer-meta, .site-footer-host {
		text-align: center;
		justify-self: center;
	}
}
.site-footer-host a, .buskery-host-tip {
	color: var(--c-muted);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
.buskery-host-tip:hover { color: var(--c-accent); }

/* Buttons */
.btn {
	display: inline-block;
	background: var(--c-accent);
	color: var(--c-accent-fg);
	text-decoration: none;
	padding: 0.625rem 1rem;
	border-radius: var(--radius);
	font-family: var(--ff-ui);
	font-weight: 500;
	border: 1px solid transparent;
}
.btn:hover { background: #ffffff; color: var(--c-accent-fg); }
.btn-quiet {
	background: transparent; color: var(--c-fg);
	border: 1px solid var(--c-rule);
}
.btn-quiet:hover { border-color: var(--c-rule-2); color: var(--c-link-hover); background: transparent; }

/* Hero */
.hero { padding: 3rem 0 1rem; }
.hero-title { font-size: clamp(2.25rem, 5vw, 3.5rem); margin: 0 0 0.5rem; }
.hero-tagline { font-size: 1.25rem; max-width: var(--measure); margin: 0 0 1.5rem; }
.hero-defn {
	font-family: var(--ff-text);
	font-size: 1rem;
	color: var(--c-fg-soft);
	max-width: var(--measure);
	margin: 0 0 1rem;
	padding-left: 1rem;
	border-left: 2px solid var(--c-rule);
}
.hero-defn strong { color: var(--c-fg); }
.hero-defn em { color: var(--c-muted); font-style: italic; }
.hero-actions .btn { margin-right: 0.5rem; margin-bottom: 0.5rem; }

/* How it works */
.how-it-works { margin: 3rem 0; }
.steps { padding-left: 1.25rem; max-width: 48rem; }
.steps li { margin-bottom: 0.5rem; }

/* Artist grid (front + browse + taxonomy) — equal-height cards */
.artist-grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
	grid-auto-rows: 1fr;
	margin-top: 1.5rem;
}
.artist-card {
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--c-surface);
	transition: border-color 120ms ease, transform 120ms ease;
	display: flex;
	flex-direction: column;
}
.artist-card:hover { border-color: var(--c-rule-2); }
.artist-card-link {
	display: flex;
	flex-direction: column;
	flex: 1;
	text-decoration: none;
	color: inherit;
	padding: 0 0 0.875rem;
}
.artist-card-image img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; }
.artist-card-title { margin: 0.75rem 1rem 0.25rem; font-size: 1.1rem; }
.artist-card-tagline { margin: 0 1rem 0.75rem; color: var(--c-muted); font-size: 0.95rem; }

/* Discipline pill — used both inside cards and inline next to h1.artist-name */
.buskery-discipline {
	display: inline-flex;
	align-items: center;
	background: var(--c-accent-soft);
	color: var(--c-fg-soft);
	font-family: var(--ff-ui);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	text-decoration: none;
	line-height: 1.4;
}
.buskery-discipline:hover { background: var(--c-surface-2); color: var(--c-fg); }

/* Disciplines container — pin to bottom of card, consistent padding + gap */
.artist-card .buskery-disciplines {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	padding: 0.25rem 1rem 0;
	margin-top: auto;
}

/* Single artist */
.artist-single .artist-header {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
	margin-bottom: 1.5rem;
}
@media (min-width: 40rem) {
	.artist-single .artist-header { grid-template-columns: 18rem 1fr; }
}
.artist-portrait img { border-radius: var(--radius); }
.artist-name {
	margin-top: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6rem;
}
.artist-name .buskery-disciplines {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.3rem;
}
.artist-name .buskery-discipline {
	font-size: 0.7rem;
	position: relative;
	top: -0.15em;
}
.artist-tagline { font-size: 1.15rem; color: var(--c-muted); margin: 0.25rem 0; }
.artist-realname {
	font-family: var(--ff-text);
	font-style: italic;
	font-size: 1rem;
	color: var(--c-fg-soft);
	margin: 0.1rem 0 0.25rem;
}
.artist-quickfacts { color: var(--c-muted); font-family: var(--ff-ui); font-size: 0.95rem; margin: 0.25rem 0 0.75rem; }
.artist-website {
	margin: 0.5rem 0 0;
	font-family: var(--ff-ui);
	font-size: 0.95rem;
}
.artist-website a {
	color: var(--c-fg);
	text-decoration: none;
	border-bottom: 1px solid var(--c-rule-2);
	padding-bottom: 1px;
}
.artist-website a:hover {
	color: var(--c-link-hover);
	border-bottom-color: var(--c-fg-soft);
}
.artist-website span { color: var(--c-muted); margin-left: 0.25rem; }

.artist-bio, .artist-tips, .artist-case, .artist-gallery-section, .artist-links {
	margin: 2rem 0;
}
.artist-tips, .artist-case {
	padding: 1.25rem;
	background: var(--c-surface);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
}

/* Linktree-style button grids: tips + external links share the same shape. */
.tip-grid, .link-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.625rem;
	margin: 0.75rem 0 0;
}
@media (min-width: 36rem) {
	.tip-grid, .link-grid {
		grid-template-columns: 1fr 1fr;
	}
}

.tip-button, .link-button {
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
	padding: 0.85rem 1rem;
	background: var(--c-surface);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	color: var(--c-fg);
	text-decoration: none;
	font-family: var(--ff-ui);
	transition: background 120ms ease, border-color 120ms ease, transform 120ms ease;
}
.tip-button:hover, .link-button:hover {
	background: var(--c-surface-2);
	border-color: var(--c-rule-2);
	color: var(--c-link-hover);
}

.tip-button-platform, .link-button-platform {
	font-size: 1rem;
	font-weight: 600;
	color: var(--c-fg);
}
.tip-button-detail, .link-button-detail {
	font-size: 0.85rem;
	color: var(--c-muted);
	font-family: var(--ff-ui);
	word-break: break-word;
}
.tip-button:hover .tip-button-detail,
.link-button:hover .link-button-detail { color: var(--c-fg-soft); }
.tip-button-note { font-size: 0.8rem; color: var(--c-muted); margin-top: 0.25rem; }

/* Static tip entries (Zelle, mailing address, custom) — non-clickable but visually consistent */
.tip-button-static {
	border-style: dashed;
	cursor: default;
}
.tip-button-static:hover {
	background: var(--c-surface);
	border-color: var(--c-rule);
	color: var(--c-fg);
}
.tip-button-static .tip-button-detail { white-space: pre-line; }

/* Gallery */
.buskery-gallery {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
}
.buskery-gallery figure { margin: 0; }
.buskery-gallery img { border-radius: var(--radius); }

/* Pagination + search */
.archive-pagination { margin-top: 2rem; font-family: var(--ff-ui); }
.archive-pagination .nav-links { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.search-form { display: flex; gap: 0.5rem; }
.search-form input[type="search"] {
	flex: 1; padding: 0.5rem 0.75rem;
	background: var(--c-surface);
	color: var(--c-fg);
	border: 1px solid var(--c-rule); border-radius: var(--radius);
	font: inherit;
}
.search-form input[type="search"]::placeholder { color: var(--c-muted); }
.search-form input[type="search"]:focus { outline: none; border-color: var(--c-rule-2); }
.search-form button {
	padding: 0.5rem 1rem; border: 0;
	background: var(--c-accent); color: var(--c-accent-fg);
	border-radius: var(--radius);
	font-family: var(--ff-ui); cursor: pointer;
}
.search-form button:hover { background: #fff; }

/* Voting / nomination section */
.vote-section {
	margin: 1.5rem 0;
	padding: 1.25rem;
	background: var(--c-surface);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
}
.vote-grid {
	display: grid;
	gap: 0.5rem;
	grid-template-columns: 1fr;
	margin: 0.75rem 0 0;
}
@media (min-width: 36rem) {
	.vote-grid { grid-template-columns: 1fr 1fr; }
}
.vote-button-form {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.vote-button {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.7rem 1rem;
	background: var(--c-surface-2);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	color: var(--c-fg);
	text-decoration: none;
	font-family: var(--ff-ui);
	font-size: 0.95rem;
	cursor: pointer;
	width: 100%;
	text-align: left;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.vote-button:hover { background: var(--c-bg); border-color: var(--c-rule-2); }
.vote-button-on {
	background: rgba(245,166,166,0.08);
	border-color: rgba(245,166,166,0.45);
	color: var(--c-fg);
}
.vote-button-on:hover { background: rgba(245,166,166,0.14); }
.vote-button-disabled {
	cursor: not-allowed;
	opacity: 0.6;
}
.vote-heart {
	font-size: 1.2rem;
	line-height: 1;
}
.vote-button-on .vote-heart { color: #f5a6a6; }
.vote-label { flex: 1; }
.vote-count { color: var(--c-muted); font-variant-numeric: tabular-nums; }
.vote-button-on .vote-count { color: var(--c-fg-soft); }
.vote-private {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--c-muted);
	font-size: 0.8rem;
	cursor: pointer;
	padding-left: 0.25rem;
}
.vote-private input { margin: 0; }

/* Recent supporters row */
.vote-supporters { margin-top: 1rem; display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.vote-supporters ul { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: -0.25rem; }
.vote-supporters li {
	width: 28px; height: 28px;
	border-radius: 50%;
	overflow: hidden;
	border: 2px solid var(--c-surface);
	margin-left: -8px;
}
.vote-supporters li:first-child { margin-left: 0; }
.vote-supporters img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Share intent after voting */
.vote-share {
	display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap;
	margin: 0.75rem 0 1.5rem;
	padding: 0.75rem 1rem;
	background: var(--c-surface);
	border: 1px dashed var(--c-rule-2);
	border-radius: var(--radius);
}

/* Leaderboard on /discipline/{slug}/ */
.leaderboard-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	margin: 0 0 1rem;
	border-bottom: 1px solid var(--c-rule);
	font-family: var(--ff-ui);
}
.leaderboard-tab {
	padding: 0.5rem 0.875rem;
	color: var(--c-muted);
	text-decoration: none;
	font-size: 0.9rem;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color 120ms ease, border-color 120ms ease;
}
.leaderboard-tab:hover { color: var(--c-fg); }
.leaderboard-tab.is-current {
	color: var(--c-fg);
	border-bottom-color: var(--c-fg);
}

.leaderboard {
	list-style: none;
	margin: 0 0 2.5rem;
	padding: 0;
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	background: var(--c-surface);
	overflow: hidden;
}
.leaderboard-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.6rem 1rem;
	border-bottom: 1px solid var(--c-rule);
}
.leaderboard-row:last-child { border-bottom: 0; }
.leaderboard-rank {
	font-family: var(--ff-ui);
	color: var(--c-muted);
	font-size: 0.85rem;
	font-variant-numeric: tabular-nums;
	min-width: 2.5rem;
}
.leaderboard-link {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	flex: 1;
	color: var(--c-fg);
	text-decoration: none;
}
.leaderboard-link:hover { color: var(--c-link-hover); }
.leaderboard-thumb {
	display: block;
	width: 32px; height: 32px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
}
.leaderboard-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.leaderboard-name { font-weight: 500; }
.leaderboard-count {
	color: var(--c-fg-soft);
	font-family: var(--ff-ui);
	font-size: 0.9rem;
	font-variant-numeric: tabular-nums;
}
.leaderboard-heart { color: #f5a6a6; margin-right: 0.2rem; }
.leaderboard-empty { margin: 0.5rem 0 2rem; }
.archive-recency h2 { margin-top: 2rem; }

/* Vote count on artist cards */
.artist-card-votes {
	margin: 0 1rem 0.75rem;
	font-size: 0.85rem;
	color: var(--c-muted);
	font-family: var(--ff-ui);
	font-variant-numeric: tabular-nums;
}
.artist-card-votes span { color: #f5a6a6; }

/* Nomination form checkbox group */
.form-checkbox-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem 0.75rem;
	padding: 0.5rem 0;
}
.form-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.9rem;
	color: var(--c-fg-soft);
	cursor: pointer;
}

/* Claim CTA on artist profiles */
.claim-cta {
	margin: 1.5rem 0;
	padding: 1rem 1.25rem;
	background: var(--c-surface);
	border: 1px dashed var(--c-rule-2);
	border-radius: var(--radius);
}
.claim-cta p { margin: 0.25rem 0; }
.claim-cta details summary {
	cursor: pointer;
	list-style: none;
	font-family: var(--ff-ui);
}
.claim-cta details summary::-webkit-details-marker { display: none; }
.claim-cta details[open] summary { margin-bottom: 1rem; }
.claim-cta .claim-form { margin-top: 0.5rem; }
.claim-cta .form-fineprint { font-size: 0.85rem; }

/* Pages */
.page-content { max-width: var(--measure); }

/* Register page state panel */
.register-state {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	max-width: var(--measure);
	margin: 1.5rem 0;
	padding: 1.25rem;
	background: var(--c-surface);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
}
.register-state-out { align-items: flex-start; }

/* Forms (account, signup, etc.) */
.account-form, .buskery-form {
	max-width: 36rem;
	font-family: var(--ff-ui);
}
.dashboard-form { max-width: 42rem; }
.dashboard-header { margin-bottom: 1rem; }
.dashboard-actions { margin-top: 1.5rem; }
.dashboard-actions .btn { margin-right: 0.5rem; }
.form-row textarea { min-height: 4rem; }
.account-form fieldset, .buskery-form fieldset {
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	padding: 1rem 1.25rem 0.5rem;
	margin: 0 0 1.25rem;
	background: var(--c-surface);
}
.account-form legend, .buskery-form legend {
	padding: 0 0.4rem;
	font-size: 0.85rem;
	color: var(--c-muted);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.form-row {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	margin: 0 0 1rem;
}
.form-row label {
	font-size: 0.85rem;
	color: var(--c-fg-soft);
}
.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="password"],
.form-row input[type="url"],
.form-row textarea,
.form-row select {
	background: var(--c-bg);
	color: var(--c-fg);
	border: 1px solid var(--c-rule);
	border-radius: var(--radius);
	padding: 0.5rem 0.75rem;
	font: inherit;
	font-size: 1rem;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
	outline: none;
	border-color: var(--c-rule-2);
}
.form-row .form-static {
	color: var(--c-fg-soft);
	font-family: var(--ff-text);
}
.form-row-static small { display: block; font-size: 0.8rem; }
.form-actions { margin-top: 1rem; }
.form-flash {
	padding: 0.625rem 0.875rem;
	border-radius: var(--radius);
	margin: 0 0 1rem;
	font-size: 0.9rem;
	border: 1px solid transparent;
}
.form-flash-ok {
	background: rgba(255,255,255,0.04);
	border-color: var(--c-rule-2);
	color: var(--c-fg);
}
.form-flash-err {
	background: rgba(255,80,80,0.08);
	border-color: rgba(255,80,80,0.4);
	color: #ffb0b0;
}

/* Not found */
.not-found h1 { font-size: 3rem; }
