/* --- Archive-inspired redesign (2026) --- */
:root {
	--color-bg: #f7f7f5;
	--color-surface: #ffffff;
	--color-text: #1a1a1a;
	--color-muted: #4a4a48;
	--color-link: #0b57d0;
	--color-link-hover: #0842a0;
	--color-border: #c8c8c4;
	--color-accent-warm: #f5e6a3;
	--color-badge-new: #ffe08a;
	--color-badge-updated: #fff3c4;
	--font-serif: "Source Serif 4", Georgia, "Times New Roman", serif;
	--font-sans: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--space-1: 0.25rem;
	--space-2: 0.5rem;
	--space-3: 0.75rem;
	--space-4: 1rem;
	--space-5: 1.5rem;
	--space-6: 2rem;
	--space-8: 3rem;
	--radius: 6px;
	--shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	--max-content: 72rem;
}

@media (prefers-reduced-motion: no-preference) {
	html {
		scroll-behavior: smooth;
	}
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0.75rem;
	z-index: 10000;
	padding: var(--space-2) var(--space-4);
	font-weight: 700;
	font-size: 0.9rem;
	background: var(--color-surface);
	color: var(--color-link);
	border: 2px solid var(--color-link);
	border-radius: var(--radius);
	text-decoration: none;
	box-shadow: var(--shadow);
}

.skip-link:focus {
	left: 0.75rem;
	outline: none;
}

.theme-archive :focus-visible {
	outline: 2px solid var(--color-link);
	outline-offset: 2px;
}

.http-error {
	max-width: 36rem;
	margin: var(--space-8) auto;
	padding: var(--space-6);
	text-align: center;
}

.http-error__code {
	font-family: var(--font-serif);
	font-size: clamp(3rem, 8vw, 4.5rem);
	margin: 0;
	line-height: 1;
	color: var(--color-muted);
}

.http-error__title {
	font-size: 1.35rem;
	font-weight: 700;
	margin: var(--space-4) 0 var(--space-2);
}

.http-error__lead {
	margin: 0 0 var(--space-6);
	color: var(--color-muted);
	line-height: 1.55;
}

.http-error__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	justify-content: center;
}

.http-error__btn {
	display: inline-block;
	padding: var(--space-3) var(--space-5);
	font-weight: 700;
	text-decoration: none;
	border-radius: 999px;
	border: 1px solid var(--color-border);
	background: linear-gradient(180deg, #fff 0%, #e8eaee 100%);
	color: var(--color-text);
	box-shadow: var(--shadow);
}

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

.http-error__btn--ghost {
	background: transparent;
	box-shadow: none;
}

.theme-archive.site-body {
	margin: 0;
	min-height: 100vh;
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.5;
	color: var(--color-text);
	background-color: var(--color-bg);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cg fill='none' stroke='%23c8c8c0' stroke-width='1' opacity='0.35'%3E%3Cpath d='M25 78c8-18 22-28 38-30 10-1 18 2 24 8M42 52c6-12 16-18 28-18 12 0 20 6 24 16M55 40c-4-8-2-16 4-20M18 82c4 10 12 16 24 18'/%3E%3Ccircle cx='78' cy='58' r='8'/%3E%3C/g%3E%3C/svg%3E");
	background-size: 280px 280px;
}

.site-canvas {
	max-width: var(--max-content);
	margin: 0 auto;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	background: rgba(247, 247, 245, 0.92);
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.04);
}

.site-masthead {
	background: linear-gradient(180deg, #e4e6ea 0%, #d5d8df 100%);
	border-bottom: 1px solid var(--color-border);
	padding: var(--space-4) var(--space-4) var(--space-3);
}

.site-masthead__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--space-4);
	max-width: 100%;
}

.site-masthead__welcome {
	margin: 0;
	font-size: 0.9rem;
	color: var(--color-muted);
	text-align: center;
}

.site-masthead__brand {
	flex: 1 1 280px;
	text-align: center;
}

.site-masthead__titlelink {
	text-decoration: none;
	color: inherit;
}

.site-masthead__titlelink:hover .site-masthead__title {
	color: var(--color-link);
}

.site-masthead__title {
	display: block;
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: clamp(1.5rem, 4vw, 2.15rem);
	letter-spacing: -0.02em;
	margin: var(--space-1) 0 0;
	line-height: 1.15;
}

