/* PhuketNext Modern Gen-Z Theme Overrides */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Noto+Sans+Thai:wght@400;500;600;700&display=swap');

:root {
	--pn-primary: #6366f1;
	--pn-primary-dark: #4f46e5;
	--pn-accent: #f43f5e;
	--pn-accent2: #06b6d4;
	--pn-bg: #f8fafc;
	--pn-surface: #ffffff;
	--pn-text: #1e293b;
	--pn-text-muted: #64748b;
	--pn-border: #e2e8f0;
	--pn-radius: 16px;
	--pn-radius-sm: 10px;
	--pn-shadow: 0 4px 24px rgba(99, 102, 241, 0.08);
	--pn-shadow-lg: 0 12px 40px rgba(99, 102, 241, 0.15);
	--pn-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #ec4899 100%);
	--pn-gradient-soft: linear-gradient(135deg, #eef2ff 0%, #fdf2f8 100%);
}

html {
	background: var(--pn-gradient-soft);
	font-family: 'Inter', 'Noto Sans Thai', sans-serif;
	scroll-behavior: smooth;
}

body {
	background: var(--pn-bg);
	color: var(--pn-text);
	font-family: 'Inter', 'Noto Sans Thai', sans-serif;
	-webkit-font-smoothing: antialiased;
}

/* Header */
#top_section {
	background: var(--pn-surface);
	border-bottom: 1px solid var(--pn-border);
	box-shadow: var(--pn-shadow);
	backdrop-filter: blur(12px);
}

/* ─── Hero Section (Homepage) ─── */
.pn-hero {
	position: relative;
	z-index: 1;
	overflow: hidden;
	margin: 0 auto 1.25rem;
	max-width: 1200px;
	border-radius: 0 0 28px 28px;
	min-height: 420px;
	display: flex;
	align-items: flex-end;
	box-shadow: 0 24px 64px rgba(15, 23, 42, 0.18);
}

.pn-hero__bg {
	--pn-hero-image: url('https://images.unsplash.com/photo-1552465011-b21e7e7d70fc?auto=format&fit=crop&w=1600&q=80');
	position: absolute;
	inset: 0;
	background:
		linear-gradient(160deg, rgba(8, 47, 73, 0.55) 0%, rgba(15, 23, 42, 0.75) 45%, rgba(30, 27, 75, 0.85) 100%),
		var(--pn-hero-image) center/cover no-repeat;
	transform: scale(1.02);
}

.pn-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.03) 0%,
		rgba(15, 23, 42, 0.2) 40%,
		rgba(15, 23, 42, 0.92) 100%
	);
}

.pn-hero__glow {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.45;
	pointer-events: none;
}

.pn-hero__glow--1 {
	width: 320px;
	height: 320px;
	top: -80px;
	right: -40px;
	background: #06b6d4;
}

.pn-hero__glow--2 {
	width: 280px;
	height: 280px;
	bottom: 20px;
	left: -60px;
	background: #f59e0b;
}

.pn-hero__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	padding: 2rem 2.5rem 2.25rem;
}

.pn-hero__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.5rem;
}

.pn-hero__brand {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.pn-hero__logo {
	height: 52px;
	width: auto;
	max-width: 200px;
	object-fit: contain;
	filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.25));
}

.pn-hero__logo-text {
	font-size: 1.35rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.02em;
}

.pn-hero__badge {
	display: inline-flex;
	align-items: center;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #fef3c7;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.22);
	backdrop-filter: blur(8px);
}

.pn-hero__eyebrow {
	margin: 0 0 0.5rem;
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #67e8f9;
}

.pn-hero__title {
	margin: 0 0 0.85rem;
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: #fff;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
}

.pn-hero__title span {
	background: linear-gradient(90deg, #fde68a, #fbbf24, #f472b6);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.pn-hero__subtitle {
	margin: 0 0 1.5rem;
	max-width: 640px;
	font-size: 1.05rem;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.82);
}

.pn-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-bottom: 1.75rem;
}

