/* ============================================================
    Base Resets
   ============================================================ */

html {
	scroll-behavior: smooth;
	scrollbar-width: none;
}

body {
	margin: 0;
	min-height: 100vh;
	background: var(--background);
	background-attachment: fixed;
	color: var(--foreground);
	font-family: var(--font-text);
	font-size: var(--font-text-size);
	line-height: var(--font-text-line-height);
	font-weight: var(--weight-text);
}

::selection {
	background: var(--selection-bg);
	color: var(--selection-text);
}

::-webkit-scrollbar {
	width: 0;
	height: 0;
}

.show-scrollbars ::-webkit-scrollbar {
	width: 12px;
	height: 12px;
}

.show-scrollbars ::-webkit-scrollbar-track {
	background: var(--input-border);
	border-radius: var(--radius-sm);
}

.show-scrollbars ::-webkit-scrollbar-thumb {
	background: var(--muted);
	border-radius: var(--radius-sm);
	border: 2px solid var(--input-border);
}

.show-scrollbars {
	scrollbar-width: auto;
	scrollbar-color: var(--muted) var(--input-border);
}

blockquote, cite {
	margin: 0;
	padding: var(--space-4) 0;
	border: none;
	white-space: pre-line;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
	color: var(--foreground);
	font-weight: var(--weight-title);
	line-height: var(--font-subtitle-line-height);
	white-space: pre-line;
}

p {
	margin: 0;
	line-height: var(--line-height-normal);
	font-weight: var(--weight-text);
}

h1 {
	font-family: var(--font-title);
	font-size: var(--font-title-size);
	font-weight: var(--weight-heading);
	line-height: var(--font-title-line-height);
	text-transform: capitalize;
}

h2 {
	font-family: var(--font-subtitle);
	font-size: var(--font-subtitle-size);
	text-transform: capitalize;
}

h3 {
	font-size: var(--text-lg);
}


label,
.label,
.field-label {
	font-weight: var(--weight-label);
}

a {
	font-weight: var(--weight-link);
	cursor: pointer;
	color: var(--primary);
	text-decoration: none;
}

address {
	font-style: normal;
}



/* ============================================================
   Form Elements
   ============================================================ */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="date"],
select,
textarea {
	background-color: var(--input-bg);
	border: var(--input-border-width) var(--input-border-style) var(--input-border-color);
	border-radius: var(--input-radius);
	padding: var(--space-3) var(--space-4);
	font-size: var(--text-base);
	font-family: inherit;
	color: var(--input-text);
	transition: border-color 0.2s, background-color 0.2s;
	width: 100%;
	box-sizing: border-box;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
input[type="date"]:focus,
select:focus,
textarea:focus {
	outline: none;
	background-color: var(--input-focus-bg);
	border-color: var(--input-focus-border);
	color: var(--input-focus-text);
}

select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: var(--space-10);
	cursor: pointer;
}

.dark {
	color-scheme: dark;
}

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

::placeholder {
	color: var(--muted);
	opacity: 0.7;
}

.dark select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23aaa' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

.input-field {
	width: 100%;
	background-color: var(--input-bg);
	color: var(--input-text);
	border: var(--input-border-width) solid var(--input-border);
	border-radius: var(--input-radius);
	padding: var(--space-3) var(--space-4);
	font-size: var(--font-text-size);
}

.input-field::placeholder {
	color: var(--muted);
}

.input-field:focus {
	outline: 2px solid var(--input-focus-border);
	outline-offset: 2px;
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--gap-base);
}


.form-group input,
.form-group select {
	width: 100%;
	border: 1px solid var(--input-border);
	border-radius: var(--radius-md);
	font-size: var(--text-base);
}

.form-group input:focus,
.form-group select:focus {
	outline: none;
	border-color: var(--primary);
}

.form-group input::placeholder {
	color: var(--muted);
}