.site-masthead__updated {
	margin: var(--space-2) 0 0;
	font-size: 0.85rem;
	color: var(--color-link);
}

.site-masthead__updated-label {
	color: var(--color-muted);
}

.site-nav {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	justify-content: center;
	padding-bottom: var(--space-1);
}

.site-nav__link {
	font-weight: 600;
	font-size: 0.95rem;
	padding: var(--space-2) var(--space-4);
	border-radius: 999px;
	border: 1px solid #9aa0a8;
	background: linear-gradient(180deg, #fff 0%, #e8eaee 100%);
	color: var(--color-text);
	text-decoration: none;
	box-shadow: var(--shadow);
}

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

.site-nav__link:focus-visible {
	outline: 2px solid var(--color-link);
	outline-offset: 2px;
}

.site-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	flex: 1;
	padding: var(--space-4);
	box-sizing: border-box;
}

@media (min-width: 1100px) {
	.site-layout {
		grid-template-columns: 1fr 160px;
		align-items: start;
	}
}

.site-main {
	min-width: 0;
}

.site-ad {
	justify-self: center;
}

@media (min-width: 1100px) {
	.site-ad {
		position: sticky;
		top: var(--space-4);
		justify-self: end;
	}
}

.site-ad__ins {
	min-width: 120px;
	min-height: 240px;
}

.site-footer {
	margin-top: auto;
	background: linear-gradient(180deg, #e4e6ea 0%, #d5d8df 100%);
	border-top: 1px solid var(--color-border);
	padding: var(--space-5) var(--space-4);
	font-size: 0.9rem;
}

.site-footer__inner {
	max-width: 56rem;
	margin: 0 auto;
}

.site-footer__row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--space-3);
	margin-bottom: var(--space-3);
}

.site-footer__text {
	margin: 0;
	color: var(--color-text);
}

.site-footer__meta {
	color: var(--color-muted);
	font-size: 0.85rem;
}

.site-footer__brand {
	font-weight: 700;
}

.site-footer__quiet {
	color: var(--color-link);
	text-decoration: none;
	font-weight: 600;
}

.site-footer__quiet:hover {
	text-decoration: underline;
}

.site-footer__easter {
	margin: var(--space-4) 0 0;
	font-size: 0.78rem;
	color: var(--color-muted);
	font-style: italic;
	text-align: center;
	border-top: 1px dashed var(--color-border);
	padding-top: var(--space-3);
}

/* Home */
.home-intro {
	text-align: center;
	max-width: 42rem;
	margin: 0 auto var(--space-6);
}

.home-intro__title {
	font-family: var(--font-serif);
	font-size: 1.35rem;
	font-weight: 600;
	margin: 0 0 var(--space-2);
}

.home-intro__lead {
	margin: 0;
	color: var(--color-muted);
}

.home-search {
	max-width: 28rem;
	margin: 0 auto var(--space-6);
}

.home-search__label {
	display: block;
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: var(--space-2);
}

.home-search__input {
	width: 100%;
	box-sizing: border-box;
	padding: var(--space-3) var(--space-3);
	border-radius: var(--radius);
	border: 1px solid var(--color-border);
	font: inherit;
}

.home-search__input:focus {
	outline: 2px solid var(--color-link);
	outline-offset: 1px;
	border-color: var(--color-link);
}

.home-catalog {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}