.pn-hero__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.65rem 1.35rem;
	border-radius: 999px;
	font-family: inherit;
	font-size: 0.9375rem;
	font-weight: 700;
	line-height: 1.5;
	text-decoration: none;
	transition: box-shadow 0.2s ease, background 0.2s ease, filter 0.2s ease;
	border: 2px solid transparent;
	-webkit-font-smoothing: antialiased;
}

.pn-hero__btn--primary {
	background: linear-gradient(135deg, #fbbf24, #f59e0b);
	color: #1e293b !important;
	box-shadow: 0 8px 24px rgba(245, 158, 11, 0.4);
}

.pn-hero__btn--primary:hover {
	filter: brightness(1.05);
	box-shadow: 0 10px 28px rgba(245, 158, 11, 0.48);
}

.pn-hero__btn--ghost {
	background: rgba(255, 255, 255, 0.95);
	color: #0f172a !important;
}

.pn-hero__btn--ghost:hover {
	filter: brightness(1.02);
	background: #fff;
}

.pn-hero__btn--outline {
	background: transparent;
	color: #fff !important;
	border-color: rgba(255, 255, 255, 0.45);
}

.pn-hero__btn--outline:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: #fff;
}

.pn-hero__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	max-width: 520px;
}

.pn-hero__stat {
	padding: 0.85rem 1rem;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	backdrop-filter: blur(12px);
	text-align: center;
}

.pn-hero__stat strong {
	display: block;
	font-size: 1.35rem;
	font-weight: 800;
	color: #fff;
	line-height: 1.2;
}

.pn-hero__stat span {
	font-size: 0.78rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.65);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* Compact header (inner pages) */
.pn-header-compact {
	background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #312e81 100%) !important;
	padding: 1rem 1.25rem 1.25rem !important;
	border-radius: 0 0 20px 20px !important;
	margin-bottom: 0.5rem;
	box-shadow: 0 8px 32px rgba(15, 23, 42, 0.15);
}

.pn-header-compact .forumtitle a,
.pn-header-compact .forumtitle a img {
	color: #fff !important;
}

.pn-header-compact__slogan,
.pn-header-compact #siteslogan {
	color: rgba(255, 255, 255, 0.75) !important;
	font-size: 0.9rem !important;
	padding: 0.25rem 0 0 0.5rem !important;
}

body.action_home #wrapper {
	padding-top: 0;
}

body.action_home #upper_section {
	position: relative;
	z-index: 200;
	background: transparent;
}

body.action_home #main_menu {
	position: relative;
	z-index: 210;
}

body.action_home #main_menu .dropmenu li ul,
body.action_home #main_menu .top_menu {
	z-index: 220;
}

body.action_home #inner_section {
	background: var(--pn-surface);
	border-radius: var(--pn-radius);
	border: 1px solid var(--pn-border);
	box-shadow: var(--pn-shadow);
	margin-top: 0.5rem;
}

/* Legacy header override */
#header:not(.pn-header-compact) {
	display: none;
}

#header.pn-header-compact {
	display: flex !important;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 0.5rem;
}

#header .forumtitle a {
	color: #fff !important;
	font-weight: 800;
	font-size: 1.6rem;
	letter-spacing: -0.02em;
	text-shadow: none;
}

#siteslogan {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.95rem;
	font-weight: 500;
}

/* Navigation */
.navigate_section {
	background: var(--pn-surface);
	border-radius: var(--pn-radius-sm);
	padding: 0.6rem 1rem;
	margin: 0.75rem 0;
	border: 1px solid var(--pn-border);
}

.navigate_section a {
	color: var(--pn-primary);
	font-weight: 500;
}

/* Cards / Roundframes */
.roundframe, .windowbg, .windowbg2, .windowbg3 {
	background: var(--pn-surface) !important;
	border: 1px solid var(--pn-border) !important;
	border-radius: var(--pn-radius) !important;
	box-shadow: var(--pn-shadow) !important;
	margin-bottom: 1rem;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.roundframe:hover, .windowbg:hover {
	box-shadow: var(--pn-shadow-lg) !important;
}

/* Board index table */
#board_table .info, .table_list tbody tr {
	border-radius: var(--pn-radius-sm);
}

.table_list tbody tr:hover {
	background: #f1f5f9 !important;
}

