/* =============================================================
   PopOut&Share — base.css
   Global tokens, layout, components, social UI, gallery system
   All page-specific CSS lives in css/pages/[page].css
   ============================================================= */

/* ===== RESET ===== */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html, body {
	width: 100%;
	height: 100%;
	overflow-x: hidden;
	background-color: var(--bg-primary);
	color: var(--text-primary);
}

body {
	font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI',
		Roboto, sans-serif;
	color: var(--text-primary);
	line-height: 1.6;
	transition: background-color var(--transition-normal),
		color var(--transition-normal);
	background: var(--bg-primary);
	font-size: var(--font-base);
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Lora', Georgia, serif;
	font-weight: 600;
	line-height: 1.3;
	margin-bottom: 0.5rem;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img, video { display: block; max-width: 100%; }
input, textarea, select { font-family: inherit; }

/* ===== THEME & TOKENS ===== */
:root {
	/* Font scale */
	--font-base: 16px;
	--font-sm: 0.95rem;
	--font-xs: 0.8rem;
	--icon-base: 1.15rem;
	--icon-lg: 1.4rem;

	/* Sunset Orange */
	--sunset-orange: #ff6b35;
	--sunset-orange-light: #ff9e6d;
	--sunset-orange-dark: #e55a2b;

	/* Ocean Teal */
	--ocean-teal: #00a8cc;
	--ocean-teal-light: #5bcefa;
	--ocean-teal-dark: #0088a8;

	/* Sand Beige */
	--sand-beige: #f4e9d8;
	--sand-beige-light: #faf4e8;
	--sand-beige-dark: #e8dbc4;

	/* Adventure Colors */
	--adventure-green: #38b000;
	--exploration-blue: #3a86ff;
	--cultural-purple: #8338ec;
	--reflection-pink: #ff006e;

	/* Semantic */
	--primary-color: var(--sunset-orange);
	--secondary-color: var(--ocean-teal);
	--accent-color: var(--sunset-orange);
	--success-color: var(--adventure-green);
	--info-color: var(--exploration-blue);
	--warning-color: #ff9e00;
	--danger-color: var(--reflection-pink);

	/* Alias used in HTML inline styles */
	--journey-orange: var(--sunset-orange);
	--journey-blue: var(--ocean-teal);

	/* Backgrounds */
	--bg-primary: var(--sand-beige-light);
	--bg-secondary: var(--sand-beige);
	--bg-tertiary: #e8dbc4;
	--bg-card: #ffffff;
	--bg-elevated: rgba(255, 255, 255, 0.9);
	--bg-overlay: rgba(244, 233, 216, 0.95);

	/* Text */
	--text-primary: #2d3748;
	--text-secondary: #4a5568;
	--text-muted: #718096;
	--text-light: #a0aec0;

	/* Borders */
	--border-color: rgba(237, 223, 202, 0.8);
	--border-subtle: rgba(148, 163, 184, 0.15);
	--border-strong: rgba(237, 223, 202, 1);

	/* Shadows */
	--shadow-sm: 0 4px 12px rgba(237, 223, 202, 0.3);
	--shadow-md: 0 6px 20px rgba(237, 223, 202, 0.4);
	--shadow-lg: 0 10px 30px rgba(237, 223, 202, 0.5);
	--shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.08);
	--shadow-elevated: 0 20px 60px rgba(237, 223, 202, 0.6);

	/* Corners */
	--radius-xs: 8px;
	--radius-sm: 12px;
	--radius-md: 16px;
	--radius-lg: 20px;
	--radius-xl: 24px;
	--radius-pill: 999px;
	--radius-card: 20px;

	/* Transitions */
	--transition-fast: 200ms ease;
	--transition-normal: 300ms ease;
	--transition-slow: 450ms ease;
	--transition-bounce: 400ms cubic-bezier(0.34, 1.56, 0.64, 1);

	/* Layout */
	--header-height: 68px;
	--bottom-nav-height: 60px;
	--drawer-width: 320px;
	--max-content: 1200px;
	--spacing-md: 1rem;

	/* Gradients */
	--gradient-sunset: linear-gradient(135deg, var(--sunset-orange), var(--sunset-orange-light));
	--gradient-ocean: linear-gradient(135deg, var(--ocean-teal), var(--ocean-teal-light));
	--gradient-adventure: linear-gradient(135deg, var(--sunset-orange), var(--ocean-teal));
	--gradient-card: linear-gradient(135deg, rgba(255,255,255,0.9), rgba(255,255,255,0.95));
	--gradient-overlay: linear-gradient(to bottom, transparent, rgba(244,233,216,0.9));
}

/* ===== DARK THEME ===== */
[data-theme="dark"] {
	/* Brand — slightly brighter for dark surfaces */
	--sunset-orange:       #ff8040;
	--sunset-orange-light: #ffa070;
	--sunset-orange-dark:  #e06020;
	--ocean-teal:          #2ec4e8;
	--ocean-teal-light:    #70d8f8;
	--ocean-teal-dark:     #0098bb;

	/* Warm sand tones darkened */
	--sand-beige:          #1e1914;
	--sand-beige-light:    #141008;
	--sand-beige-dark:     #2c2520;

	/* Backgrounds — true dark, not sepia */
	--bg-primary:    #111111;
	--bg-secondary:  #181818;
	--bg-tertiary:   #1f1f1f;
	--bg-card:       #1c1c1e;
	--bg-elevated:   rgba(28, 28, 30, 0.97);
	--bg-overlay:    rgba(12, 12, 12, 0.98);

	/* Text — clean, vivid, good contrast */
	--text-primary:   #f0f0f0;
	--text-secondary: #d0cfcc;
	--text-muted:     #9a9a9a;
	--text-light:     #6e6e6e;

	/* Borders */
	--border-color:  rgba(255, 255, 255, 0.10);
	--border-subtle: rgba(255, 255, 255, 0.06);
	--border-strong: rgba(255, 255, 255, 0.20);

	/* Shadows — richer in dark mode */
	--shadow-sm:       0 2px 8px  rgba(0,0,0,0.50);
	--shadow-md:       0 4px 16px rgba(0,0,0,0.60);
	--shadow-lg:       0 8px 28px rgba(0,0,0,0.70);
	--shadow-soft:     0 14px 40px rgba(0,0,0,0.55);
	--shadow-elevated: 0 20px 60px rgba(0,0,0,0.80);

	/* Gradient card */
	--gradient-card: linear-gradient(135deg, rgba(28,28,30,0.98), rgba(28,28,30,1));
}

/* ── Dark-mode element overrides ──────────────────────────────────────────── */
[data-theme="dark"] .app-header,
[data-theme="dark"] .bottom-nav {
	background: rgba(17, 17, 17, 0.97);
	border-color: var(--border-color);
}

[data-theme="dark"] .modal {
	background: var(--bg-card);
	color: var(--text-primary);
	border: 1px solid var(--border-color);
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
	border-color: var(--border-subtle);
}

[data-theme="dark"] .form-control,
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select {
	background: var(--bg-tertiary);
	color: var(--text-primary);
	border-color: var(--border-color);
}

[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="datetime-local"],
[data-theme="dark"] input[type="month"],
[data-theme="dark"] input[type="time"] {
	color-scheme: dark;
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
	color: var(--text-muted);
}

[data-theme="dark"] .card {
	background: var(--bg-card);
	border-color: var(--border-color);
}

[data-theme="dark"] .feed-card,
[data-theme="dark"] .trip-card,
[data-theme="dark"] .event-card,
[data-theme="dark"] .buddy-card,
[data-theme="dark"] .forum-card,
[data-theme="dark"] .marketplace-card,
[data-theme="dark"] .memory-card,
[data-theme="dark"] .badge-card,
[data-theme="dark"] .safety-card,
[data-theme="dark"] .offline-card {
	background: var(--bg-card);
	border-color: var(--border-color);
}

/* Drawer */
[data-theme="dark"] .profile-drawer {
	background: var(--bg-secondary);
	border-right-color: var(--border-color);
}

[data-theme="dark"] .drawer-header {
	background: linear-gradient(135deg, var(--sunset-orange-dark), var(--ocean-teal-dark));
}

[data-theme="dark"] .drawer-nav-item {
	color: var(--text-secondary);
}

[data-theme="dark"] .drawer-nav-item:hover {
	background: var(--bg-elevated);
	color: var(--text-primary);
}

/* Notifications / toasts */
[data-theme="dark"] .notification {
	background: var(--bg-elevated);
	border-left-color: var(--sunset-orange);
	color: var(--text-primary);
}

/* Options sheet */
[data-theme="dark"] .options-sheet-btn {
	color: var(--text-primary);
	border-bottom-color: var(--border-subtle);
}

[data-theme="dark"] .options-sheet-btn:hover {
	background: var(--bg-elevated);
}

/* Tab / filter buttons */
[data-theme="dark"] .filter-tab,
[data-theme="dark"] .filter-btn,
[data-theme="dark"] .feed-filter {
	color: var(--text-muted);
	background: var(--bg-tertiary);
	border-color: var(--border-color);
}

[data-theme="dark"] .filter-tab.active,
[data-theme="dark"] .filter-btn.active,
[data-theme="dark"] .feed-filter.active {
	color: var(--sunset-orange);
	background: rgba(255, 128, 64, 0.12);
	border-color: var(--sunset-orange);
}

/* Buttons */
[data-theme="dark"] .btn-outline {
	color: var(--text-primary);
	border-color: var(--border-strong);
}

[data-theme="dark"] .btn-outline:hover {
	background: var(--bg-elevated);
}

[data-theme="dark"] .btn-ghost {
	color: var(--text-secondary);
}

[data-theme="dark"] .btn-ghost:hover {
	background: var(--bg-elevated);
	color: var(--text-primary);
}

/* Avatars and icons */
[data-theme="dark"] .avatar,
[data-theme="dark"] .profile-avatar,
[data-theme="dark"] .message-avatar,
[data-theme="dark"] .buddy-avatar {
	background: var(--bg-tertiary);
	color: var(--text-muted);
	border-color: var(--border-color);
}

/* Badges */
[data-theme="dark"] .badge {
	background: rgba(255,255,255,0.08);
	color: var(--text-secondary);
}

/* Page header titles */
[data-theme="dark"] .page-title {
	color: var(--text-primary);
}

[data-theme="dark"] .page-subtitle {
	color: var(--text-muted);
}

/* Empty states */
[data-theme="dark"] .empty-state {
	color: var(--text-muted);
}

/* Profile tabs */
[data-theme="dark"] .profile-tab {
	color: var(--text-muted);
}

[data-theme="dark"] .profile-tab.active {
	color: var(--sunset-orange);
	border-bottom-color: var(--sunset-orange);
}

/* Thread categories modal */
[data-theme="dark"] .thread-category-btn {
	background: var(--bg-tertiary);
	color: var(--text-secondary);
	border-color: var(--border-color);
}

[data-theme="dark"] .thread-category-btn.active {
	background: rgba(255,128,64,0.15);
	color: var(--sunset-orange);
	border-color: var(--sunset-orange);
}

/* Comment bubbles */
[data-theme="dark"] .comment-bubble {
	background: var(--bg-elevated);
	color: var(--text-primary);
}

[data-theme="dark"] .comment-author {
	color: var(--text-secondary);
}

[data-theme="dark"] .comment-time {
	color: var(--text-muted);
}

/* Search */
[data-theme="dark"] .search-result-item {
	color: var(--text-primary);
	border-bottom-color: var(--border-subtle);
}

[data-theme="dark"] .search-result-item:hover {
	background: var(--bg-elevated);
}

[data-theme="dark"] .search-result-meta {
	color: var(--text-muted);
}

/* Dropdown select */
[data-theme="dark"] select option {
	background: var(--bg-secondary);
	color: var(--text-primary);
}

/* Scrollbars */
[data-theme="dark"] ::-webkit-scrollbar-track {
	background: var(--bg-primary);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
	background: var(--border-strong);
	border-radius: 4px;
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
	background: var(--text-light);
}


/* ===== LAYOUT UTILS ===== */
.container {
	width: 100%;
	max-width: var(--max-content);
	margin: 0 auto;
	padding: 0 1rem;
}

