/*
Theme Name: ks
Text Domain: ks
*/

/* ============================================
   CSS VARIABLES & RESET
   ============================================ */

:root {
	--bg: #ffffff;
	--card: #ffffff;
	--muted: #475569;
	--text: #0f172a;
	--brand: #0A66C2;
	--brand-2: #2275c8;
	--border: #d8e0ec;
	--surface: rgba(255, 255, 255, 0.55);
	--surface-alt: #f8fafc;
}

* {
	box-sizing: border-box;
}

body {
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, Arial, sans-serif;
	margin: 0;
	background: var(--bg);
	color: var(--text);
	padding-top: 0;
	transition: padding-top 0.8s ease-in-out;
}

button,
input[type="button"],
input[type="submit"],
input[type="search"] {
	border-radius: 100em;
}
a {
	color: inherit;
	text-decoration: none;
}

a:not(.btn):not(.card-icon-btn):not(.filter-chip-remove):not(.card-share-icon):hover,
a:not(.btn):not(.card-icon-btn):not(.filter-chip-remove):not(.card-share-icon):focus-visible {
	color: #1A73E8;
	text-decoration: none;
}

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

p {
	display: block;
	margin-block-start: 10px;
	margin-block-end: 10px;
}

/* ============================================
   LAYOUT & CONTAINERS
   ============================================ */

.container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 16px;
}

.container.single-event {
	padding-top: 0;
}

.content {
	padding: 0 10px;
}

.site-main {
	position: relative;
	z-index: 1;
}

/* Body background gradient */
body.home,
body.single,
body.single-event,
body.policy-page,
body.page-privacy-policy,
body.page-cookie-policy,
body.page-terms-of-use,
body.event-listing-page {
	position: relative;
}

/* ============================================
   HEADER & NAVIGATION
   ============================================ */

.header-inner {
	padding: 10px 16px;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: rgba(255, 255, 255, 0.95);
	z-index: 51;
}

.header-inner-content {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 5px;
}

.header-inner.header-has-border {
	border-bottom: 1px solid #ddd;
}

.logo {
	font-weight: 800;
	font-size: 20px;
	color: var(--text);
	display: inline-flex;
	align-items: center;
}

.logo img {
	height: auto;
	max-height: 20px;
	width: auto;
	display: block;
	filter: brightness(0) saturate(100%) invert(21%) sepia(1%) saturate(0%) hue-rotate(270deg) brightness(95%) contrast(95%);
}

.header-nav {
	display: flex;
	gap: 2px;
	align-items: center;
	font-size: 14px;
}
.header-nav a {
	opacity: .85;
	color: var(--text);
	display: inline-flex;
	align-items: center;
	gap: 2px;
	font-weight: 400;
	text-decoration: none;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 100em;
	padding: 8px;
	font-size: 15px;
}
.header-nav a:hover {
	opacity: 1;
	background-color: var(--text) !important;
	color: var(--bg) !important;
}

.header-nav a:hover img {
	filter: brightness(0) invert(1);
}

.header-nav a img {
	width: 15px;
	height: 15px;
	display: block;
	transition: filter .2s ease;
}

.header-nav a span {
	display: inline-flex;
	align-items: center;
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 50;
	transform: translateY(0);
	transition: transform 0.8s ease-in-out, opacity 0.8s ease-in-out;
	will-change: transform;
	overflow: visible;
	background: rgba(255, 255, 255, 0.95);
	border-bottom: 1px solid #ddd;
	opacity: 1;
}

.site-header.header-hidden {
	transform: translateY(-100%);
	opacity: 0;
}

/* Language switcher */
.lang-switch {
	position: relative;
}

.lang-switch .lang-toggle {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	gap: 6px;
}
.lang-switch .lang-toggle-chevron {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	transition: opacity .2s ease;
}

.lang-menu {
	position: fixed;
	display: none;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
	padding: 8px 0;
	z-index: 300;
}

.lang-menu.open {
	display: block;
}

.lang-menu a {
	display: block;
	padding: 8px 16px;
	color: var(--text);
	text-decoration: none;
	font-size: 14px;
}

@media (max-width: 768px) {
	.site-header {
		border-radius: 0 0 25px 25px;
	}
}
/* ============================================
   TYPOGRAPHY & PAGE TITLES
   ============================================ */

/* SEO-only listing hero: visible to crawlers/screen readers, not on-screen layout */
.listing-hero-seo {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
}

.listing-hero-title,
.listing-hero-description {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
}
/* Page titles - shared base styles */
.publish-event-title,
.login-page-title,
.register-page-title {
	font-family: "Aeonik", sans-serif;
	font-size: 58px;
	font-weight: 700;
	line-height: 58px;
	text-align: center;
	margin: 20px 0 0;
	color: var(--text);
}

.publish-event-title {
	margin: 20px 0;
}

/* Page subtitles - shared base styles */
.login-page-subtitle,
.register-page-subtitle,
.submit-event-subtitle {
	display: block;
	font-family: "Aeonik", sans-serif;
	font-size: 18px;
	font-weight: 700;
	line-height: 18px;
	color: var(--text);
	text-align: center;
	margin: 12px 0 24px;
}

.submit-event-subtitle {
	margin: 0 0 24px;
}
.submit-event-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--brand);
	text-decoration: none;
}

.submit-event-link:hover {
	text-decoration: underline;
}
.submit-event-link img {
	width: 18px;
	height: 18px;
	display: inline-block;
}

/* ============================================
   FILTERS & SEARCH
   ============================================ */

.filter {
	padding: 10px 16px 10px;
	position: relative;
	z-index: 100;
}

.filter .row {
	display: grid;
	grid-template-columns: 4fr 1fr 1fr 2fr;
	gap: 12px;
	max-width: 1100px;
	margin: 0 auto;
	align-items: flex-end;
}
.filter .field label {
	display: block;
	font-size: 16px;
	color: var(--muted);
	margin-bottom: 0;
}

.filter input[type=text],
.filter select {
	width: 100%;
	padding: 10px 12px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 100em;
	color: var(--text);
	font-size: 16px;
}

.location-with-categories input[type=text] {
	border: none;
	background: transparent;
	color: var(--text);
}

/* Location field with embedded category dropdown */
.location-input-wrapper {
	position: relative;
	display: flex;
	align-items: stretch;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 100em;
	overflow: visible;
	box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
	gap: 8px;
}

.location-input-wrapper .location-icon {
	width: 18px;
	height: 18px;
	margin-left: 16px;
	flex-shrink: 0;
	opacity: .55;
	align-self: center;
}

.location-input-wrapper #f-location {
	flex: 1;
	padding: 10px 0;
	background: transparent;
	border: none;
	border-radius: 100em;
	color: var(--text);
	font-size: 16px;
	outline: none;
}

.location-input-wrapper #f-location:focus {
	outline: none;
}

.location-input-wrapper #f-location::placeholder {
	color: var(--muted);
	opacity: .8;
}

.location-input-wrapper .category-dropdown {
	position: relative;
	flex: 0 0 35%;
	display: flex;
	align-items: stretch;
	overflow: visible;
	z-index: 1;
}

.location-input-wrapper .category-dropdown-toggle {
	width: 100%;
	padding: 8px 10px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	font-size: 16px;
}

.location-input-wrapper .category-dropdown-toggle:hover {
	background: rgba(19, 21, 23, .04);
}

.location-input-wrapper .category-dropdown-menu {
	position: absolute;
	top: calc(100% + 2px);
	left: 0;
	right: 0;
	width: 100%;
	margin-top: 0;
	z-index: 9999;
	padding: 4px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.1);
	background: rgba(255, 255, 255, 0.98);
}

.location-with-categories {
	position: relative;
}