@media (min-width: 720px) {
	.home-catalog {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.home-catalog {
		grid-template-columns: repeat(3, 1fr);
	}
}

.home-category {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

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

.home-category__placeholder {
	width: 100%;
	height: 100%;
	min-height: 140px;
	background: repeating-linear-gradient(
		-45deg,
		#e8e8e4,
		#e8e8e4 8px,
		#deded8 8px,
		#deded8 16px
	);
}

.home-category__hero {
	display: block;
	aspect-ratio: 4 / 3;
	background: #e8e8e4;
	border-bottom: 1px solid var(--color-border);
	overflow: hidden;
}

.home-category__hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.home-category__title {
	margin: 0;
	padding: var(--space-3);
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-weight: 700;
	text-align: center;
	background: linear-gradient(180deg, #e0e0dc 0%, #d0d0cc 100%);
	border-bottom: 1px solid var(--color-border);
}

.home-category__list {
	list-style: none;
	margin: 0;
	padding: var(--space-3) var(--space-3) var(--space-4);
	font-size: 0.92rem;
	line-height: 1.45;
	flex: 1;
}

.home-category__list li {
	margin: 0.15rem 0;
}

.home-category__list a {
	color: var(--color-link);
	text-decoration: underline;
	text-underline-offset: 2px;
}

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

.home-category__list li[data-home-search-hidden="1"] {
	display: none;
}

.badge {
	display: inline-block;
	font-size: 0.65rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 0.1rem 0.35rem;
	border-radius: 3px;
	margin-left: var(--space-2);
	vertical-align: middle;
}

.badge--new {
	background: var(--color-badge-new);
	color: #3d3500;
	border: 1px solid #d4b84a;
}

.badge--updated {
	background: var(--color-badge-updated);
	color: #4a3b00;
	border: 1px solid #d4b84a;
}

.home-secondary-nav {
	text-align: center;
	margin: var(--space-8) auto var(--space-4);
	padding: var(--space-4);
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}

.home-secondary-nav__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-3);
	list-style: none;
	margin: 0;
	padding: 0;
}

.home-secondary-nav__links a {
	font-weight: 700;
	color: var(--color-link);
	font-size: 1.05rem;
}

/* Bike detail redesign */
.bike-page {
	max-width: 56rem;
	margin: 0 auto;
}

.bike-page__title {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin: 0 0 var(--space-4);
}

.bike-page__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}

@media (min-width: 900px) {
	.bike-page__grid {
		grid-template-columns: 1fr 1fr;
		align-items: start;
	}
}

.bike-page__gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: var(--space-3);
}

.bike-page__gallery .bike-photo-thumb img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius);
	border: 1px solid var(--color-border);
}

.bike-spec {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.92rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
}

.bike-spec th,
.bike-spec td {
	padding: var(--space-2) var(--space-3);
	border-bottom: 1px solid #e4e4e0;
	vertical-align: top;
}

.bike-spec tr:last-child th,
.bike-spec tr:last-child td {
	border-bottom: none;
}

.bike-spec td:first-child {
	width: 42%;
	color: var(--color-muted);
	font-weight: 600;
	background: #f3f3f0;
}

.bike-spec .bike-spec__section th {
	font-family: var(--font-serif);
	text-align: left;
	background: #e0e0dc;
	color: var(--color-text);
}

.bike-related {
	margin-top: var(--space-8);
	padding-top: var(--space-5);
	border-top: 1px solid var(--color-border);
}

.bike-related__title {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	margin: 0 0 var(--space-3);
}

.bike-related__list {
	margin: 0;
	padding-left: 1.2rem;
}

.bike-related__list a {
	color: var(--color-link);
}

/* Community photos & comments on bike detail */
.bike-community,
.bike-comments {
	margin-top: var(--space-8);
	padding-top: var(--space-5);
	border-top: 1px solid var(--color-border);
}

.bike-community__title,
.bike-comments__title {
	font-family: var(--font-serif);
	font-size: 1.2rem;
	margin: 0 0 var(--space-3);
}

.bike-community__note,
.bike-community__empty,
.bike-comments__empty,
.bike-community__cta,
.bike-comments__cta {
	margin: 0 0 var(--space-4);
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--color-muted);
}

.bike-community__note a,
.bike-community__cta a,
.bike-comments__cta a {
	color: var(--color-link);
	font-weight: 600;
}

.bike-community__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--space-4);
	margin-bottom: var(--space-5);
}

.bike-community__cell .bike-photo-thumb img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius);
	border: 1px solid var(--color-border);
}

.bike-community__meta {
	margin: var(--space-2) 0 0;
	font-size: 0.85rem;
	color: var(--color-muted);
	line-height: 1.4;
}

.bike-community__form,
.bike-comments__form {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-3);
	max-width: 36rem;
}

.bike-community__label,
.bike-comments__label {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-text);
}

.bike-community__input {
	width: 100%;
	max-width: 28rem;
}

.bike-comments__textarea {
	width: 100%;
	max-width: 36rem;
	min-height: 7rem;
	padding: var(--space-2) var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font: inherit;
	resize: vertical;
	box-sizing: border-box;
}

