/* 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;
	--font-display: "Fraunces", Georgia, "Times New Roman", serif;
}

@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;
	}
}

/* Fraunces — characterful display serif, self-hosted. Used for the
   Händelser agenda headings and date numerals via --font-display. */
@font-face {
	font-family: "Fraunces";
	font-style: normal;
	font-weight: 400 700;
	font-display: swap;
	src: url("../font/fraunces-latin.5d2835174326.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
		U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
		U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: "Fraunces";
	font-style: normal;
	font-weight: 400 700;
	font-display: swap;
	src: url("../font/fraunces-latin-ext.3592119408ee.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7,
		U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F,
		U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F,
		U+A720-A7FF;
}

/* 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: "Twemoji Country Flags", 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-send {
	--icon: url("../vendor/lucide/send.3a29252f3513.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;
}

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

/* Danger button (delete confirmations) */
.btn-danger {
	color: #c44;
	border-color: #c44;
}

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

/* Events */
/* Händelser — agenda / happenings timeline */
.agenda-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1em;
	flex-wrap: wrap;
	margin-bottom: 1.6em;
}

.agenda-kicker {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: 0.4em;
}

.agenda-title {
	margin: 0;
	font-family: var(--font-display);
	font-optical-sizing: auto;
	font-weight: 600;
	font-size: clamp(2.4rem, 9vw, 3.4rem);
	line-height: 0.92;
	letter-spacing: -0.015em;
}

.agenda-new {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin: 0;
	white-space: nowrap;
}

.agenda-new-plus {
	font-size: 1.2em;
	line-height: 1;
}

@keyframes agenda-rise {
	from {
		opacity: 0;
		translate: 0 0.6em;
	}
	to {
		opacity: 1;
		translate: 0 0;
	}
}

/* Hero — the next happening */
/* Shared by the index hero (.agenda-hero, a link) and the detail header
   (.event-hero, static); see the .event-hero notes further down. */
.agenda-hero,
.event-hero {
	position: relative;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 1.5em;
	padding: 1.6em 1.6em 1.6em 1.9em;
	overflow: hidden;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	background:
		radial-gradient(135% 150% at 0% 0%, color-mix(in srgb, var(--color-accent) 13%, transparent), transparent 58%),
		var(--color-surface);
	box-shadow: var(--shadow-card);
}

/* Link-only affordances; the detail header is not clickable. */
.agenda-hero {
	color: var(--color-text);
	text-decoration: none;
	transition: transform 0.18s ease, box-shadow 0.18s ease;
	animation: agenda-rise 0.5s both;
}

.agenda-hero::before,
.event-hero::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 4px;
	background: var(--color-accent);
}

.agenda-hero:visited {
	color: var(--color-text);
}

.agenda-hero:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 34px rgba(0, 0, 0, 0.14), 0 0 0 1px var(--color-border);
}

.agenda-hero-date {
	display: grid;
	justify-items: center;
	align-content: start;
	gap: 0.1em;
	min-width: 4.6em;
	padding-right: 1.5em;
	border-right: 1px solid var(--color-post-border);
	text-align: center;
}

.agenda-hero-weekday {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-accent);
}

.agenda-hero-day {
	font-family: var(--font-display);
	font-optical-sizing: auto;
	font-weight: 600;
	font-size: clamp(3.6rem, 14vw, 5.2rem);
	line-height: 0.82;
	letter-spacing: -0.02em;
}

.agenda-hero-month {
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-muted);
}

.agenda-hero-body {
	min-width: 0;
}

.agenda-tags {
	display: flex;
	align-items: center;
	gap: 0.5em;
	flex-wrap: wrap;
	margin-bottom: 0.55em;
}