.location-with-categories #location-suggest {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	z-index: 1200;
}
.filter .checks {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.filter .checks label {
	font-size: 12px;
	color: var(--muted);
}

/* Category dropdown */
.category-dropdown {
	position: relative;
	width: 100%;
	z-index: 100;
}

.category-dropdown-toggle {
	width: 100%;
	padding: 10px 12px;
	border: none;
	border-left: 1px solid #d8e0ec;
	background-color: transparent;
	border-radius: 100em;
	color: var(--text);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	font-size: 16px;
}

.category-dropdown-toggle:hover {
	background: rgba(255, 255, 255, 0.68);
}

.category-placeholder {
	color: var(--muted);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.category-count {
	display: none;
	font-weight: 600;
	color: var(--brand);
}

.category-arrow {
	opacity: .8;
	display: inline-flex;
	align-items: center;
	margin-left: 5px;
	flex-shrink: 0;
}

.category-arrow img {
	width: 14px;
	height: 14px;
	min-width: 14px;
	min-height: 14px;
	max-width: 14px;
	max-height: 14px;
	display: block;
	flex-shrink: 0;
	object-fit: contain;
}

.category-dropdown.active .category-arrow {
	opacity: 1;
}

.category-dropdown-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	margin-top: 4px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	z-index: 9999;
	padding: 4px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.category-option {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	cursor: pointer;
	border-radius: 6px;
	font-size: 13px;
	color: var(--text);
	margin: 2px 0;
}

.category-option input[type=checkbox] {
	margin: 0;
	cursor: pointer;
	accent-color: var(--brand);
}

.category-parent-group {
	margin: 2px 0;
	background: none;
}

.category-parent {
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 8px;
	position: relative;
}

.category-parent label {
	display: flex;
	align-items: center;
	gap: 8px;
	flex: 1;
	cursor: pointer;
	margin: 0;
}

.category-parent-label {
	pointer-events: all;
}

.category-child {
	padding-left: 32px;
	font-weight: 400;
}

.category-children {
	display: none;
	margin-left: 0;
	padding-left: 0;
}

.category-expand-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	cursor: pointer;
	flex-shrink: 0;
	margin-right: 0;
	position: relative;
	z-index: 10;
	pointer-events: all;
	background: none;
	border: none;
	padding: 0;
	outline: none;
}

.category-expand-toggle:hover {
	opacity: 0.7;
}

.category-expand-toggle:focus {
	outline: 2px solid var(--brand);
	outline-offset: 2px;
	border-radius: 2px;
}

.category-expand-toggle .expand-icon {
	width: 16px;
	height: 16px;
	transition: opacity .2s ease;
	pointer-events: none;
}

.category-name {
	flex: 1;
}

/* Filter dropdowns (Date & Price) */
.filter-dropdown {
	position: relative;
	width: 100%;
	z-index: 100;
}

.filter-dropdown-toggle {
	width: 100%;
	padding: 10px 16px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 100em;
	color: var(--text);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	font-size: 16px;
	overflow: hidden;
	gap: 8px;
}

.filter-dropdown-toggle:hover {
	background: rgb(226, 232, 240, 0.55);
}

.filter-placeholder {
	opacity: .7;
	color: var(--muted);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex: 1;
	min-width: 0;
	overflow-x: auto;
	white-space: nowrap;
	scrollbar-width: none;
	scrollbar-color: transparent transparent;
	-ms-overflow-style: none;
}

.filter-placeholder::-webkit-scrollbar {
	display: none;
	width: 0;
	height: 0;
}

.filter-placeholder img {
	width: 16px;
	height: 16px;
	display: block;
	opacity: .55;
	flex-shrink: 0;
}

.filter-count {
	display: none;
	font-weight: 600;
	color: var(--brand);
	margin-right: 4px;
	flex: 1;
	min-width: 0;
	overflow-x: auto;
	white-space: nowrap;
	scrollbar-width: none;
	scrollbar-color: transparent transparent;
	-ms-overflow-style: none;
}

.filter-count::-webkit-scrollbar {
	display: none;
	width: 0;
	height: 0;
}

.filter-arrow {
	opacity: .8;
	display: inline-flex;
	align-items: center;
	margin-left: 8px;
	flex-shrink: 0;
}

.filter-arrow img {
	width: 14px;
	height: 14px;
	min-width: 14px;
	min-height: 14px;
	max-width: 14px;
	max-height: 14px;
	display: block;
	flex-shrink: 0;
	object-fit: contain;
}

.filter-dropdown.active .filter-arrow {
	opacity: 1;
}

.filter-dropdown-menu {
	display: none;
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid var(--border);
	border-radius: 10px;
	max-height: 500px;
	overflow-y: auto;
	z-index: 9999;
	padding: 12px;
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
	min-width: 280px;
}

/* Date dropdown - higher z-index to appear above Price */
.date-dropdown {
	position: relative;
	z-index: 200;
}

.date-dropdown .filter-dropdown-menu {
	z-index: 10000;
}

/* Price dropdown - lower z-index so Date appears above it */
.price-dropdown {
	position: relative;
	z-index: 150;
}

.price-dropdown .filter-dropdown-menu {
	z-index: 9999;
}

.filter-option {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	cursor: pointer;
	border-radius: 6px;
	font-size: 13px;
	color: var(--text);
	margin: 2px 0;
}

.filter-option:hover {
	background: var(--surface-alt);
}

.filter-option input[type=checkbox] {
	margin: 0;
	cursor: pointer;
	accent-color: var(--brand);
}

/* Toggle groups */
.toggle-group {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.date-presets {
	border-bottom: 1px solid var(--border);
	padding-bottom: 12px;
	margin-bottom: 2px;
}

.date-calendar-wrapper {
	padding-top: 12px;
}

.filter-toggle {
	position: relative;
	display: inline-flex;
}

.filter-toggle input {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip-path: inset(50%);
	white-space: nowrap;
}

.filter-toggle span {
	display: inline-flex;
	align-items: center;
	padding: 8px 14px;
	background: var(--surface-alt);
	border: 1px solid var(--border);
	border-radius: 100em;
	color: var(--text);
	font-size: 16px;
	transition: all .2s;
	white-space: nowrap;
}

.filter-toggle span:hover {
	background: #e2e8f0;
	border-color: var(--brand);
}

.filter-toggle input:checked + span {
	background: var(--brand);
	border-color: var(--brand-2);
	color: #ffffff;
	font-weight: 600;
}

/* ============================================
   CALENDAR
   ============================================ */

#date-range-calendar {
	width: 100%;
}

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

.calendar-month-year {
	font-weight: 600;
	color: var(--text);
	font-size: 14px;
}

.calendar-weekdays {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 4px;
	margin-bottom: 8px;
}

.calendar-weekday {
	text-align: center;
	font-size: 11px;
	color: var(--muted);
	font-weight: 600;
	padding: 4px;
}

.calendar-days {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 4px;
}

.calendar-day {
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 6px;
	cursor: pointer;
	font-size: 13px;
	color: var(--text);
	transition: all .2s;
	position: relative;
	background: var(--surface);
}

.calendar-day:hover {
	background: #e2e8f0;
	color: var(--text);
}

.calendar-day.other-month {
	opacity: .4;
	cursor: default;
	background: var(--surface-alt);
}

.calendar-day.other-month:hover {
	background: var(--surface-alt);
}

.calendar-day.today {
	background: #e0f2fe;
	font-weight: 600;
	color: #0369a1;
}

.calendar-day.selected {
	background: var(--brand);
	color: #ffffff;
	font-weight: 600;
}

.calendar-day.range-start {
	background: var(--brand);
	color: #ffffff;
	font-weight: 600;
	border-top-left-radius: 6px;
	border-bottom-left-radius: 6px;
}

.calendar-day.range-end {
	background: var(--brand);
	color: #ffffff;
	font-weight: 600;
	border-top-right-radius: 6px;
	border-bottom-right-radius: 6px;
}

.calendar-day.in-range {
	background: rgba(10, 102, 194, 0.15);
	color: var(--text);
}

.calendar-day.in-range:hover {
	background: rgba(10, 102, 194, 0.25);
}

/* Account calendar layout & event highlights (reuse filter colors) */
.account-calendar-wrapper {
	margin-bottom: 16px;
}

.account-calendar-wrapper #account-events-calendar {
	display: block;
}

.account-calendar-months {
	display: flex;
	flex-wrap: nowrap;
	gap: 16px;
	align-items: flex-start;
	justify-content: center;
}

.account-calendar-month {
	flex: 0 0 320px;
	max-width: 100%;
}

.calendar-day.has-event.event-author {
	background: rgba(59, 130, 246, 0.15);
}

.calendar-day.has-event.event-favorite {
	background: rgba(244, 63, 94, 0.15);
}

.calendar-day.has-event.event-organizer {
	background: rgba(16, 185, 129, 0.15);
}

.account-calendar-legend {
	display: flex;
	gap: 16px;
	margin-top: 8px;
	font-size: 18px;
	color: var(--muted);
	flex-wrap: wrap;
}

.account-calendar-legend .legend-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.account-calendar-legend .legend-dot {
	width: 18px;
	height: 18px;
	border-radius: 6px;
	display: inline-block;
}

.legend-dot-favorite {
	background: rgba(244, 63, 94, 0.15);
	border: 1px solid rgba(244, 63, 94, 0.6);
}

.legend-dot-author {
	background: rgba(59, 130, 246, 0.15);
	border: 1px solid rgba(59, 130, 246, 0.6);
}

.legend-dot-organizer {
	background: rgba(16, 185, 129, 0.15);
	border: 1px solid rgba(16, 185, 129, 0.6);
}

.legend-dot-today {
	background: #000;
	border: 1px solid #000;
}