.bike-comments__textarea:focus {
	outline: 2px solid var(--color-link);
	outline-offset: 2px;
}

.bike-comments__list {
	list-style: none;
	margin: 0 0 var(--space-5);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.bike-comments__item {
	padding: var(--space-3) var(--space-4);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
}

.bike-comments__head {
	font-size: 0.9rem;
	margin-bottom: var(--space-2);
	color: var(--color-muted);
}

.bike-comments__date {
	font-weight: 400;
	opacity: 0.9;
}

.bike-comments__body {
	font-size: 0.95rem;
	line-height: 1.55;
	word-break: break-word;
}

.bike-comments__body br {
	content: '';
	display: block;
	margin-bottom: 0.35em;
}

/* Bot honeypot: off-screen, not display:none (some bots skip hidden inputs) */
.account-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
}

/* Colophon */
.colophon {
	max-width: 40rem;
	margin: 0 auto;
	padding: var(--space-4);
}

.colophon h1 {
	font-family: var(--font-serif);
}

/* Soften legacy global link rules inside theme */
.theme-archive .blog-list a,
.theme-archive .blog-post a {
	color: var(--color-link);
}

.theme-archive .site-main .blog-list,
.theme-archive .site-main .blog-post,
.theme-archive .site-main .blog-empty {
	margin-left: auto;
	margin-right: auto;
	max-width: 48rem;
	padding: 0 var(--space-2);
}

.theme-archive .site-main .account-wrap,
.theme-archive .site-main .account-container {
	margin-left: auto;
	margin-right: auto;
}

/* Legacy link colors: only for non-redesigned pages (no .theme-archive on body) */
body:not(.theme-archive) a:link { color: black; }
body:not(.theme-archive) a:visited { color: black; }
body:not(.theme-archive) a:hover { color: red; }
body:not(.theme-archive) a:active { color: blue; }
body:not(.theme-archive) a:-webkit-any-link { text-decoration: none; }

.theme-archive .site-nav__link,
.theme-archive .http-error__btn {
	text-decoration: none;
}

@font-face {
    font-family: moonhouse;
    src: url('moonhouse.ttf');
}

.tableheader {
	font-weight: bold;
	padding: 15px 0px 0px 0px;
}

.biketable {
	font-family: helvetica;
	font-size: 14px;
}

.text {
	font-family: helvetica;
	font-size: 14px;
}