.form-group label {
	display: block;
	font-size: var(--text-sm);
	font-weight: 500;
	margin-bottom: var(--space-2);
	color: var(--foreground);
}

.input-group-centered {
	display: flex;
	justify-content: center;
	padding: 1.5rem 0;
}

.form-hint-warning {
	color: #f59e0b;
}


/* ============================================================
   Buttons
   ============================================================ */

.btn,
.btn-primary,
.btn-secondary,
.btn-default,
.btn-danger,
.btn-warning,
.btn-success,
.btn-premium {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--button-padding);
	border-radius: var(--button-radius);
	font-weight: var(--weight-button);
	font-size: var(--text-sm);
	border: none;
	cursor: pointer;
	transition: background-color 0.2s, border-color 0.2s, opacity 0.2s;
	white-space: nowrap;
	text-decoration: none !important;
}

.btn:disabled,
.btn-primary:disabled,
.btn-secondary:disabled,
.btn-default:disabled,
.btn-danger:disabled,
.btn-warning:disabled,
.btn-success:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.btn-premium {
	background: linear-gradient(135deg, var(--vip-gold) 0%, var(--vip-gold-dark) 100%);
	color: var(--vip-button-text);
	border: none;
	box-shadow: 0 4px 12px rgba(255, 165, 0, 0.4);
}

.btn-primary {
	background-color: var(--button-bg) !important;
	color: var(--button-text) !important;
}

.btn-secondary {
	background: var(--accent);
	color: var(--foreground);
	border: 1px solid var(--border);
}

.btn-default {
	background: transparent;
	color: var(--foreground);
	border: 1px solid var(--border);
}

.btn-default.warning {
	border-color: var(--warning);
	color: #b45309;
}

.btn-text {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	color: var(--muted);
	border: none;
	padding: var(--space-2);
	transition: color 0.2s;
}

.btn-danger {
	background: var(--error);
	color: white;
}

.btn-warning {
	background: var(--warning);
	color: white;
}

.btn-success {
	background: var(--success);
	color: white;
}

.btn-sm {
	padding: var(--space-1) var(--space-2);
	font-size: var(--text-xs);
}

.btn-md {
	padding: var(--space-2) var(--space-4);
	font-size: var(--text-sm);
}

.btn-lg {
	padding: var(--space-3) var(--space-5);
	font-size: var(--text-base);
}

.btn-link {
	width: 100%;
	margin-top: var(--space-3);
	padding: var(--space-2);
	background: none;
	border: none;
	font-size: var(--text-sm);
	color: var(--primary);
	transition: color 0.2s ease;
}

.btn-back {
	background: none;
	border: none;
	padding: var(--space-2);
	color: var(--foreground);
}

.btn-back svg {
	width: 24px;
	height: 24px;
}

/* Close button */
.btn-close {
	width: 32px;
	height: 32px;
	border: none;
	border-radius: var(--radius-full);
	padding: 0;
	line-height: 1;
	transition: background 0.15s, opacity 0.15s;
}

.btn-close svg {
	width: 18px;
	height: 18px;
}

.btn-close-lg {
	width: 44px;
	height: 44px;
}

.btn-close-lg svg {
	width: 24px;
	height: 24px;
}

.btn-close-muted {
	background: var(--border);
	color: var(--muted);
}

.btn-close-overlay {
	background: var(--overlay-light);
	color: white;
}

.btn-close-light {
	background: rgba(255, 255, 255, 0.1);
	color: white;
}

.btn-close-ghost {
	background: transparent;
	color: var(--muted);
}

.btn-close-abs {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	z-index: 10;
}

/* Hint button */
.btn-hint {
	display: inline-flex;
	align-items: center;
	padding: var(--space-1) var(--space-3);
	font-size: var(--text-xs);
	color: var(--primary);
	background: transparent;
	border: 1px solid var(--primary);
	border-radius: var(--radius-md);
	text-decoration: none;
}