.agenda-countdown {
	display: inline-flex;
	align-items: center;
	padding: 0.28em 0.75em;
	border-radius: 999px;
	background: var(--color-accent);
	color: var(--color-surface);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

.agenda-hero-title {
	margin: 0;
	font-family: var(--font-display);
	font-optical-sizing: auto;
	font-weight: 600;
	font-size: clamp(1.65rem, 5.5vw, 2.4rem);
	line-height: 1.04;
	letter-spacing: -0.012em;
}

.agenda-hero-place {
	display: flex;
	align-items: center;
	gap: 0.4em;
	margin: 0.55em 0 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.agenda-hero-place .icon {
	color: var(--color-accent);
}

.agenda-attendees {
	display: flex;
	align-items: center;
	gap: 0.7em;
	margin-top: 1.1em;
}

.agenda-attendees-label {
	color: var(--color-text-muted);
	font-size: 0.85rem;
}

/* Overlapping avatar initials */
.agenda-avatar-stack {
	display: inline-flex;
}

.agenda-avatar {
	display: inline-grid;
	place-items: center;
	width: 2.1em;
	height: 2.1em;
	margin-left: -0.55em;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-surface) 76%, var(--color-accent));
	box-shadow: 0 0 0 2px var(--color-surface);
	color: var(--color-text);
	font-size: 0.8em;
	font-weight: 700;
}

.agenda-avatar:first-child {
	margin-left: 0;
}

.agenda-avatar-more {
	background: var(--color-post-border);
	color: var(--color-text-muted);
	font-size: 0.68em;
}

.agenda-avatar-stack-sm .agenda-avatar {
	width: 1.7em;
	height: 1.7em;
	font-size: 0.72em;
}

/* Timeline of the remaining happenings */
.agenda-timeline {
	position: relative;
	margin: 1.5em 0 0;
	padding: 0 0 0 1.1em;
	list-style: none;
}

.agenda-timeline::before {
	content: "";
	position: absolute;
	top: 0.7em;
	bottom: 0.7em;
	left: 0.32em;
	width: 2px;
	background: linear-gradient(
		var(--color-post-border),
		color-mix(in srgb, var(--color-post-border) 25%, transparent)
	);
}

.agenda-row {
	position: relative;
	animation: agenda-rise 0.45s both calc(var(--i, 0) * 55ms);
}

.agenda-row::before {
	content: "";
	position: absolute;
	top: 1.45em;
	left: -0.78em;
	width: 0.72em;
	height: 0.72em;
	border-radius: 999px;
	background: var(--color-surface);
	border: 2px solid var(--color-accent);
	transform: translate(-50%, -50%);
	z-index: 1;
}

.agenda-row-link {
	display: grid;
	grid-template-columns: 2.8em minmax(0, 1fr) auto;
	align-items: center;
	gap: 0.9em;
	padding: 0.7em 0.7em 0.7em 0;
	border-radius: var(--radius-small);
	color: var(--color-text);
	text-decoration: none;
	transition: background 0.15s ease, transform 0.15s ease;
}

.agenda-row-link:visited {
	color: var(--color-text);
}

.agenda-row-link:hover {
	background: color-mix(in srgb, var(--color-surface) 88%, var(--color-accent));
	transform: translateX(2px);
}

.agenda-row-date {
	display: grid;
	justify-items: center;
	line-height: 1;
}

.agenda-row-day {
	font-family: var(--font-display);
	font-optical-sizing: auto;
	font-weight: 600;
	font-size: 1.65rem;
	line-height: 0.9;
}

.agenda-row-month {
	margin-top: 0.15em;
	font-size: 0.62rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-muted);
}

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

.agenda-row-title {
	margin: 0;
	font-weight: 600;
	font-size: 1.02rem;
	line-height: 1.25;
}

.agenda-row-meta {
	display: flex;
	align-items: center;
	gap: 0.85em;
	flex-wrap: wrap;
	margin-top: 0.2em;
	color: var(--color-text-muted);
	font-size: 0.85rem;
}

.agenda-row-place {
	display: inline-flex;
	align-items: center;
	gap: 0.3em;
	min-width: 0;
}

.agenda-row-when {
	color: var(--color-accent);
	font-weight: 600;
}

/* Cancelled happenings */
.agenda-hero.is-cancelled .agenda-hero-title,
.event-hero.is-cancelled .agenda-hero-title,
.agenda-row.is-cancelled .agenda-row-title {
	text-decoration: line-through;
	text-decoration-thickness: 1px;
	opacity: 0.8;
}

.agenda-hero.is-cancelled::before,
.event-hero.is-cancelled::before,
.event-hero.is-past::before {
	background: var(--color-text-muted);
}

.agenda-hero.is-cancelled .agenda-countdown {
	background: var(--color-text-muted);
}

.agenda-row.is-cancelled::before {
	border-color: var(--color-text-muted);
}

