/* CSS custom properties */
:root {
	--color-bg: #f0eeeb;
	--color-bg-gradient: linear-gradient(145deg, #f0eeeb 0%, #e6e2dd 100%);
	--color-surface: #fff;
	--color-nav: #1e1e1e;
	--color-nav-text: #888;
	--color-nav-text-active: #f0f0f0;
	--color-text: #1a1a1a;
	--color-text-muted: #777;
	--color-link: #001329;
	--color-link-hover: #225942;
	--color-border: rgba(0, 0, 0, 0.08);
	--color-post-border: #eee;
	--color-accent: #225942;
	--color-new: #e03030;
	--shadow-card: 0 2px 20px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.04);
	--radius-card: 14px;
	--radius-small: 6px;
	--font-stack: -apple-system, system-ui, sans-serif;
	--font-mono: ui-monospace, "Cascadia Code", "Fira Code", monospace;
}

@media (prefers-color-scheme: dark) {
	:root {
		color-scheme: dark;
		--color-bg: #141210;
		--color-bg-gradient: #141210;
		--color-surface: #1c1916;
		--color-nav: #151210;
		--color-nav-text: #6a5f50;
		--color-nav-text-active: #d4a853;
		--color-text: #e8dcc8;
		--color-text-muted: #8a7e6e;
		--color-link: #d4a853;
		--color-link-hover: #e8c070;
		--color-border: #302a22;
		--color-post-border: #2a2420;
		--color-accent: #d4a853;
		--color-new: #d4a853;
		--shadow-card: 0 4px 24px rgba(0, 0, 0, 0.4), 0 0 0 1px #302a22;
	}
}

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

html {
	scrollbar-gutter: stable;
	scrollbar-color: var(--color-post-border) transparent;
	scrollbar-width: thin;
}

body {
	margin: 0;
	font-family: var(--font-stack);
	background: var(--color-bg-gradient);
	color: var(--color-text);
	padding: 0;
}

/* Layout */
#wrapper {
	max-width: 42em;
	margin: 0 auto;
	background: var(--color-surface);
}

main {
	padding: 1.5em;
}

/* Nav */
nav {
	background: var(--color-nav);
}

nav ul {
	list-style: none;
	margin: 0;
	padding: 0.75em 1em;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25em;
}

nav li {
	display: block;
}

nav a,
nav a:visited {
	color: var(--color-nav-text);
	text-decoration: none;
	padding: 0.35em 0.6em;
	border-radius: var(--radius-small);
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 0.75rem;
}

nav a:hover,
nav button:hover {
	color: var(--color-nav-text-active);
}

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

nav form {
	display: contents;
}

nav button {
	all: unset;
	color: var(--color-nav-text);
	cursor: pointer;
	padding: 0.35em 0.6em;
	border-radius: var(--radius-small);
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 0.75rem;
	font-family: var(--font-stack);
}

.icon {
	display: inline-block;
	width: 1em;
	height: 1em;
	background: currentColor;
	mask: var(--icon) center / contain no-repeat;
	-webkit-mask: var(--icon) center / contain no-repeat;
}

.icon-arrow-left {
	--icon: url("../vendor/lucide/arrow-left.76acdfafa973.svg");
}

.icon-calendar-days {
	--icon: url("../vendor/lucide/calendar-days.32065998d7e0.svg");
}

.icon-check-circle {
	--icon: url("../vendor/lucide/check-circle.4b83e1954ddb.svg");
}

.icon-circle-x {
	--icon: url("../vendor/lucide/circle-x.0712fc0d822a.svg");
}

.icon-file-text {
	--icon: url("../vendor/lucide/file-text.c42a3ba3b75d.svg");
}

.icon-key-round {
	--icon: url("../vendor/lucide/key-round.e97be1d2e304.svg");
}

.icon-log-in {
	--icon: url("../vendor/lucide/log-in.24b453d6e352.svg");
}

.icon-log-out {
	--icon: url("../vendor/lucide/log-out.e359d736d093.svg");
}

.icon-map-pin {
	--icon: url("../vendor/lucide/map-pin.9d6bd793e5f6.svg");
}

.icon-pencil {
	--icon: url("../vendor/lucide/pencil.2a5e6f70fd2d.svg");
}

.icon-reply {
	--icon: url("../vendor/lucide/reply.45bc64271c15.svg");
}

.icon-rotate-ccw {
	--icon: url("../vendor/lucide/rotate-ccw.b93ebf0a0659.svg");
}

