@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:FILL@0..1&icon_names=add_photo_alternate,add_reaction,edit_square,forum,mail,repeat,reply,settings&display=block');

.material-symbols-outlined {
	font-family: 'Material Symbols Outlined';
	font-weight: normal;
	font-style: normal;
	font-size: 24px;
	display: inline-block;
	line-height: 1;
	text-transform: none;
	letter-spacing: normal;
	word-wrap: normal;
	white-space: nowrap;
	direction: ltr;
}

.material-symbols-outlined.compact {
	font-size: 20px;
}

.material-symbols-outlined.is-active {
	font-variation-settings: 'FILL' 1;
}

:root {
	color-scheme: light;
	--bg: #f3f5f9;
	--surface: #ffffff;
	--surface-soft: #f8faff;
	--text: #1f2937;
	--text-muted: #6b7280;
	--border: #dbe2ea;
	--primary: #2563eb;
	--primary-hover: #1d4ed8;
	--danger-bg: #fef2f2;
	--danger-text: #b91c1c;
	--danger-border: #fecaca;
	--shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
	--bg-gradient-start: #e9f0ff;
	--bg-gradient-end: #f3f5f9;
	--heading: #0f172a;
	--brand: #0b1220;
	--hero-start: #eff6ff;
	--hero-end: #ffffff;
	--field-bg: #ffffff;
	--field-border: #c9d4e2;
	--focus-outline: rgba(37, 99, 235, 0.15);
	--focus-border: #93c5fd;
	--secondary-bg: #eef2ff;
	--secondary-text: #1f2937;
	--secondary-border: #cbd5e1;
	--secondary-hover-bg: #e2e8f0;
	--secondary-active-bg: #1f2937;
	--secondary-active-text: #f9fafb;
	--secondary-active-border: #1f2937;
	--chip-bg: #ffffff;
	--chip-border: #dbe2ea;
	--chip-active-bg: #eff6ff;
	--chip-active-border: #93c5fd;
	--mono-bg: #f1f5f9;
	--mono-border: #dbe7f5;
	--pill-bg: #e8efff;
	--pill-text: #1d4ed8;
	--empty-bg: #f8fafc;
	--empty-border: #cfd8e3;
	--hide-read-toggle-on-bg: #facc15;
	--hide-read-toggle-on-text: #111827;
	--hide-read-toggle-off-bg: #2563eb;
	--hide-read-toggle-off-text: #eff6ff;
	--feed-author-unread: #2563eb;
	--feed-author-read: var(--text);
	--radius: 14px;
	--tap-target-min: 44px;
	--mobile-text-min: 0.875rem;
	--mobile-control-text-min: 1rem;
	--focus-ring: 2px solid var(--focus-border);
}

html[data-theme="dark"] {
	color-scheme: dark;
	--bg: #0b1220;
	--surface: #111827;
	--surface-soft: #1f2937;
	--text: #e5e7eb;
	--text-muted: #9ca3af;
	--border: #374151;
	--primary: #60a5fa;
	--primary-hover: #3b82f6;
	--danger-bg: #3f1d1d;
	--danger-text: #fca5a5;
	--danger-border: #7f1d1d;
	--shadow: 0 14px 32px rgba(2, 6, 23, 0.5);
	--bg-gradient-start: #1f2937;
	--bg-gradient-end: #0b1220;
	--heading: #f9fafb;
	--brand: #f9fafb;
	--hero-start: #1f2937;
	--hero-end: #111827;
	--field-bg: #111827;
	--field-border: #4b5563;
	--focus-outline: rgba(96, 165, 250, 0.25);
	--focus-border: #60a5fa;
	--secondary-bg: #1f2937;
	--secondary-text: #e5e7eb;
	--secondary-border: #4b5563;
	--secondary-hover-bg: #374151;
	--secondary-active-bg: #374151;
	--secondary-active-text: #f9fafb;
	--secondary-active-border: #6b7280;
	--chip-bg: #111827;
	--chip-border: #4b5563;
	--chip-active-bg: #1e3a5f;
	--chip-active-border: #60a5fa;
	--mono-bg: #1f2937;
	--mono-border: #4b5563;
	--pill-bg: #1e3a5f;
	--pill-text: #93c5fd;
	--empty-bg: #111827;
	--empty-border: #4b5563;
	--hide-read-toggle-on-bg: #facc15;
	--hide-read-toggle-on-text: #111827;
	--hide-read-toggle-off-bg: #3b82f6;
	--hide-read-toggle-off-text: #e5e7eb;
	--feed-author-unread: #60a5fa;
	--feed-author-read: var(--text);
}

* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
	font-family: "Inter", "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;
	color: var(--text);
}

html {
	background-color: var(--bg);
}

body {
	min-height: 100vh;
	min-height: 100dvh;
	background-color: var(--bg);
	background-image: radial-gradient(circle at top right, var(--bg-gradient-start), var(--bg-gradient-end) 45%);
}

html[data-theme="dark"] body {
	background-color: var(--bg);
	background-image: radial-gradient(circle at top right, var(--bg-gradient-start), var(--bg-gradient-end) 45%);
}

a {
	color: var(--primary);
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

.followed {
	font-style: italic;
}

a:focus-visible {
	outline: var(--focus-ring);
	outline-offset: 2px;
	text-decoration: underline;
}

h1,
h2,
h3 {
	margin: 0;
	color: var(--heading);
}

p {
	margin: 0;
	line-height: 1.55;
}

ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.hidden {
	display: none !important;
}

.app-shell {
	max-width: 1140px;
	margin: 0 auto;
	padding: 28px 24px 44px;
}

.app-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
}

.app-brand {
	display: inline-block;
	font-size: clamp(1.25rem, 1.05rem + 0.9vw, 1.5rem);
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--brand);
}

.app-main {
	display: grid;
	gap: 18px;
}

.hero {
	background: linear-gradient(140deg, var(--hero-start), var(--hero-end) 65%);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 18px 20px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 8px;
}

.feed-mode-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	padding-top: 4px;
}

.feed-mode-controls .button-secondary.is-active,
.feed-mode-controls .button-secondary[aria-pressed="true"] {
	background: var(--secondary-active-bg);
	border-color: var(--secondary-active-border);
	color: var(--secondary-active-text);
	box-shadow: inset 0 0 0 1px currentColor;
}

.feed-emoji-picker {
	font-size: 0.9rem;
	color: var(--text-muted);
	margin-left: 6px;
}

.feed-emoji-buttons {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 6px;
}

.feed-emoji-button {
	min-width: 40px;
	padding-left: 10px;
	padding-right: 10px;
}

.feed-emoji-button.is-active,
.feed-emoji-button[aria-pressed="true"] {
	background: var(--secondary-active-bg);
	border-color: var(--secondary-active-border);
	color: var(--secondary-active-text);
}

.discussion-parent {
	gap: 10px;
}

.discussion-list {
	gap: 12px;
}

.discussion-item {
	gap: 10px;
}

.discussion-children {
	margin-left: 14px;
	padding-left: 10px;
	border-left: 2px solid var(--border);
	gap: 10px;
}

.discussion-reply-form textarea {
	min-height: 74px;
}

.discussion-reply-toggle {
	display: grid;
	gap: 8px;
}

.discussion-reply-summary {
	cursor: pointer;
	color: var(--text-muted);
	font-weight: 600;
	font-size: 0.95rem;
	user-select: none;
}

.discussion-reply-summary:hover {
	color: var(--text);
}

.discussion-reply-summary:focus-visible {
	outline: var(--focus-ring);
	outline-offset: 2px;
	border-radius: 6px;
}

.discussion-collapsible {
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 8px;
	background: var(--surface-soft);
}

.discussion-collapsible > summary {
	cursor: pointer;
	font-weight: 600;
	color: var(--text-muted);
}

.subtext {
	color: var(--text-muted);
	font-size: 0.96rem;
}

.page-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.social-grid {
	grid-template-columns: minmax(0, 1.7fr) minmax(280px, 1fr);
	align-items: start;
}

.social-grid > * {
	min-width: 0;
}

.sidebar-stack {
	display: grid;
	gap: 16px;
}

.card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 16px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 12px;
}

.card-soft {
	background: var(--surface-soft);
}

.card-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}

.stack {
	display: grid;
	gap: 10px;
}