/* "Tidigare" divider + receded past timeline */
.agenda-divider {
	display: flex;
	align-items: center;
	gap: 1em;
	margin: 2.4em 0 0.4em;
	color: var(--color-text-muted);
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.agenda-divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--color-post-border);
}

.agenda-timeline-past {
	opacity: 0.72;
}

.agenda-timeline-past .agenda-row::before {
	border-color: var(--color-text-muted);
}

.agenda-timeline-past .agenda-row-day {
	color: var(--color-text-muted);
}

.agenda-timeline-past .agenda-row-when {
	color: var(--color-text-muted);
	font-weight: 400;
}

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

@media (prefers-reduced-motion: reduce) {
	.agenda-hero,
	.agenda-row {
		animation: none;
	}
}

.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,
.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-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);
}

/* The detail header is the index hero "opened": it shares the .agenda-hero
   box and the .agenda-hero-* date/title elements, adding only the meta line
   below. Past events also grey out the weekday the way the list does. */
.event-hero.is-past .agenda-hero-weekday {
	color: var(--color-text-muted);
}

.event-hero-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em 1.1em;
	margin: 0.55em 0 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.event-hero-metaitem {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	min-width: 0;
}

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

.event-hero-creator .icon {
	color: var(--color-text-muted);
}

.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: flex;
	gap: 0.6em;
}

.comment-main {
	display: grid;
	gap: 0.35em;
	flex: 1;
	min-width: 0;
}

.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;
	opacity: 0;
	transition: opacity 0.15s;
}

.comment:hover .comment-actions,
.comment:focus-within .comment-actions {
	opacity: 1;
}

.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 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4em;
	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;
}

.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-list {
	display: flex;
	flex-direction: column;
	gap: 0.75em;
}

.archive-card {
	display: flex;
	align-items: center;
	gap: 1em;
	padding: 0.75em;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	color: var(--color-text);
	text-decoration: none;
	transition: border-color 0.15s, box-shadow 0.15s;
}

.archive-card:hover {
	border-color: var(--color-accent);
	box-shadow: var(--shadow-card);
}

.archive-card-thumb {
	width: 5.5rem;
	height: 4rem;
	object-fit: cover;
	border-radius: var(--radius-small);
	flex-shrink: 0;
}

.archive-card-pdf {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-bg);
	color: var(--color-text-muted);
	font-family: var(--font-mono);
	font-size: 0.75em;
	font-weight: 600;
	letter-spacing: 0.05em;
}

.archive-card-body {
	flex: 1;
	min-width: 0;
}

.archive-card-year {
	display: block;
	font-family: var(--font-mono);
	font-size: 0.75em;
	color: var(--color-text-muted);
}

.archive-card-title {
	display: block;
	font-weight: 600;
	color: var(--color-link);
}

.archive-card:hover .archive-card-title {
	color: var(--color-link-hover);
}

.archive-card-text {
	display: block;
	margin-top: 0.15em;
	font-size: 0.85em;
	color: var(--color-text-muted);
}

.archive-card-arrow {
	color: var(--color-text-muted);
	transition: transform 0.15s, color 0.15s;
}

.archive-card:hover .archive-card-arrow {
	transform: translateX(3px);
	color: var(--color-accent);
}

/* 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 */
.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;
	}

	/* Touch devices have no hover, so keep comment actions visible. */
	.comment-actions {
		opacity: 1;
	}

	/* 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;
	}

	.agenda-header {
		align-items: stretch;
	}

	.agenda-new {
		justify-content: center;
	}

	.agenda-hero,
	.event-hero {
		grid-template-columns: 1fr;
		gap: 1em;
		padding: 1.2em 1.2em 1.2em 1.5em;
	}

	.agenda-hero-date {
		display: flex;
		align-items: baseline;
		gap: 0.5em;
		min-width: 0;
		padding: 0 0 0.9em;
		border-right: 0;
		border-bottom: 1px solid var(--color-post-border);
	}

	.agenda-hero-day {
		font-size: 2.6rem;
		line-height: 1;
	}

	.agenda-row-link {
		grid-template-columns: 2.6em minmax(0, 1fr);
		gap: 0.75em;
	}

	/* The avatar stack drops below the title on narrow rows. */
	.agenda-row-link .agenda-avatar-stack {
		grid-column: 2;
		margin-top: 0.4em;
	}

	.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;
	}
}