.icon-smile {
	--icon: url("../vendor/lucide/smile.4e14808d88bf.svg");
}

.icon-smile-plus {
	--icon: url("../vendor/lucide/smile-plus.4bb97d0f8c42.svg");
}

.icon-trash-2 {
	--icon: url("../vendor/lucide/trash-2.e7f85b7fbd55.svg");
}

.icon-user-round {
	--icon: url("../vendor/lucide/user-round.673bbc411a00.svg");
}

.icon-users {
	--icon: url("../vendor/lucide/users.0a3766bad1cb.svg");
}

nav a.nav-auth-control,
nav a.nav-auth-control:visited,
nav button.nav-auth-control {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 1.4rem;
	padding: 0;
	vertical-align: top;
}

.nav-auth-icon {
	width: 1rem;
	height: 1rem;
}

/* Footer */
footer {
	background: var(--color-nav);
	color: var(--color-nav-text);
	text-align: center;
	padding: 1.5em 0;
}

/* Links */
a,
a:visited {
	color: var(--color-link);
}

a:hover {
	color: var(--color-link-hover);
}

/* Focus */
:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
	letter-spacing: -0.3px;
}

/* Forms */
input,
select,
textarea,
button {
	font: inherit;
	border-radius: var(--radius-small);
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="search"],
input[type="url"],
input[type="number"],
input[type="date"],
select,
textarea {
	display: block;
	width: 100%;
	padding: 0.5em 0.65em;
	border: 1px solid var(--color-post-border);
	background: var(--color-surface);
	color: var(--color-text);
}

input[type="text"]:focus-visible,
input[type="password"]:focus-visible,
input[type="email"]:focus-visible,
input[type="search"]:focus-visible,
input[type="url"]:focus-visible,
input[type="number"]:focus-visible,
input[type="date"]:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: -1px;
	border-color: var(--color-accent);
}

textarea {
	width: 100%;
	field-sizing: content;
	min-height: 3em;
	max-height: 16em;
	resize: vertical;
}

label {
	display: block;
	font-size: 0.9em;
	font-weight: 500;
	margin-top: 0.75em;
	margin-bottom: 0.25em;
}

form > .btn {
	margin-top: 0.75em;
}

.errorlist {
	margin: 0.25em 0;
	padding: 0;
	list-style: none;
	color: var(--color-new);
	font-size: 0.9em;
}

.form-help {
	margin-top: 0.25em;
	color: var(--color-text-muted);
	font-size: 0.85em;
}

.form-help ul {
	margin: 0;
	padding-left: 1.2em;
}

/* Button */
.btn {
	display: inline-block;
	padding: 0.45em 0.85em;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-small);
	text-decoration: none;
	color: var(--color-link);
	background: transparent;
	cursor: pointer;
	min-height: 2.25em;
}

.btn:hover {
	border-color: var(--color-link-hover);
	color: var(--color-link-hover);
}

/* Flash messages */
.flash {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75em 1em;
	margin: 0.5em 1em;
	border-radius: var(--radius-small);
	border: 1px solid var(--color-border);
	background: var(--color-surface);
}

.flash-success {
	background: #1b3d2a;
	color: #a8d5b5;
	border-color: #2d6644;
}

.flash-error {
	background: #3d1b1b;
	color: #d5a8a8;
	border-color: #662d2d;
}

.flash-warning {
	background: #3d3419;
	color: #d5caa8;
	border-color: #66582d;
}

.flash-info {
	background: #193d3d;
	color: #a8d5d5;
	border-color: #2d6666;
}

.flash-close {
	background: none;
	border: none;
	cursor: pointer;
	font-size: 1.25em;
	line-height: 1;
	padding: 0 0.25em;
	color: inherit;
	opacity: 0.6;
}

.flash-close:hover {
	opacity: 1;
}

/* Online users */
.online-users {
	text-align: right;
	padding: 0.5em 1em;
	font-size: 0.85em;
	color: var(--color-text-muted);
}

/* Profile */
.profile-card {
	display: flex;
	align-items: center;
	gap: 1.25em;
	flex-wrap: wrap;
	margin-bottom: 1em;
	padding: 1.25em;
	border: 1px solid var(--color-post-border);
	border-radius: var(--radius-card);
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-accent));
}

.profile-card h1 {
	margin: 0;
	font-size: 1.6em;
}

.profile-avatar {
	width: 6em;
	height: 6em;
	border-radius: var(--radius-card);
	object-fit: cover;
	flex-shrink: 0;
}