.account-calendar-wrapper .calendar-day.today,
.account-calendar-wrapper .calendar-day.today.has-event,
.account-calendar-wrapper .calendar-day.today.has-event.event-author,
.account-calendar-wrapper .calendar-day.today.has-event.event-favorite,
.account-calendar-wrapper .calendar-day.today.has-event.event-organizer {
	background: #000;
	color: #fff;
	font-weight: 600;
}

.account-calendar-wrapper .calendar-day.today:hover,
.account-calendar-wrapper .calendar-day.today.has-event:hover {
	background: #000;
	color: #fff;
}
.filter .actions {
	display: flex;
	gap: 8px;
	align-items: center;
}

/* Form actions (Submit Event, Save as draft) */
.front-form .actions,
#event-form .actions {
	display: flex;
	flex-direction: column;
	gap: 15px;
	align-items: stretch;
}

/* Suggestions */
.suggest {
	position: relative;
}

.suggest ul {
	position: absolute;
	top: 4px;
	left: 0;
	right: 0;
	list-style: none;
	margin: 0;
	padding: 0;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	overflow: hidden;
	z-index: 20;
	box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
}

.suggest li {
	padding: 8px 10px;
	cursor: pointer;
	border-bottom: 1px solid var(--border);
	background: var(--surface);
	color: var(--text);
}

.suggest li:last-child {
	border-bottom: none;
}

.suggest li:hover {
	background: var(--surface-alt);
}

/* ============================================
   BUTTONS
   ============================================ */

.btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border-radius: 100em;
	border: 1px solid #000000;
	padding: 10px 14px;
	background: #000000;
	color: #ffffff;
	cursor: pointer;
	transition: background .2s, border-color .2s, transform .2s;
	font-size: 16px;
}

.btn:hover {
	background: #333333;
	border: 1px solid #333333;
}
.btn .btn-arrow-icon {
	opacity: 0;
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	transition: opacity 160ms ease-out, transform 160ms ease-out;
	transform: translateX(-4px);
}

.btn:hover .btn-arrow-icon {
	opacity: 1;
	transform: translateX(0);
}

.btn .btn-text {
	font-size: 16px;
	transition: transform 160ms ease-out;
	transform: translateX(-4px);
}

.btn:hover .btn-text {
	transform: translateX(0);
}
.btn-primary {
	font-size: 16px;
	background: var(--brand);
	border-color: var(--brand-2);
	color: #ffffff;
}

.btn-primary:hover {
	background: var(--brand-2);
	border: 1px solid var(--brand-2);
}
/* .btn-ghost and .btn-secondary are identical - using one class */
.btn-ghost,
.btn-secondary {
	background: #000000;
	border: 1px solid #000000;
	color: #ffffff;
}

.btn-ghost:hover,
.btn-secondary:hover {
	background: #333333;
	border: 1px solid #333333;
}

/* ============================================
   ACTIVE FILTER CHIPS
   ============================================ */
.active-filters{display:flex;flex-wrap:wrap;gap:8px;padding:12px 0}
.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text)}
.filter-chip-value{font-weight:600;color:var(--brand)}
.filter-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:22px;line-height:1;padding:0;border-radius:4px;transition:all .2s;text-decoration:none}
.filter-chip-remove:hover{background:#e2e8f0;color:var(--text)}

/* ============================================
   CARDS & GRID
   ============================================ */

.card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	min-height: 200px;
}

.no-events-found {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 60px 20px;
}

.no-events-found .no-events-message {
	margin-bottom: 24px;
	font-size: 18px;
	color: var(--muted);
	line-height: 1.6;
}

.card {
	border-radius: 25px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: height .3s ease;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 0px 0px 1px;
}
.card-thumb{
	position:relative;
}
.card-thumb::before{
	content:'';
	position:absolute;
	inset:0;
	background:linear-gradient(to top, rgba(0,0,0,0.25), rgba(0,0,0,0.1));
	z-index:1;
	pointer-events:none;
}
.card-thumb-link{display:block;height:180px;overflow:hidden}
.card-thumb-link img{width:100%;height:180px;object-fit:cover;display:block}
.card-thumb .no-thumb{height:180px;display:flex;align-items:center;justify-content:center;background:var(--surface-alt);color:var(--muted)}

