/* Тема «Святые Албанцы» */

:root {
	--bg:        #0e0e10;
	--bg-2:      #16161a;
	--bg-3:      #1d1d23;
	--text:      #e7e5df;
	--muted:     #8a8780;
	--line:      #2a2a31;
	--accent:    #c9a567;
	--accent-2:  #b88f4d;
	--danger:    #8a1f2b;
	--maxw:      1120px;
	--radius:    14px;
	--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--font-serif: Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
	background: var(--bg);
	color: var(--text);
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-2); text-decoration: underline; }

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

h1, h2, h3, h4 {
	font-family: var(--font-serif);
	font-weight: 700;
	letter-spacing: 0.01em;
	color: #f5f3ec;
	margin: 0 0 0.5em;
}

.container {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0 24px;
}

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

/* ---------- Шапка ---------- */

.site-header {
	border-bottom: 1px solid var(--line);
	background: rgba(14,14,16,0.92);
	backdrop-filter: blur(8px);
	position: sticky;
	top: 0;
	z-index: 50;
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 14px 24px;
}
.site-brand {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--text);
	text-decoration: none;
	font-family: var(--font-serif);
	font-size: 20px;
}
.site-brand:hover { text-decoration: none; color: #fff; }
.site-brand__mark { font-size: 22px; }
.site-brand__title { font-weight: 700; letter-spacing: 0.02em; }

.site-nav__list {
	display: flex;
	gap: 22px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.site-nav__list a {
	color: var(--text);
	text-decoration: none;
	font-size: 15px;
}
.site-nav__list a:hover { color: var(--accent); }

.site-account {
	display: flex;
	align-items: center;
	gap: 16px;
	font-size: 14px;
}
.site-account__name { color: var(--muted); }
.site-account__link {
	border: 1px solid var(--line);
	padding: 8px 14px;
	border-radius: 8px;
	color: var(--text);
}
.site-account__link:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

/* ---------- Кнопки ---------- */

.btn {
	display: inline-block;
	padding: 12px 22px;
	border-radius: 10px;
	border: 1px solid var(--line);
	background: transparent;
	color: var(--text);
	font-size: 15px;
	cursor: pointer;
	transition: all 0.15s ease;
}
.btn:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.btn--primary {
	background: var(--accent);
	border-color: var(--accent);
	color: #1a1410;
	font-weight: 600;
}
.btn--primary:hover { background: var(--accent-2); border-color: var(--accent-2); color: #1a1410; }

/* ---------- Hero ---------- */

.hero {
	padding: 96px 0 72px;
	background: radial-gradient(circle at 30% 20%, rgba(201,165,103,0.08), transparent 60%),
	            radial-gradient(circle at 80% 80%, rgba(138,31,43,0.10), transparent 60%);
}
.hero__inner { max-width: 760px; }
.hero__eyebrow {
	color: var(--accent);
	text-transform: uppercase;
	letter-spacing: 0.18em;
	font-size: 13px;
	margin: 0 0 18px;
}
.hero__title {
	font-size: 72px;
	margin: 0 0 24px;
	line-height: 1.05;
}
.hero__lead {
	font-size: 19px;
	color: #d6d3ca;
	max-width: 620px;
	margin: 0 0 32px;
}
.hero__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.hero__hint { color: var(--muted); font-size: 14px; }

/* ---------- Секции ---------- */

.section { padding: 64px 0; }
.section__header { margin-bottom: 32px; }
.section__title {
	font-size: 36px;
	margin: 0 0 8px;
}
.section__sub { color: var(--muted); margin: 0; font-size: 16px; }

.section--features { padding-top: 24px; padding-bottom: 96px; }
.features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.feature {
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 28px;
}
.feature__icon { font-size: 28px; margin-bottom: 12px; }
.feature__title { font-size: 22px; margin: 0 0 8px; }
.feature p { margin: 0; color: #c4c1b9; }

/* ---------- Сетка членов ---------- */

.member-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 18px;
}
.member-card {
	display: flex;
	flex-direction: column;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	color: var(--text);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease;
}
.member-card:hover {
	border-color: var(--accent);
	color: var(--text);
	text-decoration: none;
	transform: translateY(-2px);
}
.member-card__photo {
	aspect-ratio: 1 / 1;
	background: var(--bg-3);
	overflow: hidden;
}
.member-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.member-card__photo-placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-serif);
	font-size: 64px;
	color: var(--accent);
	background: linear-gradient(135deg, #1d1d23, #0e0e10);
}
.member-card__photo-placeholder--large { font-size: 120px; }

.member-card__body { padding: 16px 18px 20px; }
.member-card__name {
	font-size: 18px;
	margin: 0 0 6px;
}
.member-card__meta { color: var(--muted); margin: 0; font-size: 14px; }

/* ---------- Карточка члена клуба ---------- */

.member-page { padding: 48px 0 72px; }
.member-page__grid {
	display: grid;
	grid-template-columns: 360px 1fr;
	gap: 48px;
	align-items: start;
}
.member-page__photo {
	aspect-ratio: 1 / 1;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
}
.member-page__photo img { width: 100%; height: 100%; object-fit: cover; }
.member-page__name {
	font-size: 44px;
	margin: 0 0 24px;
	line-height: 1.1;
}

.member-facts {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 14px 20px;
	margin: 0 0 32px;
	padding: 24px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--bg-2);
}
.member-facts dt { color: var(--muted); font-size: 14px; }
.member-facts dd { margin: 0; }

.member-page__about h2 {
	font-size: 24px;
	margin: 0 0 12px;
	color: var(--accent);
}
.member-page__back { margin-top: 32px; }

/* ---------- Каталог ---------- */

.cat-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 32px;
}
.cat-filter__chip {
	border: 1px solid var(--line);
	background: var(--bg-2);
	color: var(--text);
	padding: 8px 14px;
	border-radius: 999px;
	font-size: 14px;
}
.cat-filter__chip:hover {
	border-color: var(--accent);
	color: var(--accent);
	text-decoration: none;
}
.cat-filter__chip.is-active {
	background: var(--accent);
	border-color: var(--accent);
	color: #1a1410;
}