.profile-meta {
	margin: 0.25em 0 0;
	color: var(--color-text-muted);
	font-size: 0.92em;
}

.profile-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1em;
	align-items: start;
}

@media (max-width: 600px) {
	.profile-grid {
		grid-template-columns: 1fr;
	}
}

.profile-panel {
	padding: 1em 1.25em 1.25em;
	border: 1px solid var(--color-post-border);
	border-radius: var(--radius-card);
}

.profile-panel h2 {
	margin: 0;
	font-size: 1.05em;
}

.profile-panel input[type="file"] {
	display: block;
	width: 100%;
	font-size: 0.9em;
}

.profile-actions {
	display: flex;
	gap: 0.5em;
	flex-wrap: wrap;
	margin-top: 1em;
}

/* display: contents lifts the buttons out of their form wrappers so
   both actions are flex items and render at the same height. */
.profile-actions form {
	display: contents;
}

.profile-actions .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin: 0;
}

/* Guestbook */
.post {
	display: flex;
	gap: 0.65em;
	padding: 0.75em 0;
	border-bottom: 1px solid var(--color-post-border);
}

.post:last-child {
	border-bottom: none;
}

.avatar {
	width: 2.25em;
	height: 2.25em;
	border-radius: var(--radius-small);
	flex-shrink: 0;
}

.post-content {
	flex: 1;
	min-width: 0;
}

.post-header {
	display: flex;
	align-items: baseline;
	gap: 0.4em;
	flex-wrap: wrap;
	margin-bottom: 0.2em;
}

.post-author {
	font-weight: 600;
	font-size: 0.85em;
}

.post-time {
	font-size: 0.75em;
	color: var(--color-text-muted);
}

.post-actions {
	margin-left: auto;
	opacity: 0;
	transition: opacity 0.15s;
}

.post:hover .post-actions {
	opacity: 1;
}

.post-actions a,
.post-actions .reaction-add {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75em;
	height: 1.75em;
	border-radius: var(--radius-small);
	font-size: 1em;
	line-height: 1;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: background-color 0.15s;
}

.post-actions a:hover,
.post-actions .reaction-add:hover {
	background-color: var(--color-border);
	color: var(--color-link);
}

.post-actions .reaction-add-active:hover {
	background-color: transparent;
}

.post-body {
	font-size: 0.9em;
	color: var(--color-text-muted);
	line-height: 1.5;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.post-body p {
	margin: 0.25em 0;
}

.post-body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-small);
}

.post-edited {
	font-size: 0.75em;
	color: var(--color-text-muted);
	font-style: italic;
	margin-top: 0.25em;
}

.post-form-actions {
	display: flex;
	gap: 0.5em;
	margin-top: 0.5em;
}

.post-confirm-delete {
	opacity: 0.7;
}

.btn-danger {
	color: #c44;
	border-color: #c44;
}

.btn-danger:hover {
	color: #e55;
	border-color: #e55;
}

.post-actions > * + * {
	margin-left: 0.1em;
}

/* Events */
.event-index-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1em;
	flex-wrap: wrap;
	margin-bottom: 1.25em;
}

.event-index-header h1 {
	margin: 0;
}

.event-new-link {
	margin-top: 0;
}

#event-list {
	display: grid;
	gap: 0.65em;
}

.event {
	border: 1px solid var(--color-post-border);
	border-radius: var(--radius-small);
	background: color-mix(in srgb, var(--color-surface) 94%, var(--color-accent));
	overflow: hidden;
}

.event-list-link {
	display: grid;
	grid-template-columns: 4.7em minmax(0, 1fr);
	gap: 0.85em;
	align-items: center;
	padding: 0.8em;
	color: var(--color-text);
	text-decoration: none;
}

.event-list-link:visited {
	color: var(--color-text);
}

.event-list-link:hover {
	color: var(--color-text);
	background: color-mix(in srgb, var(--color-surface) 88%, var(--color-accent));
}

.event-date-badge {
	display: grid;
	place-items: center;
	align-content: center;
	min-height: 4.7em;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-small);
	background: var(--color-surface);
	line-height: 1.1;
	text-align: center;
}

.event-date-day {
	font-size: 1.55em;
	font-weight: 700;
	color: var(--color-text);
}

.event-date-month,
.event-date-year {
	color: var(--color-text-muted);
	font-size: 0.75em;
	text-transform: uppercase;
}

.event-list-main {
	min-width: 0;
}

.event-title-row {
	display: flex;
	align-items: center;
	gap: 0.5em;
	flex-wrap: wrap;
}