/* Event date/time overlays on card thumb */
.card-date-badge{
	position:absolute;
	top:15px;
	left:20px;
	z-index:2;
	color:#fff;
	text-shadow:0 2px 2px rgba(0,0,0,0.6);
}
.card-date-badge .card-date-top{
	font-size:24px;
	font-weight:750;
	line-height:1;
	text-shadow:0 2px 2px rgba(0,0,0,0.6);
}
.card-date-badge .card-date-bottom{
	font-size:18px;
	font-weight:500;
	line-height:1;
	text-shadow:0 2px 2px rgba(0,0,0,0.6);
	display:flex;
	align-items:center;
	gap:8px;
}
.card-date-badge .card-date-year{
	font-size:13px;
	font-weight:400;
	line-height:1;
	text-shadow:0 2px 2px rgba(0,0,0,0.6);
}
.card-time-badge{
	position:absolute;
	left:8px;
	bottom:8px;
	z-index:2;
	font-size:17px;
	font-weight:500;
	letter-spacing:-0.5px;
	color:#fff;
	text-shadow:0 2px 2px rgba(0,0,0,0.6);
}
.card-icon-btn{position:absolute;z-index:2;background:rgba(255,255,255,0.95);border:1px solid rgba(148,163,184,0.3);border-radius:100em;display:inline-flex;align-items:center;gap:6px;cursor:pointer;box-shadow:0 4px 12px rgba(15,23,42,0.15);padding:10px 10px;font-size:15px;font-weight:500;color:var(--text);white-space:nowrap}
.card-icon-btn .btn-text{display:inline-block}
.card-icon-btn .btn-icon-wrapper{position:relative;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}
.card-icon-btn img{width:18px;height:18px;display:block;transition:opacity .2s ease,transform .2s ease;pointer-events:none}
.card-icon-btn .icon-default{opacity:1;transform:scale(1);position:absolute;top:0;left:0}
.card-icon-btn .icon-hover{opacity:0;transform:scale(0.9);position:absolute;top:0;left:0}
.card-icon-btn:hover .icon-default{opacity:0;transform:scale(0.9)}
.card-icon-btn:hover .icon-hover{opacity:1;transform:scale(1)}
.card-icon-btn:hover .btn-icon-wrapper{transform:scale(1.05)}
.card-icon-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.card-icon-save{top:5px;right:20px;width:45px;height:45px;padding:0;justify-content:center;align-items:center;background:transparent;border:none;box-shadow:none}
.card-icon-save .btn-text{display:none}
.card-icon-save .btn-icon-wrapper{width:40px;height:40px;transition:opacity .2s ease}
.card-icon-save img{width:60px;height:60px;transition:opacity .2s ease;filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(0,0,0,0.3))}
.card-icon-save .icon-default{opacity:1;visibility:visible;transform:none;position:absolute;top:0;left:0;pointer-events:none;transition:opacity .4s cubic-bezier(0.4, 0, 0.2, 1), visibility .4s cubic-bezier(0.4, 0, 0.2, 1);will-change:opacity;backface-visibility:hidden;z-index:1}
.card-icon-save .icon-hover{opacity:0;visibility:hidden;transform:none;position:absolute;top:0;left:0;pointer-events:none;transition:opacity .4s cubic-bezier(0.4, 0, 0.2, 1), visibility .4s cubic-bezier(0.4, 0, 0.2, 1);will-change:opacity;backface-visibility:hidden;z-index:2}
.card-icon-save:hover .icon-default{opacity:0;visibility:hidden}
.card-icon-save:hover .icon-hover{opacity:1;visibility:visible}
.card-icon-save:hover .btn-icon-wrapper{transform:none}
.card-bottom{background-color:rgba(255, 255, 255, 0.2);border-radius:25px;padding:10px 10px;box-shadow:rgba(27, 31, 35, 0.04) 0px 1px 0px, rgba(255, 255, 255, 0.25) 0px 1px 0px inset}
.card .meta{font-size:16px;font-weight:600;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;padding-bottom:12px;border-bottom:1px dotted var(--border);margin-bottom:0}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;padding-bottom:0;gap:12px;margin-top:0}
.card-organizer-wrapper{display:flex;gap:2px;flex:1}
.card-share{margin-top:auto;padding-top:12px}
.card-share-toggle{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;width:100%;background:transparent;border:none;cursor:pointer;transition:opacity .2s;color:var(--muted);text-align:left}
.card-share-toggle:hover{opacity:0.8}
.card-share-toggle:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}
.card-share-content{display:flex;flex-direction:column;align-items:flex-start;flex:1;text-align:left}
.card-share-label-text{font-size:17px;color:var(--muted);font-weight:600;line-height:1.4}
.card-share-chevron{width:16px;height:16px;transition:opacity .2s ease;flex-shrink:0;margin-top:2px}
.card-share-hint{font-size:12px;color:var(--muted);font-weight:400;margin-top:4px;text-align:left}
.card-share-icons{display:flex;align-items:center;justify-content:center;gap:7px;flex-wrap:wrap;overflow:hidden;transition:max-height .3s ease,opacity .3s ease}
.card-share-icons.is-open{display:flex}
.card-share-icon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:auto;min-width:45px;height:auto;padding:0;border:none;background:transparent;cursor:pointer;transition:opacity .2s;text-decoration:none;color:inherit}
.card-share-icon:hover{color:#1A73E8;text-decoration:none}
.card-share-icon:active{color:#1A73E8}
.card-share-icon img{width:30px;height:30px;flex-shrink:0;filter:grayscale(100%) opacity(0.6);transition:filter .2s}
.card-share-icon-label{font-size:11px;color:var(--muted);font-weight:400;line-height:1.2;text-align:center}
.card-share-icon:hover img{filter:brightness(0) saturate(100%) invert(27%) sepia(95%) saturate(2476%) hue-rotate(207deg) brightness(98%) contrast(91%)}
.card-organizer{font-size:13px;color:var(--muted);font-weight:500}
.card-follow-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 15px;
	color: var(--text);
	text-decoration: none;
	background: none;
	border: none;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 100em;
	padding: 8px 22px;
	margin: 0;
	cursor: pointer;
	font-weight: 500;
	transition: background-color .2s ease, color .2s ease;
}
.card-follow-link:hover{background-color:var(--text)!important;color:var(--bg)!important;text-decoration:none}
.card-follow-link .follow-text-wrapper{position:relative;display:inline-block}
.card-follow-link .follow-text{display:inline-block;transition:opacity .2s ease}
.card-follow-link .follow-text-hover{display:inline-block;opacity:0;position:absolute;left:0;top:0;white-space:nowrap;transition:opacity .2s ease;pointer-events:none}
.card-follow-link.is-following:hover .follow-text{opacity:0}
.card-follow-link.is-following:hover .follow-text-hover{opacity:1;pointer-events:all}
.card-icon-btn.is-saved .icon-default{opacity:1}
.card-icon-save.is-saved:hover .icon-default{opacity:0;visibility:hidden}
.card .body{padding:10px;display:flex;flex-direction:column;flex:1;background:linear-gradient(rgba(244, 244, 244, 0.12) 30%, rgba(244, 244, 244, 0.64) 70%)}
.card .event-category{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px;padding-left:4px}
.card .title {
	font-size: 20px;
	font-family: "Franklin ITC", sans-serif;
	margin: 0 0 6px;
	color: var(--text);
}
.card .excerpt{opacity:.9;color:var(--text)}

.load-more-wrap{padding:16px;text-align:right}
.load-more-wrap .btn{width:auto;display:inline-block}
#load-more{width:auto;display:block;margin-left:auto;margin-right:6px;margin-top:26px}
.js-only{display:none}
.nojs{display:block}

/* ============================================
   SINGLE EVENT PAGE
   ============================================ */

.single-event .single-head {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 16px;
}
.single-head-top{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.single-head-top .event-category{font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.single-head-top h1{margin:0;flex:1}
.single-meta{display:flex;flex-wrap:wrap;gap:12px;padding: 0 10px 0 10px;align-items:center}
.single-meta span{display:inline-flex;align-items:center;gap:6px}
.single-meta img{width:16px;height:16px;flex-shrink:0;opacity:0.8}
.single-meta-date,.single-meta-time,.single-meta-remaining{font-weight:700}
.single-meta-date img,.single-meta-time img,.single-meta-remaining img{opacity:1;filter:contrast(1.2) brightness(0.9)}
.single-head-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap;margin-top:8px}
.single-head-actions .btn{width:auto;display:inline-block}
.single-head-actions .card-icon-btn{position:static;top:auto;right:auto}
.single-event .single-thumb {
	margin: 10px 0;
	border-radius: 25px;
	overflow: hidden;
	width: 100%;
	max-width: 1070px;
	position: relative;
}
.single-event .single-thumb:not(.has-slideshow)::before {
	content: '';
	position: absolute;
	inset: -40px;
	background-image: var(--thumb-url);
	background-size: cover;
	background-position: center;
	filter: blur(48px) saturate(1.15);
	transform: scale(1.15);
	z-index: 0;
	pointer-events: none;
}
.single-event .single-thumb img {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 100%;
	height: auto;
	object-fit: contain;
	display: block;
	margin: 0 auto;
}
.single-event .single-thumb-btn{position:absolute;z-index:2}
.single-event .single-thumb-btn-save{top:4px;right:4px}

/* Event Slideshow */
.event-slideshow {
	position: relative;
	width: 100%;
}

.event-slide {
	display: none;
	position: relative;
	width: 100%;
	overflow: hidden;
}

.event-slide::before {
	content: '';
	position: absolute;
	inset: -40px;
	background-image: var(--slide-bg);
	background-size: cover;
	background-position: center;
	filter: blur(48px) saturate(1.15);
	transform: scale(1.15);
	z-index: 0;
	pointer-events: none;
}

.event-slide.active {
	display: block;
}

.event-slide img {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 100%;
	height: auto;
	object-fit: contain;
	display: block;
	margin: 0 auto;
}

.event-slideshow-prev,
.event-slideshow-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background-color: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(148, 163, 184, 0.3);
	border-radius: 100em;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 18px;
	color: var(--text);
	z-index: 3;
	transition: all 0.2s ease;
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.15);
}

.event-slideshow-prev:hover,
.event-slideshow-next:hover {
	background-color: var(--text);
	color: var(--bg);
}

.event-slideshow-prev {
	left: 10px;
}

.event-slideshow-next {
	right: 10px;
}

.event-slideshow-dots {
	position: absolute;
	bottom: 10px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	z-index: 3;
}

.event-slideshow-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.9);
	background-color: rgba(255, 255, 255, 0.5);
	cursor: pointer;
	padding: 0;
	transition: all 0.2s ease;
}

.event-slideshow-dot.active {
	background-color: rgba(255, 255, 255, 0.9);
	border-color: rgba(255, 255, 255, 1);
}

.event-slideshow-dot:hover {
	background-color: rgba(255, 255, 255, 0.8);
}

/* Event Images Upload Form */
.event-images-upload {
	margin-top: 10px;
}

.event-images-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 16px;
}

.event-image-item {
	position: relative;
	border: 2px solid var(--border);
	border-radius: 10px;
	overflow: hidden;
	background: var(--surface-alt);
}

.event-image-preview {
	position: relative;
	width: 100%;
	padding-top: 75%; /* 4:3 aspect ratio */
	overflow: hidden;
}

.event-image-preview img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.event-image-remove {
	position: absolute;
	top: 5px;
	right: 5px;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.95);
	border: 1px solid rgba(148, 163, 184, 0.3);
	color: var(--text);
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
	transition: all 0.2s ease;
	box-shadow: 0 2px 4px rgba(15, 23, 42, 0.15);
}

.event-image-remove:hover {
	background-color: #ef4444;
	color: white;
	border-color: #ef4444;
}

.event-image-primary-label {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px;
	cursor: pointer;
	font-size: 14px;
	background: var(--surface);
	border-top: 1px solid var(--border);
}

.event-image-primary-label input[type="radio"] {
	margin: 0;
	cursor: pointer;
}

.event-image-upload-item {
	margin-top: 10px;
}

.event-image-upload-item .file-input-label {
	display: inline-block;
	padding: 10px 16px;
	background: var(--surface);
	border: 2px dashed var(--border);
	border-radius: 10px;
	cursor: pointer;
	transition: all 0.2s ease;
}

.event-image-upload-item .file-input-label:hover {
	background: var(--surface-alt);
	border-color: var(--brand);
}