/* Load more */
.load-more-container {
	display: flex;
	justify-content: center;
	text-align: center;
	margin-top: 1rem;
	padding: var(--space-8) var(--space-4);
}

.btn-load-more {
	padding: var(--space-3) var(--space-8);
	background: var(--primary);
	color: var(--button-text);
	border: none;
	border-radius: var(--radius-md);
	font-size: var(--text-base);
	font-weight: 500;
	transition: background 0.2s, opacity 0.2s;
}

.btn-load-more:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}


/* ============================================================
   Utilities
   ============================================================ */


/* Loading state */
.loading-state {
	text-align: center;
	padding: var(--space-8);
	color: var(--muted);
}

/* Spin animation for refresh */
.spin {
	animation: spin 1s linear infinite;
}

.mt-sm {
	margin-top: 0.75rem;
}

.min-h-60 {
	min-height: 60vh;
}

.w-full {
	width: 100%;
}

/* ==================== */
/* Toast Notifications (sonner) */
/* ==================== */

/* Toast container positioning */
[data-sonner-toaster] {
	--toast-bg-error: rgba(220, 38, 38, 0.9);
	--toast-bg-success: rgba(255, 255, 255, 0.9);
	--toast-bg-warning: rgba(234, 88, 12, 0.9);
	--toast-bg-info: rgba(255, 255, 255, 0.9);
	--width: 360px;
	z-index: 99999;
}

/* Base toast style - larger padding and font */
[data-sonner-toast] {
	font-family: var(--font-sans, system-ui, sans-serif);
	border-radius: var(--radius-lg);
	padding: 16px 20px;
	font-size: var(--text-base);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
	backdrop-filter: blur(12px);
	border: none;
}

[data-sonner-toast] [data-title] {
	font-size: var(--text-base);
	font-weight: 600;
}

[data-sonner-toast] [data-description] {
	font-size: var(--text-base);
	margin-top: 4px;
}

/* Error toast - red */
[data-sonner-toast][data-type="error"] {
	background: var(--toast-bg-error);
	color: white;
}

[data-sonner-toast][data-type="error"] [data-title] {
	color: white;
}

[data-sonner-toast][data-type="error"] [data-close-button] {
	color: white;
	background: rgba(255, 255, 255, 0.2);
}

/* Success toast - white with dark text */
[data-sonner-toast][data-type="success"] {
	background: var(--toast-bg-success);
	color: var(--foreground);
}

[data-sonner-toast][data-type="success"] [data-title] {
	color: var(--foreground);
}

[data-sonner-toast][data-type="success"] [data-close-button] {
	color: var(--foreground);
	background: rgba(0, 0, 0, 0.1);
}

/* Warning toast - orange */
[data-sonner-toast][data-type="warning"] {
	background: var(--toast-bg-warning);
	color: white;
}

[data-sonner-toast][data-type="warning"] [data-title] {
	color: white;
}

[data-sonner-toast][data-type="warning"] [data-close-button] {
	color: white;
	background: rgba(255, 255, 255, 0.2);
}

/* Info/default toast - white with dark text */
[data-sonner-toast][data-type="info"],
[data-sonner-toast][data-type="default"] {
	background: var(--toast-bg-info);
	color: var(--foreground);
}

[data-sonner-toast][data-type="info"] [data-title],
[data-sonner-toast][data-type="default"] [data-title] {
	color: var(--foreground);
}

[data-sonner-toast][data-type="info"] [data-close-button],
[data-sonner-toast][data-type="default"] [data-close-button] {
	color: var(--foreground);
	background: rgba(0, 0, 0, 0.1);
}

/* Close button styling */
[data-sonner-toast] [data-close-button] {
	border: none;
	border-radius: var(--radius-full);
	width: 20px;
	height: 20px;
	cursor: pointer;
	transition: background 0.2s;
}

/* Toast icon */
[data-sonner-toast] [data-icon] {
	margin-right: 8px;
}

