/* ============================================================
   Lazer Runner — WordPress-specific additions
   (extends assets/css/style.css)
   ============================================================ */

/* Nav menu rendered by wp_nav_menu uses a <ul>; style it like the static nav */
.nav .nav-list { list-style: none; display: flex; align-items: center; gap: var(--space-1); margin: 0; padding: 0; }
.nav .nav-list li { position: relative; }
.nav .nav-list a,
.nav > a {
	font-family: var(--font-display); font-weight: 600;
	font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--text);
	padding: var(--space-2) var(--space-3); border-radius: var(--radius-full);
	position: relative; display: inline-block;
}
.nav .nav-list a:hover, .nav > a:hover { color: var(--magenta); }
.nav .nav-list a::after, .nav > a::after {
	content: ''; position: absolute; left: 50%; bottom: 2px; transform: translateX(-50%);
	width: 0; height: 2px; background: var(--cyan); border-radius: 2px;
	transition: width var(--transition); box-shadow: var(--glow-cyan);
}
.nav .nav-list a:hover::after, .nav > a:hover::after { width: 60%; }

/* Dropdown sub-menus */
.nav .nav-list ul.sub-menu {
	position: absolute; top: 100%; left: 0; min-width: 200px;
	list-style: none; margin: 0; padding: var(--space-2);
	background: rgba(10,14,28,0.97); backdrop-filter: blur(14px);
	border: 1px solid var(--border); border-radius: var(--radius-md);
	display: none; flex-direction: column; gap: 2px; z-index: 120;
}
.nav .nav-list li:hover > ul.sub-menu { display: flex; }
.nav .nav-list ul.sub-menu a { display: block; }

/* current page highlight */
.nav .nav-list .current-menu-item > a { color: var(--cyan); }

/* ---------- Generic page hero (interior pages) ---------- */
.page-hero {
	position: relative; padding-top: 150px; padding-bottom: var(--space-16);
	overflow: hidden; border-bottom: 1px solid var(--border);
}
.page-hero .page-hero-bg { position: absolute; inset: 0; z-index: -1; }
.page-hero .page-hero-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.22; }
.page-hero .page-hero-bg::after { content:''; position:absolute; inset:0; background: linear-gradient(180deg, rgba(6,8,16,0.6), var(--bg)); }
.page-hero h1 { font-size: var(--text-3xl); text-transform: uppercase; line-height: 0.95; margin-top: var(--space-4); }
.page-hero .lead { color: var(--text-muted); font-size: var(--text-lg); max-width: 680px; margin-top: var(--space-5); }
.breadcrumbs { font-size: var(--text-xs); color: var(--text-faint); letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: var(--space-2); }
.breadcrumbs a { color: var(--text-muted); }
.breadcrumbs a:hover { color: var(--cyan); }

/* ---------- Long-form content (pages, location, single) ---------- */
.content-prose { max-width: 760px; }
.content-prose h2 { font-size: var(--text-xl); text-transform: none; margin-top: var(--space-12); margin-bottom: var(--space-4); color: var(--text); }
.content-prose h3 { font-family: var(--font-body); font-weight: 700; font-size: var(--text-lg); margin-top: var(--space-8); margin-bottom: var(--space-3); color: var(--text); }
.content-prose p { color: var(--text-muted); margin-bottom: var(--space-5); }
.content-prose ul, .content-prose ol { color: var(--text-muted); margin: 0 0 var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); }
.content-prose li { padding-left: var(--space-1); }
.content-prose a { color: var(--cyan); text-decoration: underline; text-underline-offset: 3px; }
.content-prose a:hover { color: var(--cyan-soft); }
.content-prose strong { color: var(--text); }
.content-prose img { border-radius: var(--radius-md); margin-block: var(--space-6); border: 1px solid var(--border); }
.content-prose blockquote {
	border-left: 3px solid var(--magenta); padding: var(--space-2) var(--space-6);
	margin: var(--space-8) 0; color: var(--text); font-size: var(--text-lg);
}