.field-help-small {
	font-size: 13px;
	color: var(--muted);
	margin-top: 6px;
}
.details{padding:16px 16px;border-radius:25px;background:linear-gradient(rgba(244, 244, 244, 0.12) 0%, rgba(244, 244, 244, 0.64) 100%);box-shadow:rgba(0, 0, 0, 0.05) 0px 0px 0px 1px}
.details ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.details li{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px;color:var(--text)}
.details-content{display:flex;flex-direction:column;gap:8px}
.detail-field{color:var(--text);padding:0;margin:0}
.detail-field.map-title{margin-top:15px;padding:0 10px 0 10px}
.detail-organizer-field{padding:16px 16px}
.single-event-map-full{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:0;margin-bottom:-70px;max-width:none}
.listing-events-map-full{width:100%;max-width:100%;margin:0 0 -70px 0;position:relative;overflow-x:clip;box-sizing:border-box}
.listing-events-map-full.is-collapsed{display:none}
.listing-events-map-full .listing-events-map{pointer-events:auto}
#listing-events-map{position:relative;width:100%;max-width:100%;height:300px;overflow:hidden;margin:0 0 -100px 0;box-shadow:none;border-radius:0;box-sizing:border-box;mask-image:linear-gradient(to bottom,black 0%,black calc(100% - 170px),rgba(0,0,0,0.5) calc(100% - 85px),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 0%,black calc(100% - 170px),rgba(0,0,0,0.5) calc(100% - 85px),transparent 100%)}
body.single.single-event{overflow-x:clip}
.event-map{position:relative;width:100%;height:300px;overflow:hidden;margin:0;box-shadow:none;border-radius:0;mask-image:linear-gradient(to bottom, black 0%, black calc(100% - 170px), rgba(0,0,0,0.5) calc(100% - 85px), transparent 100%);-webkit-mask-image:linear-gradient(to bottom, black 0%, black calc(100% - 170px), rgba(0,0,0,0.5) calc(100% - 85px), transparent 100%)}
.event-map::after{content:none}
.event-map .leaflet-container,
.event-map.leaflet-container{background:transparent!important;outline-offset:0!important}
.event-map .leaflet-tile{filter:grayscale(96%) brightness(1.2) contrast(0.95)}
.leaflet-overlay-pane svg{-webkit-user-select:none;-moz-user-select:none;user-select:none}
.leaflet-bottom.leaflet-right{top:5px;bottom:auto}
.leaflet-bottom.leaflet-right .leaflet-control-attribution{margin:0}
.event-map.leaflet-container .leaflet-control-attribution,
.event-map .leaflet-control-attribution{background:transparent!important}
.event-map .leaflet-control-attribution,
.event-map .leaflet-control-scale-line{padding:0 10px!important}
.leaflet-container a.leaflet-popup-close-button{display:none}
.event-route-icon-wrapper {
	position: absolute;
	top: 30px;
	right: 24px;
	z-index: 500;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
}

.event-route-icon {
	padding: 0;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 50%;
	text-align: center;
	height: 45px;
	width: 45px;
	box-shadow: 0 5px 33px rgba(0, 0, 0, .2);
	transition: .2s ease;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #0f172a;
}

.event-route-icon:hover {
	box-shadow: 0 5px 33px rgba(0, 0, 0, .3);
}

.event-route-icon:active {
	transform: scale(0.95);
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.2);
}