.table_list h3 a, .table_list h3 {
	font-weight: 700;
	color: var(--pn-text);
}

.table_list h3 a:hover {
	color: var(--pn-primary);
}

/* ─── Professional Buttons (Thai-safe, readable) ─── */
.button,
input.button,
button:not(.pn-ai-send):not(.hide_popup),
.quickbuttons > li > a,
.inline_mod_check,
.buttonlist a,
.buttonrow .button,
.pagesection .button,
.mark_read .button,
#quick_actions .button,
#quick_actions .qaction,
.mobile_buttons .button,
#mobile_action .button,
#mobile_moderation .button,
.button_strip a,
.button_strip_new_topic a,
.paid-index-cta__btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.4rem;
	min-height: 2.625rem !important;
	height: auto !important;
	padding: 0.5rem 1.125rem !important;
	margin: 0.125rem;
	font-family: 'Inter', 'Noto Sans Thai', sans-serif !important;
	font-size: 0.875rem !important;
	font-weight: 600 !important;
	line-height: 1.5 !important;
	letter-spacing: 0;
	text-transform: none !important;
	text-shadow: none !important;
	text-decoration: none !important;
	white-space: nowrap;
	overflow: visible !important;
	box-sizing: border-box !important;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	border: 1px solid transparent !important;
	border-radius: 10px !important;
	background: var(--pn-gradient) !important;
	color: #fff !important;
	box-shadow: 0 2px 8px rgba(99, 102, 241, 0.28) !important;
	transition: background 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease !important;
	cursor: pointer;
}

/* Pagelinks / secondary actions */
.pagelinks .button,
.navigate_section .button {
	min-height: 2.25rem !important;
	padding: 0.45rem 0.95rem !important;
	font-size: 0.8125rem !important;
	background: #fff !important;
	color: var(--pn-primary-dark) !important;
	border: 1px solid var(--pn-border) !important;
	box-shadow: none !important;
}

.pagelinks .button:hover,
.pagelinks .button:focus,
.navigate_section .button:hover {
	background: #eef2ff !important;
	color: var(--pn-primary) !important;
	border-color: #c7d2fe !important;
	box-shadow: none !important;
}

.button:hover,
.button:focus,
input.button:hover,
input.button:focus,
button:hover:not(.pn-ai-send),
button:focus:not(.pn-ai-send),
.quickbuttons > li:hover > a,
.quickbuttons > li > a:focus {
	transform: none !important;
	color: #fff !important;
	border-color: transparent !important;
	box-shadow: 0 4px 14px rgba(99, 102, 241, 0.38) !important;
	filter: brightness(1.06);
	text-decoration: none !important;
}

.pagelinks .button:hover,
.pagelinks .button:focus {
	color: var(--pn-primary) !important;
	filter: none;
}

.button.active,
.button.active:hover,
.button.active:focus {
	background: var(--pn-primary-dark) !important;
	color: #fff !important;
	border-color: var(--pn-primary-dark) !important;
	font-weight: 700 !important;
}

/* Icons inside buttons */
.button .main_icons::before,
.quickbuttons .main_icons::before {
	line-height: 1 !important;
	vertical-align: middle;
}

/* Posts — subtle quick action buttons */
.quickbuttons > li > a {
	min-height: 2rem !important;
	padding: 0.35rem 0.7rem !important;
	font-size: 0.8125rem !important;
	line-height: 1.45 !important;
	border-radius: 8px !important;
	background: #f8fafc !important;
	color: var(--pn-text) !important;
	border: 1px solid var(--pn-border) !important;
	box-shadow: none !important;
}

.quickbuttons > li:hover > a,
.quickbuttons > li > a:focus {
	background: #eef2ff !important;
	color: var(--pn-primary-dark) !important;
	border-color: #c7d2fe !important;
	filter: none;
}

/* Joined button groups */
.buttonrow .button {
	border-radius: 0 !important;
	margin: 0 !important;
}

.buttonrow .button:first-child {
	border-radius: 10px 0 0 10px !important;
}

.buttonrow .button:last-child {
	border-radius: 0 10px 10px 0 !important;
}