/* Layout: prose + sticky sidebar */
.page-layout { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-16); align-items: start; }
.sidebar { position: sticky; top: 110px; display: flex; flex-direction: column; gap: var(--space-6); }
.sidebar .info-box h4 { color: var(--cyan); }
.sidebar .btn { width: 100%; }
@media (max-width: 980px) { .page-layout { grid-template-columns: 1fr; } .sidebar { position: static; } }

/* ---------- Blog index / archive ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
@media (max-width: 980px) { .blog-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .blog-grid { grid-template-columns: 1fr; } }

.post-card {
	display: flex; flex-direction: column; border-radius: var(--radius-lg); overflow: hidden;
	border: 1px solid var(--border); background: linear-gradient(160deg, var(--surface), var(--surface-2));
	transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.post-card:hover { transform: translateY(-6px); border-color: var(--border-glow); box-shadow: var(--shadow-lg); }
.post-card .thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--surface-3); }
.post-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms var(--ease-out); }
.post-card:hover .thumb img { transform: scale(1.05); }
.post-card .pc-body { padding: var(--space-6); display: flex; flex-direction: column; flex: 1; }
.post-card .cat { font-family: var(--font-display); font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--magenta-soft); margin-bottom: var(--space-3); }
.post-card h3 { font-family: var(--font-body); font-weight: 700; font-size: var(--text-lg); line-height: 1.25; margin-bottom: var(--space-3); }
.post-card h3 a { color: var(--text); }
.post-card h3 a:hover { color: var(--cyan); }
.post-card p { color: var(--text-muted); font-size: var(--text-sm); margin-bottom: var(--space-5); }
.post-card .meta { margin-top: auto; font-size: var(--text-xs); color: var(--text-faint); display: flex; gap: var(--space-3); }
.post-card .read-link { font-family: var(--font-display); font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--cyan); margin-top: var(--space-4); display: inline-flex; align-items: center; gap: var(--space-2); }

/* ---------- Single post ---------- */
.single-hero { padding-top: 140px; padding-bottom: var(--space-10); }
.single-hero .cat { font-family: var(--font-display); font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; color: var(--magenta-soft); }
.single-hero h1 { font-family: var(--font-body); font-weight: 700; font-size: var(--text-2xl); line-height: 1.1; margin-block: var(--space-4); max-width: 18ch; }
.single-hero .meta { font-size: var(--text-sm); color: var(--text-faint); display: flex; gap: var(--space-4); }
.single-feature { margin-bottom: var(--space-10); border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border-glow); }
.single-feature img { width: 100%; height: auto; }

.post-tags { margin-top: var(--space-10); display: flex; flex-wrap: wrap; gap: var(--space-2); }
.post-tags a { font-size: var(--text-xs); padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); border: 1px solid var(--border); color: var(--text-muted); }
.post-tags a:hover { border-color: var(--cyan); color: var(--cyan); }

.post-nav { display: flex; justify-content: space-between; gap: var(--space-6); margin-top: var(--space-12); padding-top: var(--space-8); border-top: 1px solid var(--border); }
.post-nav a { color: var(--text-muted); font-size: var(--text-sm); max-width: 45%; }
.post-nav a:hover { color: var(--cyan); }

/* ---------- Comments ---------- */
.comments-area { margin-top: var(--space-16); padding-top: var(--space-10); border-top: 1px solid var(--border); }
.comments-area h2, .comment-reply-title { font-size: var(--text-xl); margin-bottom: var(--space-6); }
.comment-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-6); }
.comment-list .comment-body { padding: var(--space-5); border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface); }
.comment-list .children { list-style: none; margin: var(--space-4) 0 0 var(--space-8); display: flex; flex-direction: column; gap: var(--space-4); }
.comment-author .fn { color: var(--text); font-weight: 600; }
.comment-metadata a { color: var(--text-faint); font-size: var(--text-xs); }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea {
	width: 100%; padding: var(--space-3) var(--space-4); background: var(--surface);
	border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); margin-bottom: var(--space-4);
}
.comment-form label { display: block; font-size: var(--text-sm); color: var(--text-muted); margin-bottom: var(--space-2); }