.event-route-icon img {
	width: 18px;
	height: 18px;
	display: block;
}
.event-route-icon-text{font-size:13px;color:#0f172a;font-weight:600;white-space:nowrap;line-height:1}
.event-route-manual{position:absolute;left:50%;top:105px;transform:translate(-50%,0);display:flex;flex-direction:column;align-items:center;z-index:500;width:auto;max-width:90%;padding:10px;color:#0f172a;background-color:rgba(218,221,245,0.25);border:1px solid rgba(218,221,245,0.1);border-radius:15px;backdrop-filter:blur(5px);pointer-events:all}
.event-route-manual.has-result{top:210px}
.event-route-distance{font-weight:600;color:#0f172a;font-size:16px}
.event-route-manual.is-hidden{display:none}
.event-route-mode-selector{display:flex;gap:16px;justify-content:center;margin-bottom:5px}
.event-route-mode-btn{padding:8px;background:rgba(255,255,255,0.9);border:1px solid rgba(218,221,245,0.3);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:80px;height:36px}
.event-route-mode-btn:hover{background:rgba(255,255,255,1);border-color:rgba(218,221,245,0.5);transform:scale(1.05)}
.event-route-mode-btn:active{transform:scale(0.95)}
.event-route-mode-btn.active{background:rgba(0,123,139,0.15);border-color:#007b8b}
.event-route-mode-btn img{width:24px;height:24px;display:block}
.event-route-close{background:rgba(255,255,255,0.9)}
.event-route-mode-btn.event-route-close{width:36px;height:36px;border-radius:100em}
.event-route-manual-message{margin:0 0 5px;font-size:14px;text-align:center;color:#0f172a}
.event-route-manual-form{display:flex;flex-wrap:nowrap;gap:8px;justify-content:center;align-items:center}
.event-route-manual-form .btn{flex:0 0 auto;white-space:nowrap}
.event-route-manual-form input[type=text]{flex:1 1 220px;min-width:0;padding:10px 12px;border-radius:100em;border:1px solid rgba(255,255,255,0.35);background-color:rgba(15,23,42,0.6);color:#ffffff;font-size:16px}
.event-route-manual-form input[type=text]::placeholder{color:rgba(255,255,255,0.6)}
.event-route-manual-form input[type=text]:focus{outline:2px solid rgba(255,255,255,0.5);outline-offset:2px;border-color:#ffffff;background-color:rgba(15,23,42,0.75)}
.event-route-result{display:flex;align-items:flex-start;gap:12px;justify-content:center;width:auto}
.event-route-result-content{display:flex;flex-direction:row;gap:8px;align-items:center}
.event-route-result-distance{font-size:16px;font-weight:600;color:#0f172a;line-height:1.2}
.event-route-result-duration{font-size:16px;font-weight:600;color:#0f172a;line-height:1.2}
.event-route-result-close{padding:4px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s;flex-shrink:0}
.event-route-result-close:hover{opacity:0.7}
.event-route-result-close img{width:20px;height:20px;display:block}
.btn-small {
	width: auto;
	padding: 10px 5px;
	font-size: 14px;
	border-radius: 100em;
	border: 1px solid #000000;
	background-color: #000000;
	color: #ffffff;
	cursor: pointer;
}

.btn-small:hover {
	background-color: #333333;
	border: 1px solid #333333;
}

/* ============================================
   FORMS
   ============================================ */

/* Front form */
.front-form .grid2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}
.front-form label{display:flex;flex-direction:column;gap:6px;margin-bottom:6px;font-size:14px;color:var(--text)}
.front-form input, .front-form textarea{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:16px}

/* front-event-form and event-form shared styles - both forms must be identical */
#front-event-form, #event-form{
	margin-top:25px;
	max-width:700px;
	margin-left:auto;
	margin-right:auto;
}
#front-event-form .grid2, #event-form .grid2{display:grid;grid-template-columns:1fr;gap:12px}

/* Event form styling */
.form-title{font-size:24px;font-weight:700;margin:0 0 12px;color:var(--text)}
.form-intro{margin:0 0 8px;color:var(--muted);font-size:14px}
.form-fields{display:flex;flex-direction:column;gap:20px;margin:24px 0}
.form-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
	position: relative;
}
.form-field-dates {
	display: flex;
	flex-direction: row;
	gap: 20px;
}
.form-field-dates .form-field {
	flex: 1;
}
@media (max-width: 700px) {
	.form-field-dates {
		flex-direction: column;
	}
}
.form-field-prices {
	display: flex;
	flex-direction: row;
	gap: 20px;
}
.form-field-prices .form-field {
	flex: 1;
}
@media (max-width: 700px) {
	.form-field-prices {
		flex-direction: column;
	}
}

.form-field > div {
	margin-left: 0;
	padding-left: 0;
}

.form-field > div > label {
	display: block;
	margin-left: 0;
	padding-left: 0;
	text-align: left;
}

.field-label {
	font-size: 14px;
	color: var(--text);
	margin: 0;
}

.field-label .optional {
	font-weight: 400;
	opacity: 0.7;
}

.field-label-small {
	font-size: 12px;
	color: var(--muted);
	margin: 0 0 4px 0;
	display: block;
	font-weight: 500;
}

.field-help {
	margin: 0;
	font-size: 13px;
	color: var(--muted);
	line-height: 1.4;
}


.time-input-wrapper {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	margin-bottom: 0;
}

.time-format-field,
.time-value-field {
	flex: 1;
	width: 50%;
	display: flex;
	flex-direction: column;
	position: relative;
}

.time-input-wrapper select,
.time-input-wrapper input {
	width: 100%;
}

.time-input-help {
	margin: 4px 0 0 0;
	font-size: 12px;
	line-height: 1.4;
	min-height: 0;
}

.time-input-help:empty {
	display: none;
}

.time-input-help.success {
	color: #22c55e;
}

.time-input-help.error {
	color: #ef4444;
}

/* Form field validation styles - apply to all inputs (including #event-time-input) */
.front-form input[type="text"].is-valid,
.front-form input[type="email"].is-valid,
.front-form input[type="url"].is-valid,
.front-form input[type="number"].is-valid,
.front-form input[type="date"].is-valid,
.front-form input[type="time"].is-valid,
.front-form input[type="tel"].is-valid,
.front-form select.is-valid,
.front-form textarea.is-valid {
	border-color: #22c55e;
	box-shadow: 0 0 0 1px #22c55e;
}

.front-form input[type="text"].is-invalid,
.front-form input[type="email"].is-invalid,
.front-form input[type="url"].is-invalid,
.front-form input[type="number"].is-invalid,
.front-form input[type="date"].is-invalid,
.front-form input[type="time"].is-invalid,
.front-form input[type="tel"].is-invalid,
.front-form select.is-invalid,
.front-form textarea.is-invalid {
	border-color: #ef4444;
	box-shadow: 0 0 0 1px #ef4444;
}

/* Time Picker Styles */
.time-input-container {
	position: relative;
	display: flex;
	align-items: center;
}

.time-input-container input {
	padding-right: 45px;
}

.time-picker-btn {
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--muted);
	transition: color 0.2s;
	border-radius: 6px;
}

.time-picker-btn:hover {
	color: var(--text);
	background: var(--surface-alt);
}

.time-picker-btn svg {
	width: 20px;
	height: 20px;
}

.time-picker-popup {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	z-index: 1000;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
	min-width: 280px;
}

@media (max-width: 700px) {
	.time-picker-popup {
		left: auto;
		right: 0;
	}
}

.time-picker-content {
	padding: 20px;
}

.time-picker-inputs {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	gap: 8px;
	margin-bottom: 16px;
}

.time-picker-hour,
.time-picker-minute {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.time-picker-hour label,
.time-picker-minute label {
	font-size: 11px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.time-picker-hour input,
.time-picker-minute input {
	width: 60px;
	padding: 8px;
	text-align: center;
	font-size: 18px;
	font-weight: 600;
	border: 1px solid var(--border);
	border-radius: 8px;
	background: var(--surface-alt);
	color: var(--text);
}

.time-picker-separator {
	font-size: 24px;
	font-weight: 600;
	color: var(--text);
	margin-bottom: 8px;
}

.time-picker-period {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-left: 8px;
}

.time-picker-period button {
	padding: 6px 12px;
	border: 1px solid var(--border);
	background: var(--surface-alt);
	color: var(--text);
	border-radius: 6px;
	cursor: pointer;
	font-size: 12px;
	font-weight: 600;
	transition: all 0.2s;
}

.time-picker-period button:hover {
	background: var(--border);
}

.time-picker-period button.active {
	background: var(--text);
	color: var(--bg);
	border-color: var(--text);
}

.time-picker-actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
}

.time-picker-actions .btn {
	padding: 8px 16px;
	font-size: 14px;
}

.front-form input[type="text"],
.front-form input[type="email"],
.front-form input[type="url"],
.front-form input[type="number"],
.front-form input[type="date"],
.front-form input[type="time"],
.front-form input[type="file"],
.front-form select,
.front-form textarea{width:100%;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:16px;font-family:inherit}

/* Ensure date/time inputs match other fields on iOS Safari */
.front-form input[type="date"],
.front-form input[type="time"]{
	max-width:100%;
	appearance:none;
	-webkit-appearance:none;
	padding:10px 12px;
	min-height:44px;
}
.front-form input::placeholder,
.front-form textarea::placeholder{color:var(--muted);opacity:0.6}
.category-toggles{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.category-toggle{display:inline-flex;align-items:center}
.category-toggle input[type="checkbox"]{position:absolute;opacity:0;width:1px;height:1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap}
.category-toggle span{opacity:.85;color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:2px;font-weight:500;text-decoration:none;background-color:rgba(255,255,255,0.2);border:1px solid #e5e7eb;backdrop-filter:blur(4px);border-radius:100em;padding:6px;font-size:14px;transition:all .2s;cursor:pointer;white-space:normal;text-align:center;line-height:1.2;min-height:3.6em;height:3.6em}
.form-field.has-error input,
.form-field.has-error select,
.form-field.has-error textarea{border-color:#ef4444; box-shadow:0 0 0 2px rgba(239,68,68,0.08)}
.form-field .field-error{margin:0; color:#ef4444; font-size:12px}
.form-field.has-error .category-toggles,
.form-field.has-error .category-groups{outline:2px solid rgba(239,68,68,0.6); outline-offset:2px; border-radius:10px}
.category-toggle span:hover{opacity:1;background-color:var(--text)!important;color:var(--bg)!important}
.category-toggle input:checked + span{opacity:1;background-color:var(--text)!important;color:var(--bg)!important}
.category-toggle input:disabled + span{opacity:0.5;cursor:not-allowed}
.category-groups{display:flex;flex-wrap:wrap;gap:12px}
.category-group{flex:1 1 320px;min-width:260px;padding:12px;border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 14px rgba(15,23,42,0.04)}
.category-group-title{margin-bottom:8px}
.category-group-title .category-toggle span{font-weight:700}
.category-group-items{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.category-group-items .category-toggle{width:100%}
.category-group-items .category-toggle span{width:100%}
@media (max-width: 700px){
	.category-group-items{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.file-input-label{display:inline-block;padding:10px 12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:14px;color:var(--text);margin-top:8px}
.file-input-label:hover{background:#e2e8f0}
#event-image-input{display:none}
.current-image {
	margin-top: 12px;
}

.current-image p {
	margin: 0 0 8px;
	font-size: 14px;
	color: var(--text);
}

.current-image img {
	border-radius: 8px;
	max-width: 300px;
}

.form-field {
	position: relative;
}

#se-location-suggest {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 1000;
	margin-top: 4px;
}

.event-submit-success {
	padding: 24px;
	margin: 24px 0;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
}

.event-submit-success .success-message {
	font-size: 16px;
	color: var(--text);
	margin: 0 0 16px;
	line-height: 1.5;
}

.event-submit-success .return-link {
	margin: 0;
	text-align: right;
}

.event-submit-success .return-link .btn {
	width: auto;
	display: inline-block;
}

/* ============================================
   ACCOUNT PAGES
   ============================================ */

.account-form {
	max-width: 700px;
	margin: 0 auto;
}
.account-form label {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 12px;
	font-size: 14px;
	color: var(--text);
}

.account-form .remember-me-label {
	flex-direction: row;
	align-items: center;
	gap: 8px;
}

.account-form input,
.account-form select,
.account-form textarea {
	padding: 10px 12px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	color: var(--text);
	font-size: 16px;
}

.account-form input[type=checkbox] {
	width: auto;
	margin-right: 8px;
}
.account-form p{margin-top:12px;color:var(--muted);font-size:14px}
.account-form #login-message, .account-form #register-message, .account-form #forgot-password-message, .account-form #reset-password-message{color:var(--brand);font-weight:600}
.account-form #login-message.status-error, .account-form #register-message.status-error, .account-form #forgot-password-message.status-error, .account-form #reset-password-message.status-error{color:#b91c1c}
.account-form #login-message.status-success, .account-form #register-message.status-success, .account-form #forgot-password-message.status-success, .account-form #reset-password-message.status-success{color:#15803d}

.oauth-divider{display:flex;align-items:center;text-align:center;margin:24px 0;color:var(--muted);font-size:14px}
.oauth-divider::before,.oauth-divider::after{content:'';flex:1;border-bottom:1px solid var(--border)}
.oauth-divider span{padding:0 12px}
.oauth-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.btn-oauth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 16px;border-radius:100em;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-oauth:hover{background:var(--surface-alt);border-color:var(--border);transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,23,42,0.08)}
.btn-oauth:active{transform:translateY(0)}
.btn-oauth svg{flex-shrink:0}
.btn-google{border-color:#dadce0}
.btn-google:hover{background:#f8f9fa;border-color:#dadce0}
.account-dashboard {
	margin-top: 24px;
}

.my-events-search {
	margin-bottom: 16px;
	max-width: 360px;
}

.my-events-search .field-label-small {
	display: block;
	margin-bottom: 4px;
}

.my-events-search-input {
	width: 100%;
	padding: 8px 12px;
	border-radius: 100em;
	border: 1px solid var(--border);
	background: var(--surface);
	font-size: 14px;
}

.account-dashboard-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 24px;
}

.account-dashboard-header-left {
	display: flex;
	align-items: center;
	gap: 16px;
}

.account-dashboard-header h1 {
	margin: 0;
}

.account-tabs {
	display: flex;
	gap: 10px;
	margin-bottom: 24px;
	border-bottom: 1px solid var(--border);
	padding-bottom: 12px;
	flex-wrap: wrap;
}

.my-events-tabs {
	display: flex;
	gap: 10px;
	margin-bottom: 24px;
	border-bottom: 1px solid var(--border);
	padding-bottom: 12px;
	flex-wrap: wrap;
}
/* Tab buttons - unified styles */
.tab-btn,
.tab-btn-logout {
	opacity: .85;
	color: var(--text);
	display: inline-flex;
	align-items: center;
	gap: 2px;
	font-weight: 500;
	text-decoration: none;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 100em;
	padding: 8px;
	font-size: 14px;
	cursor: pointer;
}

.tab-btn:hover,
.tab-btn-logout:hover {
	opacity: 1;
	background-color: var(--text) !important;
	color: var(--bg) !important;
}

.tab-btn:hover img,
.tab-btn-logout:hover img {
	filter: brightness(0) invert(1);
}

.load-more-wrap {
	padding: 16px;
	text-align: right;
}

.status.status-info {
	margin-left: 8px;
}

.users-toolbar {
	margin-bottom: 16px;
}

.users-sort-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

#users-sort {
	padding: 6px 12px;
	border: 1px solid var(--border);
	border-radius: 6px;
	font-size: 14px;
}

.users-list {
	overflow-x: auto;
}

#users-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.users-table-header-row {
	border-bottom: 1px solid var(--border);
}

.users-table-header-cell,
.users-table-cell {
	padding: 8px;
	text-align: left;
}

.users-table-header-cell {
	font-weight: 600;
}

.user-row {
	border-bottom: 1px solid var(--border);
}

.tab-btn.active {
	opacity: 1;
	background-color: var(--text) !important;
	color: var(--bg) !important;
}

.tab-btn.active img {
	filter: brightness(0) invert(1);
}

.tab-btn img,
.tab-btn-logout img {
	width: 15px;
	height: 15px;
	display: block;
	transition: filter .2s ease;
}

.tab-btn-logout img {
	flex-shrink: 0;
}

.tab-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	background-color: #dc2626;
	color: #ffffff;
	border-radius: 10px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1;
	margin-left: 6px;
}

.calendar-nav-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 45px;
	height: 45px;
	padding: 0;
	border: none;
	background: none;
	cursor: pointer;
}

.calendar-nav-btn span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.calendar-nav-btn span img {
	width: 55%;
	height: 55%;
	display: block;
	object-fit: contain;
	flex-shrink: 0;
}

.tab-content {
	display: none;
}

.tab-content.active {
	display: block;
}

.tab-content h2 {
	margin-top: 0;
}

/* My Events status filter tabs */
.my-events-tabs {
	display: flex;
	gap: 10px;
	margin-bottom: 24px;
	border-bottom: 1px solid var(--border);
	padding-bottom: 12px;
	flex-wrap: wrap;
}

.my-events-tab-btn {
	opacity: .85;
	color: var(--text);
	display: inline-flex;
	align-items: center;
	gap: 2px;
	font-weight: 500;
	text-decoration: none;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 100em;
	padding: 6px;
	font-size: 14px;
	cursor: pointer;
	border: none;
}

.my-events-tab-btn:hover {
	opacity: 1;
	background-color: var(--text) !important;
	color: var(--bg) !important;
}

.my-events-tab-btn.active {
	opacity: 1;
	background-color: var(--text) !important;
	color: var(--bg) !important;
}
.account-settings-section {
	margin-bottom: 24px;
}

.account-settings-section-muted {
	color: var(--muted);
	margin-bottom: 24px;
}
.notice-warning {
	padding: 16px;
	background: #fff3cd;
	border: 1px solid #ffc107;
	border-radius: 8px;
	margin-bottom: 24px;
}

.profile-avatar-wrapper {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 12px;
}

.profile-avatar-wrapper > div {
	display: flex;
	gap: 8px;
	flex-direction: row;
}

.avatar-preview {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--border);
}

.avatar-upload-input {
	display: none;
}

.field-help-small {
	color: var(--muted);
	margin-top: 4px;
	display: block;
}
.password-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.password-section h3{margin-bottom:16px}
.password-field-wrapper{position:relative}
.password-input-with-toggle{padding-right:40px;width:100%}
.password-toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;color:var(--muted)}
.eye-icon{width:16px;height:16px}
.eye-slash-icon{width:16px;height:16px;display:none}
.profile-message{margin-top:12px;color:var(--brand);font-weight:600}
.account-delete-section{
	margin-top:32px;
	padding-top:24px;
	border-top:1px solid var(--border);
	max-width:700px;
	margin-left:auto;
	margin-right:auto;
}
.account-delete-section h3{margin-bottom:8px}
.account-delete-warning{color:var(--danger,#b00020);margin-bottom:16px}
.account-delete-message{margin-top:12px;color:var(--danger,#b00020);font-weight:600}
.subscription-section{margin-bottom:32px}
.subscription-intro{color:var(--muted);margin-bottom:16px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:24px 0}
.stat{padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;text-align:center;box-shadow:0 12px 24px rgba(15,23,42,0.06)}
.stat strong{display:block;font-size:24px;color:var(--brand);margin-bottom:4px}

.event-manage{position:relative}
.event-actions-wrapper{margin-top:12px;margin-bottom:5px;background-color:rgba(255,255,255,0.2);border-radius:25px;padding:10px 10px;backdrop-filter:blur(4px);box-shadow:rgba(27,31,35,0.04) 0px 1px 0px, rgba(255,255,255,0.25) 0px 1px 0px inset}
.event-status-row{
	display:flex;
	flex-wrap:wrap;
	align-items:flex-start;
	gap:6px 8px;
	margin-bottom:12px;
}
.event-status-row .status{
	white-space:normal;
	line-height:1.35;
	max-width:100%;
}
.event-status-row .status.status-info{
	margin-left:0;
	flex:1 1 12rem;
}
.event-actions{display:flex;gap:8px;align-items:center}
.event-actions .btn{font-size:14px;font-weight:500;line-height:1.4}
.event-statistics{display:flex;gap:35px;margin-top:12px;padding-top:12px;justify-content:center}
.event-statistics .stat-item{display:flex;flex-direction:column;gap:4px}
.event-statistics .stat-item strong{font-size:18px;font-weight:700;color:var(--text)}
.event-statistics .stat-item span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.follower-count{margin-top:12px;padding:12px;color:var(--text);font-size:15px;border-radius:15px;background:linear-gradient(rgba(244,244,244,0.12) 0%,rgba(244,244,244,0.64) 100%);box-shadow:rgba(0,0,0,0.05) 0px 0px 0px 1px}
.status{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600}
.status.status-pending{background:#f59e0b20;color:#f59e0b}
.status.status-draft{background:#64748b20;color:#94a3b8}
.status.status-trash{background:#ef444420;color:#ef4444}
.status.status-info{background:#0369a120;color:#0369a1}

.filters-and-save-wrapper{
	display:flex;
	justify-content:space-between;
	align-items:flex-start;
	gap:16px;
	margin-bottom:24px;
	flex-wrap:wrap;
	position:relative;
	z-index:400; /* Keep filters (including Sort by dropdown) above cards */
}
.filters-and-save-wrapper .active-filters{flex:1;min-width:0}
.save-search-preferences{width:100%;flex:1 1 auto;display:flex;align-items:center;gap:16px;margin-top:8px;color:var(--text);background:none;border:none;padding:0;border-radius:0}
.save-search-title {
	margin: 0;
	font-weight: 600;
	font-size: 16px;
	color: var(--muted);
	white-space: nowrap;
	text-shadow: 0 2px 2px rgba(255, 255, 255, 0.95);
}
.save-search-toggle-row,.save-search-select-row{display:inline-flex;align-items:center;gap:8px}
.save-search-label {
	font-size: 16px;
	white-space: nowrap;
	text-shadow: 0 2px 2px rgba(255, 255, 255, 0.95);
}
.save-search-select-row{margin-left:auto}
.event-sort-switch{
	position:relative;
	display:inline-flex;
	align-items:center;
	flex:0 0 auto;
	background-color: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 100em;
	padding: 6px;
}
.event-sort-toggle{display:inline-flex;align-items:center;gap:4px;text-decoration:none;color:var(--text);font-size:16px;opacity:.85;transition:all .2s ease}
.event-sort-toggle:hover{opacity:1;background-color:var(--text)!important;color:var(--bg)!important;border-radius:100em;padding:6px;margin:-6px}
.event-sort-toggle:hover .event-sort-chevron{filter:brightness(0) invert(1)}
.event-sort-chevron{width:16px;height:16px;display:block;transition:transform .2s ease,filter .2s ease}
.event-sort-toggle[aria-expanded="true"] .event-sort-chevron{transform:rotate(180deg)}
.event-sort-menu{
	position:absolute;
	top:calc(100% + 6px);
	right:1px;
	left:auto;
	display:none;
	background:var(--surface);
	border:1px solid var(--border);
	border-radius:10px;
	box-shadow:0 12px 24px rgba(15,23,42,0.12);
	padding:8px 0;
	z-index:1000; /* Ensure dropdown is above cards and other content */
	min-width:160px;
}
.event-sort-menu.open{display:block}
.event-sort-menu a{display:block;padding:8px 16px;color:var(--text);text-decoration:none;font-size:14px}
.event-sort-menu a.is-selected{background:var(--surface-alt);font-weight:500}


/* Custom checkbox toggle */
.checkbox-wrapper-5 {
	display: flex;
	justify-content: center;
}
.checkbox-wrapper-5 .check {
	--size: 36px;
	position: relative;
	background: linear-gradient(90deg, #f19af3, #f099b5);
	line-height: 0;
	perspective: 400px;
	font-size: var(--size);
}
.checkbox-wrapper-5 .check input[type="checkbox"],
.checkbox-wrapper-5 .check label,
.checkbox-wrapper-5 .check label::before,
.checkbox-wrapper-5 .check label::after,
.checkbox-wrapper-5 .check {
	appearance: none;
	display: inline-block;
	border-radius: var(--size);
	border: 0;
	transition: .35s ease-in-out;
	box-sizing: border-box;
	cursor: pointer;
}
.checkbox-wrapper-5 .check label {
	width: calc(2.2 * var(--size));
	height: var(--size);
	background: #fff;
	border: 1px solid #e5e7eb;
	overflow: hidden;
}
.checkbox-wrapper-5 .check input[type="checkbox"] {
	position: absolute;
	z-index: 1;
	width: calc(.8 * var(--size));
	height: calc(.8 * var(--size));
	top: calc(.1 * var(--size));
	left: calc(.1 * var(--size));
	background: linear-gradient(45deg, #dedede, #ffffff);
	outline: none;
	margin: 0;
}
.checkbox-wrapper-5 .check input[type="checkbox"]:checked {
	left: calc(1.3 * var(--size));
}
.checkbox-wrapper-5 .check input[type="checkbox"]:checked + label {
	background: transparent;
}
.checkbox-wrapper-5 .check label::before,
.checkbox-wrapper-5 .check label::after {
	content: "· ·";
	position: absolute;
	overflow: hidden;
	left: calc(.15 * var(--size));
	top: calc(.5 * var(--size));
	height: var(--size);
	letter-spacing: calc(-0.04 * var(--size));
	color: #9b9b9b;
	font-family: "Times New Roman", serif;
	z-index: 2;
	font-size: calc(.6 * var(--size));
	border-radius: 0;
	transform-origin: 0 0 calc(-0.5 * var(--size));
	backface-visibility: hidden;
}
.checkbox-wrapper-5 .check label::after {
	content: "●";
	top: calc(.65 * var(--size));
	left: calc(.2 * var(--size));
	height: calc(.1 * var(--size));
	width: calc(.35 * var(--size));
	font-size: calc(.2 * var(--size));
	transform-origin: 0 0 calc(-0.4 * var(--size));
}
.checkbox-wrapper-5 .check input[type="checkbox"]:checked + label::before,
.checkbox-wrapper-5 .check input[type="checkbox"]:checked + label::after {
	left: calc(1.55 * var(--size));
	top: calc(.4 * var(--size));
	line-height: calc(.1 * var(--size));
	transform: rotateY(360deg);
}
.checkbox-wrapper-5 .check input[type="checkbox"]:checked + label::after {
	height: calc(.16 * var(--size));
	top: calc(.55 * var(--size));
	left: calc(1.6 * var(--size));
	font-size: calc(.6 * var(--size));
	line-height: 0;
}

.organizer-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.organizer-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 12px 24px rgba(15,23,42,0.06)}
.organizer-avatar img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.organizer-avatar-fallback{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:600;font-size:20px}
.organizer-card-body h3{margin:0 0 4px}
.organizer-meta{margin:0 0 8px;font-size:14px;color:var(--muted)}
.organizer-link{color:var(--brand);font-weight:600}
.organizer-link:hover{text-decoration:none}

.subscription-item{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;box-shadow:0 12px 24px rgba(15,23,42,0.06)}
.subscription-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.subscription-item h3{margin:0}
.subscription-item p{margin:0;font-size:14px;color:var(--muted)}
.subscription-expiry{font-size:12px;color:var(--muted)}
.subscription-controls{display:flex;flex-wrap:wrap;gap:12px 24px;align-items:center}
.subscription-controls label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted)}
.subscription-controls select{padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text)}
.subscription-controls input[type=checkbox]{width:16px;height:16px}

/* Vertical layout for subscription email + frequency */
.subscription-controls-vertical{
	display:flex;
	flex-direction:column;
	align-items:flex-start;
	gap:12px; /* 12px tarpas tarp eilučių */
}
.subscription-controls-vertical .subscription-email label{
	display:flex;
	align-items:center;
	gap:8px;
	font-size:14px;
	color:var(--muted);
}
.subscription-controls-vertical .subscription-frequency-label{
	display:block;
	margin-bottom:4px;
	font-size:14px;
	color:var(--muted);
}
.subscription-controls-vertical .subscription-frequency select{
	padding:6px 10px;
	border-radius:6px;
	border:1px solid var(--border);
	background:var(--surface);
	color:var(--text);
}
.saved-event-item,.organizer-card-item{display:flex;flex-direction:column;gap:12px;height:100%}
.saved-event-item .card{flex:1;display:flex;flex-direction:column}
.saved-event-item .btn,.organizer-card-item .btn{align-self:flex-start;margin-top:auto}

.form-field-event-url .event-url-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.form-field-event-url input[type=url]{flex:1;min-width:220px}
.field-status{margin-top:6px;font-size:14px;color:var(--muted)}
.field-status.status-info{color:#0369a1}
.field-status.status-success{color:#15803d}
.field-status.status-error{color:#b91c1c}
.field-autofilled input,
.field-autofilled textarea,
.field-autofilled select{border-color:var(--brand);box-shadow:0 0 0 1px rgba(10,102,194,0.35)}
.autofill-image-preview{margin-top:12px;padding:12px;border:1px dashed var(--border);border-radius:10px;background:var(--surface-alt);display:flex;gap:12px;align-items:flex-start}
.autofill-image-preview img{width:140px;height:auto;object-fit:cover;border-radius:8px;box-shadow:0 10px 24px rgba(15,23,42,0.15)}
.autofill-image-meta{flex:1;min-width:0}
.autofill-image-url{font-size:13px;color:var(--muted);word-break:break-all;margin:4px 0 8px}
.link-button{background:none;border:none;padding:0;color:var(--brand);font-weight:600;cursor:pointer;text-decoration:none}
.link-button:focus{outline:2px solid var(--brand);outline-offset:2px}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 980px) {
	.filter .row {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.details ul {
		grid-template-columns: 1fr;
	}
	.account-tabs {
		flex-wrap: wrap;
	}
}
@media (max-width: 768px) {
	.save-search-preferences {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}
	.save-search-title {
		width: 100%;
		font-size: 16px;
	}
	.save-search-toggle-row,
	.save-search-select-row {
		width: 100%;
		margin-left: 0;
	}
	.save-search-select-row {
		justify-content: flex-end;
	}
	.save-search-label {
		font-size: 16px;
	}
	.event-sort-toggle {
		font-size: 16px;
	}
}

@media (max-width: 640px) {
	.filter .row {
		grid-template-columns: 1fr;
	}
	.card-grid {
		grid-template-columns: 1fr;
	}
	.stats {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   UTILITIES
   ============================================ */

.load-more-wrap {
	padding: 16px;
	text-align: right;
}

.load-more-wrap .btn {
	width: auto;
	display: inline-block;
}

#load-more {
	width: auto;
	display: block;
	margin-left: auto;
	margin-right: 6px;
	margin-top: 26px;
}

.js-only {
	display: none;
}

.nojs {
	display: block;
}

/* Back to top button */
a.back-to-top {
	position: fixed;
	right: 30px;
	bottom: 30px;
	background-color: rgba(255, 255, 255, 0.2);
	border: 1px solid #e5e7eb;
	backdrop-filter: blur(4px);
	border-radius: 50%;
	text-align: center;
	height: 45px;
	width: 45px;
	box-shadow: 0 5px 33px rgba(0, 0, 0, .2);
	transition: .2s ease;
	opacity: 0;
	visibility: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #000;
	text-decoration: none;
	z-index: 1000;
}

a.back-to-top:hover {
	box-shadow: 0 5px 33px rgba(0, 0, 0, .3);
}

a.back-to-top:active {
	transform: scale(0.95);
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.2);
}

a.back-to-top.visible {
	opacity: 1;
	visibility: visible;
}

a.back-to-top img {
	width: 18px;
	height: 18px;
	display: block;
}

/* ============================================
   FOOTER
   ============================================ */

.site-footer {
	padding-top: 40px;
	padding-bottom: 40px;
	text-align: center;
	color: #0f172a;
}

.site-footer p {
	margin: 0;
}

.site-footer-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 12px;
}

.site-footer-copyright {
	white-space: nowrap;
}

.site-footer-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 15px;
}