/* Dark mode adjustments - success and info use dark bg */
.dark [data-sonner-toast][data-type="info"],
.dark [data-sonner-toast][data-type="default"],
.dark [data-sonner-toast][data-type="success"] {
	background: rgba(31, 41, 55, 0.9);
	color: white;
}

.dark [data-sonner-toast][data-type="info"] [data-title],
.dark [data-sonner-toast][data-type="default"] [data-title],
.dark [data-sonner-toast][data-type="success"] [data-title] {
	color: white;
}

.dark [data-sonner-toast][data-type="info"] [data-close-button],
.dark [data-sonner-toast][data-type="default"] [data-close-button],
.dark [data-sonner-toast][data-type="success"] [data-close-button] {
	color: white;
	background: rgba(255, 255, 255, 0.2);
}

/* Desktop: Even larger, wider toasts */
@media (min-width: 768px) {
	[data-sonner-toaster] {
		--width: 420px;
	}

	[data-sonner-toast] {
		padding: 20px 28px;
		font-size: 1rem;
		border-radius: var(--radius-lg);
	}

	[data-sonner-toast] [data-title] {
		font-size: 1rem;
		font-weight: 600;
	}

	[data-sonner-toast] [data-description] {
		font-size: var(--text-base);
	}
}


.dropdown-chevron {
	transition: transform 0.2s;
}

.dropdown-chevron.open {
	transform: rotate(180deg);
}

/* Saved/Saving indicators */
.saved-indicator {
	color: var(--success);
	font-size: var(--text-sm);
}

.saving-indicator {
	color: var(--muted);
	font-size: var(--text-sm);
}


.redirect-page {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	color: var(--foreground);
}

.show-more-comments {
	display: block;
	width: 100%;
	padding: var(--space-3);
	margin-top: var(--space-2);
	background: transparent;
	border: none;
	color: var(--primary);
	font-size: var(--text-sm);
	font-weight: 500;
	cursor: pointer;
	text-align: center;
}



/* Empty state sub-elements */
.empty-icon {
	width: 80px;
	height: 80px;
	margin-bottom: var(--margin-base);
	border-radius: var(--radius-full);
	color: var(--muted);
}

/* Empty State */
.empty-state {
	text-align: center;
	padding: var(--space-8) var(--space-4);
	color: var(--muted);
}


.empty-state h3 {
	margin: 0 0 0.5rem;
	font-size: var(--text-xl);
}

.empty-state p {
	margin: 0 0 1.5rem;
	color: var(--muted);
}
.empty-state-text {
	text-align: center;
	padding: 2rem;
	color: var(--muted);
}


.loading-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid var(--border);
	border-top-color: var(--primary);
	border-radius: var(--radius-full);
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}
/* Loading spinner (small variant) */
.loading-spinner[data-size="sm"] {
	width: 20px;
	height: 20px;
	border-width: 2px;
}

H2.section-description {
	margin: var(--margin-base) 0;
	text-align: center;
	font-weight: 200;
	text-transform: none;
}	

@media (max-width: 768px) {
	H2.section-description {
		margin: var(--space-3) 0;
		font-size: var(--text-lg);
		display:none;
	}	
}
.section-description-box {
	flex: 1;
}

.discovery-filters-content {
    text-align: left;
}

.info-row {
	font-size: var(--text-xs);
	color: var(--muted);
}

.btn-submit {
	width: 100%;
	margin-top: var(--space-4);
	background-color: var(--button-bg);
	color: var(--button-text);
	padding:var(--button-padding)
}

.btn-submit:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.btn-cancel {
	text-align: center;
	color: var(--muted);
	font-size: var(--text-sm);
}

.btn-retry {
	margin-top: var(--space-4);
	padding: var(--space-2) var(--space-6);
	background: var(--muted);
	color: var(--foreground);
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	font-size: var(--text-sm);
	cursor: pointer;
}