/* Login / signup top bar */
#top_info .button_login a,
#top_info .button_signup a {
	min-height: 2.25rem !important;
	padding: 0.45rem 1rem !important;
	line-height: 1.5 !important;
	font-size: 0.8125rem !important;
	border-radius: 999px !important;
}

#top_info a .textmenu {
	line-height: 1.5;
	display: inline;
	vertical-align: baseline;
}

#top_info .button_signup a {
	background: var(--pn-accent) !important;
}

#top_info .button_login a {
	background: #fff !important;
	color: var(--pn-primary-dark) !important;
	border: 1px solid var(--pn-border) !important;
	box-shadow: none !important;
}

#top_info .button_login a:hover {
	background: #eef2ff !important;
	color: var(--pn-primary) !important;
}

/* Search */
#search_form input[type="search"] {
	border-radius: 10px 0 0 10px !important;
	border: 2px solid var(--pn-border) !important;
	padding: 0.5rem 1rem !important;
	line-height: 1.5 !important;
	min-height: 2.625rem;
	box-sizing: border-box;
}

#search_form input.button {
	border-radius: 0 10px 10px 0 !important;
	min-height: 2.625rem !important;
	line-height: 1.5 !important;
	padding: 0.5rem 1rem !important;
}

/* Avoid clipping on hover/transform */
.pagesection,
.buttonlist,
.buttonrow,
.mark_read,
#top_info,
#top_info > li,
.pn-hero__actions {
	overflow: visible;
}

/* Posts */
.post_wrapper, .post {
	border-radius: var(--pn-radius) !important;
}

.poster h4 a {
	color: var(--pn-primary-dark);
	font-weight: 700;
}

.postarea, .inner {
	font-size: 1rem;
	line-height: 1.75;
}

/* Paid CTA — premium card */
.paid-index-cta {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, #1e3a5f 0%, #312e81 55%, #4c1d95 100%) !important;
	border-radius: 20px !important;
	padding: 1.75rem 2rem !important;
	margin: 0 0 1.5rem !important;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.12) !important;
	box-shadow: 0 16px 48px rgba(49, 46, 129, 0.25) !important;
}

.paid-index-cta::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -20%;
	width: 280px;
	height: 280px;
	background: radial-gradient(circle, rgba(251, 191, 36, 0.25) 0%, transparent 70%);
	pointer-events: none;
}

.paid-index-cta__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
}

.paid-index-cta h2 {
	font-size: 1.35rem;
	font-weight: 800;
	margin: 0 0 0.35rem;
	letter-spacing: -0.02em;
}

.paid-index-cta__text p {
	margin: 0;
	opacity: 0.85;
	font-size: 0.95rem;
	line-height: 1.55;
}

.paid-index-cta__btn--primary {
	background: linear-gradient(135deg, #fbbf24, #f59e0b) !important;
	color: #1e293b !important;
	font-weight: 700 !important;
	line-height: 1.5 !important;
	min-height: 2.75rem !important;
	box-shadow: 0 6px 20px rgba(245, 158, 11, 0.35) !important;
}

.paid-index-cta__btn--primary:hover {
	filter: brightness(1.05);
	transform: none !important;
}

/* Footer */
#footer {
	background: var(--pn-surface);
	border-top: 1px solid var(--pn-border);
	padding: 1.5rem 0;
	margin-top: auto;
}

#footer a {
	color: var(--pn-primary);
}