/* ---------- Pagination ---------- */
.lr-pagination { display: flex; justify-content: center; gap: var(--space-2); margin-top: var(--space-16); }
.lr-pagination .page-numbers {
	font-family: var(--font-display); font-size: var(--text-sm);
	padding: var(--space-2) var(--space-4); border-radius: var(--radius-sm);
	border: 1px solid var(--border); color: var(--text-muted);
}
.lr-pagination .page-numbers.current { background: var(--magenta); color: #fff; border-color: var(--magenta); }
.lr-pagination a.page-numbers:hover { border-color: var(--cyan); color: var(--cyan); }

/* ---------- Sidebar widget (blog) ---------- */
.widget { padding: var(--space-6); border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface); }
.widget-title { font-family: var(--font-display); font-size: var(--text-base); text-transform: uppercase; color: var(--cyan); margin-bottom: var(--space-4); letter-spacing: 0.05em; }
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget li { padding-block: var(--space-2); border-bottom: 1px solid var(--border); }
.widget a { color: var(--text-muted); font-size: var(--text-sm); }
.widget a:hover { color: var(--cyan); }

/* WP alignment + caption utilities used inside content */
.aligncenter { margin-inline: auto; }
.alignright { float: right; margin: 0 0 var(--space-4) var(--space-6); }
.alignleft { float: left; margin: 0 var(--space-6) var(--space-4) 0; }
.wp-caption-text { font-size: var(--text-xs); color: var(--text-faint); text-align: center; }
.sticky, .gallery-caption { display: block; }
.bypostauthor { display: block; }


