/*
Theme Name:        ProVN
Theme URI:         https://provn.org
Author:            Colin Cecil
Author URI:        https://provn.org
Description:       Theme for ProVN Platform. Renders all campaign content via [provn_campaign] shortcode. Minimal chrome — header, footer, and single page template only.
Version:           0.4.0
Requires at least: 6.4
Tested up to:      6.7
Requires PHP:      8.1
License:           Proprietary
Text Domain:       provn-campaign
*/

/*
 * All campaign presentation styles are owned by the provn-campaign plugin
 * and injected via CSS custom properties scoped to #provn-campaign-{N}.
 *
 * This stylesheet contains only theme-level chrome: body reset, site header,
 * site footer, and the single-column page layout used for campaign pages.
 */

/* ── Reset / base ─────────────────────────────────────────────────────────── */

*, *::before, *::after {
	box-sizing: border-box;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	padding: 0;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	font-size: 1rem;
	line-height: 1.6;
	color: #1a1a1a;
	background: #fff;
}

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

a {
	color: inherit;
}

/* ── Skip link ────────────────────────────────────────────────────────────── */

.provn-skip-link {
	position: absolute;
	top: -9999px;
	left: 1rem;
	padding: .5rem 1rem;
	background: #161d6b;
	color: #fff;
	font-size: .875rem;
	font-weight: 600;
	border-radius: 0 0 4px 4px;
	z-index: 9999;
	text-decoration: none;
}

.provn-skip-link:focus {
	top: 0;
}

/* ── Site header ──────────────────────────────────────────────────────────── */

/*
 * The site header is intentionally minimal — campaign pages own their own
 * in-page header rendered by the plugin. This header is used only for
 * WP admin bar offset and potential ProVN branding on non-campaign pages.
 */

.provn-site-header {
	display: none; /* hidden by default — campaigns render their own header */
}

/* Show a minimal header on non-campaign pages (404, search, etc.) */
.provn-site-header--visible {
	display: block;
	background: #161d6b;
	padding: 1rem 1.5rem;
}

.provn-site-header__brand {
	color: #fff;
	font-size: 1.125rem;
	font-weight: 700;
	text-decoration: none;
}

.provn-site-header__brand:hover {
	text-decoration: underline;
}

.provn-site-header--visible {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.provn-site-header__nav {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.provn-site-header__nav-link {
	color: #c8a951;
	font-size: .875rem;
	font-weight: 600;
	text-decoration: none;
	letter-spacing: .03em;
}

.provn-site-header__nav-link:hover {
	text-decoration: underline;
	color: #fff;
}

/* ── Main content ─────────────────────────────────────────────────────────── */

#provn-main {
	outline: none; /* skip-link target */
}

/*
 * Campaign pages are full-bleed — no container padding at this level.
 * The plugin's section templates handle their own internal max-width and
 * padding.
 */

.provn-page--campaign {
	padding: 0;
}

/* Non-campaign pages (e.g. 404) get basic centering */
.provn-page--default {
	max-width: 800px;
	margin: 0 auto;
	padding: 2rem 1.5rem;
}

/* ── Site footer ──────────────────────────────────────────────────────────── */

/*
 * Campaign pages render their own paid-for-by footer via the plugin.
 * This site footer is hidden on campaign pages and shown only on
 * WP utility pages.
 */

.provn-site-footer {
	display: none;
}

.provn-site-footer--visible {
	display: block;
	background: #161d6b;
	color: #c8a951;
	text-align: center;
	padding: 1.25rem 1.5rem;
	font-size: .75rem;
}

/* ── WP admin bar offset ──────────────────────────────────────────────────── */

.admin-bar .provn-site-header--visible {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .provn-site-header--visible {
		top: 46px;
	}
}