.inline-form {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 2px 0;
}

label {
	font-size: 0.92rem;
	color: var(--text-muted);
	font-weight: 600;
}

input,
textarea,
select,
button {
	font: inherit;
}

input,
textarea,
select {
	width: 100%;
	border: 1px solid var(--field-border);
	border-radius: 10px;
	padding: 10px 12px;
	background: var(--field-bg);
	color: var(--text);
}

textarea {
	resize: vertical;
	min-height: 90px;
}

input:focus,
textarea:focus,
select:focus {
	outline: 2px solid var(--focus-outline);
	outline-offset: 1px;
	border-color: var(--focus-border);
}

button:focus-visible,
.button-secondary:focus-visible,
.hide-read-toggle-link:focus-visible,
.feed-emoji-button:focus-visible,
.reaction-chip:focus-visible,
.following-remove:focus-visible,
.token-link:focus-visible,
.discussion-collapsible > summary:focus-visible {
	outline: var(--focus-ring);
	outline-offset: 2px;
}

.form-grid {
	display: grid;
	gap: 10px;
}

.actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.composer-toolbar {
	display: flex;
	align-items: center;
	gap: 8px;
}

.composer-editor {
	width: 100%;
	border: 1px solid var(--field-border);
	border-radius: 10px;
	padding: 10px 12px;
	background: var(--field-bg);
	color: var(--text);
	min-height: 90px;
	white-space: pre-wrap;
	word-break: break-word;
}

.composer-editor:focus {
	outline: 2px solid var(--focus-outline);
	outline-offset: 1px;
	border-color: var(--focus-border);
}

.composer-editor.is-dragover {
	outline: 2px solid var(--focus-outline);
	outline-offset: 1px;
	border-color: var(--focus-border);
	background: var(--surface-soft);
}

.composer-editor:empty::before {
	content: attr(data-placeholder);
	color: var(--text-muted);
	pointer-events: none;
}

.composer-image,
.feed-image {
	display: block;
	max-width: min(100%, 640px);
	max-height: 1280px;
	width: auto;
	height: auto;
	border-radius: 10px;
	border: 1px solid var(--border);
	margin: 6px 0;
}

.top-search-row {
	display: flex;
	gap: 8px;
	align-items: center;
}

.top-search-row input {
	flex: 1;
}

button {
	border: none;
	border-radius: 10px;
	padding: 9px 14px;
	font-weight: 600;
	background: var(--primary);
	color: #fff;
	cursor: pointer;
}

@media (hover: hover) and (pointer: fine) {
	button:hover {
		background: var(--primary-hover);
	}
}

.button-secondary {
	background: var(--secondary-bg);
	color: var(--secondary-text);
	border: 1px solid var(--secondary-border);
}

@media (hover: hover) and (pointer: fine) {
	.button-secondary:hover {
		background: var(--secondary-hover-bg);
	}
}

.list {
	display: grid;
	gap: 8px;
}

.list-item {
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 10px 12px;
	background: var(--surface);
	display: grid;
	gap: 8px;
}

.feed-list {
	gap: 12px;
}

.feed-header {
	align-items: baseline;
}

.feed-item {
	gap: 10px;
}

.feed-topline {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 10px;
}

.feed-author {
	font-size: clamp(1rem, 0.96rem + 0.25vw, 1.04rem);
	font-weight: 700;
	color: var(--heading);
}

.feed-author a,
.feed-author a:visited {
	color: inherit;
}

.feed-author.feed-author-unread {
	color: var(--feed-author-unread);
}

.feed-author.feed-author-read {
	color: var(--feed-author-read);
}

.feed-text {
	white-space: pre-wrap;
	word-break: break-word;
}

.feed-tags {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 4px;
}

.feed-tags-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	flex-basis: 100%;
	margin-bottom: 6px;
}

.feed-tags-list[hidden] {
	display: none;
}

.feed-tags-list .token-link {
	font-weight: 400;
	font-style: normal;
}

.feed-tags-list .token-link.followed {
	font-style: italic;
}

.feed-tags > .inline-form {
	margin-left: auto;
}

.link-preview-card {
	display: flex;
	align-items: stretch;
	gap: 10px;
	padding: 10px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--surface-soft);
	text-decoration: none;
	color: inherit;
	max-width: 100%;
}