.section-count {
	font-size: var(--text-sm);
	color: var(--muted);
	white-space: nowrap;
	padding: var(--space-4);
}

.no-more-profiles {
	color: var(--muted);
	font-size: var(--text-sm);
}


.action-btn {
	width: 36px;
	height: 36px;
	border: none;
	border-radius: var(--radius-full);
	background: rgba(0, 0, 0, 0.3);
	color: white;
	cursor: pointer;
	transition: background 0.2s, transform 0.1s;
}

.action-btn svg {
	width: 24px;
	height: 24px;
	flex-shrink: 0;
}

.insufficient-coins {
	text-align: center;
	color: var(--error);
	font-size: var(--text-sm);
	margin-bottom: var(--space-2);
}

/* Company Info */
.company-info {
	padding: var(--space-4) 0;
	line-height: var(--line-height-normal);
	text-align: center;
}


/* Not set placeholder */
.not-set {
	color: var(--muted);
	font-style: italic;
	font-size: var(--text-sm);
	margin: 0;
}


/* Locked Photos Overlay (main photo) */
.locked-badge {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	background: var(--overlay-dark);
	color: white;
	padding: var(--space-2) var(--space-3);
	border-radius: var(--radius-md);
	font-size: var(--text-sm);
	font-weight: 500;
}

.locked-badge svg {
	width: 16px;
	height: 16px;
}

/* Unlock Photos CTA */
.unlock-photos-cta {
	background: linear-gradient(135deg, var(--card-bg), var(--secondary));
	border: 2px dashed var(--border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	text-align: center;
	margin-bottom: var(--space-4);
}

/* btn-unlock styles defined in Likes section */

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

.unlock-hint {
	margin: var(--space-3) 0 0;
	font-size: var(--text-sm);
	color: var(--muted);
}


/* Photo Lightbox - full-size photo view */
.photo-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.9);
	z-index: 9999;
	padding: var(--space-4);
}

.lightbox-content {
	max-width: 90vw;
	max-height: 90vh;
}

.lightbox-image {
	max-width: 100%;
	max-height: 90vh;
	object-fit: contain;
	border-radius: var(--radius-md);
	border: 1rem solid rgba(255, 255, 255, 0.25);
}


.unlock-unavailable {
	font-size: var(--text-sm);
	color: var(--muted);
	font-style: italic;
	margin-bottom: var(--margin-base);
}

.view-profile-link {
	display: block;
	text-align: center;
	padding: var(--space-3);
	font-size: var(--text-sm);
	border-top: 1px solid var(--border);
}

.btn-unlock {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-6);
	background: linear-gradient(135deg, var(--vip-gold) 0%, var(--vip-gold-dark) 100%);
	color: var(--vip-button-text);
	border: none;
	border-radius: 2rem;
	font-size: var(--text-base);
	font-weight: 600;
	cursor: pointer;
	transition: var(--transition-lift);
	box-shadow: 0 4px 12px rgba(255, 165, 0, 0.4);
}

.btn-unlock:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.add-coins-link {
	background: none;
	border: none;
	font-size: var(--text-sm);
	font-weight: 500;
	cursor: pointer;
	margin-top: var(--space-2);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.divider {
	display: flex;
	align-items: center;
	gap: var(--gap-base);
	margin: var(--margin-base) 0;
	color: var(--muted);
	font-size: var(--text-xs);
	text-transform: uppercase;
}

.divider::before,
.divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--border);
}

.btn-vip-alt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-2) var(--space-4);
	background: transparent;
	color: var(--vip-gold);
	border: 1px solid var(--vip-gold);
	border-radius: 1.5rem;
	font-size: var(--text-sm);
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}

/* Swipe Indicators */
.swipe-indicator {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	padding: var(--space-4) var(--space-8);
	border-radius: var(--radius-md);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-2);
	font-weight: 600;
	font-size: var(--text-xl);
	pointer-events: none;
	opacity: 0.9;
}