.item-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 20px;
}
.item-card {
	display: flex;
	flex-direction: column;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	color: var(--text);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease;
}
.item-card:hover {
	border-color: var(--accent);
	color: var(--text);
	text-decoration: none;
	transform: translateY(-2px);
}
.item-card__photo {
	aspect-ratio: 4 / 3;
	background: var(--bg-3);
	overflow: hidden;
}
.item-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.item-card__photo-placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	font-size: 64px;
	color: var(--muted);
}
.item-card__photo-placeholder--large { font-size: 96px; }
.item-card__body { padding: 16px 18px 20px; }
.item-card__cat { color: var(--accent); margin: 0 0 4px; font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em; }
.item-card__title { font-size: 18px; margin: 0 0 6px; }
.item-card__excerpt { color: var(--muted); margin: 0; font-size: 14px; }

/* ---------- Страница вещи ---------- */

.item-page { padding: 48px 0 72px; }
.item-page__grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 48px;
	align-items: start;
}
.item-page__photo {
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
}
.item-page__cat { color: var(--accent); margin: 0 0 8px; text-transform: uppercase; letter-spacing: 0.14em; font-size: 13px; }
.item-page__title { font-size: 40px; margin: 0 0 16px; line-height: 1.1; }
.item-page__lead { font-size: 18px; color: #d6d3ca; }
.item-page__content { margin-top: 16px; }
.item-page__owner { font-size: 14px; margin-top: 24px; }
.item-page__back { margin-top: 32px; }

/* Карточка-владелец на странице вещи */
.item-page__owner-card {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 24px;
	padding: 14px 18px;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.item-page__owner-photo {
	width: 64px; height: 64px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
	background: var(--bg-3);
}
.item-page__owner-photo img { width: 100%; height: 100%; object-fit: cover; }
.item-page__owner-photo-placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-serif);
	font-size: 28px;
	color: var(--accent);
}
.item-page__owner-label {
	margin: 0; color: var(--muted); font-size: 12px;
	text-transform: uppercase; letter-spacing: 0.14em;
}
.item-page__owner-name { margin: 4px 0 0; font-size: 17px; font-weight: 600; }