.link-preview-list {
	display: grid;
	gap: 8px;
	margin-top: 8px;
}

@media (hover: hover) and (pointer: fine) {
	.link-preview-card:hover {
		background: var(--surface);
	}
}

.link-preview-card-x {
	padding: 0;
	border-radius: 14px;
	background: var(--surface);
	overflow: hidden;
}

@media (hover: hover) and (pointer: fine) {
	.link-preview-card-x:hover {
		background: var(--surface-soft);
	}
}

.link-preview-body-x {
	padding: 12px;
	gap: 10px;
}

.link-preview-x-header {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.link-preview-x-avatar {
	width: 36px;
	height: 36px;
	border-radius: 999px;
	flex: 0 0 36px;
	background: var(--surface-soft);
	border: 1px solid var(--border);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--text-muted);
	overflow: hidden;
}

.link-preview-x-avatar-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.link-preview-x-identity {
	min-width: 0;
	display: grid;
	gap: 2px;
}

.link-preview-x-name {
	font-weight: 700;
	line-height: 1.2;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.link-preview-x-byline {
	font-size: 0.84rem;
	color: var(--text-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.link-preview-x-text {
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
}

.link-preview-x-media-wrap {
	width: 100%;
	max-width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid var(--border);
	background: var(--bg);
}

.link-preview-x-media {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.link-preview-x-footer {
	font-size: 0.82rem;
	color: var(--text-muted);
}

.link-preview-image-wrap {
	width: 88px;
	height: 88px;
	flex: 0 0 88px;
	overflow: hidden;
	border-radius: 8px;
	background: var(--bg);
}

.link-preview-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.link-preview-body {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.link-preview-title {
	font-weight: 700;
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.link-preview-video-container {
	margin-top: 8px;
	border-radius: 10px;
	overflow: hidden;
	background: var(--bg);
	max-width: 100%;
	width: 100%;
}

.link-preview-audio-container {
	margin-top: 8px;
	padding: 8px 10px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--surface-soft);
	max-width: 100%;
	width: 100%;
}

.link-preview-audio-player {
	width: 100%;
	display: block;
}

.link-preview-video-iframe {
	width: 100%;
	height: 360px;
	border: none;
	border-radius: 10px;
	display: block;
	aspect-ratio: 16 / 9;
}

.link-preview-host {
	font-size: 0.82rem;
	color: var(--text-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.link-preview-description {
	font-size: 0.9rem;
	color: var(--text-muted);
	overflow-x: hidden;
	overflow-y: auto;
	max-height: 12rem;
}

.feed-image-remote.is-blurred {
	filter: blur(16px);
	transition: filter 0.16s ease-in-out;
	cursor: pointer;
}

.feed-image-remote.is-blurred:hover,
.feed-image-remote.is-unblurred {
	filter: blur(0);
}

.feed-image-remote.is-blurred:active {
	filter: blur(0);
}

.feed-tags .button-secondary {
	padding: 4px 6px;
	min-height: 28px;
	min-width: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.feed-tags .material-symbols-outlined {
	font-size: 20px;
}

.feed-meta {
	font-size: 0.88rem;
}

.reaction-menu {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px;
	border: 1px solid var(--border);
	border-radius: 999px;
	background: var(--surface-soft);
}

.reaction-menu[hidden] {
	display: none;
}

.reaction-chip {
	border: 1px solid var(--chip-border);
	background: var(--chip-bg);
	color: var(--text);
	padding: 4px 6px;
	border-radius: 999px;
	font-size: 0.88rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 28px;
	min-width: 28px;
}

.reaction-chip.is-active {
	border-color: var(--chip-active-border);
	background: var(--chip-active-bg);
	font-weight: 700;
}

.reaction-chip .reaction-count {
	font-size: 0.68em;
	line-height: 1;
	vertical-align: super;
	margin-left: 1px;
}

.reaction-summary {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.mention-popup-menu,
.hashtag-popup-menu {
	position: fixed;
	z-index: 1200;
	min-width: 180px;
	padding: 6px;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: var(--surface);
	box-shadow: var(--shadow);
	display: grid;
	gap: 2px;
}

.mention-popup-menu[hidden],
.hashtag-popup-menu[hidden] {
	display: none;
}

.popup-menu-item {
	appearance: none;
	border: 1px solid transparent;
	background: transparent;
	color: var(--text);
	font: inherit;
	font-size: 0.92rem;
	text-align: left;
	padding: 8px 10px;
	border-radius: 8px;
	cursor: pointer;
}


.popup-menu-item:hover {
	background: var(--secondary-bg);
	border-color: var(--secondary-border);
}

.popup-menu-item:focus-visible {
	background: var(--secondary-bg);
	border-color: var(--secondary-border);
	outline: var(--focus-ring);
	outline-offset: 2px;
}

.popup-menu-item.is-destructive {
	color: var(--danger-text);
}

.feed-item.feed-item-ignored {
	display: none;
}

.hide-read-toggle {
	position: fixed;
	top: calc(12px + env(safe-area-inset-top, 0px));
	right: calc(12px + env(safe-area-inset-right, 0px));
	z-index: 1400;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 10px;
	border: 1px solid var(--border);
	border-radius: 999px;
	background: var(--surface);
	box-shadow: var(--shadow);
}

.hide-read-toggle-sep {
	color: var(--text-muted);
	font-size: 0.9rem;
}

.hide-read-toggle-link {
	appearance: none;
	border: none;
	background: transparent;
	padding: 0 6px;
	margin: 0;
	color: var(--text);
	text-decoration: none;
	font: inherit;
	font-size: 0.95rem;
	line-height: 1;
	cursor: pointer;
	min-height: var(--tap-target-min);
	min-width: var(--tap-target-min);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.hide-read-toggle-mail {
	font-size: 1.35rem;
	line-height: 1;
}

.hide-read-toggle-count {
	font-size: 0.62rem;
	font-weight: 700;
	vertical-align: super;
	margin-left: 2px;
}

.hide-read-toggle-compose {
	font-size: 1.1rem;
}

.hide-read-toggle-button {
	appearance: none;
	width: 42px;
	height: 26px;
	border-radius: 999px;
	border: 1px solid transparent;
	background: var(--hide-read-toggle-off-bg);
	color: var(--hide-read-toggle-off-text);
	cursor: pointer;
	font-size: 0.75rem;
	font-weight: 700;
	transition: background-color 120ms ease;
}

.hide-read-toggle-button.is-active {
	background: var(--hide-read-toggle-on-bg);
	color: var(--hide-read-toggle-on-text);
}

.hide-read-toggle-label {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--text);
}

.floating-compose {
	position: fixed;
	top: calc(58px + env(safe-area-inset-top, 0px));
	right: calc(12px + env(safe-area-inset-right, 0px));
	z-index: 1390;
	width: min(92vw, 420px);
}

.floating-compose[hidden] {
	display: none;
}

.floating-compose .card {
	margin: 0;
}

@media (max-width: 640px) {
	.link-preview-video-iframe {
		height: 224px;
	}

	.hide-read-toggle {
		top: calc(8px + env(safe-area-inset-top, 0px));
		right: calc(8px + env(safe-area-inset-right, 0px));
		padding: 6px 8px;
		gap: 8px;
	}

	.hide-read-toggle-label,
	.hide-read-toggle-sep,
	.feed-meta,
	.link-preview-host,
	.link-preview-x-byline,
	.link-preview-x-footer,
	.feed-emoji-picker,
	.reaction-chip,
	.popup-menu-item {
		font-size: var(--mobile-text-min);
	}

	.hide-read-toggle-link,
	.button-secondary,
	button,
	.feed-emoji-button,
	.popup-menu-item,
	.reaction-chip {
		min-height: var(--tap-target-min);
	}

	.hide-read-toggle-link,
	.feed-emoji-button {
		min-width: var(--tap-target-min);
	}

	button,
	.button-secondary,
	.popup-menu-item {
		font-size: var(--mobile-control-text-min);
	}

	.hide-read-toggle-button {
		width: var(--tap-target-min);
		height: var(--tap-target-min);
		font-size: var(--mobile-text-min);
	}

	.hide-read-toggle-count {
		font-size: var(--mobile-text-min);
	}

	.hide-read-toggle-mail {
		font-size: 1.2rem;
	}

	.floating-compose {
		top: calc(52px + env(safe-area-inset-top, 0px));
		right: calc(8px + env(safe-area-inset-right, 0px));
		width: calc(100vw - 16px - env(safe-area-inset-right, 0px));
	}

	.following-label,
	.pill,
	.empty {
		font-size: var(--mobile-text-min);
	}

	.following-remove,
	.token-link {
		min-height: var(--tap-target-min);
		font-size: var(--mobile-control-text-min);
	}

	.following-remove {
		min-width: var(--tap-target-min);
		height: var(--tap-target-min);
		padding: 0 10px;
	}
}

.following-list {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.following-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border: 1px solid var(--border);
	border-radius: 999px;
	background: var(--surface);
}

.following-label {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--text);
}

.following-remove {
	padding: 0;
	min-width: 20px;
	height: 20px;
	border-radius: 999px;
	font-size: 0.9rem;
	line-height: 1;
	background: var(--surface-soft);
	color: var(--text-muted);
	border: 1px solid var(--border);
}

@media (hover: hover) and (pointer: fine) {
	.following-remove:hover {
		background: var(--bg);
		color: var(--text);
	}
}

.token-link {
	border: none;
	padding: 0;
	margin: 0;
	background: transparent;
	color: var(--primary);
	font: inherit;
	cursor: pointer;
	font-weight: 600;
}

.feed-sentinel {
	height: 1px;
}

.feed-loading {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 0;
}

#feed-subtext.is-fetching {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.feed-loading[hidden] {
	display: none;
}

.feed-retry {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 6px 0;
}

.feed-retry[hidden] {
	display: none;
}

.feed-spinner {
	width: 16px;
	height: 16px;
	border-radius: 999px;
	border: 2px solid var(--border);
	border-top-color: var(--primary);
	animation: feed-spin 0.8s linear infinite;
}

@keyframes feed-spin {
	to {
		transform: rotate(360deg);
	}
}

.feed-skeleton {
	opacity: 0.9;
}

.feed-skeleton-item {
	gap: 10px;
}

.feed-skeleton-line {
	height: 12px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--surface-soft), var(--bg) 45%, var(--surface-soft));
	background-size: 200% 100%;
	animation: feed-skeleton-wave 1.1s ease-in-out infinite;
}

.feed-skeleton-author {
	width: 36%;
	height: 14px;
}

.feed-skeleton-body {
	width: 100%;
}

.feed-skeleton-item .feed-skeleton-body:last-child {
	width: 78%;
}

@keyframes feed-skeleton-wave {
	0% {
		background-position: 100% 0;
	}
	100% {
		background-position: -100% 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}

	.feed-spinner,
	.feed-skeleton-line {
		animation: none !important;
	}

	.feed-image-remote.is-blurred {
		transition: none !important;
	}
}

.list-item-head {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	align-items: baseline;
}

.mono {
	font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.9rem;
	background: var(--mono-bg);
	padding: 2px 6px;
	border-radius: 6px;
	border: 1px solid var(--mono-border);
	word-break: break-all;
	overflow-wrap: anywhere;
}

.pill {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 4px 8px;
	border-radius: 999px;
	background: var(--pill-bg);
	color: var(--pill-text);
}

.empty {
	padding: 12px;
	border-radius: 10px;
	border: 1px dashed var(--empty-border);
	background: var(--empty-bg);
	color: var(--text-muted);
	font-size: 0.95rem;
}

.error-text {
	background: var(--danger-bg);
	color: var(--danger-text);
	border: 1px solid var(--danger-border);
	border-radius: 10px;
	padding: 10px 12px;
	font-weight: 600;
}

.auth-wrap {
	max-width: 520px;
	margin: 38px auto 0;
}

.auth-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 22px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 14px;
}

.auth-footer {
	font-size: 0.95rem;
	color: var(--text-muted);
}

@media (max-width: 900px) {
	.page-grid,
	.social-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 620px) {
	.app-shell {
		padding: 18px 14px 28px;
	}

	.card,
	.auth-card,
	.hero {
		padding: 14px;
	}

	.top-search-row {
		flex-direction: column;
		align-items: stretch;
	}
}