.flex      { display: flex; }
.flex-col  { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.items-end    { align-items: flex-end; }
.justify-center  { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end     { justify-content: flex-end; }
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.ml-2    { margin-left: 0.5rem; }
.ml-auto { margin-left: auto; }
.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-4 { margin-top: 1rem; }
.mb-2 { margin-bottom: 0.5rem; }
.mb-3 { margin-bottom: 0.75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }
.p-0  { padding: 0; }
.p-4  { padding: 1rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.pt-4 { padding-top: 1rem; }
.pb-2 { padding-bottom: 0.5rem; }
.w-full       { width: 100%; }
.hidden       { display: none !important; }
.text-sm      { font-size: var(--font-sm); }
.text-xs      { font-size: var(--font-xs); }
.text-muted   { color: var(--text-muted); }
.text-white   { color: #fff; }
.font-semibold { font-weight: 600; }


/* ===== SCROLLBARS ===== */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-tertiary); border-radius: var(--radius-sm); }
::-webkit-scrollbar-thumb {
	background: linear-gradient(135deg, var(--sunset-orange), var(--ocean-teal));
	border-radius: var(--radius-sm);
}
::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(135deg, var(--sunset-orange-dark), var(--ocean-teal-dark));
}

/* ===== BUTTONS ===== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.5rem;
	border-radius: var(--radius-lg);
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 0.9rem;
	border: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	text-decoration: none;
	white-space: nowrap;
	position: relative;
	overflow: hidden;
}
.btn::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(rgba(255,255,255,0.1), rgba(255,255,255,0));
	opacity: 0;
	transition: opacity var(--transition-fast);
}
.btn:hover::after { opacity: 1; }

.btn-primary {
	background: var(--gradient-sunset);
	color: #fff;
	box-shadow: 0 4px 15px rgba(255,107,53,0.3);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(255,107,53,0.4); }

.btn-outline {
	background: transparent;
	border: 2px solid var(--border-strong);
	color: var(--text-primary);
}
.btn-outline:hover { border-color: var(--sunset-orange); color: var(--sunset-orange); transform: translateY(-2px); }

.btn-ghost {
	padding: 0.5rem 1rem;
	border-radius: var(--radius-pill);
	border: 1px solid var(--border-subtle);
	background: var(--bg-elevated);
	color: var(--text-primary);
	font-size: 0.8rem;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	transition: all var(--transition-fast);
}
.btn-ghost:hover { border-color: var(--sunset-orange); color: var(--sunset-orange); }

.btn-icon {
	width: 2.75rem;
	height: 2.75rem;
	border-radius: var(--radius-lg);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: var(--bg-elevated);
	color: var(--text-primary);
	font-size: var(--icon-base);
	transition: all var(--transition-normal);
}
.btn-icon:hover { background: var(--gradient-sunset); color: #fff; transform: translateY(-2px); box-shadow: var(--shadow-sm); }

.btn-sm  { padding: 0.5rem 1rem; font-size: 0.8rem; }
.btn-xs  { padding: 0.3rem 0.75rem; font-size: 0.75rem; }
.btn-retry {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: var(--gradient-sunset);
	color: #fff;
	border: none;
	border-radius: var(--radius-pill);
	padding: 0.75rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
}

.btn-journey {
	background: linear-gradient(135deg, var(--sunset-orange) 0%, var(--ocean-teal) 100%);
	color: #fff;
	padding: 1rem 2rem;
	border-radius: var(--radius-lg);
	font-weight: 600;
	font-size: 1rem;
	border: none;
	position: relative;
	overflow: hidden;
	transition: all var(--transition-normal);
}
.btn-journey::before {
	content: '';
	position: absolute;
	top: 0; left: -100%; width: 100%; height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
	transition: left 0.7s ease;
}
.btn-journey:hover::before { left: 100%; }
.btn-journey:hover { transform: translateY(-3px); box-shadow: 0 15px 30px rgba(255,107,53,0.3); }
.btn-journey:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ===== BADGES ===== */
.badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.375rem 0.75rem;
	border-radius: var(--radius-pill);
	font-size: 0.8rem;
	font-weight: 600;
	background: var(--bg-elevated);
	color: var(--text-secondary);
	border: 1px solid var(--border-subtle);
}
.badge-stops    { background: var(--gradient-sunset); color: #fff; border: none; }
.badge-bucket   { background: var(--gradient-ocean); color: #fff; border: none; }
.badge-adventure { background: linear-gradient(135deg,var(--adventure-green),#2ecc71); color:#fff; border:none; }
.badge-cultural  { background: linear-gradient(135deg,var(--cultural-purple),#9d4edd); color:#fff; border:none; }
.badge-success   { background: linear-gradient(135deg,var(--adventure-green),#2ecc71); color:#fff; border:none; }
.badge-danger    { background: var(--danger-color); color: #fff; border: none; }

/* ===== AVATARS ===== */
.avatar {
	width: 2.75rem;
	height: 2.75rem;
	border-radius: var(--radius-lg);
	background: var(--gradient-sunset);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 600;
	font-size: 1rem;
	border: 3px solid var(--bg-card);
	box-shadow: var(--shadow-sm);
	flex-shrink: 0;
}
.avatar-sm { width: 2.25rem; height: 2.25rem; font-size: 0.85rem; border-width: 2px; }
.avatar-lg { width: 3.5rem; height: 3.5rem; font-size: 1.25rem; border-width: 3px; }
.avatar-xl { width: 5rem; height: 5rem; font-size: 1.75rem; border-width: 4px; }
.avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: inherit;
	display: block;
}
.avatar:has(img[style*="display:block"]) i {
	display: none !important;
}

/* ===== CARDS ===== */
.card {
	background: var(--gradient-card);
	border-radius: var(--radius-card);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	padding: 1.5rem;
	transition: all var(--transition-normal);
}
.card:hover { box-shadow: var(--shadow-md); }
.card-title {
	font-family: 'Lora', serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: 0;
}

/* ===== FORMS ===== */
.form-control {
	width: 100%;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-lg);
	border: 1px solid var(--border-color);
	background: var(--bg-primary);
	color: var(--text-primary);
	font-size: 0.9rem;
	outline: none;
	transition: border-color var(--transition-fast), background-color var(--transition-fast);
}
.form-control:focus { border-color: var(--sunset-orange); background-color: var(--bg-card); }
select.form-control {
    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 0.75rem center;
    padding-right: 2rem;
}
.form-group { margin-bottom: 1rem; }
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.textarea {
	width: 100%;
	min-height: 120px;
	resize: vertical;
	border-radius: var(--radius-lg);
	border: 1px solid var(--border-color);
	background: var(--bg-primary);
	color: var(--text-primary);
	padding: 0.75rem;
	font-size: 0.9rem;
	outline: none;
	font-family: inherit;
	line-height: 1.5;
}
.textarea:focus { border-color: var(--sunset-orange); }

/* ===== APP STRUCTURE ===== */
#app {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	/* On mobile: true full-screen PWA layout */
	position: relative;
}

/* Header */
.app-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	height: var(--header-height);
	background: var(--bg-overlay);
	backdrop-filter: blur(20px);
	border-bottom: 1px solid var(--border-color);
	z-index: 1000;
	padding: 0 0.75rem;
}
.header-content {
	height: 100%;
	max-width: var(--max-content);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
}
.profile-menu-btn {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	background: none;
	border: none;
	padding: 0.5rem;
	border-radius: var(--radius-lg);
	cursor: pointer;
	transition: all var(--transition-fast);
	color: var(--text-primary);
	flex-shrink: 0;
}
.profile-menu-btn:hover { background: var(--bg-elevated); }
.profile-avatar {
	width: 2.4rem; height: 2.4rem;
	border-radius: var(--radius-lg);
	background: var(--gradient-sunset);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 600;
	font-size: 0.9rem;
}
.brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex: 1;
	min-width: 0;
}
.brand-name {
	font-family: 'Lora', serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	white-space: nowrap;
	background: var(--gradient-adventure);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.brand-sub {
	font-size: 0.65rem;
	color: var(--text-muted);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	white-space: nowrap;
}
.header-search {
	display: none;
	flex: 0 0 320px;
	margin-left: 1.5rem;
}
.header-search input {
	width: 100%;
	padding: 0.5rem 0.875rem;
	border-radius: var(--radius-pill);
	border: 1px solid var(--border-subtle);
	background: var(--bg-elevated);
	color: var(--text-primary);
	font-size: 0.9rem;
	outline: none;
}
.header-search input:focus { border-color: var(--sunset-orange); }
.header-actions { display: flex; align-items: center; gap: 0.25rem; flex-shrink: 0; }
.action-btn {
	width: 2.4rem; height: 2.4rem;
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--bg-elevated);
	border: 1px solid var(--border-subtle);
	color: var(--text-primary);
	cursor: pointer;
	transition: all var(--transition-fast);
	position: relative;
}
.action-btn i { font-size: var(--icon-base); }
.action-btn:hover { background: var(--gradient-sunset); color: #fff; border-color: transparent; transform: translateY(-1px); }
.action-btn.active { background: var(--gradient-sunset); color: #fff; border-color: transparent; }

/* Main content */
.main-content {
	flex: 1;
	padding-top: calc(var(--header-height) + 1rem);
	padding-bottom: calc(var(--bottom-nav-height) + 2rem + env(safe-area-inset-bottom, 0px));
	background: var(--bg-primary);
	overflow-y: auto;
	/* Ensure content area stretches to push nav to bottom */
	min-height: calc(100vh - var(--header-height));
}

/* Pages */
.page { display: none; padding: 1rem 0; animation: fadeIn 0.4s ease; }
.page.active { display: block; }
@keyframes fadeIn {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}
.page-header { margin-bottom: 2rem; text-align: center; }
.page-title {
	font-family: 'Lora', serif;
	font-size: 1.9rem;
	font-weight: 700;
	color: var(--text-primary);
	margin-bottom: 0.5rem;
	background: linear-gradient(135deg, var(--sunset-orange), var(--ocean-teal));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.page-subtitle {
	font-size: 0.9rem;
	color: var(--text-muted);
	max-width: 600px;
	margin: 0 auto;
}

/* Section title */
.section-title {
	font-family: 'Lora', serif;
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: 1rem;
}

@media (max-width: 480px) {
	:root {
		--bottom-nav-height: 60px;
	}
}

@media (min-width: 1024px) {
	:root {
		--bottom-nav-height: 52px;
	}
}

/* ===== BOTTOM NAV ===== */
.bottom-nav {
	position: fixed;
	left: 0; 
	right: 0; 
	bottom: 0;
	width: 100%;
	height: var(--bottom-nav-height);
	background: var(--bg-overlay);
	backdrop-filter: blur(20px);
	border-top: 1px solid var(--border-color);
	z-index: 999;
	padding: 0.75rem 0 calc(0.75rem + env(safe-area-inset-bottom, 0px));
	transform: translateY(0);
	transition: transform var(--transition-normal), box-shadow var(--transition-normal), width var(--transition-normal);
	box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.05);
}
.bottom-nav.hidden,
.bottom-nav.nav-hidden { transform: translateY(calc(100% + 12px)); }
.nav-items {
	display: flex;
	justify-content: space-around;
	align-items: center;
	height: 100%;
	max-width: var(--max-content);
	margin: 0 auto;
}
.nav-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.375rem;
	color: var(--text-muted);
	text-decoration: none;
	font-size: 0.75rem;
	transition: all var(--transition-fast);
	cursor: pointer;
	flex: 1;
	position: relative;
}
.nav-item i { font-size: 1.3rem; transition: all var(--transition-normal); }
.nav-item.active { color: var(--sunset-orange); }
.nav-item:hover  { color: var(--sunset-orange); }
.nav-item:hover i { transform: translateY(-2px); }
.nav-indicator {
	width: 0.375rem; height: 0.375rem;
	border-radius: 50%;
	background: var(--sunset-orange);
	opacity: 0;
	transition: opacity var(--transition-fast);
}
.nav-item.active .nav-indicator { opacity: 1; }
.post-nav-item { flex: 0; padding: 0; }
.post-fab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem; height: 3rem;
	border-radius: 50%;
	border: none;
	background: var(--gradient-adventure);
	color: #fff;
	font-size: 1.25rem;
	cursor: pointer;
	box-shadow: 0 4px 15px rgba(255,107,53,0.4);
	transition: transform var(--transition-bounce), box-shadow var(--transition-bounce);
}
.post-fab:hover { transform: scale(1.08); box-shadow: 0 8px 24px rgba(255,107,53,0.5); }

@media (max-width: 480px) {
	.bottom-nav {
		padding: 0.45rem 0 calc(0.45rem + env(safe-area-inset-bottom, 0px));
	}
	.nav-item i { font-size: 1.15rem; }
	.nav-item { font-size: 0.72rem; }
}

@media (min-width: 1024px) {
	.bottom-nav {
		padding: 0.4rem 0 calc(0.4rem + env(safe-area-inset-bottom, 0px));
	}
	.nav-item {
		font-size: 0.78rem;
	}
	.nav-item i { font-size: 1.15rem; }
}

/* ===== PROFILE DRAWER ===== */
.profile-drawer {
	position: fixed;
	top: 0; left: -100%;
	width: 100%; max-width: var(--drawer-width);
	height: 100%;
	background: var(--bg-overlay);
	backdrop-filter: blur(20px);
	z-index: 1001;
	transition: left var(--transition-normal);
	overflow-y: auto;
	box-shadow: var(--shadow-lg);
	border-right: 1px solid var(--border-color);
}
.profile-drawer.active { left: 0; }
.drawer-header {
	padding: 2rem 1.5rem 1.5rem;
	border-bottom: 1px solid var(--border-color);
	background: linear-gradient(135deg, var(--sunset-orange), var(--ocean-teal));
	color: #fff;
}
.drawer-profile { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.drawer-profile .avatar { width: 4rem; height: 4rem; border: 3px solid rgba(255,255,255,0.3); }
.drawer-profile-info h3 { color: #fff; margin-bottom: 0.2rem; }
.drawer-profile-info p  { font-size: 0.85rem; opacity: 0.85; }
.drawer-nav { padding: 1.5rem; }
.drawer-nav-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem;
	color: var(--text-primary);
	text-decoration: none;
	border-radius: var(--radius-lg);
	transition: all var(--transition-fast);
	margin-bottom: 0.25rem;
	font-size: 0.95rem;
	background: none;
	border: none;
	width: 100%;
	text-align: left;
	cursor: pointer;
}
.drawer-nav-item:hover { background: var(--bg-elevated); color: var(--sunset-orange); }
.drawer-nav-item.active { color: var(--sunset-orange); background: var(--bg-elevated); }
.drawer-divider { height: 1px; background: var(--border-color); margin: 1rem 0; }

/* Drawer overlay */
.drawer-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 999;
  opacity: 0;
  transition: opacity var(--transition-normal);
}
.drawer-overlay.active {
  display: block;
  opacity: 1;
}

/* ===== AI ASSISTANT BTN ===== */
.ai-assistant-btn {
	position: fixed;
	bottom: calc(var(--bottom-nav-height) + 1.5rem);
	right: 1.5rem;
	width: 3.75rem; height: 3.75rem;
	border-radius: var(--radius-lg);
	background: var(--gradient-adventure);
	color: #fff;
	border: none;
	box-shadow: 0 8px 25px rgba(255,107,53,0.4);
	cursor: pointer;
	z-index: 90;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--icon-lg);
	transition: all var(--transition-bounce);
}
.ai-assistant-btn:hover { transform: scale(1.1) rotate(5deg); box-shadow: 0 12px 35px rgba(255,107,53,0.5); }

/* ===== MODALS ===== */
.modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.55);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 1100;
	padding: 1rem;
}
.modal-overlay.active { display: flex; }
.modal {
	width: 100%;
	max-width: 480px;
	background: var(--bg-card);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-elevated);
	max-height: 90vh;
	overflow-y: auto;
	animation: slideUp 0.3s var(--transition-bounce);
}
@keyframes slideUp {
	from { transform: translateY(40px); opacity: 0; }
	to   { transform: translateY(0); opacity: 1; }
}
.modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--border-subtle);
	position: sticky;
	top: 0;
	background: var(--bg-card);
	z-index: 1;
}
.modal-title { font-size: 1.1rem; font-weight: 600; margin-bottom: 0; }
.modal-close {
	border: none;
	background: transparent;
	cursor: pointer;
	color: var(--text-muted);
	width: 2rem; height: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-sm);
	transition: all var(--transition-fast);
}
.modal-close:hover { background: var(--bg-elevated); color: var(--text-primary); }
.modal-body   { padding: 1.25rem 1.5rem; }
.modal-footer {
	padding: 1rem 1.5rem;
	border-top: 1px solid var(--border-subtle);
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	position: sticky;
	bottom: 0;
	background: var(--bg-card);
}

/* Bottom sheet modal */
.modal-bottom {
	position: fixed;
	bottom: 0; left: 0; right: 0;
	max-width: 100%;
	border-radius: var(--radius-xl) var(--radius-xl) 0 0;
	margin: 0;
	padding-bottom: env(safe-area-inset-bottom, 1rem);
	animation: sheetUp 0.35s var(--transition-bounce);
}
@keyframes sheetUp {
	from { transform: translateY(100%); }
	to   { transform: translateY(0); }
}
.modal-overlay:has(.modal-bottom) { align-items: flex-end; padding: 0; }

/* Fullscreen modal */
.modal-fullscreen {
	position: fixed;
	inset: 0;
	max-width: 100%;
	max-height: 100%;
	border-radius: 0;
	margin: 0;
	padding: 0;
	background: rgba(0,0,0,0.97);
}
.modal-overlay:has(.modal-fullscreen) { padding: 0; }

/* ===== OPTIONS SHEET BUTTONS ===== */
.options-sheet-btn {
	display: flex;
	align-items: center;
	gap: 1rem;
	width: 100%;
	padding: 1rem 1.5rem;
	background: none;
	border: none;
	border-bottom: 1px solid var(--border-subtle);
	color: var(--text-primary);
	font-size: 1rem;
	cursor: pointer;
	text-align: left;
	transition: background var(--transition-fast);
}
.options-sheet-btn:hover  { background: var(--bg-elevated); }
.options-sheet-btn:last-child { border-bottom: none; }
.options-sheet-btn i { width: 1.5rem; color: var(--sunset-orange); }
.options-sheet-btn.text-danger { color: var(--danger-color); }
.options-sheet-btn.text-danger i { color: var(--danger-color); }
.options-cancel {
	color: var(--text-muted);
	font-weight: 600;
	justify-content: center;
	margin-top: 0.25rem;
	border-top: 2px solid var(--border-color);
}
.options-cancel i { display: none; }