.event-list-title {
	margin: 0;
	font-size: 1.08em;
	line-height: 1.25;
}

.event-list-meta {
	display: block;
	margin-top: 0.25em;
	color: var(--color-text-muted);
	font-size: 0.92em;
}

.event-past {
	opacity: 0.68;
}

.event-status {
	display: inline-block;
	padding: 0.1em 0.45em;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-small);
	color: var(--color-text-muted);
	font-size: 0.75em;
	font-weight: 600;
}

.event-discussion-hint,
.post-new,
.comment-new {
	display: inline-block;
	padding: 0.1em 0.45em;
	border: 1px solid color-mix(in srgb, var(--color-new) 55%, var(--color-border));
	border-radius: var(--radius-small);
	color: var(--color-new);
	font-size: 0.75em;
	font-weight: 700;
}

.event-empty {
	color: var(--color-text-muted);
}

.event-detail-header {
	padding-bottom: 1.25em;
	border-bottom: 1px solid var(--color-post-border);
}

.event-back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	margin-bottom: 0.8em;
	color: var(--color-text-muted);
	font-size: 0.85em;
	text-decoration: none;
}

.event-back-link:hover {
	color: var(--color-link-hover);
}

.event-detail-title-row {
	display: flex;
	align-items: center;
	gap: 0.65em;
	flex-wrap: wrap;
}

.event-detail-title-row h1 {
	margin: 0;
}

.event-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75em;
	margin: 1.1em 0 0;
}

.event-meta-grid div {
	padding: 0.65em 0.75em;
	border-left: 3px solid var(--color-accent);
	background: color-mix(in srgb, var(--color-surface) 92%, var(--color-accent));
	border-radius: var(--radius-small);
}

.event-meta-grid dt {
	display: flex;
	align-items: center;
	gap: 0.4em;
	color: var(--color-text-muted);
	font-size: 0.72em;
	font-weight: 700;
	text-transform: uppercase;
}

.event-meta-icon {
	color: var(--color-accent);
	font-size: 1.05em;
}

.event-meta-grid dd {
	margin: 0.15em 0 0;
	font-weight: 600;
}

.event-actions {
	display: flex;
	align-items: center;
	gap: 0.5em;
	flex-wrap: wrap;
	margin-top: 1em;
}

.event-actions form {
	display: contents;
}

.event-actions .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin-top: 0;
}

.event-detail-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(14em, 0.52fr);
	gap: 1.5em;
	align-items: start;
	margin-top: 1.25em;
}

.event-panel {
	padding: 0;
}

.event-panel h2 {
	margin: 0 0 0.65em;
	font-size: 1em;
}

.event-panel-title {
	display: flex;
	align-items: center;
	gap: 0.45em;
}

.event-panel-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.75em;
	margin-bottom: 0.75em;
}

.event-panel-header h2 {
	margin: 0;
}

.event-count {
	display: inline-grid;
	place-items: center;
	min-width: 1.9em;
	min-height: 1.9em;
	border-radius: 999px;
	background: var(--color-accent);
	color: var(--color-surface);
	font-size: 0.82em;
	font-weight: 700;
}

.event-description {
	color: var(--color-text-muted);
	line-height: 1.55;
}

.event-description p {
	margin: 0.35em 0;
}

#event-attendance {
	margin-top: 0;
	padding-left: 1.25em;
	border-left: 1px solid var(--color-post-border);
}

.event-rsvp-form {
	margin-bottom: 0.8em;
}

.event-rsvp-form-secondary {
	margin: 0.75em 0 0;
}

.event-rsvp-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45em;
	width: 100%;
}

.event-rsvp-secondary {
	appearance: none;
	-webkit-appearance: none;
	background: transparent;
	border: none;
	padding: 0;
	color: var(--color-text-muted);
	cursor: pointer;
	font: inherit;
	font-size: 0.85em;
}

.event-rsvp-secondary:hover {
	color: var(--color-link-hover);
	text-decoration: underline;
}

.event-attendee-list {
	display: grid;
	gap: 0.45em;
	margin: 0;
	padding: 0;
	list-style: none;
}

.event-attendee-list li {
	display: flex;
	align-items: center;
	gap: 0.55em;
}

.event-attendee-avatar {
	display: inline-grid;
	place-items: center;
	width: 2em;
	height: 2em;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 80%, var(--color-accent));
	color: var(--color-text);
	font-size: 0.8em;
	font-weight: 700;
}

.event-form-page {
	max-width: 34em;
}