/* Mobile bottom nav */
@media (max-width: 720px) {
	#wrapper {
		padding-bottom: 72px;
	}

	.pn-mobile-nav {
		display: flex !important;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		background: var(--pn-surface);
		border-top: 1px solid var(--pn-border);
		box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
		z-index: 9998;
		padding: 0.5rem 0;
		justify-content: space-around;
	}

	.pn-mobile-nav a {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0.2rem;
		color: var(--pn-text-muted);
		font-size: 0.7rem;
		font-weight: 600;
		text-decoration: none;
		padding: 0.25rem 0.5rem;
		border-radius: var(--pn-radius-sm);
		transition: color 0.15s;
	}

	.pn-mobile-nav a:hover, .pn-mobile-nav a.active {
		color: var(--pn-primary);
	}

	.pn-mobile-nav .pn-nav-icon {
		font-size: 1.4rem;
		line-height: 1;
	}

	.pn-hero {
		min-height: 360px;
		border-radius: 0 0 20px 20px;
		margin-left: -0.5rem;
		margin-right: -0.5rem;
		max-width: none;
	}

	.pn-hero__inner {
		padding: 1.5rem 1.25rem 1.75rem;
	}

	.pn-hero__title {
		font-size: 1.85rem;
	}

	.pn-hero__stats {
		max-width: 100%;
	}

	.pn-hero__actions {
		flex-direction: column;
	}

	.pn-hero__btn {
		width: 100%;
	}

	#header .forumtitle a {
		font-size: 1.2rem;
	}

	.roundframe, .windowbg {
		border-radius: var(--pn-radius-sm) !important;
	}

	.post_wrapper {
		margin: 0 -0.5rem;
	}
}

@media (min-width: 721px) {
	.pn-mobile-nav {
		display: none !important;
	}
}

/* AI Assistant Widget */
#pn-ai-widget {
	position: fixed;
	bottom: 90px;
	right: 20px;
	z-index: 9999;
	font-family: 'Inter', 'Noto Sans Thai', sans-serif;
}

@media (min-width: 721px) {
	#pn-ai-widget {
		bottom: 24px;
	}
}

#pn-ai-toggle {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--pn-gradient);
	border: none;
	color: #fff;
	font-size: 1.5rem;
	cursor: pointer;
	box-shadow: var(--pn-shadow-lg);
	transition: transform 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

#pn-ai-toggle:hover {
	transform: scale(1.08);
}

#pn-ai-panel {
	display: none;
	position: absolute;
	bottom: 68px;
	right: 0;
	width: 340px;
	max-width: calc(100vw - 40px);
	background: var(--pn-surface);
	border-radius: var(--pn-radius);
	box-shadow: var(--pn-shadow-lg);
	border: 1px solid var(--pn-border);
	overflow: hidden;
}

#pn-ai-panel.open {
	display: flex;
	flex-direction: column;
	animation: pnSlideUp 0.25s ease;
}

@keyframes pnSlideUp {
	from { opacity: 0; transform: translateY(12px); }
	to { opacity: 1; transform: translateY(0); }
}

#pn-ai-header {
	background: var(--pn-gradient);
	color: #fff;
	padding: 0.85rem 1rem;
	font-weight: 700;
	font-size: 0.95rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#pn-ai-close {
	background: none;
	border: none;
	color: #fff;
	font-size: 1.2rem;
	cursor: pointer;
	opacity: 0.8;
}

#pn-ai-actions {
	padding: 0.75rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	border-bottom: 1px solid var(--pn-border);
}

.pn-ai-btn {
	background: #f1f5f9;
	border: 1px solid var(--pn-border);
	border-radius: 999px;
	padding: 0.3rem 0.75rem;
	font-size: 0.75rem;
	font-weight: 600;
	cursor: pointer;
	color: var(--pn-text);
	transition: background 0.15s;
}

.pn-ai-btn:hover {
	background: #eef2ff;
	color: var(--pn-primary);
}

#pn-ai-messages {
	flex: 1;
	max-height: 260px;
	overflow-y: auto;
	padding: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.6;
}

.pn-ai-msg {
	margin-bottom: 0.6rem;
	padding: 0.5rem 0.75rem;
	border-radius: var(--pn-radius-sm);
}

.pn-ai-msg.user {
	background: #eef2ff;
	margin-left: 1.5rem;
}

.pn-ai-msg.bot {
	background: #f8fafc;
	border: 1px solid var(--pn-border);
	margin-right: 1.5rem;
}

.pn-ai-msg.error {
	background: #fef2f2;
	color: #dc2626;
}

#pn-ai-input-row {
	display: flex;
	padding: 0.6rem;
	gap: 0.4rem;
	border-top: 1px solid var(--pn-border);
}

#pn-ai-input {
	flex: 1;
	border: 2px solid var(--pn-border);
	border-radius: 999px;
	padding: 0.4rem 0.85rem;
	font-size: 0.875rem;
	outline: none;
	font-family: inherit;
}