/* Владелец в карточке каталога */
.item-card__owner {
	margin: 8px 0 0;
	font-size: 13px;
	color: var(--text);
}

/* Адрес в карточке члена */
.member-address {
	font-style: normal;
	line-height: 1.5;
}
.member-address div { display: block; }

/* Блок «В каталоге» на странице члена */
.member-owned {
	margin-top: 32px;
	padding: 20px 24px;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.member-owned h2 {
	font-size: 22px;
	margin: 0 0 12px;
	color: var(--accent);
}
.member-owned__list {
	margin: 0; padding-left: 20px;
}
.member-owned__list li { margin-bottom: 4px; }

/* ---------- Страница ---------- */

.page__header { padding: 56px 0 16px; }
.page__title { font-size: 42px; margin: 0; }
.page__content {
	font-size: 17px;
	line-height: 1.7;
	max-width: 760px;
	padding: 16px 0 64px;
}
.page__content h2 { margin-top: 1.6em; }
.page__content ul, .page__content ol { padding-left: 22px; }

/* ---------- Регламент ---------- */

.reglament__hero {
	padding: 80px 0 36px;
	background: linear-gradient(180deg, rgba(201,165,103,0.08), transparent);
	border-bottom: 1px solid var(--line);
}
.reglament__eyebrow {
	color: var(--accent);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-size: 13px;
	margin: 0 0 12px;
}
.reglament__title { font-size: 56px; margin: 0 0 12px; }
.reglament__sub { color: var(--muted); margin: 0; }
.reglament__body {
	font-size: 17px;
	line-height: 1.75;
	padding: 48px 0 96px;
	max-width: 820px;
}
.reglament__body h2 {
	font-size: 28px;
	margin: 2em 0 0.6em;
	padding-top: 8px;
	border-top: 1px solid var(--line);
}
.reglament__body h3 { font-size: 22px; margin: 1.6em 0 0.4em; }
.reglament__body em {
	color: var(--muted);
	font-style: italic;
}
.reglament__body ul { padding-left: 22px; }
.reglament__body li { margin-bottom: 6px; }

/* ---------- Календарь ---------- */

.section__header--with-action {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
}
.section__action { text-align: right; }
.section__h2 {
	font-size: 22px;
	margin: 32px 0 16px;
	color: var(--accent);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.section__h2--past { margin-top: 56px; }

.btn--small { padding: 8px 14px; font-size: 14px; }
.btn--block { display: block; text-align: center; }
.btn--ghost {
	background: transparent;
	border-color: var(--line);
	color: var(--text);
}

.ics-help {
	margin-top: 12px;
	max-width: 380px;
	font-size: 13px;
	color: var(--muted);
	text-align: left;
}
.ics-help summary {
	cursor: pointer;
	color: var(--accent);
}
.ics-help[open] summary { margin-bottom: 8px; }
.ics-help code {
	background: var(--bg-3);
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 11px;
}

.event-list {
	list-style: none;
	margin: 0; padding: 0;
}
.event-row {
	display: grid;
	grid-template-columns: 96px 1fr auto;
	gap: 20px;
	align-items: center;
	padding: 20px 24px;
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	margin-bottom: 12px;
}
.event-row--past { opacity: 0.7; }
.event-row__date {
	display: flex;
	flex-direction: column;
	align-items: center;
	background: var(--bg-3);
	border: 1px solid var(--line);
	border-radius: 10px;
	padding: 10px 8px;
	color: var(--text);
	text-decoration: none;
}
.event-row__date:hover { border-color: var(--accent); text-decoration: none; }
.event-row__date-day {
	font-family: var(--font-serif);
	font-size: 30px;
	line-height: 1;
	color: var(--accent);
}
.event-row__date-month {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-top: 4px;
}
.event-row__date-time {
	font-size: 13px;
	color: var(--muted);
	margin-top: 6px;
}
.event-row__title {
	font-size: 19px;
	margin: 0 0 4px;
}
.event-row__loc { margin: 4px 0 0; color: #c4c1b9; font-size: 14px; }
.event-row__org { margin: 4px 0 0; font-size: 13px; }
.event-row__desc { margin: 6px 0 0; color: var(--muted); font-size: 14px; }

.event-row__date.event-row__date {
	/* dummy для специфичности — даже когда event-row__date это span (прошедшие) */
}

.notice-box {
	background: var(--bg-2);
	border: 1px dashed var(--line);
	border-radius: var(--radius);
	padding: 20px 24px;
	color: var(--muted);
}
.notice-box p { margin: 0 0 8px; }
.notice-box p:last-child { margin: 0; }

.attendees-list {
	margin: 8px 0 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px 10px;
}
.attendees-list li {
	background: var(--bg-3);
	border: 1px solid var(--line);
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 14px;
}
.event-page__attendees { margin: 16px 0; }

.event-page { padding: 32px 0 72px; }
.event-page__hero { padding: 32px 0 8px; }
.event-page__eyebrow {
	margin: 0 0 8px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-size: 12px;
}
.event-page__title { font-size: 44px; margin: 0 0 8px; }
.event-page__when { font-size: 18px; color: #d6d3ca; }
.event-page__grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 48px;
	align-items: start;
	margin-top: 24px;
}
.event-page__main p { margin: 8px 0; }
.event-page__content {
	margin-top: 24px;
	font-size: 17px;
	line-height: 1.7;
}
.event-page__side {
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 20px 22px;
	position: sticky;
	top: 90px;
}
.small { font-size: 13px; }

@media (max-width: 880px) {
	.event-row { grid-template-columns: 88px 1fr; }
	.event-row__cta { grid-column: 1 / -1; }
	.event-page__grid { grid-template-columns: 1fr; }
}

/* ---------- Подвал ---------- */

.site-footer {
	border-top: 1px solid var(--line);
	padding: 32px 0;
	margin-top: 48px;
}
.site-footer__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
}
.site-footer__brand { font-family: var(--font-serif); margin: 0; }
.site-footer__note { color: var(--muted); margin: 0; font-size: 14px; }

/* ---------- Pagination ---------- */

.nav-links { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 32px; }
.nav-links .page-numbers {
	border: 1px solid var(--line);
	padding: 8px 14px;
	border-radius: 8px;
	color: var(--text);
}
.nav-links .page-numbers.current {
	background: var(--accent);
	color: #1a1410;
	border-color: var(--accent);
}
.nav-links .page-numbers:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

/* ---------- Адаптив ---------- */

@media (max-width: 880px) {
	.hero { padding: 64px 0 48px; }
	.hero__title { font-size: 48px; }
	.section__title { font-size: 28px; }
	.features { grid-template-columns: 1fr; }
	.member-page__grid, .item-page__grid { grid-template-columns: 1fr; gap: 28px; }
	.member-page__photo { max-width: 360px; }
	.member-facts { grid-template-columns: 1fr; }
	.member-facts dt { margin-top: 6px; }
	.reglament__title { font-size: 36px; }
}

@media (max-width: 580px) {
	.site-header__inner { flex-wrap: wrap; gap: 12px; padding: 12px 16px; }
	.site-nav { width: 100%; order: 3; }
	.site-nav__list { gap: 16px; flex-wrap: wrap; }
	.container { padding: 0 16px; }
	.hero__title { font-size: 38px; }
	.member-page__name { font-size: 32px; }
	.item-page__title { font-size: 28px; }
}