.event-form-page h1 {
	margin-top: 0;
}

.event-form {
	display: grid;
	gap: 0.85em;
}

.event-form-field label {
	margin-top: 0;
}

.event-form-field .errorlist {
	margin: 0.35em 0 0;
	padding-left: 1.2em;
	color: var(--color-new);
}

.event-form-actions {
	display: flex;
	align-items: center;
	gap: 0.75em;
	flex-wrap: wrap;
	margin-top: 0.25em;
}

.event-form-actions .btn {
	margin-top: 0;
}

/* Comments */
.comments-thread {
	display: grid;
	gap: 1em;
}

.comment-form textarea,
.comment-reply-form textarea {
	min-height: 5em;
}

.comment-reply-form textarea {
	min-height: 4em;
}

.comment-list,
.comment-replies {
	display: grid;
	gap: 0.75em;
	margin: 0;
	padding: 0;
	list-style: none;
}

.comment-list:empty {
	display: none;
}

.comment {
	padding-top: 0.85em;
	border-top: 1px solid color-mix(in srgb, var(--color-post-border) 72%, transparent);
}

.comment-reply {
	margin-left: 1.5em;
	padding-left: 0.75em;
	border-left: 2px solid color-mix(in srgb, var(--color-post-border) 72%, transparent);
}

.comment-body {
	display: grid;
	gap: 0.35em;
}

.comment-header {
	display: flex;
	align-items: baseline;
	gap: 0.5em;
	flex-wrap: wrap;
}

.comment-author {
	font-weight: 600;
	font-size: 0.9em;
}

.comment-time {
	color: var(--color-text-muted);
	font-size: 0.78em;
}

.comment-actions {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	margin-left: auto;
}

.comment-actions a,
.comment-actions .reaction-add,
.comment-reply-toggle {
	appearance: none;
	-webkit-appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.25em;
	border: none;
	background: transparent;
	color: var(--color-text-muted);
	cursor: pointer;
	font: inherit;
	font-size: 0.85em;
	padding: 0.15em 0.25em;
	text-decoration: none;
}

.comment-actions a:hover,
.comment-actions .reaction-add:hover,
.comment-reply-toggle:hover {
	color: var(--color-link-hover);
}

.comment-content {
	color: var(--color-text-muted);
	font-size: 0.92em;
	line-height: 1.5;
	overflow-wrap: break-word;
}

.comment-content p {
	margin: 0.25em 0;
}

.comment-edited {
	color: var(--color-text-muted);
	font-size: 0.82em;
	font-style: italic;
}

.comment-replies,
.comment-reply-form {
	margin-top: 0.65em;
}

.event-comments-panel {
	margin-top: 1.5em;
	padding-top: 1.25em;
	border-top: 1px solid var(--color-post-border);
}

/* Form toolbar */
.form-toolbar {
	display: flex;
	align-items: center;
	gap: 0.5em;
	margin-top: 0.75em;
}

.form-toolbar .btn {
	margin-top: 0;
}

.emoji-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	line-height: 1;
	min-width: 2.25em;
}

/* Emoji picker */
.emoji-picker-container {
	margin-top: 0.5em;
}

.emoji-picker-container emoji-picker {
	--border-color: var(--color-post-border);
	--background: var(--color-surface);
	--input-border-color: var(--color-post-border);
	--category-font-color: var(--color-text-muted);
	width: 100%;
	max-width: 22em;
}

/* Reactions */
.reaction-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em;
	margin: 0.5em 0 0;
	padding: 0;
	list-style: none;
}

.reaction-list:empty {
	display: none;
}

.reaction-group {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	padding: 0.15em 0.55em;
	border: 1px solid var(--color-post-border);
	border-radius: 999px;
	background: var(--color-surface);
	font-size: 0.85em;
	line-height: 1.4;
}

.reaction-emoji {
	font-size: 1.1em;
	line-height: 1;
}

.reaction-user {
	color: var(--color-text-muted);
}

.reaction-user-own {
	appearance: none;
	-webkit-appearance: none;
	background: none;
	border: none;
	padding: 0;
	font: inherit;
	color: var(--color-link);
	cursor: pointer;
}

.reaction-user-own:hover {
	color: var(--color-link-hover);
	text-decoration: line-through;
}

.post-actions .reaction-add {
	appearance: none;
	-webkit-appearance: none;
	background: transparent;
	border: none;
	padding: 0;
	font: inherit;
	cursor: pointer;
}

.reaction-popover {
	position: absolute;
	z-index: 20;
}