/* ===== NOTIFICATIONS ===== */
.notification-container {
	position: fixed;
	top: 1rem; right: 1rem;
	z-index: 9999;
}
.notification {
	padding: 1rem 1.5rem;
	border-radius: var(--radius-lg);
	background: var(--gradient-card);
	box-shadow: var(--shadow-lg);
	display: flex;
	align-items: center;
	gap: 0.75rem;
	transform: translateX(150%);
	transition: transform 0.3s ease;
	max-width: 400px;
	margin-bottom: 0.5rem;
	border: 1px solid var(--border-color);
}
.notification.show { transform: translateX(0); }
.notification-icon { width:1.5rem; height:1.5rem; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-sm); }
.notification-success { border-left:4px solid var(--success-color); }
.notification-success .notification-icon { background:rgba(56,176,0,0.18); color:var(--success-color); }
.notification-error   { border-left:4px solid var(--danger-color); }
.notification-error .notification-icon   { background:rgba(255,0,110,0.18); color:var(--danger-color); }
.notification-warning { border-left:4px solid var(--warning-color); }
.notification-warning .notification-icon { background:rgba(255,158,0,0.18); color:var(--warning-color); }
.notification-info    { border-left:4px solid var(--info-color); }
.notification-info .notification-icon    { background:rgba(58,134,255,0.18); color:var(--info-color); }
.notification-content { flex:1; }
.notification-title   { font-weight:600; font-size:0.9rem; margin-bottom:0.125rem; }
.notification-message { font-size:0.8rem; color:var(--text-secondary); }
.notification-close   { background:none; border:none; color:var(--text-muted); cursor:pointer; padding:0.25rem; font-size:0.9rem; }

/* ===== EMPTY STATE ===== */
.empty-state { text-align:center; padding:3rem 1rem; }
.empty-state-icon { width:4rem; height:4rem; border-radius:var(--radius-lg); background:var(--bg-elevated); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:1.5rem; margin:0 auto 1rem; }
.empty-state-title { font-family:'Lora',serif; font-size:1.25rem; color:var(--text-primary); margin-bottom:0.5rem; }
.empty-state-message { font-size:0.9rem; color:var(--text-muted); max-width:400px; margin:0 auto 1.5rem; }

/* ===== APP FOOTER ===== */
.app-footer { border-top:1px solid var(--border-color); background:var(--bg-secondary); color:var(--text-muted); font-size:0.8rem; }
.app-footer-content { display:flex; justify-content:space-between; align-items:center; padding:0.75rem 1rem; max-width:var(--max-content); margin:0 auto; flex-wrap:wrap; gap:0.5rem; }
.app-footer a { color:var(--text-muted); text-decoration:none; font-size:0.8rem; }
.app-footer a:hover { color:var(--sunset-orange); text-decoration:underline; }
.app-footer-brand { font-weight:600; }
.app-footer-links { display:flex; align-items:center; gap:0.5rem; flex-wrap:wrap; }

/* ===== PROFILE HEADER ===== */
.profile-header {
	padding:3rem 1rem;
	text-align:center;
	background: linear-gradient(135deg, var(--sunset-orange), var(--ocean-teal));
	color:#fff;
	margin-bottom:2rem;
	border-radius:var(--radius-card);
	position:relative;
	overflow:hidden;
}
.profile-avatar-container { position:relative; display:inline-block; margin-bottom:1.5rem; }
.profile-avatar-container .avatar { width:6rem; height:6rem; border:5px solid rgba(255,255,255,0.3); }
.profile-stats { display:flex; justify-content:center; gap:2rem; margin-top:1.5rem; }
.stat-item { text-align:center; }
.stat-number { font-size:1.75rem; font-weight:700; font-family:'Lora',serif; }
.stat-label  { font-size:0.8rem; opacity:0.9; text-transform:uppercase; letter-spacing:0.05em; }
.profile-tabs { display:flex; gap:0.5rem; margin-bottom:2rem; overflow-x:auto; padding:0.5rem 0; }
.profile-tab {
	padding:0.75rem 1.5rem;
	border-radius:var(--radius-pill);
	background:var(--bg-elevated);
	color:var(--text-secondary);
	border:2px solid var(--border-subtle);
	cursor:pointer;
	white-space:nowrap;
	font-size:0.9rem;
	font-weight:500;
	transition:all var(--transition-fast);
}
.profile-tab.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; box-shadow:0 4px 12px rgba(255,107,53,0.3); }
.tab-content { display:none; }
.tab-content.active { display:block; }

/* ===== DETAIL TOPBAR ===== */
.detail-topbar {
	display:flex;
	align-items:center;
	justify-content:space-between;
	padding:0.75rem var(--spacing-md);
	position:sticky;
	top:var(--header-height);
	background:var(--bg-primary);
	z-index:100;
	border-bottom:1px solid var(--border-subtle);
}