/* ---------- Kids "Real Smiles" photo strip ---------- */
.smiles-grid {
	display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-4);
}
.smiles-grid .smile {
	border-radius: var(--radius-md); overflow: hidden;
	border: 1px solid var(--border); background: var(--surface-3);
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.smiles-grid .smile img { width: 100%; height: auto; display: block; }
.smiles-grid .smile:hover { transform: translateY(-4px); border-color: var(--magenta); box-shadow: var(--glow-magenta); }
@media (max-width: 980px) { .smiles-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .smiles-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Instagram feed ---------- */
.ig-feed { margin-top: var(--space-4); }
.ig-fallback {
	text-align: center; padding: var(--space-12) var(--space-6);
	border: 1px dashed var(--border-glow); border-radius: var(--radius-lg);
	background: var(--surface);
}
.ig-fallback p { color: var(--text-muted); margin-bottom: var(--space-6); }

/* ---------- Pre-footer booking band ---------- */
.book-band {
	border-top: 1px solid var(--border);
	background:
		radial-gradient(60% 140% at 12% 0%, rgba(227,10,120,0.07), transparent 60%),
		radial-gradient(60% 140% at 88% 100%, rgba(11,188,214,0.07), transparent 60%),
		var(--bg-2);
	padding-block: clamp(var(--space-12), 6vw, var(--space-20));
}
.book-band-inner {
	display: flex; align-items: center; justify-content: space-between;
	flex-wrap: wrap; gap: var(--space-8);
}
.book-band-copy { max-width: 560px; }
.book-band-copy h2 { font-size: var(--text-2xl); text-transform: uppercase; margin-top: var(--space-3); }
.book-band-copy p { color: var(--text-muted); margin-top: var(--space-4); font-size: var(--text-lg); }
.book-band-copy a { color: var(--cyan); }
.book-band-actions { display: flex; flex-wrap: wrap; gap: var(--space-4); }
@media (max-width: 760px) {
	.book-band-inner { flex-direction: column; align-items: flex-start; }
	.book-band-actions { width: 100%; }
	.book-band-actions .btn { flex: 1; }
}
/* Keep the BriqBookings widget mount compact and unobtrusive.
   The widget powers the popup; its own inline button is de-emphasized. */
.bw-mount { margin-top: var(--space-8); }
.bw-mount .bw-widget { max-width: 720px; }

/* ---------- Hello bar (top announcement) ---------- */
.hello-bar {
	position: fixed; top: 0; left: 0; right: 0; z-index: 110;
	background: linear-gradient(100deg, var(--magenta), var(--cyan));
	color: #fff;
	font-family: var(--font-display); font-weight: 600;
	font-size: var(--text-sm); letter-spacing: 0.04em;
	text-align: center;
}
.hello-bar-inner {
	display: flex; align-items: center; justify-content: center; gap: var(--space-3);
	padding-block: var(--space-2);
}
.hello-bar strong { color: #fff; font-weight: 700; }
.hello-bar .hello-dot {
	width: 8px; height: 8px; border-radius: 50%; background: #fff;
	box-shadow: 0 0 0 0 rgba(255,255,255,0.7); animation: pulse 2s infinite;
}
/* Push the fixed header down by the hello bar's height */
.header { top: 38px; }
/* When header hides on scroll-down, it still tucks under the bar cleanly */
.header.hidden { transform: translateY(calc(-100% - 38px)); }
/* Give the hero / first section room so the bar+header don't overlap content */
body.lr-theme .hero { padding-top: 150px; }
@media (max-width: 600px) {
	.hello-bar { font-size: 0.78rem; }
	.header { top: 34px; }
}

/* ---------- Homepage feature slider ---------- */
.feature-slider-section { padding-block: clamp(var(--space-10), 5vw, var(--space-16)); }
.feature-slider { position: relative; }
.fs-viewport { overflow: hidden; border-radius: var(--radius-xl); border: 1px solid var(--border); box-shadow: var(--shadow-lg); }
.fs-container { display: flex; }
.fs-slide {
	position: relative; flex: 0 0 100%; min-width: 0;
	display: grid; grid-template-columns: 1fr 1fr; align-items: stretch;
	background: linear-gradient(120deg, var(--surface), var(--surface-2));
}
.fs-photo {
	/* Native aspect ratio preserved; photo sits on a soft surface, never cropped awkwardly */
	display: flex; align-items: center; justify-content: center;
	background: var(--surface-3); padding: var(--space-4);
}
.fs-photo img { width: auto; max-width: 100%; max-height: 520px; height: auto; border-radius: var(--radius-lg); display: block; box-shadow: var(--shadow-md); }
.fs-caption {
	display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
	gap: var(--space-4); padding: clamp(var(--space-6), 4vw, var(--space-16));
}
.fs-caption h2 { font-size: var(--text-2xl); text-transform: uppercase; }
.fs-caption p { color: var(--text-muted); font-size: var(--text-lg); max-width: 42ch; }

/* arrows */
.fs-btn {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
	width: 48px; height: 48px; border-radius: 50%;
	display: grid; place-items: center; color: var(--text);
	background: rgba(255,255,255,0.9); border: 1px solid var(--border);
	box-shadow: var(--shadow-md);
}
.fs-btn:hover { color: var(--magenta); border-color: var(--magenta); transform: translateY(-50%) scale(1.06); }
.fs-prev { left: var(--space-4); }
.fs-next { right: var(--space-4); }

/* dots */
.fs-dots { display: flex; gap: var(--space-2); justify-content: center; margin-top: var(--space-6); }
.fs-dots button { width: 10px; height: 10px; border-radius: 50%; background: var(--border-glow); border: none; transition: all var(--transition); }
.fs-dots button.is-selected { background: linear-gradient(100deg, var(--magenta), var(--cyan)); width: 26px; border-radius: var(--radius-full); }

@media (max-width: 860px) {
	.fs-slide { grid-template-columns: 1fr; }
	.fs-photo { padding: var(--space-3); }
	.fs-photo img { max-height: 400px; }
	.fs-caption { text-align: center; align-items: center; padding-block: var(--space-8); }
	.fs-btn { width: 40px; height: 40px; }
	.fs-prev { left: var(--space-2); } .fs-next { right: var(--space-2); }
}

/* ---------- Horizontal-scroll safety ---------- */
.feature-slider-section, .marquee, .feature-slider { overflow-x: clip; }
.feature-slider-section .wrap-wide { overflow: visible; }
/* Ensure full-bleed sections never exceed viewport width */
.section, .book-band, .footer, .marquee, .feature-slider-section { max-width: 100vw; }

/* ---------- Mobile button safety (prevent overflow) ---------- */
.ig-fallback .btn { max-width: 100%; }
@media (max-width: 600px) {
	.btn {
		white-space: normal;            /* allow wrap instead of overflowing */
		max-width: 100%;
		padding-inline: var(--space-5);
		text-align: center;
		line-height: 1.2;
	}
	.ig-fallback .btn { width: auto; }
}