.reaction-popover.hidden {
	display: none;
}

.reaction-popover emoji-picker {
	--border-color: var(--color-post-border);
	--background: var(--color-surface);
	--input-border-color: var(--color-post-border);
	--category-font-color: var(--color-text-muted);
}

/* Pagination */
.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.5em;
	padding: 1em 0;
}

.pagination a,
.pagination a:visited {
	color: var(--color-text-muted);
	text-decoration: none;
	padding: 0.35em 0.5em;
	font-size: 0.9em;
}

.pagination a:hover {
	color: var(--color-link);
}

.pagination .current {
	color: var(--color-text-muted);
	font-size: 0.9em;
}

/* Members table */
.members-table {
	width: 100%;
	border-collapse: collapse;
}

.members-table th,
.members-table td {
	padding: 0.5em 0.75em;
	text-align: left;
}

.members-table tbody tr:nth-child(even) {
	background: rgba(128, 128, 128, 0.06);
}

/* Movie cards */
.movie {
	border-bottom: 1px solid var(--color-border);
	padding: 1em 0;
	overflow: hidden;
}

.movie-poster {
	float: left;
	width: 200px;
	height: auto;
	margin: 0 1em 0.5em 0;
}

/* Anthem */
.anthem-cover {
	float: left;
	margin: 0 1em 1em 0;
}

.anthem-credits {
	margin-bottom: 1em;
}

.anthem-lyrics {
	clear: both;
}

/* Archive */
.archive-entry {
	margin-bottom: 2em;
}

.archive-entry img {
	max-width: 100%;
	height: auto;
}

/* Embed container: responsive 16:9 */
.embed-container {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	margin: 0 0.5em;
}

.embed-container iframe,
.embed-container object,
.embed-container embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* Help table */
.help-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-mono);
	font-size: 0.85em;
}

.help-table th,
.help-table td {
	padding: 0.5em 0.75em;
	text-align: left;
	border-bottom: 1px solid var(--color-border);
}

/* htmx transitions */
.post.htmx-added {
	animation: fade-in 0.3s ease-out;
}

.post.htmx-swapping {
	opacity: 0;
	transition: opacity 0.15s ease-out;
}

.htmx-request .btn[type="submit"] {
	opacity: 0.5;
	pointer-events: none;
}

@keyframes fade-in {
	from { opacity: 0; transform: translateY(-0.5em); }
	to { opacity: 1; transform: translateY(0); }
}

/* Utility */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.hidden {
	display: none;
}

/* Mobile */
@media (max-width: 767px) {
	nav ul {
		padding: 0.5em;
		gap: 0.15em;
		justify-content: center;
	}

	nav a,
	nav a:visited,
	nav button {
		padding: 0.5em 0.5em;
		font-size: 0.7rem;
	}

	main {
		padding: 1em;
	}

	/* Post actions always visible on touch devices */
	.post-actions {
		opacity: 1;
	}

	.post-actions a {
		padding: 0.25em 0;
	}

	/* Movie posters stack on mobile */
	.movie-poster {
		float: none;
		width: 100%;
		max-width: 300px;
		margin: 0 0 0.75em;
	}

	/* Anthem cover */
	.anthem-cover {
		float: none;
		display: block;
		margin: 0 0 1em;
	}

	/* Members table scroll */
	.members-table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	/* Embed container full width */
	.embed-container {
		margin: 0;
	}

	.event-index-header {
		align-items: stretch;
	}

	.event-index-header .btn {
		text-align: center;
	}

	.event-list-link {
		grid-template-columns: 4.2em minmax(0, 1fr);
		gap: 0.7em;
		padding: 0.7em;
	}

	.event-date-badge {
		min-height: 4.2em;
	}

	.event-meta-grid,
	.event-detail-layout {
		grid-template-columns: 1fr;
	}

	#event-attendance {
		padding-left: 0;
		padding-top: 1em;
		border-left: 0;
		border-top: 1px solid var(--color-post-border);
	}
}

/* Desktop */
@media (min-width: 768px) {
	body {
		padding: 2em;
		background: var(--color-bg-gradient);
	}

	#wrapper {
		box-shadow: var(--shadow-card);
		border-radius: var(--radius-card);
	}

	nav {
		border-radius: var(--radius-card) var(--radius-card) 0 0;
	}

	footer {
		border-radius: 0 0 var(--radius-card) var(--radius-card);
	}

	.avatar {
		width: 2.5em;
		height: 2.5em;
	}
}