#pn-ai-input:focus {
	border-color: var(--pn-primary);
}

#pn-ai-send {
	background: var(--pn-primary);
	color: #fff;
	border: none;
	border-radius: 50%;
	width: 36px;
	height: 36px;
	cursor: pointer;
	font-size: 1rem;
	flex-shrink: 0;
}

.pn-ai-loading {
	opacity: 0.6;
	font-style: italic;
}

/* Topic title enhancement */
#forumposts .pagesection .floatleft h3,
.windowbg .subject a {
	font-weight: 700;
}

/* Info center */
#info_center .windowbg {
	border-radius: var(--pn-radius) !important;
}

/* Selection */
::selection {
	background: #c7d2fe;
	color: var(--pn-text);
}

/* Scrollbar */
::-webkit-scrollbar {
	width: 6px;
}
::-webkit-scrollbar-thumb {
	background: #cbd5e1;
	border-radius: 3px;
}

/* ─── Board & Topic Cards ─── */
.pn-boardindex {
	margin-top: 0.5rem;
}

.pn-category {
	margin-bottom: 1.75rem;
}

.pn-category__header {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 0 0.75rem !important;
	margin: 0 !important;
}

.pn-category__title,
.pn-category__header .catbg {
	background: transparent !important;
	color: var(--pn-text) !important;
	font-size: 1.15rem !important;
	font-weight: 800 !important;
	padding: 0 !important;
	border: none !important;
	letter-spacing: -0.02em;
}

.pn-category__desc {
	color: var(--pn-text-muted);
	font-size: 0.9rem;
	margin-top: 0.25rem;
}

.pn-board-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1rem;
}

.pn-board-card {
	position: relative;
	background: var(--pn-surface);
	border: 1px solid var(--pn-border);
	border-radius: var(--pn-radius);
	overflow: hidden;
	box-shadow: var(--pn-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.pn-board-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--pn-shadow-lg);
	border-color: #c7d2fe;
}

.pn-board-card--new {
	border-color: #a5b4fc;
}

.pn-board-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

.pn-board-card__media {
	position: relative;
	height: 140px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--pn-board-accent, #6366f1), #8b5cf6);
}

.pn-board-card__media--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, color-mix(in srgb, var(--pn-board-accent, #6366f1) 75%, #fff), color-mix(in srgb, var(--pn-board-accent, #6366f1) 40%, #1e293b));
}

.pn-board-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.35s ease;
}

.pn-board-card:hover .pn-board-card__img {
	transform: scale(1.05);
}

.pn-board-card__initial {
	font-size: 2.5rem;
	font-weight: 800;
	color: rgba(255, 255, 255, 0.92);
	text-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.pn-board-card__badge {
	position: absolute;
	top: 0.65rem;
	right: 0.65rem;
	background: #f43f5e;
	color: #fff;
	font-size: 0.7rem;
	font-weight: 800;
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.pn-board-card__body {
	padding: 1rem 1.1rem 1.15rem;
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	flex: 1;
}

.pn-board-card__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 800;
	color: var(--pn-text);
	line-height: 1.35;
	letter-spacing: -0.02em;
}

.pn-board-card__desc {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.55;
	color: var(--pn-text-muted);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.pn-board-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.85rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--pn-primary-dark);
}

.pn-board-card__last {
	font-size: 0.78rem;
	color: var(--pn-text-muted);
	line-height: 1.45;
	margin-top: auto;
	padding-top: 0.35rem;
	border-top: 1px dashed var(--pn-border);
}

.pn-board-card__last a {
	color: var(--pn-primary);
	font-weight: 600;
}

.pn-board-card__mods,
.pn-board-card__children {
	padding: 0 1.1rem 1rem;
	font-size: 0.78rem;
	color: var(--pn-text-muted);
}

.pn-board-card__children-label {
	display: block;
	font-weight: 700;
	margin-bottom: 0.35rem;
	color: var(--pn-text);
}

.pn-board-chip-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
}

.pn-board-chip {
	display: inline-flex;
	align-items: center;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	background: #eef2ff;
	color: var(--pn-primary-dark) !important;
	font-size: 0.75rem;
	font-weight: 600;
	text-decoration: none !important;
}