body {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

.parent {
	margin-left: auto;
	margin-right: auto;
	width: 965px;
	background-color: rgb(232, 230, 235);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.page-content {
	flex: 1;
}

.content-row {
	overflow: auto;
}

.ad-sidebar {
	float: right;
	padding: 10px;
}

.site-footer {
	margin-top: auto;
}

.blog-list {
	font-family: helvetica;
	font-size: 14px;
	margin: 20px;
	max-width: 780px;
}

.blog-intro {
	margin-bottom: 15px;
}

.blog-list-items {
	list-style: none;
	margin: 0;
	padding: 0;
}

.blog-list-items li {
	margin-bottom: 20px;
}

.blog-post {
	font-family: helvetica;
	font-size: 14px;
	margin: 20px;
	max-width: 780px;
	line-height: 1.5;
}

.blog-back {
	margin-top: 1.5em;
	padding-top: 1em;
	border-top: 1px solid #ddd;
}

.blog-empty {
	font-family: helvetica, Arial, sans-serif;
	margin: 20px;
	max-width: 780px;
	color: #555;
}

.blog-empty code {
	font-size: 13px;
}

/* --- Admin visit stats --- */
.visit-stats {
	font-family: helvetica, Arial, sans-serif;
	margin: 16px 0 32px;
	max-width: 920px;
}

.visit-stats__title {
	margin: 0 0 8px;
	font-size: 1.35rem;
}

.visit-stats__note,
.visit-stats__warn {
	font-size: 13px;
	line-height: 1.45;
	color: #444;
	margin: 0 0 16px;
}

.visit-stats__warn {
	color: #7a1e1e;
	background: #fde8e8;
	padding: 10px 12px;
	border-radius: 6px;
	border: 1px solid #e8b4b4;
}

.visit-stats__summary {
	margin: 0 0 20px;
	padding-left: 1.2em;
	line-height: 1.6;
}

.visit-stats h2 {
	font-size: 1.05rem;
	margin: 22px 0 10px;
}

.visit-stats__table {
	border-collapse: collapse;
	width: 100%;
	max-width: 920px;
	font-size: 13px;
	margin-bottom: 8px;
}

.visit-stats__table th,
.visit-stats__table td {
	border: 1px solid #ccc;
	padding: 6px 8px;
	text-align: left;
	vertical-align: top;
}

.visit-stats__table th {
	background: #e8ecf2;
}

.visit-stats__uri {
	word-break: break-all;
	max-width: 420px;
}

.visit-stats__ua {
	max-width: 280px;
	word-break: break-word;
}

.visit-stats__table--wide {
	font-size: 12px;
}

.visit-stats__filters {
	font-family: helvetica, Arial, sans-serif;
	font-size: 14px;
	margin: 0 0 16px;
}

.visit-stats__filter {
	color: #1a4a8a;
	font-weight: 600;
	text-decoration: none;
}

.visit-stats__filter:hover {
	text-decoration: underline;
}

.visit-stats__filter--active {
	color: #111;
	text-decoration: underline;
}

.visit-stats__sep {
	color: #888;
	margin: 0 6px;
}

.visit-stats__tag {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 4px;
	text-transform: uppercase;
}

.visit-stats__tag--human {
	background: #d4edda;
	color: #155724;
}

.visit-stats__tag--bot {
	background: #e2e3e5;
	color: #383d41;
}

/* --- Admin shell --- */
.admin-shell {
	max-width: 900px;
	margin: 10px 0 0 25px;
	box-sizing: border-box;
}

.admin-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 10px;
	align-items: center;
	background: #dfe3e8;
	border: 1px solid #c5ccd6;
	border-radius: 8px;
	padding: 10px 12px;
	margin-bottom: 4px;
}

.admin-nav__link {
	font-family: helvetica, Arial, sans-serif;
	font-size: 14px;
	font-weight: 600;
	padding: 8px 14px;
	border-radius: 8px;
	border: 1px solid #b8c0cc;
	background: linear-gradient(180deg, #fff 0%, #eef1f5 100%);
	color: #1a1a1a;
	text-decoration: none;
	display: inline-block;
}

.admin-nav__link:hover {
	border-color: #5a7aad;
	color: #1e3a5f;
}

.admin-nav__link:focus-visible {
	outline: 2px solid #5a7aad;
	outline-offset: 2px;
}

.admin-nav__disabled {
	font-family: helvetica, Arial, sans-serif;
	font-size: 13px;
	padding: 8px 12px;
	border-radius: 8px;
	color: #6b7280;
	background: #e8eaed;
	border: 1px dashed #b8c0cc;
	cursor: not-allowed;
}

/* --- Admin bike selector + AJAX root --- */
.admin-bike-toolbar {
	font-family: helvetica, Arial, sans-serif;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px 16px;
	background: #eef2f7;
	border: 1px solid #c5ccd6;
	border-radius: 8px;
	padding: 14px 16px;
	margin: 12px 0 0;
	max-width: 880px;
	box-sizing: border-box;
}

.admin-bike-toolbar__label {
	font-weight: 600;
	font-size: 14px;
	color: #333;
}

.admin-bike-toolbar__select {
	font-family: inherit;
	font-size: 14px;
	min-width: 280px;
	max-width: 100%;
	padding: 8px 10px;
	border-radius: 6px;
	border: 1px solid #b8c0cc;
	background: #fff;
}

.admin-ajax-root {
	max-width: 880px;
	margin-top: 16px;
	min-height: 120px;
	box-sizing: border-box;
}

.admin-ajax-loading,
.admin-ajax-error {
	font-family: helvetica, Arial, sans-serif;
	font-size: 14px;
	padding: 20px;
	color: #555;
}

.admin-ajax-error {
	color: #8b2c2c;
	background: #fde8e8;
	border-radius: 8px;
	border: 1px solid #e8b4b4;
}

/* --- Modern upload (drag & drop) --- */
.upload-card-modern {
	font-family: helvetica, Arial, sans-serif;
	background: #fff;
	border: 1px solid #c5ccd6;
	border-radius: 10px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	padding: 22px 22px 20px;
	max-width: 880px;
	box-sizing: border-box;
}

.upload-card-modern__head {
	margin-bottom: 18px;
}

.upload-card-modern__title {
	margin: 0 0 6px;
	font-size: 1.35rem;
	font-weight: 600;
	color: #1a1a1a;
}

.upload-card-modern__subtitle {
	margin: 0;
	font-size: 14px;
	line-height: 1.45;
	color: #444;
}

.upload-card-modern__form {
	margin: 0;
}

.upload-card-modern__file-input {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.upload-dropzone {
	border: 2px dashed #9aacbf;
	border-radius: 10px;
	background: linear-gradient(180deg, #f8fafc 0%, #eef3f9 100%);
	padding: 32px 20px;
	text-align: center;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.upload-dropzone:hover,
.upload-dropzone:focus {
	outline: none;
	border-color: #5a7aad;
	box-shadow: 0 0 0 3px rgba(90, 122, 173, 0.2);
}

.upload-dropzone--active {
	border-color: #3d5a80;
	background: #e8f0fc;
	box-shadow: inset 0 0 0 1px rgba(61, 90, 128, 0.15);
}

.upload-dropzone__icon {
	font-size: 2.2rem;
	line-height: 1;
	color: #6b7c90;
	margin-bottom: 8px;
}

.upload-dropzone__text {
	margin: 0 0 4px;
	font-size: 16px;
	color: #2a3340;
}

.upload-dropzone__hint {
	margin: 0;
	font-size: 13px;
	color: #5c6570;
}

.upload-card-modern__errors {
	margin: 12px 0 0;
	padding: 10px 12px;
	font-size: 13px;
	background: #fff8e6;
	border: 1px solid #e8d48b;
	border-radius: 6px;
	color: #6b5a1a;
}

.upload-preview-modern {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 12px;
	margin-top: 16px;
	min-height: 0;
}

.upload-preview-modern--has-items {
	margin-bottom: 8px;
}

.upload-thumb-cell {
	position: relative;
	background: #f4f6f9;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid #dce2eb;
}

.upload-thumb-img {
	display: block;
	width: 100%;
	height: 100px;
	object-fit: cover;
}

.upload-thumb-ph {
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	color: #8899aa;
}

.upload-thumb-remove {
	position: absolute;
	top: 4px;
	right: 4px;
	width: 26px;
	height: 26px;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.upload-thumb-remove:hover {
	background: rgba(180, 40, 40, 0.9);
}

.upload-thumb-cap {
	font-size: 11px;
	padding: 6px 8px;
	color: #444;
	word-break: break-all;
	line-height: 1.3;
}

.upload-card-modern__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 18px;
	padding-top: 14px;
	border-top: 1px solid #e4e9f0;
}

.upload-btn {
	font-family: inherit;
	font-size: 14px;
	padding: 10px 18px;
	border-radius: 6px;
	cursor: pointer;
	border: 1px solid #b8c0cc;
	background: #fff;
}

.upload-btn--primary {
	background: linear-gradient(to bottom, #5a7aad, #3d5a80);
	color: #fff;
	border-color: #2f4a6e;
	font-weight: 600;
}

.upload-btn--primary:hover:not(:disabled) {
	filter: brightness(1.06);
}

.upload-btn--primary:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.upload-btn--ghost:hover {
	border-color: #6b8cce;
}

.moderate-community {
	max-width: 880px;
	margin: 0 0 24px;
}

.moderate-community__h2 {
	font-size: 1.05rem;
	margin: 24px 0 12px;
}

.moderate-community__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.moderate-community__item {
	padding: 12px 0;
	border-bottom: 1px solid #e8ecf0;
	font-size: 14px;
	line-height: 1.45;
}

.moderate-community__preview {
	display: inline-block;
	margin-top: 6px;
	color: #475569;
	word-break: break-word;
}

.moderate-community__form {
	display: inline-block;
	margin: 8px 0 0 8px;
	vertical-align: middle;
}

/* --- Edit pictures panel --- */
.editpics-panel {
	font-family: helvetica, Arial, sans-serif;
	background: #fff;
	border: 1px solid #c5ccd6;
	border-radius: 10px;
	padding: 18px 20px 8px;
	max-width: 880px;
	box-sizing: border-box;
}

.editpics-panel__title {
	margin: 0 0 16px;
	font-size: 1.2rem;
	font-weight: 600;
}

.editpics-row {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	align-items: flex-start;
	padding: 14px 0;
	border-bottom: 1px solid #e8ecf0;
}

.editpics-row:last-of-type {
	border-bottom: none;
}

.editpics-row__check {
	padding-top: 36px;
}

.editpics-row__thumb {
	flex: 0 0 auto;
}

.editpics-row__thumb img {
	display: block;
	max-width: 200px;
	height: auto;
	border-radius: 6px;
	border: 1px solid #ddd;
}

.editpics-row__meta {
	flex: 1 1 240px;
	min-width: 200px;
}

.editpics-label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	margin-bottom: 6px;
	color: #444;
}

.editpics-textarea {
	width: 100%;
	box-sizing: border-box;
	font-family: inherit;
	font-size: 13px;
	padding: 8px 10px;
	border-radius: 6px;
	border: 1px solid #b8c0cc;
}

.upload-card {
	font-family: helvetica;
	font-size: 14px;
	background: #f4f8ff;
	border: 1px solid #c7d6ef;
	padding: 14px;
	margin: 10px 0 0 0;
	width: 720px;
	box-sizing: border-box;
}

.upload-title {
	margin: 0 0 10px 0;
	font-size: 18px;
}

.upload-label {
	display: block;
	margin-bottom: 8px;
	font-weight: bold;
}

.upload-help {
	margin: 8px 0 10px 0;
	color: #333;
}

.upload-preview {
	background: #fff;
	border: 1px solid #d8d8d8;
	min-height: 34px;
	padding: 8px;
	margin-bottom: 12px;
	max-height: 180px;
	overflow-y: auto;
}

.upload-preview-row {
	padding: 3px 0;
	border-bottom: 1px solid #efefef;
}

.upload-submit {
	font-family: helvetica;
	font-size: 14px;
	padding: 8px 14px;
	cursor: pointer;
}

.bikelist {
font-family: helvetica;
font-size: 14px;
list-style: none;
margin: 0px;
padding: 0px;
line-height: 1.4;
}

.bikes {
vertical-align: left;
border: 2px;
float: left;
width: 215;
background-color: rgb(198, 202, 248);
margin: 20px;
}

button.adminbutton {
font-family: helvetica;
font-size: 12px;
color: black;
//margin: 25px 4px;
//padding: 10px 20px;
//background: -webkit-gradient( linear, left top, left bottom, from(#ffffff), color-stop(0.50, #ffffff), to(grey));
//-moz-border-radius: 10px;
//-webkit-border-radius: 10px;
//border-radius: 10px;
//border: 1px solid black;
}

button.css3button {
	font-family: helvetica;
	font-size: 15px;
	color: black;
	margin: 25px 4px;
	padding: 10px 20px;
	background: -webkit-gradient( linear, left top, left bottom, from(#ffffff), color-stop(0.50, #ffffff), to(grey));
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	border: 1px solid black;
}

/* --- Account area (login / dashboard) --- */
.account-wrap {
	font-family: helvetica, Arial, sans-serif;
	max-width: 420px;
	margin: 28px auto 48px;
	padding: 0 16px;
	box-sizing: border-box;
}

.account-card {
	background: #fff;
	border: 1px solid #c5ccd6;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
	padding: 28px 28px 22px;
}

.account-title {
	margin: 0 0 8px;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
}

.account-lead {
	margin: 0 0 20px;
	font-size: 14px;
	line-height: 1.45;
	color: #444;
}

.account-flash {
	margin: 0 0 16px;
	padding: 10px 12px;
	border-radius: 6px;
	font-size: 14px;
}

.account-flash--error {
	background: #fde8e8;
	border: 1px solid #f5b5b5;
	color: #7a1e1e;
}

.account-form {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.account-label {
	display: block;
	margin-top: 14px;
	margin-bottom: 6px;
	font-size: 13px;
	font-weight: 600;
	color: #333;
}

.account-label:first-of-type {
	margin-top: 0;
}

.account-input {
	font-family: inherit;
	font-size: 15px;
	padding: 10px 12px;
	border: 1px solid #b8c0cc;
	border-radius: 6px;
	width: 100%;
	box-sizing: border-box;
}

.account-input:focus {
	outline: 2px solid #6b8cce;
	outline-offset: 1px;
	border-color: #6b8cce;
}

.account-btn {
	font-family: inherit;
	font-size: 15px;
	margin-top: 22px;
	padding: 11px 18px;
	border-radius: 6px;
	cursor: pointer;
	border: 1px solid #3d5a80;
}

.account-btn--primary {
	background: linear-gradient(to bottom, #5a7aad, #3d5a80);
	color: #fff;
	font-weight: 600;
}

.account-btn--primary:hover {
	filter: brightness(1.05);
}

.account-foot {
	margin: 18px 0 0;
	font-size: 13px;
}

.account-toolbar {
	font-family: helvetica, Arial, sans-serif;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	background: linear-gradient(180deg, #f8f9fc 0%, #eef1f7 100%);
	border: 1px solid #c5ccd6;
	border-radius: 12px;
	padding: 14px 18px;
	margin: 20px 0 0;
	max-width: 960px;
	box-sizing: border-box;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.account-toolbar__identity {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
}

.account-avatar {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, #5a7aad 0%, #3d5a80 100%);
	color: #fff;
	font-size: 1.1rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 6px rgba(61, 90, 128, 0.35);
}

.account-toolbar__meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.account-toolbar__eyebrow {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #64748b;
}

.account-toolbar__user {
	font-size: 1.05rem;
	font-weight: 700;
	color: #0f172a;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 220px;
}

.account-toolbar__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	justify-content: flex-end;
}

.account-toolbar__link {
	font-size: 13px;
	font-weight: 600;
	padding: 8px 12px;
	border-radius: 8px;
	background: #fff;
	border: 1px solid #c5ccd6;
	color: #1e293b;
	text-decoration: none;
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.account-toolbar__link:hover {
	border-color: #6b8cce;
	color: #1e3a5f;
	background: #f8fafc;
}

.account-toolbar__link:focus-visible {
	outline: 2px solid #6b8cce;
	outline-offset: 2px;
}

.account-toolbar__link--ghost {
	background: transparent;
	border-color: transparent;
	color: #475569;
}

.account-toolbar__link--ghost:hover {
	background: rgba(255, 255, 255, 0.7);
	border-color: #c5ccd6;
	color: #1e293b;
}

.account-toolbar__link--danger {
	border-color: #e2b6b6;
	background: #fff5f5;
	color: #991b1b;
}

.account-toolbar__link--danger:hover {
	border-color: #dc2626;
	background: #fef2f2;
	color: #7f1d1d;
}

.account-container {
	font-family: helvetica, Arial, sans-serif;
	max-width: 960px;
	margin: 20px 0 40px;
	padding: 0 4px;
	box-sizing: border-box;
}

.account-home {
	margin: 0;
}

.account-home__intro {
	margin: 0 0 24px;
	padding: 0 2px;
}

.account-home__title {
	margin: 0 0 10px;
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
}

.account-home__lead {
	margin: 0;
	max-width: 52ch;
	font-size: 15px;
	line-height: 1.55;
	color: #475569;
}

.account-home__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
}

.account-tile {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 6px;
	padding: 20px 20px 18px;
	background: #fff;
	border: 1px solid #c5ccd6;
	border-radius: 12px;
	text-decoration: none;
	color: inherit;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
	min-height: 100%;
	box-sizing: border-box;
}

.account-tile:hover {
	border-color: #8fa8d4;
	box-shadow: 0 6px 20px rgba(61, 90, 128, 0.12);
	transform: translateY(-2px);
}

.account-tile:focus-visible {
	outline: 2px solid #6b8cce;
	outline-offset: 3px;
}

.account-tile--muted {
	background: #fafbfc;
}

.account-tile--muted:hover {
	background: #fff;
}

.account-tile__kicker {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #64748b;
}

.account-tile__title {
	font-size: 1.05rem;
	font-weight: 700;
	color: #0f172a;
	line-height: 1.25;
}

.account-tile__desc {
	font-size: 14px;
	line-height: 1.5;
	color: #64748b;
	flex: 1;
	margin: 4px 0 10px;
}

.account-tile__action {
	font-size: 13px;
	font-weight: 600;
	color: #3d5a80;
	margin-top: auto;
}

.account-tile:hover .account-tile__action {
	color: #1e3a5f;
	text-decoration: underline;
	text-underline-offset: 3px;
}