/* ===== MESSAGES ===== */
.messages-panel { flex:1; overflow-y:auto; background:var(--bg-card); border-radius:var(--radius-lg); }
.message-thread { display:flex; align-items:flex-start; gap:1rem; padding:1rem; border-bottom:1px solid var(--border-subtle); cursor:pointer; transition:background 0.2s; }
.message-thread:hover { background:var(--bg-elevated); }
.message-avatar { width:3rem; height:3rem; border-radius:var(--radius-lg); background:var(--gradient-sunset); display:flex; align-items:center; justify-content:center; color:#fff; font-weight:600; flex-shrink:0; }
.message-details { flex:1; min-width:0; }
.message-details h4 { font-size:0.95rem; margin-bottom:0.25rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.message-preview  { font-size:0.85rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.message-meta     { display:flex; align-items:center; gap:0.5rem; font-size:0.75rem; color:var(--text-muted); }
.unread-dot       { width:0.6rem; height:0.6rem; border-radius:50%; background:var(--sunset-orange); }
.message-badge    { background:var(--sunset-orange); color:#fff; border-radius:var(--radius-pill); padding:0.2rem 0.5rem; font-size:0.75rem; font-weight:600; }
.message-composer {
	position:fixed;
	bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom, 0px));
	left:0; right:0;
	background:var(--bg-card);
	border-top:1px solid var(--border-color);
	padding:1rem;
	box-shadow:var(--shadow-sm);
	z-index:100;
}
.composer-input-group { display:flex; gap:0.75rem; align-items:flex-end; }
#messageInput { flex:1; border-radius:var(--radius-lg); }
.char-counter { font-size:0.75rem; color:var(--text-muted); text-align:right; margin-top:0.25rem; }
.char-counter.warning { color:var(--warning-color); }

/* ===== NOTIFICATIONS PANEL ===== */
.notifications-panel { background:var(--gradient-card); border-radius:var(--radius-card); border:1px solid var(--border-color); box-shadow:var(--shadow-sm); }
.notification-item { display:flex; align-items:flex-start; gap:0.75rem; padding:1rem 1.25rem; border-bottom:1px solid var(--border-subtle); }
.notification-item:last-child { border-bottom:none; }
.notification-dot { width:0.6rem; height:0.6rem; border-radius:50%; background:var(--sunset-orange); margin-top:0.35rem; flex-shrink:0; }
.notification-item.read .notification-dot { background:var(--border-subtle); }
.notification-text-main { font-size:0.9rem; color:var(--text-primary); }
.notification-text-time { font-size:0.8rem; color:var(--text-muted); margin-top:0.15rem; }

/* ===== SETTINGS TOGGLE ===== */
.settings-row { display:flex; align-items:center; justify-content:space-between; padding:0.5rem 0; }
.settings-row-title { font-size:0.95rem; font-weight:500; color:var(--text-primary); }
.settings-row-sub   { font-size:0.8rem; color:var(--text-muted); margin-top:0.15rem; }
.toggle-switch { position:relative; display:inline-block; width:3rem; height:1.625rem; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-slider {
	position:absolute;
	inset:0;
	background:var(--border-strong);
	border-radius:var(--radius-pill);
	transition:all var(--transition-normal);
	cursor:pointer;
}
.toggle-slider::before {
	content:'';
	position:absolute;
	height:1.125rem; width:1.125rem;
	left:0.25rem; bottom:0.25rem;
	background:#fff;
	border-radius:50%;
	transition:all var(--transition-normal);
}
.toggle-switch input:checked + .toggle-slider { background:var(--gradient-adventure); }
.toggle-switch input:checked + .toggle-slider::before { transform:translateX(1.375rem); }

/* ===== RATING STARS ===== */
.rating-stars { display:flex; gap:0.2rem; color:var(--warning-color); }
.rating-stars i { font-size:1rem; }

/* ===== ABOUT ROW (public profile) ===== */
.about-row { display:flex; align-items:center; gap:0.75rem; font-size:0.875rem; padding:0.375rem 0; }
.about-row i { color:var(--sunset-orange); width:1.25rem; text-align:center; }

/* ===== BADGES STRIP (profile) ===== */
.badges-strip { display:flex; gap:0.5rem; overflow-x:auto; padding:0.75rem var(--spacing-md); scrollbar-width:none; }
.badges-strip::-webkit-scrollbar { display:none; }

/* ===== PUBLIC PROFILE ACTIONS ===== */
.public-profile-actions { display:flex; gap:0.75rem; flex-wrap:wrap; justify-content:center; margin-top:1rem; }

/* ===== QUICK FACTS ===== */
.quick-fact { display:flex; align-items:center; gap:0.75rem; padding:0.5rem 0; }
.quick-fact i { color:var(--sunset-orange); width:1.25rem; text-align:center; }
.quick-fact-label { font-size:0.75rem; color:var(--text-muted); }
.quick-fact-value { font-size:0.9rem; font-weight:500; color:var(--text-primary); }

/* ===== TAG INPUT ===== */
.tag-input {
	border:none; outline:none;
	background:transparent;
	font-size:0.875rem;
	color:var(--text-primary);
	min-width:80px;
	font-family:inherit;
}
.tag-trip-list { display:flex; flex-direction:column; gap:0.5rem; }
.tagged-buddies-chips { display:flex; flex-wrap:wrap; gap:0.5rem; min-height:2rem; }

/* ===== TRENDING / RECENT SEARCH ===== */
.trending-list      { display:flex; flex-direction:column; gap:0.5rem; }
.recent-searches-list { display:flex; flex-direction:column; gap:0.5rem; }
.recent-locations   { margin-top:1rem; }

/* ===== LOCATION SEARCH BAR ===== */
.location-search-bar {
	display:flex;
	align-items:center;
	gap:0.5rem;
	background:var(--bg-elevated);
	border:1px solid var(--border-color);
	border-radius:var(--radius-pill);
	padding:0.5rem 0.875rem;
}
.location-search-bar i { color:var(--text-muted); flex-shrink:0; }
.location-search-bar input { flex:1; border:none; background:transparent; outline:none; font-size:0.9rem; color:var(--text-primary); }
.location-results { display:flex; flex-direction:column; gap:0.5rem; }

/* ===== SUGGESTED BUDDIES (onboarding) ===== */
.suggested-buddies-list { display:flex; flex-direction:column; gap:0.75rem; margin-top:1rem; }

/* ===== REPLIES LIST ===== */
.replies-list   { display:flex; flex-direction:column; gap:1rem; }
.reviews-list   { display:flex; flex-direction:column; gap:1rem; }
.comments-list  { display:flex; flex-direction:column; gap:0.75rem; }
.comments-section { margin-top:1.5rem; }

/* ===== THREAD (forum-thread) ===== */
.thread-header  { margin-bottom:1.5rem; }
.thread-title   { font-family:'Lora',serif; font-size:1.4rem; font-weight:700; color:var(--text-primary); margin-bottom:0.75rem; }
.thread-body    { font-size:0.95rem; line-height:1.7; color:var(--text-secondary); }
.thread-author  { display:flex; align-items:center; gap:0.75rem; margin-bottom:1rem; }
.thread-author-name { font-weight:600; color:var(--text-primary); }
.thread-tags    { display:flex; flex-wrap:wrap; gap:0.5rem; margin-top:1rem; }
.thread-actions { display:flex; gap:1rem; margin-top:1rem; padding-top:1rem; border-top:1px solid var(--border-subtle); }

/* ===== LISTING (marketplace-listing) ===== */
.listing-gallery-wrap { width:100%; overflow:hidden; }
.listing-gallery-component { width:100%; }
.listing-title-row { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; }
.listing-title   { font-family:'Lora',serif; font-size:1.5rem; font-weight:700; color:var(--text-primary); }
.listing-price-block { text-align:right; flex-shrink:0; }
.listing-price   { font-size:1.75rem; font-weight:700; color:var(--sunset-orange); }
.listing-rating  { display:flex; align-items:center; gap:0.5rem; margin-top:0.25rem; }
.listing-quick-facts { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.listing-includes { list-style:none; display:flex; flex-direction:column; gap:0.5rem; }
.listing-includes li { display:flex; align-items:center; gap:0.5rem; font-size:0.875rem; color:var(--text-secondary); }
.listing-includes li::before { content:'✓'; color:var(--adventure-green); font-weight:700; }

/* ===== BOOKING STICKY BAR ===== */
.booking-sticky-bar {
	position:sticky;
	bottom:var(--bottom-nav-height);
	background:var(--bg-card);
	border-top:1px solid var(--border-color);
	padding:1rem 1.5rem;
	display:flex;
	align-items:center;
	justify-content:space-between;
	box-shadow:0 -4px 20px rgba(0,0,0,0.1);
	z-index:100;
}
.booking-price { font-size:1.5rem; font-weight:700; color:var(--sunset-orange); }

/* ===== DASHBOARD CARDS ===== */
.dashboard-cards { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-bottom:2rem; }
.dashboard-card {
	position:relative;
	border-radius:var(--radius-card);
	border:1px solid var(--border-color);
	background:var(--gradient-card);
	padding:1.5rem;
	box-shadow:var(--shadow-sm);
	transition:all var(--transition-normal);
}
.dashboard-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.dashboard-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; padding-bottom:1rem; border-bottom:2px solid var(--border-subtle); }
.dashboard-card-body   { font-size:0.9rem; color:var(--text-primary); margin-bottom:1rem; line-height:1.6; }
.dashboard-card-footer { display:flex; align-items:center; justify-content:space-between; }

/* ===== GRIDS ===== */
.destinations-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.destination-card  { border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-sm); background:var(--gradient-card); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.destination-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.destination-image { width:100%; height:200px; object-fit:cover; }
.destination-content { padding:1.25rem; }
.destination-title   { font-family:'Lora',serif; font-size:1.15rem; font-weight:600; color:var(--text-primary); }
.destination-description { font-size:0.9rem; color:var(--text-secondary); margin-bottom:1rem; line-height:1.5; }
.destination-stats { display:flex; justify-content:space-between; align-items:center; font-size:0.8rem; color:var(--text-muted); }

.events-search { max-width:420px; margin:0 auto 1.5rem; }
.events-grid   { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.event-card    { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); text-align:center; }
.event-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.event-icon    { width:3rem; height:3rem; border-radius:var(--radius-lg); background:var(--gradient-adventure); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.35rem; margin:0 auto 1rem; }
.event-title   { font-family:'Lora',serif; font-size:1.2rem; font-weight:600; margin-bottom:0.5rem; color:var(--text-primary); }
.event-description { font-size:0.9rem; color:var(--text-secondary); margin-bottom:1rem; line-height:1.5; }
.event-details { display:flex; justify-content:space-between; font-size:0.8rem; color:var(--text-muted); }

.trips-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.trip-card  { position:relative; border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-sm); cursor:pointer; transition:all var(--transition-normal); background:var(--gradient-card); border:1px solid var(--border-color); }
.trip-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.trip-image { width:100%; height:200px; object-fit:cover; }
.trip-info  { padding:1.25rem; }
.trip-title { font-family:'Lora',serif; font-size:1.15rem; font-weight:600; margin-bottom:0.5rem; color:var(--text-primary); }
.trip-dates { font-size:0.9rem; color:var(--text-muted); margin-bottom:1rem; }
.trip-stats { display:flex; gap:0.75rem; flex-wrap:wrap; }

.buddies-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.buddy-card   { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; text-align:center; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.buddy-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.buddy-avatar { width:5rem; height:5rem; margin:0 auto 1rem; border-radius:var(--radius-lg); background:var(--gradient-sunset); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.5rem; font-weight:600; border:4px solid var(--bg-card); box-shadow:var(--shadow-sm); }
.buddy-name     { font-family:'Lora',serif; font-size:1.15rem; font-weight:600; margin-bottom:0.25rem; color:var(--text-primary); }
.buddy-location { font-size:0.9rem; color:var(--text-muted); margin-bottom:1rem; }
.buddy-stats    { display:flex; justify-content:center; gap:1rem; font-size:0.8rem; color:var(--text-muted); }
.buddy-tag-list { display:flex; flex-direction:column; gap:0.5rem; }

.forums-grid  { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.forums-page-actions { display:flex; justify-content:flex-end; margin-bottom:1.25rem; }
.forum-card   { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.forum-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.forum-icon   { width:3rem; height:3rem; border-radius:var(--radius-lg); background:var(--gradient-sunset); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.35rem; margin-bottom:1rem; }
.forum-title  { font-family:'Lora',serif; font-size:1.15rem; font-weight:600; margin-bottom:0.5rem; color:var(--text-primary); }
.forum-description { font-size:0.9rem; color:var(--text-secondary); margin-bottom:1rem; line-height:1.5; }
.forum-stats  { display:flex; justify-content:space-between; font-size:0.8rem; color:var(--text-muted); }

.marketplace-filters { display:flex; gap:0.75rem; margin-bottom:2rem; overflow-x:auto; padding:0.5rem 0; }
.filter-btn { padding:0.75rem 1.5rem; border-radius:var(--radius-pill); background:var(--bg-elevated); color:var(--text-secondary); border:2px solid var(--border-subtle); cursor:pointer; white-space:nowrap; font-size:0.9rem; font-weight:500; transition:all var(--transition-fast); }
.filter-btn.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; box-shadow:0 4px 12px rgba(255,107,53,0.3); }
.marketplace-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.marketplace-card { background:var(--gradient-card); border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.marketplace-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.marketplace-image   { width:100%; height:180px; object-fit:cover; }
.marketplace-content { padding:1.25rem; }
.marketplace-title   { font-family:'Lora',serif; font-size:1.15rem; font-weight:600; margin-bottom:0.5rem; color:var(--text-primary); }
.marketplace-price   { color:var(--sunset-orange); font-weight:700; font-size:1.15rem; margin-bottom:0.5rem; }
.marketplace-rating  { display:flex; align-items:center; gap:0.25rem; color:var(--warning-color); font-size:0.9rem; }

.safety-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.safety-card { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; text-align:center; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.safety-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.safety-icon { width:3rem; height:3rem; border-radius:var(--radius-lg); background:var(--gradient-ocean); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.25rem; margin:0 auto 1rem; }

.badges-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.badge-card  { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; text-align:center; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.badge-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.badge-icon  { width:4rem; height:4rem; border-radius:var(--radius-lg); background:var(--gradient-adventure); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.5rem; margin:0 auto 1rem; box-shadow:0 8px 20px rgba(255,107,53,0.3); }

.offline-features { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:1.5rem; margin-top:1.5rem; }
.offline-card { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; text-align:center; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.offline-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.offline-title    { font-size:1.75rem; font-weight:700; margin-bottom:0.75rem; }
.offline-subtitle { color:var(--text-muted); max-width:360px; line-height:1.6; margin-bottom:2rem; }
.offline-tips     { background:var(--bg-card); border-radius:var(--radius-lg); padding:1.5rem; max-width:360px; width:100%; box-shadow:var(--shadow-soft); text-align:left; margin-bottom:2rem; }
.offline-tips h3  { font-size:0.875rem; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:1rem; }
.offline-tip      { display:flex; align-items:center; gap:0.75rem; padding:0.5rem 0; font-size:0.875rem; border-bottom:1px solid var(--border-subtle); }
.offline-tip:last-child { border-bottom:none; }
.offline-tip-icon { width:2rem; height:2rem; border-radius:50%; background:var(--bg-elevated); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.offline-icon     { font-size:4rem; margin-bottom:1.5rem; }

/* ===== PLANNER ===== */
.planner-container { display:grid; grid-template-columns:1fr; gap:2rem; }
.planner-sidebar, .planner-main { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; border:1px solid var(--border-color); box-shadow:var(--shadow-sm); }
.timeline { display:flex; flex-direction:column; gap:0.75rem; }
.timeline-item { position:relative; padding-left:1.5rem; }
.timeline-item::before { content:''; position:absolute; left:0; top:0.35rem; width:0.6rem; height:0.6rem; border-radius:999px; background:var(--sunset-orange); }
.timeline-time  { font-size:0.8rem; color:var(--text-muted); }
.timeline-title { font-size:0.9rem; font-weight:600; color:var(--text-primary); }
.timeline-note  { font-size:0.85rem; color:var(--text-secondary); }

/* ===== JOURNAL ===== */
.journal-form    { margin-bottom:2rem; }
.journal-entries { display:flex; flex-direction:column; gap:1.5rem; }
.journal-entry-card { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.journal-entry-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.journal-entry-header  { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1rem; }
.journal-entry-title   { font-family:'Lora',serif; font-size:1.25rem; font-weight:600; color:var(--text-primary); }
.journal-entry-date    { font-size:0.8rem; color:var(--text-muted); }
.journal-entry-content { font-size:0.9rem; line-height:1.6; color:var(--text-primary); margin-bottom:1rem; }
.journal-entry-footer  { display:flex; justify-content:space-between; align-items:center; font-size:0.8rem; color:var(--text-muted); }
.journal-stats { display:flex; gap:1rem; }
.textarea { width:100%; min-height:120px; resize:vertical; border-radius:var(--radius-lg); border:1px solid var(--border-color); background:var(--bg-primary); color:var(--text-primary); padding:0.75rem; font-size:0.9rem; outline:none; font-family:inherit; }

/* ===== TRANSLATOR ===== */
.translator-grid  { display:grid; grid-template-columns:1fr; gap:1.5rem; }
.currency-converter { display:flex; flex-wrap:wrap; gap:0.5rem; align-items:center; margin-top:1.5rem; }

/* ===== REWARDS ===== */
.rewards-summary { display:grid; grid-template-columns:1fr; gap:1rem; margin-bottom:2rem; }
.reward-card { background:var(--gradient-card); border-radius:var(--radius-card); padding:1.5rem; box-shadow:var(--shadow-sm); border:1px solid var(--border-color); }

/* ===== MEMORIES ===== */
.memories-avatar-rail { display:flex; gap:1rem; padding:1rem 0; margin-bottom:1.5rem; overflow-x:auto; scrollbar-width:none; }
.memories-avatar-rail::-webkit-scrollbar { display:none; }
.memory-avatar-item { display:flex; flex-direction:column; align-items:center; gap:0.5rem; flex-shrink:0; }
.memory-avatar { width:4.5rem; height:4.5rem; border-radius:var(--radius-lg); padding:0.1875rem; background:var(--gradient-adventure); cursor:pointer; position:relative; overflow:hidden; }
.memory-avatar img { width:100%; height:100%; border-radius:calc(var(--radius-lg) - 2px); object-fit:cover; }
.memory-avatar-add { background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center; color:var(--text-primary); font-size:1.5rem; }
.memory-avatar-name { font-size:0.8rem; color:var(--text-secondary); max-width:4.5rem; text-align:center; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.memories-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-top:1.5rem; }
.memory-card   { position:relative; border-radius:var(--radius-card); overflow:hidden; cursor:pointer; aspect-ratio:9/16; background:var(--bg-tertiary); }
.memory-thumbnail { width:100%; height:100%; object-fit:cover; transition:transform var(--transition-slow); }
.memory-card:hover .memory-thumbnail { transform:scale(1.05); }
.memory-overlay { position:absolute; bottom:0; left:0; right:0; padding:0.75rem; background:linear-gradient(to top,rgba(0,0,0,0.7),transparent); color:#fff; }
.memory-stats { display:flex; align-items:center; gap:0.5rem; font-size:0.8rem; }

/* ===== EXPLORE ===== */
.explore-categories { display:flex; gap:0.75rem; margin-bottom:2rem; overflow-x:auto; padding:0.5rem 0; scrollbar-width:none; }
.explore-categories::-webkit-scrollbar { display:none; }
.category-btn { padding:0.75rem 1.5rem; border-radius:var(--radius-pill); background:var(--bg-elevated); color:var(--text-secondary); border:2px solid var(--border-subtle); cursor:pointer; white-space:nowrap; font-size:0.9rem; font-weight:500; transition:all var(--transition-fast); }
.category-btn.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; box-shadow:0 4px 12px rgba(255,107,53,0.3); }
.category-btn:hover:not(.active) { border-color:var(--sunset-orange); color:var(--sunset-orange); }

/* ===== HELP ===== */
.help-sections { display:flex; flex-direction:column; gap:1.5rem; }
.help-grid     { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:0.75rem; margin-top:1rem; }
.help-link     { display:flex; flex-direction:column; align-items:center; gap:0.5rem; padding:1rem; border-radius:var(--radius-lg); border:1px solid var(--border-subtle); background:var(--bg-elevated); color:var(--text-secondary); text-decoration:none; font-size:0.85rem; transition:all var(--transition-fast); text-align:center; }
.help-link:hover { border-color:var(--sunset-orange); color:var(--sunset-orange); background:var(--bg-card); }
.help-link i   { font-size:1.25rem; color:var(--sunset-orange); }

/* ===== ONBOARDING ===== */
.onboarding-progress {
	position:fixed;
	top:0; left:0; right:0;
	height:4px;
	background:var(--border-subtle);
	z-index:1000;
}
.onboarding-progress-bar {
	height:100%;
	background:var(--gradient-adventure);
	transition:width var(--transition-normal);
}
.onboarding-container { max-width:480px; margin:0 auto; padding:2rem 1.25rem; min-height:100vh; display:flex; flex-direction:column; }
.onboarding-brand { text-align:center; margin-bottom:2rem; padding-top:1rem; }
.onboarding-step { display:none; flex-direction:column; flex:1; }
.onboarding-step.active { display:flex; }
.onboarding-title    { font-family:'Lora',serif; font-size:1.75rem; font-weight:700; color:var(--text-primary); margin-bottom:0.75rem; }
.onboarding-subtitle { font-size:0.95rem; color:var(--text-muted); margin-bottom:2rem; line-height:1.6; }
.onboarding-footer   { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:2rem; }
.onboarding-step-label { font-size:0.85rem; color:var(--text-muted); }
.onboarding-back { align-self:flex-start; margin-bottom:1.5rem; }
.interests-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.75rem; margin-bottom:2rem; }
.interest-btn {
	padding:0.875rem 0.75rem;
	border-radius:var(--radius-lg);
	background:var(--bg-elevated);
	color:var(--text-secondary);
	border:2px solid var(--border-subtle);
	cursor:pointer;
	font-size:0.875rem;
	font-weight:500;
	transition:all var(--transition-fast);
	text-align:center;
	line-height:1.4;
}
.interest-btn.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; box-shadow:0 4px 12px rgba(255,107,53,0.3); }
.interest-btn:hover:not(.active) { border-color:var(--sunset-orange); color:var(--sunset-orange); }

/* ===== SEARCH ===== */
.search-bar {
	display:flex;
	align-items:center;
	gap:0.75rem;
	background:var(--bg-card);
	border:1px solid var(--border-color);
	border-radius:var(--radius-pill);
	padding:0.75rem 1rem;
	margin-bottom:1.5rem;
	box-shadow:var(--shadow-sm);
}
.search-bar-icon  { color:var(--text-muted); flex-shrink:0; }
.search-bar-input { flex:1; border:none; background:transparent; outline:none; font-size:1rem; color:var(--text-primary); }
.search-filters   { display:flex; gap:0.5rem; overflow-x:auto; margin-bottom:1.5rem; padding-bottom:0.25rem; scrollbar-width:none; }
.search-filters::-webkit-scrollbar { display:none; }
.search-filter    { padding:0.5rem 1rem; border-radius:var(--radius-pill); background:var(--bg-elevated); color:var(--text-secondary); border:1.5px solid var(--border-subtle); cursor:pointer; white-space:nowrap; font-size:0.875rem; font-weight:500; transition:all var(--transition-fast); }
.search-filter.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; }
.search-results-list { display:flex; flex-direction:column; gap:0.75rem; }

/* ===== ASSISTANT ===== */
.assistant-chat { background:var(--gradient-card); border-radius:var(--radius-card); border:1px solid var(--border-color); overflow:hidden; margin-bottom:1.5rem; }
.chat-messages  { min-height:320px; max-height:60vh; overflow-y:auto; padding:1.25rem; display:flex; flex-direction:column; gap:0.75rem; }
.chat-input     { display:flex; gap:0.75rem; padding:1rem; border-top:1px solid var(--border-subtle); background:var(--bg-elevated); }
.chat-input input { flex:1; }
.assistant-quick-actions { display:flex; gap:0.75rem; flex-wrap:wrap; }

/* ===== LOGS / FEED CARDS ===== */
.logs-feed { display:flex; flex-direction:column; gap:1.5rem; }

/* Legacy log card (used by existing home.js data) */
.log-card  { background:var(--gradient-card); border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid var(--border-color); }
.log-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-elevated); }
.log-header { padding:1.25rem; display:flex; align-items:center; gap:0.875rem; border-bottom:1px solid var(--border-subtle); }
.log-user-info h4 { font-size:0.9rem; font-weight:600; color:var(--text-primary); }
.log-user-info span { font-size:0.8rem; color:var(--text-muted); }
.log-content  { padding:1.25rem; }
.log-text     { font-size:0.9rem; line-height:1.6; color:var(--text-primary); margin-bottom:1rem; }
.log-actions  { padding:1.25rem; border-top:1px solid var(--border-subtle); display:flex; justify-content:space-around; }
.log-action   { display:flex; align-items:center; gap:0.5rem; color:var(--text-muted); cursor:pointer; transition:all var(--transition-fast); padding:0.5rem 1rem; border-radius:var(--radius-lg); font-size:0.85rem; }
.log-action:hover { color:var(--sunset-orange); background:var(--bg-elevated); }
.log-action.active { color:var(--reflection-pink); }

/* ─── NEW FEED CARDS (home.js renders these) ─────────────────── */
.feed-card {
	background:var(--gradient-card);
	border-radius:var(--radius-card);
	overflow:hidden;
	border:1px solid var(--border-color);
	box-shadow:var(--shadow-sm);
	transition:all var(--transition-normal);
}
.feed-card:hover { box-shadow:var(--shadow-md); }

/* Memory card — slight opacity reduction near expiry handled by JS */
.feed-card--memory { border-left:3px solid var(--sunset-orange); }


.feed-card-header {
	display:flex;
	align-items:center;
	gap:0.75rem;
	padding:0.875rem 1rem;
}
.feed-card-author-info { flex:1; min-width:0; }
.feed-card-author-name { font-weight:600; font-size:0.9rem; color:var(--text-primary); display:block; }
.feed-card-meta        { font-size:0.75rem; color:var(--text-muted); }
.feed-card-badge       { display:inline-flex; align-items:center; gap:0.3rem; padding:0.25rem 0.625rem; border-radius:var(--radius-pill); font-size:0.75rem; font-weight:600; background:var(--bg-elevated); color:var(--text-muted); }
.feed-card-badge--memory { background:rgba(255,107,53,0.12); color:var(--sunset-orange); }
.feed-card-options { background:none; border:none; cursor:pointer; color:var(--text-muted); padding:0.5rem; border-radius:var(--radius-sm); margin-left:auto; flex-shrink:0; }
.feed-card-options:hover { color:var(--text-primary); background:var(--bg-elevated); }

/* Feed card gallery */
.feed-card-gallery { position:relative; overflow:hidden; background:var(--bg-tertiary); max-height:480px; }
.feed-card-media-main { width:100%; position:relative; }
.feed-card-media-main img,
.feed-card-media-main video { width:100%; max-height:480px; object-fit:cover; display:block; cursor:pointer; }

/* Thumbnail strip on feed cards */
.feed-card-thumbnails {
	display:flex;
	gap:0.375rem;
	padding:0.375rem 0.75rem;
	overflow-x:auto;
	background:rgba(0,0,0,0.04);
	scrollbar-width:none;
}
.feed-card-thumbnails::-webkit-scrollbar { display:none; }

/* Fading timer strip */
.feed-card-timer-strip {
	display:flex;
	align-items:center;
	gap:0.5rem;
	padding:0.5rem 1rem;
	background:rgba(255,107,53,0.08);
	font-size:0.8rem;
	color:var(--sunset-orange);
	border-top:1px solid rgba(255,107,53,0.15);
}
.feed-card-timer-strip button { margin-left:auto; }

.feed-card-caption { padding:0.875rem 1rem 0.5rem; font-size:0.9rem; color:var(--text-primary); line-height:1.5; }
.feed-card-tags    { display:flex; flex-wrap:wrap; gap:0.375rem; padding:0 1rem 0.75rem; }

/* Tags row (trips / location / buddy) */
.feed-card-tags-row { display:flex; flex-wrap:wrap; gap:0.375rem; padding:0 1rem 0.75rem; }
.feed-tag { display:inline-flex; align-items:center; gap:0.25rem; padding:0.25rem 0.625rem; border-radius:var(--radius-pill); font-size:0.75rem; font-weight:500; background:var(--bg-elevated); color:var(--text-secondary); border:1px solid var(--border-subtle); }
.feed-tag--trip     { background:rgba(0,168,204,0.1); color:var(--ocean-teal); }
.feed-tag--location { background:rgba(255,107,53,0.1); color:var(--sunset-orange); }
.feed-tag--buddy    { background:rgba(131,56,236,0.1); color:var(--cultural-purple); }

/* Feed card action bar */
.feed-card-actions {
	display:flex;
	padding:0.75rem 1rem;
	border-top:1px solid var(--border-subtle);
	gap:0.25rem;
}
.feed-card-actions .reaction-btn { flex:1; justify-content:center; }

/* Feed filter tabs */
.feed-filters {
	display:flex;
	gap:0.5rem;
	overflow-x:auto;
	margin-bottom:1.25rem;
	padding-bottom:0.25rem;
	scrollbar-width:none;
}
.feed-filters::-webkit-scrollbar { display:none; }
.feed-filter {
	padding:0.5rem 1rem;
	border-radius:var(--radius-pill);
	background:var(--bg-elevated);
	color:var(--text-secondary);
	border:1.5px solid var(--border-subtle);
	cursor:pointer;
	white-space:nowrap;
	font-size:0.875rem;
	font-weight:500;
	transition:all var(--transition-fast);
	display:flex;
	align-items:center;
	gap:0.375rem;
}
.feed-filter.active { background:var(--gradient-sunset); color:#fff; border-color:transparent; }

/* ===== STORIES RAIL ===== */
.stories-section { margin-bottom:1.25rem; }
.stories-rail-header {
	display:flex;
	align-items:center;
	justify-content:space-between;
	margin-bottom:0.75rem;
}
.stories-rail-label {
	font-size:0.875rem;
	font-weight:600;
	color:var(--text-secondary);
	display:flex;
	align-items:center;
	gap:0.375rem;
}
.stories-rail-label i { color:var(--sunset-orange); }
.stories-rail-see-all {
	font-size:0.8rem;
	color:var(--sunset-orange);
	text-decoration:none;
	display:flex;
	align-items:center;
	gap:0.25rem;
	transition:opacity var(--transition-fast);
}
.stories-rail-see-all:hover { opacity:0.75; }
.stories-rail {
	display:flex;
	gap:0.75rem;
	overflow-x:auto;
	padding:0.375rem 0;
	scrollbar-width:none;
}
.stories-rail::-webkit-scrollbar { display:none; }

/* ===== REACTION SYSTEM ===== */
.reaction-summary {
	display:flex;
	align-items:center;
	justify-content:space-between;
	padding:0.5rem 1rem;
	font-size:0.8rem;
	color:var(--text-muted);
}
.reaction-summary-icons { display:flex; align-items:center; gap:0.125rem; }

.reaction-btn {
	display:inline-flex;
	align-items:center;
	gap:0.375rem;
	padding:0.5rem 0.75rem;
	border:none;
	background:none;
	color:var(--text-muted);
	font-size:0.875rem;
	cursor:pointer;
	border-radius:var(--radius-sm);
	transition:all var(--transition-fast);
}
.reaction-btn:hover  { color:var(--sunset-orange); background:var(--bg-elevated); }
.reaction-btn.active { color:var(--reflection-pink); }

/* Post reaction bar (inside commentsModal) */
.post-reaction-bar {
	display:flex;
	padding:0.5rem 1rem;
	border-top:1px solid var(--border-subtle);
	border-bottom:1px solid var(--border-subtle);
	gap:0.25rem;
}
.reaction-bar-btn {
	flex:1;
	display:flex;
	align-items:center;
	justify-content:center;
	gap:0.375rem;
	padding:0.625rem;
	background:none;
	border:none;
	color:var(--text-muted);
	font-size:0.875rem;
	cursor:pointer;
	border-radius:var(--radius-sm);
	transition:all var(--transition-fast);
}
.reaction-bar-btn:hover { color:var(--sunset-orange); background:var(--bg-elevated); }

/* Reactions picker (floating) */
.reactions-picker {
	position:fixed;
	background:var(--bg-card);
	border-radius:var(--radius-pill);
	box-shadow:var(--shadow-elevated);
	border:1px solid var(--border-color);
	display:flex;
	gap:0.25rem;
	padding:0.5rem 0.75rem;
	z-index:1200;
	animation:pickerPop 0.25s var(--transition-bounce);
}
@keyframes pickerPop {
	from { transform:scale(0.6) translateY(10px); opacity:0; }
	to   { transform:scale(1) translateY(0); opacity:1; }
}
.reaction-option {
	width:2.5rem; height:2.5rem;
	font-size:1.375rem;
	border:none; background:none;
	cursor:pointer;
	border-radius:50%;
	display:flex; align-items:center; justify-content:center;
	transition:transform var(--transition-bounce);
}
.reaction-option:hover { transform:scale(1.3) translateY(-4px); }

/* ===== COMMENT COMPOSERS ===== */
.comment-composer-sticky {
	position:sticky;
	bottom:0;
	background:var(--bg-card);
	border-top:1px solid var(--border-color);
	padding:0.75rem 1rem;
	z-index:200;
}
.reply-context {
	display:flex;
	align-items:center;
	justify-content:space-between;
	padding:0.375rem 0.5rem;
	margin-bottom:0.5rem;
	background:var(--bg-elevated);
	border-radius:var(--radius-sm);
	font-size:0.8rem;
	color:var(--text-muted);
}
.comment-composer-row {
	display:flex;
	align-items:flex-end;
	gap:0.625rem;
}
.comment-composer-avatar { flex-shrink:0; }
.comment-input-wrap { flex:1; position:relative; }
.comment-textarea {
	width:100%;
	border:1px solid var(--border-color);
	border-radius:var(--radius-lg);
	padding:0.625rem 3rem 0.625rem 0.875rem;
	font-size:0.9rem;
	background:var(--bg-elevated);
	color:var(--text-primary);
	font-family:inherit;
	resize:none;
	outline:none;
	min-height:2.5rem;
	max-height:8rem;
	overflow-y:auto;
	transition:border-color var(--transition-fast);
	line-height:1.4;
}
.comment-textarea:focus { border-color:var(--sunset-orange); }
.comment-input-actions {
	position:absolute;
	right:0.375rem;
	bottom:0.375rem;
	display:flex;
	gap:0.125rem;
}
.comment-emoji-btn, .comment-media-btn {
	width:1.75rem; height:1.75rem;
	border:none; background:none;
	color:var(--text-muted);
	cursor:pointer;
	border-radius:var(--radius-sm);
	display:flex; align-items:center; justify-content:center;
	font-size:0.9rem;
	transition:color var(--transition-fast);
}
.comment-emoji-btn:hover, .comment-media-btn:hover { color:var(--sunset-orange); }
.comment-post-btn { flex-shrink:0; }
.comment-post-btn:disabled { opacity:0.4; cursor:not-allowed; }

/* Comments modal full-featured */
.comments-modal-full { max-width:540px; max-height:90vh; display:flex; flex-direction:column; padding:0; }
.comments-modal-post-preview { font-size:0.85rem; color:var(--text-muted); max-width:80%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.comments-modal-body { flex:1; overflow-y:auto; padding:0.75rem 1.25rem; }
.comment-composer-footer { padding:0.75rem 1.25rem; border-top:1px solid var(--border-subtle); position:sticky; bottom:0; background:var(--bg-card); }

/* ===== FADING TIMER BANNER ===== */
.fading-timer-banner {
	display:flex;
	align-items:center;
	gap:0.625rem;
	padding:0.625rem 1rem;
	background:rgba(255,107,53,0.1);
	color:var(--sunset-orange);
	font-size:0.875rem;
	font-weight:500;
	border-bottom:1px solid rgba(255,107,53,0.2);
}
.fading-timer-banner button { margin-left:auto; flex-shrink:0; }

/* ===== POST DETAIL CARD ===== */
.post-detail-card { background:var(--bg-card); }
.post-author      { display:flex; align-items:center; gap:0.75rem; padding:1rem; }
.post-author-info { flex:1; min-width:0; }
.post-author-name { font-weight:600; font-size:0.95rem; color:var(--text-primary); display:block; }
.post-meta        { font-size:0.75rem; color:var(--text-muted); display:flex; gap:0.375rem; align-items:center; flex-wrap:wrap; }
.post-content     { font-size:0.95rem; line-height:1.7; color:var(--text-primary); padding:0 1rem 0.75rem; }
.post-tags        { display:flex; flex-wrap:wrap; gap:0.375rem; padding:0 1rem 0.75rem; }
.post-reactions   { display:flex; padding:0.5rem 1rem; gap:0.25rem; border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); }
.post-reactions .reaction-btn { flex:1; justify-content:center; }

/* Post strips (tags, location, buddies, trip in composers) */
.post-tags-strip, .post-location-strip, .post-trip-tag-strip, .post-buddies-strip {
	display:flex;
	align-items:center;
	gap:0.5rem;
	padding:0.5rem 0.75rem;
	background:var(--bg-elevated);
	border-radius:var(--radius-sm);
	margin-top:0.5rem;
	font-size:0.875rem;
	color:var(--text-secondary);
}
.post-location-strip i, .post-trip-tag-strip i, .post-buddies-strip i, .post-tags-strip i { flex-shrink:0; }
.post-tagged-buddies-rail { display:flex; flex-wrap:wrap; gap:0.375rem; flex:1; }
.memory-tags-rail { display:flex; flex-wrap:wrap; gap:0.375rem; flex:1; }

/* ===== CREATE POST & MEMORY COMPOSERS ===== */
.create-post-modal, .create-memory-modal {
	max-width:560px;
	display:flex;
	flex-direction:column;
	padding:0;
	max-height:95vh;
}
.create-post-header, .modal-header {
	display:flex;
	align-items:center;
	gap:0.75rem;
	padding:0.875rem 1.25rem;
	border-bottom:1px solid var(--border-subtle);
}
.create-post-header .modal-title, .create-memory-modal .modal-title { flex:1; text-align:center; }

.create-post-body, .create-memory-body { flex:1; overflow-y:auto; padding:1rem 1.25rem; display:flex; flex-direction:column; gap:0.75rem; }
.create-post-author  { display:flex; align-items:center; gap:0.75rem; }
.create-post-author-info { display:flex; flex-direction:column; gap:0.25rem; }
.create-post-author-name { font-weight:600; font-size:0.9rem; color:var(--text-primary); }

.create-post-textarea {
	width:100%;
	border:none;
	outline:none;
	font-size:1rem;
	color:var(--text-primary);
	background:transparent;
	resize:none;
	min-height:100px;
	max-height:40vh;
	font-family:inherit;
	line-height:1.6;
}
.create-post-textarea::placeholder { color:var(--text-muted); }

/* Media preview in composers */
.post-media-preview { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.post-media-grid    { display:grid; gap:0.25rem; }
.post-media-clear-btn {
	position:absolute;
	top:0.5rem; right:0.5rem;
	width:2rem; height:2rem;
	border-radius:50%;
	background:rgba(0,0,0,0.6);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	font-size:0.875rem;
}

/* Toolbar */
.create-post-toolbar {
	display:flex;
	align-items:center;
	gap:0.25rem;
	padding:0.625rem 1.25rem;
	border-top:1px solid var(--border-subtle);
	background:var(--bg-elevated);
	position:sticky;
	bottom:0;
}
.post-tool-btn {
	width:2.25rem; height:2.25rem;
	border-radius:var(--radius-sm);
	border:none;
	background:none;
	color:var(--text-muted);
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	font-size:1.05rem;
	transition:all var(--transition-fast);
}
.post-tool-btn:hover { color:var(--sunset-orange); background:rgba(255,107,53,0.1); }
.post-char-counter { margin-left:auto; font-size:0.75rem; color:var(--text-muted); }

/* ===== VISIBILITY BUTTON ===== */
.visibility-btn {
	display:inline-flex;
	align-items:center;
	gap:0.3rem;
	padding:0.25rem 0.625rem;
	border-radius:var(--radius-pill);
	background:var(--bg-elevated);
	border:1px solid var(--border-subtle);
	color:var(--text-secondary);
	font-size:0.75rem;
	font-weight:500;
	cursor:pointer;
	transition:all var(--transition-fast);
}
.visibility-btn:hover { border-color:var(--sunset-orange); color:var(--sunset-orange); }
.visibility-check { color:var(--sunset-orange); margin-left:auto; }
.visibility-option-icon { width:2rem; height:2rem; border-radius:var(--radius-sm); background:var(--bg-elevated); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--sunset-orange); }
.visibility-option-text { flex:1; }
.visibility-option-label { font-weight:500; font-size:0.95rem; color:var(--text-primary); }
.visibility-option-sub   { font-size:0.75rem; color:var(--text-muted); }

/* ===== MEDIA SOURCE PICKER ===== */
.media-source-picker {
	display:grid;
	grid-template-columns:repeat(2,1fr);
	gap:0.75rem;
	padding:1rem;
	border-top:1px solid var(--border-subtle);
	background:var(--bg-elevated);
}
.media-source-btn {
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:0.5rem;
	padding:1.25rem 0.75rem;
	border-radius:var(--radius-lg);
	border:1.5px solid var(--border-subtle);
	background:var(--bg-card);
	color:var(--text-secondary);
	font-size:0.875rem;
	cursor:pointer;
	transition:all var(--transition-fast);
}
.media-source-btn i { font-size:1.5rem; color:var(--sunset-orange); }
.media-source-btn:hover { border-color:var(--sunset-orange); color:var(--sunset-orange); background:rgba(255,107,53,0.05); }
.media-source-cancel {
	grid-column:1/-1;
	padding:0.75rem;
	border:none;
	background:none;
	color:var(--text-muted);
	font-size:0.9rem;
	font-weight:600;
	cursor:pointer;
	border-top:1px solid var(--border-subtle);
	margin-top:0.25rem;
}

/* ===== CREATION CHOOSER SHEET ===== */
.creation-chooser { padding:0; }
.creation-chooser-handle {
	width:2.5rem; height:0.25rem;
	border-radius:var(--radius-pill);
	background:var(--border-strong);
	margin:0.875rem auto 0;
}
.creation-chooser-title {
	text-align:center;
	padding:1rem 1.5rem 0.75rem;
	font-size:1rem;
	font-weight:600;
	color:var(--text-primary);
}
.creation-chooser-options { display:flex; flex-direction:column; padding:0 0.75rem; gap:0.5rem; }
.creation-option {
	display:flex;
	align-items:center;
	gap:1rem;
	padding:1rem 1.25rem;
	border-radius:var(--radius-lg);
	border:1.5px solid var(--border-subtle);
	background:var(--bg-elevated);
	cursor:pointer;
	text-align:left;
	transition:all var(--transition-fast);
}
.creation-option:hover { border-color:var(--sunset-orange); background:rgba(255,107,53,0.04); }
.creation-option-icon {
	width:3rem; height:3rem;
	border-radius:var(--radius-lg);
	display:flex; align-items:center; justify-content:center;
	font-size:1.35rem;
	flex-shrink:0;
}
.creation-option-icon--memory { background:rgba(255,107,53,0.15); color:var(--sunset-orange); }
.creation-option-icon--post   { background:rgba(0,168,204,0.15); color:var(--ocean-teal); }
.creation-option-text  { flex:1; }
.creation-option-label { font-weight:600; font-size:0.95rem; color:var(--text-primary); }
.creation-option-sub   { font-size:0.8rem; color:var(--text-muted); margin-top:0.15rem; line-height:1.4; }
.creation-option-arrow { color:var(--text-muted); font-size:0.85rem; flex-shrink:0; }
.creation-chooser-cancel {
	width:100%;
	padding:1rem;
	border:none;
	background:none;
	color:var(--text-muted);
	font-size:0.95rem;
	font-weight:600;
	cursor:pointer;
	text-align:center;
	margin-top:0.25rem;
}

/* ===== MEDIA GALLERY COMPONENT ===== */
.media-gallery {
	position:relative;
	background:var(--bg-tertiary);
	border-radius:var(--radius-lg);
	overflow:hidden;
}
.media-gallery-main {
	width:100%;
	position:relative;
	min-height:200px;
	max-height:520px;
	overflow:hidden;
	display:flex;
	align-items:center;
	justify-content:center;
	background:#000;
}
.media-gallery-main img {
	width:100%;
	max-height:520px;
	object-fit:contain;
	display:block;
	cursor:pointer;
}
.media-gallery-video {
	width:100%;
	max-height:520px;
	object-fit:contain;
	display:block;
	background:#000;
}

/* Prev / Next overlay buttons */
.media-gallery-nav {
	position:absolute;
	top:50%;
	transform:translateY(-50%);
	width:2.5rem; height:2.5rem;
	border-radius:50%;
	background:rgba(0,0,0,0.55);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	z-index:10;
	transition:background var(--transition-fast);
}
.media-gallery-nav:hover { background:rgba(0,0,0,0.8); }
.media-gallery-prev { left:0.625rem; }
.media-gallery-next { right:0.625rem; }

/* Counter */
.media-gallery-counter {
	position:absolute;
	top:0.625rem; left:50%; transform:translateX(-50%);
	background:rgba(0,0,0,0.55);
	color:#fff;
	font-size:0.8rem;
	padding:0.25rem 0.625rem;
	border-radius:var(--radius-pill);
	z-index:10;
}

/* Expand to lightbox */
.media-gallery-expand {
	position:absolute;
	top:0.625rem; right:0.625rem;
	width:2rem; height:2rem;
	border-radius:var(--radius-sm);
	background:rgba(0,0,0,0.55);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	z-index:30;
	font-size:0.875rem;
	transition:background var(--transition-fast);
}
.media-gallery-expand:hover { background:rgba(0,0,0,0.8); }

/* Thumbnail strip */
.media-gallery-thumbnails {
	display:flex;
	gap:0.375rem;
	padding:0.5rem 0.75rem;
	overflow-x:auto;
	background:rgba(0,0,0,0.04);
	scrollbar-width:none;
}
.media-gallery-thumbnails::-webkit-scrollbar { display:none; }
.media-thumb {
	width:3rem; height:3rem;
	border-radius:var(--radius-sm);
	overflow:hidden;
	flex-shrink:0;
	border:2px solid transparent;
	cursor:pointer;
	transition:all var(--transition-fast);
	background:var(--bg-tertiary);
	display:flex; align-items:center; justify-content:center;
	position:relative;
}
.media-thumb img  { width:100%; height:100%; object-fit:cover; }
.media-thumb i    { color:#fff; font-size:1.125rem; }
.media-thumb.active      { border-color:var(--sunset-orange); }
.media-thumb:hover:not(.active) { border-color:var(--border-strong); }
/* Video thumb overlay */
.media-thumb--video::after {
	content:'';
	position:absolute;
	inset:0;
	background:rgba(0,0,0,0.35);
}
.media-thumb--video i { position:relative; z-index:1; }

/* ===== LIGHTBOX ===== */
.lightbox {
	position:relative;
	width:100%;
	height:100%;
	display:flex;
	flex-direction:column;
	align-items:center;
	justify-content:center;
}
.lightbox-close {
	position:absolute;
	top:1rem; right:1rem;
	width:2.75rem; height:2.75rem;
	border-radius:50%;
	background:rgba(255,255,255,0.15);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	font-size:1.125rem;
	z-index:10;
	transition:background var(--transition-fast);
}
.lightbox-close:hover { background:rgba(255,255,255,0.3); }
.lightbox-actions {
	position:absolute;
	top:1rem; left:1rem;
	display:flex;
	gap:0.5rem;
	z-index:10;
}
.lightbox-action-btn {
	width:2.75rem; height:2.75rem;
	border-radius:50%;
	background:rgba(255,255,255,0.15);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	font-size:1rem;
	transition:background var(--transition-fast);
}
.lightbox-action-btn:hover { background:rgba(255,255,255,0.3); }
.lightbox-main {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding: 4rem 3.5rem 1rem;
	box-sizing: border-box;
}
.lightbox-main img,
.lightbox-main video {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	border-radius: var(--radius-sm);
}

/* Lightbox Audio Player */
.lightbox-audio-player {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	max-width: 500px;
	width: 100%;
}
.audio-visualizer {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
}
.audio-visualizer i {
	font-size: 4rem;
	color: var(--sunset-orange);
	animation: pulse 2s ease-in-out infinite;
}
.audio-waves {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	height: 40px;
}
.audio-waves span {
	width: 4px;
	height: 20px;
	background: linear-gradient(180deg, var(--sunset-orange), var(--ocean-teal));
	border-radius: 2px;
	animation: wave 1s ease-in-out infinite;
}
.audio-waves span:nth-child(1) { animation-delay: 0s; }
.audio-waves span:nth-child(2) { animation-delay: 0.1s; }
.audio-waves span:nth-child(3) { animation-delay: 0.2s; }
.audio-waves span:nth-child(4) { animation-delay: 0.3s; }
.audio-waves span:nth-child(5) { animation-delay: 0.4s; }
@keyframes wave {
	0%, 100% { height: 20px; }
	50% { height: 40px; }
}
@keyframes pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.7; transform: scale(1.1); }
}
.audio-info {
	text-align: center;
}
.audio-caption {
	color: #fff;
	font-size: 1.1rem;
	font-weight: 500;
	margin: 0;
}
.lightbox-audio-player audio {
	border-radius: var(--radius-lg);
}
.lightbox-nav {
	position:absolute;
	top:50%; transform:translateY(-50%);
	width:3rem; height:3rem;
	border-radius:50%;
	background:rgba(255,255,255,0.15);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	font-size:1.125rem;
	z-index:10;
	transition:background var(--transition-fast);
}
.lightbox-nav:hover { background:rgba(255,255,255,0.3); }
.lightbox-prev { left:0.75rem; }
.lightbox-next { right:0.75rem; }
.lightbox-counter {
	position:absolute;
	top:1rem;
	left:50%; transform:translateX(-50%);
	background:rgba(255,255,255,0.15);
	color:#fff;
	font-size:0.85rem;
	padding:0.3rem 0.875rem;
	border-radius:var(--radius-pill);
	z-index:10;
}
.lightbox-thumbnails {
	display:flex;
	gap:0.375rem;
	padding:0.75rem;
	overflow-x:auto;
	scrollbar-width:none;
	align-self:stretch;
	justify-content:center;
}
.lightbox-thumbnails::-webkit-scrollbar { display:none; }
.lightbox-thumb {
	width:3.5rem; height:3.5rem;
	border-radius:var(--radius-sm);
	overflow:hidden;
	flex-shrink:0;
	border:2px solid rgba(255,255,255,0.2);
	cursor:pointer;
	transition:all var(--transition-fast);
	background:rgba(255,255,255,0.1);
	display:flex; align-items:center; justify-content:center;
}
.lightbox-thumb img { width:100%; height:100%; object-fit:cover; }
.lightbox-thumb i   { color:#fff; font-size:1.125rem; }
.lightbox-thumb.active      { border-color:#fff; }
.lightbox-thumb:hover:not(.active) { border-color:rgba(255,255,255,0.5); }
.lightbox-caption {
	padding:0.75rem 1.25rem;
	text-align:center;
	color:#fff;
	max-width:600px;
}
.lightbox-caption-meta { font-size:0.75rem; opacity:0.65; display:block; margin-top:0.25rem; }

/* ===== MEMORY VIEWER MODAL ===== */
.memory-viewer {
	position:relative;
	width:100%;
	height:100%;
	background:#000;
	display:flex;
	flex-direction:column;
	overflow:hidden;
}
.memory-viewer-header {
	position:absolute;
	top:0; left:0; right:0;
	display:flex;
	align-items:center;
	justify-content:space-between;
	padding:1rem;
	background:linear-gradient(to bottom,rgba(0,0,0,0.7),transparent);
	z-index:20;
}
.memory-viewer-author { display:flex; align-items:center; gap:0.75rem; flex:1; min-width:0; }
.memory-viewer-name   { font-weight:600; font-size:0.9rem; color:#fff; display:block; }
.memory-viewer-meta   { font-size:0.75rem; color:rgba(255,255,255,0.75); display:flex; gap:0.375rem; align-items:center; }
.memory-viewer-header-actions { display:flex; gap:0.5rem; }

.memory-viewer-timer {
	position:absolute;
	top:5rem; left:50%; transform:translateX(-50%);
	background:rgba(255,107,53,0.85);
	color:#fff;
	font-size:0.8rem;
	padding:0.3rem 0.875rem;
	border-radius:var(--radius-pill);
	display:flex; align-items:center; gap:0.375rem;
	z-index:20;
	white-space:nowrap;
}

.memory-viewer-gallery {
	flex:1;
	position:relative;
	overflow:hidden;
	display:flex;
	flex-direction:column;
}
.memory-viewer-media {
	flex:1;
	display:flex;
	align-items:center;
	justify-content:center;
	overflow:hidden;
}
.memory-viewer-media img   { width:100%; height:100%; object-fit:contain; cursor:pointer; }
.memory-viewer-video       { width:100%; height:100%; object-fit:contain; }

.memory-viewer-caption {
	position:absolute;
	bottom:7rem; left:0; right:0;
	padding:1rem;
	background:linear-gradient(to top,rgba(0,0,0,0.7),transparent);
	color:#fff;
	z-index:20;
}
.memory-viewer-tags { display:flex; flex-wrap:wrap; gap:0.375rem; margin-top:0.375rem; }
.memory-viewer-reactions { display:flex; align-items:center; gap:0.375rem; position:absolute; bottom:5.5rem; right:1rem; z-index:20; }

.memory-viewer-action-bar {
	position:absolute;
	bottom:0; left:0; right:0;
	display:flex;
	background:rgba(0,0,0,0.65);
	backdrop-filter:blur(8px);
	padding:0.5rem 0;
	z-index:20;
}
.viewer-action-btn {
	flex:1;
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:0.3rem;
	padding:0.5rem;
	background:none;
	border:none;
	color:rgba(255,255,255,0.85);
	font-size:0.75rem;
	cursor:pointer;
	transition:color var(--transition-fast);
}
.viewer-action-btn:hover { color:#fff; }
.viewer-action-btn i { font-size:1.25rem; }

/* Memory nav (between posts) */
.memory-viewer-nav {
	position:absolute;
	top:50%; transform:translateY(-50%);
	width:3rem; height:3rem;
	border-radius:50%;
	background:rgba(255,255,255,0.15);
	color:#fff;
	border:none;
	cursor:pointer;
	display:flex; align-items:center; justify-content:center;
	z-index:25;
	font-size:1.125rem;
}
.memory-viewer-prev-post { left:0.5rem; }
.memory-viewer-next-post { right:0.5rem; }

/* Comments panel slides up */
.memory-viewer-comments-panel {
	position:absolute;
	bottom:0; left:0; right:0;
	height:65%;
	background:var(--bg-card);
	border-radius:var(--radius-xl) var(--radius-xl) 0 0;
	z-index:30;
	display:flex;
	flex-direction:column;
	animation:sheetUp 0.35s var(--transition-bounce);
}
.memory-viewer-comments-header { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.25rem; border-bottom:1px solid var(--border-subtle); }
.memory-viewer-comments-list   { flex:1; overflow-y:auto; padding:0.75rem 1.25rem; }
.memory-viewer-comment-composer {
	display:flex;
	align-items:center;
	gap:0.625rem;
	padding:0.75rem 1rem;
	border-top:1px solid var(--border-subtle);
}
.memory-viewer-comment-composer textarea { flex:1; }

/* ===== ERROR PAGE (404) ===== */
.error-page     { min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:2rem; }
.error-icon     { font-size:4rem; margin-bottom:1rem; }
.error-code     { font-size:6rem; font-weight:700; line-height:1; background:var(--gradient-adventure); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.error-title    { font-size:1.5rem; font-weight:600; margin:0.5rem 0; }
.error-subtitle { color:var(--text-muted); margin-bottom:2rem; max-width:360px; }
.error-actions  { display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }

/* ===== PROFILE MENU POPUP ===== */
.profile-menu-popup { position:absolute; background:var(--bg-card); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:260px; z-index:1001; overflow:hidden; border:1px solid var(--border-color); }
.dark-theme .profile-menu-popup { background:var(--bg-secondary); }
.profile-menu-header { display:flex; align-items:center; gap:12px; padding:16px; border-bottom:1px solid var(--border-color); }
.profile-avatar-large { width:48px; height:48px; border-radius:var(--radius-lg); background:var(--gradient-sunset); display:flex; align-items:center; justify-content:center; color:#fff; font-size:24px; overflow:hidden; }
.profile-avatar-large img { width:100%; height:100%; object-fit:cover; }
.profile-menu-info { flex:1; }
.profile-menu-info strong { display:block; font-size:14px; color:var(--text-primary); }
.profile-menu-info small  { font-size:12px; color:var(--text-muted); }
.profile-menu-items { padding:8px 0; }
.profile-menu-item { display:flex; align-items:center; gap:12px; padding:10px 16px; width:100%; text-align:left; background:none; border:none; cursor:pointer; color:var(--text-primary); font-size:14px; transition:background 0.2s; text-decoration:none; }
.profile-menu-item i { width:20px; color:var(--sunset-orange); }
.profile-menu-item:hover { background:var(--bg-elevated); }
.profile-menu-divider { height:1px; background:var(--border-color); margin:8px 0; }

/* ===== RESPONSIVE ===== */
@media (max-width:480px) {
	.brand-name { font-size:0.95rem; }
	.brand-sub  { font-size:0.55rem; }
	.action-btn { width:2.2rem; height:2.2rem; }
	.action-btn i { font-size:1.05rem; }
	.nav-item i   { font-size:1.15rem; }
	.destinations-grid, .events-grid, .trips-grid, .forums-grid, .marketplace-grid { grid-template-columns:1fr; }
	.buddies-grid { grid-template-columns:repeat(2,1fr); }
	.form-row { grid-template-columns:1fr; }
	.listing-quick-facts { grid-template-columns:1fr; }
	.interests-grid { grid-template-columns:repeat(2,1fr); }
	.page-title { font-size:1.5rem; }
}
@media (min-width:481px) and (max-width:768px) {
	.destinations-grid, .events-grid, .trips-grid, .buddies-grid, .forums-grid, .marketplace-grid { grid-template-columns:repeat(2,1fr); }
}
@media (min-width:769px) and (max-width:1024px) {
	.destinations-grid, .events-grid, .trips-grid, .buddies-grid, .forums-grid, .marketplace-grid { grid-template-columns:repeat(3,1fr); }
	.planner-container { grid-template-columns:320px 1fr; }
	.translator-grid   { grid-template-columns:1fr 1fr; }
	.rewards-summary   { grid-template-columns:1fr 1fr; }
}
@media (min-width:1024px) {
	.header-content { justify-content:flex-start; gap:1.25rem; }
	.brand { align-items:flex-start; flex:0 0 auto; }
	.header-search { display:block; }
	#searchBtn { display:none; }
	.planner-container { grid-template-columns:320px 1fr; }
	.translator-grid   { grid-template-columns:1fr 1fr; }
	.rewards-summary   { grid-template-columns:1fr 1fr; }
	.memories-grid     { grid-template-columns:repeat(3,1fr); }
}

/* ===== DETAIL PAGE HEROES & TABS ===== */

/* Destination detail */
.destination-hero {
	width:100%;
	min-height:240px;
	background:var(--gradient-adventure);
	position:relative;
	display:flex;
	align-items:flex-end;
}
.destination-hero-overlay {
	width:100%;
	padding:2rem var(--spacing-md) 1.5rem;
	background:linear-gradient(to top,rgba(0,0,0,0.65),transparent);
	color:#fff;
}
.destination-region { font-size:0.9rem; color:rgba(255,255,255,0.8); margin-bottom:0.5rem; }
.destination-tags   { display:flex; flex-wrap:wrap; gap:0.375rem; margin-top:0.625rem; }
.destination-tips   { display:flex; flex-direction:column; gap:0.75rem; }
.destination-quick-facts {
	display:grid;
	grid-template-columns:repeat(2,1fr);
	gap:1rem;
}
@media (min-width:600px) {
	.destination-quick-facts { grid-template-columns:repeat(4,1fr); }
}
.destination-tabs {
	display:flex;
	gap:0;
	border-bottom:2px solid var(--border-color);
	margin:1.5rem 0 1rem;
	overflow-x:auto;
	scrollbar-width:none;
}
.destination-tabs::-webkit-scrollbar { display:none; }
.destination-tab {
	padding:0.75rem 1.25rem;
	border:none;
	background:none;
	font-size:0.875rem;
	font-weight:500;
	color:var(--text-muted);
	cursor:pointer;
	white-space:nowrap;
	border-bottom:2px solid transparent;
	margin-bottom:-2px;
	transition:all var(--transition-fast);
}
.destination-tab.active { color:var(--sunset-orange); border-bottom-color:var(--sunset-orange); }

/* Event detail */
.event-hero {
	width:100%;
	min-height:220px;
	background:var(--gradient-adventure);
	position:relative;
	display:flex;
	align-items:flex-end;
}
.event-hero-overlay {
	width:100%;
	padding:2rem var(--spacing-md) 1.5rem;
	background:linear-gradient(to top,rgba(0,0,0,0.65),transparent);
	color:#fff;
}
.event-category-badge {
	display:inline-flex;
	align-items:center;
	padding:0.25rem 0.75rem;
	border-radius:var(--radius-pill);
	background:rgba(255,255,255,0.2);
	color:#fff;
	font-size:0.8rem;
	font-weight:600;
	margin-bottom:0.5rem;
}
.event-meta-row {
	display:grid;
	grid-template-columns:repeat(2,1fr);
	gap:0.75rem;
	padding:1.25rem;
}
@media (min-width:600px) {
	.event-meta-row { grid-template-columns:repeat(4,1fr); }
}
.event-meta-item  { display:flex; align-items:center; gap:0.625rem; }
.event-meta-item i { color:var(--sunset-orange); flex-shrink:0; }
.event-meta-label { font-size:0.75rem; color:var(--text-muted); }
.event-meta-value { font-size:0.9rem; font-weight:500; color:var(--text-primary); }

/* Trip detail */
.trip-detail-hero {
	width:100%;
	min-height:220px;
	background:var(--gradient-adventure);
	position:relative;
	display:flex;
	align-items:flex-end;
}
.trip-detail-hero-overlay {
	width:100%;
	padding:2rem var(--spacing-md) 1.5rem;
	background:linear-gradient(to top,rgba(0,0,0,0.65),transparent);
	color:#fff;
}
.trip-detail-title { font-size:1.75rem; font-weight:700; color:#fff; margin:0; }
.trip-detail-meta  { font-size:0.85rem; color:rgba(255,255,255,0.85); margin:0.4rem 0 0.75rem; display:flex; gap:0.5rem; flex-wrap:wrap; align-items:center; }
.trip-stats-row    { display:grid; grid-template-columns:repeat(4,1fr); gap:0.75rem; padding:1.5rem 0; }
.trip-stat         { text-align:center; }
.trip-stat-number  { font-size:1.5rem; font-weight:700; color:var(--sunset-orange); }
.trip-stat-label   { font-size:0.7rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; }
.trip-detail-actions { display:flex; gap:0.75rem; flex-wrap:wrap; margin-bottom:1.5rem; }
.trip-detail-tabs {
	display:flex;
	gap:0;
	border-bottom:2px solid var(--border-color);
	margin-bottom:1rem;
	overflow-x:auto;
	scrollbar-width:none;
}
.trip-detail-tabs::-webkit-scrollbar { display:none; }
.trip-detail-tab {
	padding:0.75rem 1.25rem;
	border:none;
	background:none;
	font-size:0.875rem;
	font-weight:500;
	color:var(--text-muted);
	cursor:pointer;
	white-space:nowrap;
	border-bottom:2px solid transparent;
	margin-bottom:-2px;
	transition:all var(--transition-fast);
}
.trip-detail-tab.active { color:var(--sunset-orange); border-bottom-color:var(--sunset-orange); }
.trip-activity-feed { display:flex; flex-direction:column; gap:0.75rem; }

/* ── Keep brand colors vivid in dark mode ──────────────────────────────────── */
[data-theme="dark"] .badge-stops    { background: #ff6b35; color: #fff; }
[data-theme="dark"] .badge-bucket   { background: var(--ocean-teal); color: #fff; }
[data-theme="dark"] .badge-adventure{ background: #38b000; color: #fff; }
[data-theme="dark"] .badge-success  { background: #2dc653; color: #fff; }
[data-theme="dark"] .badge-danger   { background: #e63946; color: #fff; }
[data-theme="dark"] .badge-journey  { background: var(--sunset-orange); color: #fff; }

[data-theme="dark"] .btn-primary {
    background: var(--sunset-orange);
    color: #fff;
    border-color: var(--sunset-orange);
}
[data-theme="dark"] .btn-journey {
    background: var(--gradient-adventure);
    color: #fff;
}

[data-theme="dark"] .post-fab,
[data-theme="dark"] .ai-assistant-btn {
    background: var(--gradient-adventure);
    color: #fff;
}

/* Nav active indicator keeps brand color */
[data-theme="dark"] .nav-item.active .nav-indicator { background: var(--sunset-orange); }
[data-theme="dark"] .nav-item.active i,
[data-theme="dark"] .nav-item.active span { color: var(--sunset-orange); }

/* Profile header gradient stays vivid */
[data-theme="dark"] .profile-header { color: #fff; }

/* Tag badges keep their color */
[data-theme="dark"] .badge[style*="background"] { opacity: 1; }

/* Story bubble border stays orange */
[data-theme="dark"] .story-avatar-ring { border-color: var(--sunset-orange); }

/* Feed card fading badge stays orange */
[data-theme="dark"] .feed-card-badge--memory {
    background: rgba(255,107,53,.2);
    color: var(--sunset-orange);
}

/* Action buttons get a tinted hover */
[data-theme="dark"] .reaction-btn:hover,
[data-theme="dark"] .viewer-action-btn:hover { color: var(--sunset-orange); }

[data-theme="dark"] .reaction-btn.active,
[data-theme="dark"] .viewer-action-btn.active { color: var(--sunset-orange); }

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE APP LAYOUT — Proper PWA-style layout for phones
   ═══════════════════════════════════════════════════════════════════════ */

/* Full-screen PWA on mobile */
@media (max-width: 768px) {

	/* Viewport lock — no scroll bounce on iOS */
	html, body {
		height: 100%;
		overscroll-behavior: none;
		-webkit-overflow-scrolling: touch;
	}

	#app {
		height: 100vh;
		height: 100dvh; /* dynamic viewport for mobile chrome */
		overflow: hidden;
		display: flex;
		flex-direction: column;
	}

	/* Header — compact on mobile */
	.app-header {
		height: 56px;
		padding: 0 0.75rem;
	}
	.header-search { display: none !important; }
	.brand-name { font-size: 0.9rem; }
	.brand-sub  { font-size: 0.5rem; letter-spacing: 0.05em; }
	.action-btn { width: 2.1rem; height: 2.1rem; }

	/* Main content — fills between header and nav */
	.main-content {
		flex: 1;
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		padding-top: calc(56px + 0.75rem);
		padding-bottom: calc(var(--bottom-nav-height) + 1.5rem + env(safe-area-inset-bottom, 0px));
		min-height: 0; /* important: allow flex shrink */
	}

	/* Bottom nav — stays fixed, never floats up */
	.bottom-nav {
		position: fixed;
		bottom: 0; left: 0; right: 0;
		z-index: 1000;
		padding-bottom: env(safe-area-inset-bottom, 0px);
		height: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom, 0px));
	}

	/* Nav labels — smaller on mobile */
	.nav-item { font-size: 0.68rem; gap: 0.2rem; }
	.nav-item i { font-size: 1.2rem; }
	.nav-label { display: none; } /* hide text labels below 400px */

	/* Containers — full width with comfortable padding */
	.container {
		padding-left: 0.875rem;
		padding-right: 0.875rem;
	}

	/* Cards — better touch targets */
	.feed-card, .marketplace-card, .destination-card, .event-card {
		border-radius: var(--radius-xl);
		margin-bottom: 0;
	}

	/* Feed — single column on mobile */
	.logs-feed {
		display: flex;
		flex-direction: column;
		gap: 1rem;
		max-width: 100%;
		padding: 0;
	}

	/* Feed card gallery — 4:3 on mobile */
	.feed-card-media-main {
		aspect-ratio: 4 / 3;
	}

	/* Buttons — larger touch targets */
	.btn { min-height: 2.5rem; }
	.btn-sm { min-height: 2rem; }

	/* Modals — full-screen sheets on mobile */
	.modal {
		border-radius: var(--radius-2xl) var(--radius-2xl) 0 0 !important;
		position: fixed !important;
		bottom: 0 !important;
		left: 0 !important;
		right: 0 !important;
		top: auto !important;
		max-width: 100% !important;
		width: 100% !important;
		max-height: 90dvh !important;
		margin: 0 !important;
	}
	.modal-overlay {
		align-items: flex-end !important;
	}

	/* Form controls — full width */
	.form-control {
		font-size: 16px; /* prevents iOS zoom on focus */
	}

	/* Page titles — smaller */
	.page-title { font-size: 1.4rem; }
	.page-subtitle { font-size: 0.82rem; }

	/* Memories shell — stack on mobile */
	.memories-shell {
		flex-direction: column;
		height: auto;
	}
	.memories-sidebar {
		display: none; /* carousel handles it on mobile */
	}
	.memories-display {
		height: 60vw;
		min-height: 260px;
		max-height: 380px;
	}
	.memories-info-panel {
		width: 100%;
		max-width: 100%;
		height: auto;
		max-height: 250px;
	}

	/* Drawer — 85% width on mobile so it doesn't cover entire screen */
	.profile-drawer {
		width: 85% !important;
		max-width: 320px !important;
		border-radius: 0 var(--radius-xl) var(--radius-xl) 0;
		box-shadow: 4px 0 24px rgba(0,0,0,0.15);
	}

	/* Tables → stacked */
	table { display: block; overflow-x: auto; }

	/* Grid overrides for mobile */
	.destinations-grid,
	.events-grid,
	.trips-grid,
	.forums-grid,
	.marketplace-grid {
		grid-template-columns: 1fr;
		gap: 0.875rem;
	}
	.buddies-grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
	.rewards-summary { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }

	/* Stories rail — horizontal scroll */
	.stories-rail {
		gap: 0.625rem;
		padding-bottom: 0.5rem;
	}

	/* Hide decorative elements on small screens */
	.desktop-only { display: none !important; }
}

/* ── Very small phones (< 380px) ── */
@media (max-width: 380px) {
	.nav-item { font-size: 0; } /* icon only */
	.brand-name { font-size: 0.82rem; }
	.action-btn { width: 1.9rem; height: 1.9rem; }
	.page-title { font-size: 1.25rem; }
	.container { padding-left: 0.75rem; padding-right: 0.75rem; }
}

/* ── Tablet (769–1024px) ── */
@media (min-width: 769px) and (max-width: 1024px) {
	.logs-feed {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
		max-width: 100%;
	}
}

/* ── Desktop sidebar layout (> 1024px) ── */
@media (min-width: 1025px) {
	/* On desktop the bottom nav can be hidden or shown as a sidebar */
	.logs-feed {
		display: grid;
		grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
		gap: 1.5rem;
		max-width: 100%;
	}
	.modal {
		border-radius: var(--radius-2xl) !important;
		position: relative !important;
		bottom: auto !important;
		max-height: 90vh !important;
		width: auto !important;
	}
	.modal-overlay { align-items: center !important; }
}

/* ── Safe area support (notch / Dynamic Island) ── */
@supports (padding: env(safe-area-inset-top)) {
	.app-header {
		padding-top: env(safe-area-inset-top, 0px);
		height: calc(var(--header-height) + env(safe-area-inset-top, 0px));
	}
}

/* ═══════════════════════════════════════════
   AI ASSISTANT FAB (global)
   ════════════════════════════════════════ */
.ai-fab {
    position: fixed;
    bottom: calc(var(--nav-height, 64px) + 1rem);
    right: 1rem;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sunset-orange, #ff6b35) 0%, var(--ocean-teal, #20c997) 100%);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem;
    box-shadow: 0 4px 16px rgba(255,107,53,.4);
    text-decoration: none;
    z-index: 400;
    transition: transform .2s, box-shadow .2s;
    position: fixed;
}
.ai-fab:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 24px rgba(255,107,53,.5);
    color: #fff;
}
.ai-fab-pulse {
    position: absolute;
    width: 100%; height: 100%;
    border-radius: 50%;
    background: inherit;
    opacity: .4;
    animation: ai-pulse 2.5s ease-out infinite;
    z-index: -1;
}
@keyframes ai-pulse {
    0%   { transform: scale(1); opacity: .4; }
    70%  { transform: scale(1.6); opacity: 0; }
    100% { transform: scale(1.6); opacity: 0; }
}
/* Hide AI FAB on the AI assistant page itself */
[data-page="ai-assistant"] .ai-fab { display: none; }

/* ═══════════════════════════════════════════════════════════════
   POPOUT&SHARE v7.2 — TravelMate dark-first design system
   "Discovered by someone who was there."
   ═══════════════════════════════════════════════════════════════ */

/* ── Override: dark is the true default ──────────────────────── */
:root {
    /* Space-dark palette (TravelMate DNA) */
    --space-deep:     #07080f;
    --space-surface:  rgba(15, 23, 42, 0.98);
    --space-glass:    rgba(15, 23, 42, 0.88);
    --space-border:   rgba(255, 255, 255, 0.06);

    /* Gold accent (TravelMate primary) */
    --gold:           #c9a646;
    --gold-light:     #f0cc70;
    --gold-dark:      #a07c20;
    --gold-glow:      rgba(201, 166, 70, 0.25);
    --gold-subtle:    rgba(201, 166, 70, 0.12);

    /* Post type badge tokens */
    --badge-gem:      #a78bfa;   /* Hidden gem — purple */
    --badge-food:     #fb923c;   /* Food stop — orange */
    --badge-scenic:   #34d399;   /* Scenic spot — green */
    --badge-tip:      #60a5fa;   /* Local tip — blue */
    --badge-stay:     #4ade80;   /* Safe stay — bright green */
    --badge-check:    #94a3b8;   /* Checkpoint — grey */
    --badge-memory:   #ff8040;   /* Fading memory — brand orange */

    /* Admin moderation badge tokens */
    --badge-review:   #fbbf24;   /* Under review — amber */
    --badge-verified: #22c55e;   /* Verified — green */
    --badge-avoid:    #ef4444;   /* Must avoid — red */

    /* Discovery tokens */
    --discovery-gold:  #f0cc70;
    --discovery-glow:  rgba(240, 204, 112, 0.15);

    /* Live indicator */
    --live-green:     #22c55e;
    --live-glow:      rgba(34, 197, 94, 0.3);
}

/* ── Dark mode applies space-dark palette ─────────────────────── */
[data-theme="dark"] {
    --bg-primary:    var(--space-deep);
    --bg-secondary:  #0e1120;
    --bg-tertiary:   #141928;
    --bg-card:       rgba(15, 23, 42, 0.95);
    --bg-elevated:   rgba(20, 30, 55, 0.98);
    --bg-overlay:    rgba(5, 5, 13, 0.97);
    --border-color:  var(--space-border);
    --border-subtle: rgba(255, 255, 255, 0.04);
    --shadow-soft:   0 18px 45px rgba(0, 0, 0, 0.55);
    --shadow-lg:     0 10px 30px rgba(0, 0, 0, 0.65);
    --gradient-card: linear-gradient(to bottom right, rgba(15,23,42,0.98), rgba(10,16,35,0.95));
}

/* Page background with radial warmth (TravelMate signature) */
[data-theme="dark"] body {
    background:
        radial-gradient(circle at top,    rgba(201,166,70,0.07),  transparent 55%),
        radial-gradient(circle at bottom, rgba(37,99,235,0.15),   transparent 55%),
        var(--space-deep);
    min-height: 100vh;
}

/* Header — frosted glass like TravelMate */
[data-theme="dark"] .app-header {
    background: linear-gradient(
        to bottom,
        rgba(7, 8, 15, 0.96),
        rgba(7, 8, 15, 0.80),
        transparent
    ) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid var(--space-border) !important;
}

/* Bottom nav — dark glass */
[data-theme="dark"] .bottom-nav {
    background: rgba(7, 8, 15, 0.97) !important;
    border-top: 1px solid var(--space-border) !important;
    backdrop-filter: blur(12px);
}

/* ── POST TYPE BADGES ─────────────────────────────────────────── */
/* User-facing post types */
.badge-post-type {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .25rem .6rem;
    border-radius: var(--radius-pill);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .02em;
    white-space: nowrap;
    flex-shrink: 0;
}
.badge-gem     { background: rgba(167,139,250,.15); color: var(--badge-gem);    border: 1px solid rgba(167,139,250,.3); }
.badge-food    { background: rgba(251,146,60,.12);  color: var(--badge-food);   border: 1px solid rgba(251,146,60,.3); }
.badge-scenic  { background: rgba(52,211,153,.12);  color: var(--badge-scenic); border: 1px solid rgba(52,211,153,.3); }
.badge-tip     { background: rgba(96,165,250,.12);  color: var(--badge-tip);    border: 1px solid rgba(96,165,250,.3); }
.badge-stay    { background: rgba(74,222,128,.12);  color: var(--badge-stay);   border: 1px solid rgba(74,222,128,.3); }
.badge-check   { background: rgba(148,163,184,.1);  color: var(--badge-check);  border: 1px solid rgba(148,163,184,.2); }
.badge-memory-type { background: rgba(255,128,64,.12);  color: var(--badge-memory); border: 1px solid rgba(255,128,64,.3); }

/* Admin-only moderation badges */
.badge-under-review {
    background: rgba(251,191,36,.12);
    color: var(--badge-review);
    border: 1px solid rgba(251,191,36,.3);
}
.badge-verified-place {
    background: rgba(34,197,94,.12);
    color: var(--badge-verified);
    border: 1px solid rgba(34,197,94,.3);
}
.badge-must-avoid {
    background: rgba(239,68,68,.12);
    color: var(--badge-avoid);
    border: 1px solid rgba(239,68,68,.35);
    animation: avoid-pulse 2.5s ease-in-out infinite;
}
@keyframes avoid-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0); }
    50%       { box-shadow: 0 0 0 4px rgba(239,68,68,.15); }
}

/* ── DISCOVERY BADGE ──────────────────────────────────────────── */
.badge-discovery {
    background: linear-gradient(135deg, rgba(201,166,70,.18), rgba(240,204,112,.08));
    color: var(--gold-light);
    border: 1px solid rgba(201,166,70,.35);
    position: relative;
    overflow: hidden;
}
.badge-discovery::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(240,204,112,.1), transparent);
    transform: translateX(-100%);
    animation: discovery-shimmer 3s ease-in-out infinite;
}
@keyframes discovery-shimmer {
    0%   { transform: translateX(-100%); }
    60%  { transform: translateX(100%); }
    100% { transform: translateX(100%); }
}

/* Operator verified badge */
.badge-operator {
    background: rgba(34,197,94,.1);
    color: #4ade80;
    border: 1px solid rgba(34,197,94,.25);
}
.badge-local-gem {
    background: rgba(201,166,70,.1);
    color: var(--gold-light);
    border: 1px solid rgba(201,166,70,.3);
}

/* ── LIVE INDICATOR PILL ──────────────────────────────────────── */
.live-pill {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .25rem .7rem;
    border-radius: var(--radius-pill);
    background: rgba(15, 23, 42, 0.9);
    border: 1px solid rgba(34, 197, 94, 0.5);
    font-size: .72rem;
    font-weight: 600;
    color: #d1fae5;
    white-space: nowrap;
}
.live-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--live-green);
    box-shadow: 0 0 0 4px var(--live-glow);
    animation: live-pulse 2s ease-in-out infinite;
}
@keyframes live-pulse {
    0%, 100% { box-shadow: 0 0 0 0 var(--live-glow); }
    50%       { box-shadow: 0 0 0 6px rgba(34,197,94,0); }
}

/* ── DISCOVERY SECTION ────────────────────────────────────────── */
.discovery-section {
    margin-bottom: 1rem;
    padding: .875rem 1rem;
    background: linear-gradient(135deg, rgba(201,166,70,.06), rgba(15,23,42,.4));
    border: 1px solid rgba(201,166,70,.15);
    border-radius: var(--radius-xl);
}
.discovery-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .625rem;
}
.discovery-section-title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--gold-light);
    text-transform: uppercase;
    letter-spacing: .06em;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.discovery-scroll {
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    padding-bottom: .25rem;
    scrollbar-width: none;
}
.discovery-scroll::-webkit-scrollbar { display: none; }
.discovery-chip {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem .8rem;
    border-radius: var(--radius-pill);
    background: rgba(201,166,70,.1);
    border: 1px solid rgba(201,166,70,.2);
    font-size: .78rem;
    color: var(--gold-light);
    cursor: pointer;
    white-space: nowrap;
    transition: all .15s;
}
.discovery-chip:hover {
    background: rgba(201,166,70,.18);
    border-color: rgba(201,166,70,.4);
}
.discovery-chip-count {
    font-size: .68rem;
    color: var(--gold-dark);
    font-weight: 700;
}

/* ── ARC FILTER PILLS ─────────────────────────────────────────── */
.arc-filters {
    display: flex;
    gap: .4rem;
    overflow-x: auto;
    padding: .25rem 0 .5rem;
    scrollbar-width: none;
    margin-bottom: .25rem;
}
.arc-filters::-webkit-scrollbar { display: none; }
.arc-pill {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .35rem .75rem;
    border-radius: var(--radius-pill);
    background: var(--space-glass);
    border: 1px solid var(--space-border);
    font-size: .75rem;
    color: var(--text-muted);
    cursor: pointer;
    white-space: nowrap;
    transition: all .15s;
}
.arc-pill:hover, .arc-pill.active {
    background: rgba(201,166,70,.12);
    border-color: rgba(201,166,70,.3);
    color: var(--gold-light);
}
.arc-pill-traveler-count {
    font-size: .65rem;
    font-weight: 700;
    padding: .1rem .3rem;
    border-radius: 999px;
    background: rgba(201,166,70,.15);
    color: var(--gold-light);
}

/* ── OPERATOR CARD (in feed) ──────────────────────────────────── */
.feed-card-operator {
    border-color: rgba(34,197,94,.15);
    background: linear-gradient(
        to bottom right,
        rgba(15,23,42,.98),
        rgba(10,20,35,.96)
    );
}
.feed-card-operator .fc-operator-strip {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .375rem 1rem;
    font-size: .72rem;
    color: #4ade80;
    background: rgba(34,197,94,.06);
    border-bottom: 1px solid rgba(34,197,94,.1);
}

/* ── JOURNEY CONTEXT LINE ─────────────────────────────────────── */
.fc-journey-ctx {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
    padding: .3rem 1rem;
    font-size: .75rem;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(201,166,70,.03);
}
.fc-journey-ctx .fc-arc-tag {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    color: var(--gold-light);
    font-weight: 600;
}
.fc-journey-ctx .fc-location-tag {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    color: var(--text-muted);
}

/* ── CARD META ROW (TravelMate style) ────────────────────────── */
.fc-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    padding: .5rem 1rem .625rem;
    border-top: 1px dashed var(--border-subtle);
    font-size: .75rem;
    color: var(--text-muted);
    flex-wrap: wrap;
}
.fc-meta-pills {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.fc-meta-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .2rem .55rem;
    border-radius: var(--radius-pill);
    background: rgba(15,23,42,.8);
    border: 1px solid var(--space-border);
    font-size: .72rem;
    color: var(--text-muted);
}

/* ── GOLD PRIMARY BUTTON (for dark theme CTAs) ───────────────── */
.btn-gold {
    background: radial-gradient(circle at 10% 0%, #fef3c7, #c9a646);
    color: #111827;
    border: none;
    font-weight: 700;
    box-shadow: 0 8px 20px rgba(180,124,9,.35);
}
.btn-gold:hover {
    box-shadow: 0 10px 28px rgba(180,124,9,.5);
    transform: translateY(-1px);
}

/* ── DESTINATION SAFETY BADGES ───────────────────────────────── */
.safety-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .7rem;
    border-radius: var(--radius-pill);
    font-size: .72rem;
    font-weight: 700;
}
.safety-badge--clear    { background: rgba(34,197,94,.12);  color: #4ade80; border: 1px solid rgba(34,197,94,.3); }
.safety-badge--caution  { background: rgba(251,191,36,.12); color: #fcd34d; border: 1px solid rgba(251,191,36,.3); }
.safety-badge--review   { background: rgba(251,191,36,.12); color: #fbbf24; border: 1px solid rgba(251,191,36,.3); }
.safety-badge--avoid    { background: rgba(239,68,68,.12);  color: #f87171; border: 1px solid rgba(239,68,68,.3); }
.safety-badge--unknown  { background: rgba(148,163,184,.1); color: #94a3b8; border: 1px solid rgba(148,163,184,.2); }

/* ── Skeleton loading animation ───────────────────────────────── */
.skeleton {
    background: linear-gradient(
        90deg,
        var(--bg-elevated) 25%,
        rgba(255,255,255,.06) 50%,
        var(--bg-elevated) 75%
    );
    background-size: 400% 100%;
    animation: skeleton-shimmer 1.4s ease infinite;
    border-radius: 6px;
}
@keyframes skeleton-shimmer {
    0%   { background-position: 100% 50%; }
    100% { background-position: 0%   50%; }
}