.pn-board-chip--new {
	background: #fef2f2;
	color: #dc2626 !important;
}

.pn-board-card__mod {
	position: absolute;
	top: 0.5rem;
	left: 0.5rem;
	background: #f59e0b;
	color: #fff;
	width: 1.4rem;
	height: 1.4rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 0.8rem;
	text-decoration: none;
	z-index: 2;
}

.pn-mark-read {
	margin-top: 0.5rem;
}

/* Topic cards (message index) */
.pn-page-header {
	background: var(--pn-surface);
	border: 1px solid var(--pn-border);
	border-radius: var(--pn-radius);
	padding: 1.25rem 1.5rem !important;
	margin-bottom: 1rem;
	box-shadow: var(--pn-shadow);
}

.pn-page-header .display_title {
	font-size: 1.5rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	margin: 0 0 0.35rem;
}

.pn-page-header__desc,
.pn-page-header__mods,
.pn-page-header__viewing {
	color: var(--pn-text-muted);
	font-size: 0.9rem;
	margin: 0.25rem 0 0;
}

.pn-messageindex {
	margin-top: 0.5rem;
}

.pn-topic-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.85rem;
}

.pn-topic-card {
	position: relative;
	display: flex;
	background: var(--pn-surface);
	border: 1px solid var(--pn-border);
	border-radius: var(--pn-radius);
	overflow: hidden;
	box-shadow: var(--pn-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.pn-topic-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--pn-shadow-lg);
}

.pn-topic-card__link {
	display: flex;
	width: 100%;
	color: inherit;
	text-decoration: none;
	gap: 0;
}

.pn-topic-card__media {
	flex-shrink: 0;
	width: 112px;
	min-height: 100px;
	background: linear-gradient(135deg, var(--pn-board-accent, #6366f1), #8b5cf6);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.pn-topic-card__media--placeholder {
	background: linear-gradient(135deg, #eef2ff, #fdf2f8);
}

.pn-topic-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	min-height: 100px;
}

.pn-topic-card__icon {
	width: 42px;
	height: 42px;
	opacity: 0.85;
}

.pn-topic-card__body {
	padding: 0.85rem 1rem;
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.pn-topic-card__title-row {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}

.pn-topic-card__new {
	flex-shrink: 0;
	background: #f43f5e;
	color: #fff;
	font-size: 0.65rem;
	font-weight: 800;
	padding: 0.15rem 0.45rem;
	border-radius: 999px;
	text-transform: uppercase;
}

.pn-topic-card__title {
	margin: 0;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.4;
	color: var(--pn-text);
}

.pn-topic-card__title--sticky {
	color: var(--pn-primary-dark);
}

.pn-topic-card__excerpt {
	margin: 0;
	font-size: 0.85rem;
	color: var(--pn-text-muted);
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.pn-topic-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 1rem;
	font-size: 0.78rem;
	color: var(--pn-text-muted);
}

.pn-topic-card__last {
	font-size: 0.78rem;
	color: var(--pn-text-muted);
	margin-top: auto;
}

.pn-topic-card__mod {
	padding: 0.85rem 0.65rem 0.85rem 0;
	display: flex;
	align-items: flex-start;
}

.pn-empty-state {
	text-align: center;
	padding: 2rem !important;
	color: var(--pn-text-muted);
}

.pn-child-boards {
	margin-bottom: 1.25rem;
}

.pn-pagesection {
	margin: 0.75rem 0;
}

/* Hide legacy row layout when cards active */
.pn-boardindex .up_contain,
.pn-messageindex #topic_header,
.pn-messageindex #topic_container > .windowbg {
	display: none !important;
}

@media (min-width: 640px) {
	.pn-topic-grid {
		grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	}

	.pn-topic-card__link {
		flex-direction: column;
	}

	.pn-topic-card__media {
		width: 100%;
		height: 120px;
		min-height: 120px;
	}
}

@media (max-width: 480px) {
	.pn-board-grid {
		grid-template-columns: 1fr;
	}

	.pn-topic-card__media {
		width: 88px;
	}
}