.swipe-indicator-left {
	left: var(--space-4);
	background: var(--error);
	color: white;
}

.swipe-indicator-right {
	right: var(--space-4);
	background: var(--success);
	color: white;
}

/* ============================================
	 User Actions Dropdown - Reusable Block/Report
	 ============================================ */

nav.actions {
	position: relative;
	display: inline-flex;
}

nav.actions > button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border: none;
	background: transparent;
	color: var(--muted);
	cursor: pointer;
	border-radius: var(--radius-full);
	transition: background 0.15s, color 0.15s;
}

nav.actions > button:hover {
	background: var(--secondary);
	color: var(--foreground);
}

nav.actions menu {
	position: absolute;
	top: 100%;
	min-width: 160px;
	background-color: var(--background-color);
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
	z-index: 100;
	overflow: hidden;
	box-shadow: var(--shadow-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

nav.actions menu[data-position="right"] {
	right: 0;
}

nav.actions menu[data-position="left"] {
	left: 0;
}

nav.actions menu button {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	width: 100%;
	padding: var(--space-3) var(--space-4);
	border: none;
	background: none;
	color: var(--foreground);
	font-size: var(--text-sm);
	text-align: left;
	cursor: pointer;
	transition: background 0.15s;
}

nav.actions menu button:hover {
	background: var(--secondary);
}

nav.actions menu button:not(:last-child) {
	border-bottom: 1px solid var(--border);
}

nav.actions menu button.blocked {
	color: var(--error);
	font-weight: 500;
}

nav.actions menu button.blocked:hover {
	background: rgba(239, 68, 68, 0.15);
}

nav.actions menu button.blocked svg {
	color: var(--error);
}

/* ============================================================
   Utilities
   ============================================================ */

.location-icon {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	opacity: 0.7;
}

.flex-center {
	display: flex;
	align-items: center;
	justify-content: center;
}

.hide-mobile {
	display: none !important;
}

.hide-desktop {
	display: flex !important;
}

@media (min-width: 768px) {
	.hide-mobile {
		display: inline-flex !important;
	}

	.hide-desktop {
		display: none !important;
	}
}

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

.full-width {
	width: 100%;
}

.clickable {
	cursor: pointer;
}

/* These are kept for layout purposes */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.relative { position: relative; }
.absolute { position: absolute; }
.inset-0 { inset: 0; }
.z-10 { z-index: 10; }
.z-50 { z-index: 50; }
.overflow-hidden { overflow: hidden; }
.pointer-events-none { pointer-events: none; }
/* .full-width and .text-muted — migrated to site_06_utilities.css */
.icon-sm { width: 1rem; height: 1rem; }

/* Premium/VIP emoji — defined in site_02_layout.css */

/* Smaller premium emoji on photo badges */
.photo-badge-emoji .premium-emoji-img {
	width: 24px;
	height: 24px;
}

@media (min-width: 768px) {
	.app-header .header-right {
		align-items: center;
	}
	.header-membership {
		flex-direction: row;
		gap: var(--space-2);
		min-width: auto;
		padding: 0 var(--space-2) 0 0;
		border-radius: var(--radius-2xl);
		transition: background-color 0.2s;
		font-size: var(--text-base);
	}

	.membership-label {
		font-size:var(--size-md);
	}

	.header-right .premium-emoji-img {
		width: 32px;
		height: 32px;
	}
}


/* Radio circle with checkmark (alternative to radio-dot) */
.radio-circle {
	width: 24px;
	height: 24px;
	border: 2px solid var(--input-border);
	border-radius: var(--radius-full);
	transition: all 0.2s;
}

.radio-circle.checked {
	border-color: var(--primary);
	background: var(--primary);
}

.radio-circle .icon-check {
	width: 14px;
	height: 14px;
	color: white;
}
