/* ============================================================
   Provn Campaign — Public Site Styles
   Uses CSS custom properties injected per campaign:
     --provn-header-bg, --provn-header-text, --provn-accent,
     --provn-body-bg,   --provn-body-text
   ============================================================ */

/* ── Reset / base ──────────────────────────────────────────── */
.provn-campaign *,
.provn-campaign *::before,
.provn-campaign *::after { box-sizing: border-box; }

.provn-campaign {
	font-family: system-ui, -apple-system, sans-serif;
	color: var(--provn-body-text);
	background: var(--provn-body-bg);
	line-height: 1.6;
}

.provn-campaign img { max-width: 100%; height: auto; display: block; }
.provn-campaign ul  { list-style: none; margin: 0; padding: 0; }

/* ── Section colour bands ───────────────────────────────────── */
/* Backgrounds are assigned by position (light/tint alternating), not by
   section identity — so reordering sections never breaks the colour flow. */
.provn-section--light { background: #ffffff; }
.provn-section--tint  { background: var(--provn-body-bg, #f4f6fb); }
.provn-campaign a   { color: var(--provn-accent); }
.provn-campaign a:focus-visible { outline: 3px solid var(--provn-accent); outline-offset: 2px; }

/* ── Skip link ─────────────────────────────────────────────── */
.provn-skip-link {
	position: absolute; left: -9999px; top: auto;
	width: 1px; height: 1px; overflow: hidden;
}
.provn-skip-link:focus {
	position: fixed; top: 0; left: 0; z-index: 9999;
	width: auto; height: auto; padding: 8px 16px;
	background: var(--provn-header-bg); color: var(--provn-header-text);
	font-weight: 700; text-decoration: none;
}

/* ── Layout util ───────────────────────────────────────────── */
.provn-section-inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 44px 24px 64px;
}
.provn-section-title {
	font-size:     2rem;
	font-weight:   700;
	margin:        0 0 32px;
	color:         var(--provn-header-bg);
	padding-bottom: 12px;
	border-bottom:  3px solid var(--provn-accent);
	display:        inline-block;
}
.provn-see-more  { text-align: center; margin-top: 24px; }

/* Compact preview strips (home-page "next events" / "latest news") get tighter
   padding than full sections — they're a short teaser, not a destination page. */
.provn-events-preview .provn-section-inner,
.provn-news-preview .provn-section-inner { padding: 32px 24px; }
.provn-empty     { color: #666; font-style: italic; }
.provn-paid-for-by { font-size: 0.75rem; color: #888; margin-top: 16px; }

/* ── Buttons ───────────────────────────────────────────────── */
.provn-btn {
	display: inline-block; padding: 12px 28px;
	border-radius: 4px; font-weight: 700; text-decoration: none;
	cursor: pointer; border: 2px solid transparent;
	transition: opacity .15s, box-shadow .15s;
	font-size: 1rem; line-height: 1;
}
.provn-btn:focus-visible { outline: 3px solid var(--provn-accent); outline-offset: 3px; }
.provn-btn--primary {
	background: var(--provn-header-bg); color: var(--provn-header-text);
	border-color: var(--provn-header-bg);
}
.provn-btn--primary:hover  { opacity: .88; }
.provn-btn--secondary {
	background: transparent; color: var(--provn-accent);
	border-color: var(--provn-accent);
}
.provn-btn--secondary:hover { background: var(--provn-accent); color: #fff; }
/* Hero buttons — white outline + white text; solid white + main colour on hover */
.provn-btn--hero {
	background: transparent; color: #fff;
	border-color: #fff;
}
.provn-btn--hero:hover,
.provn-btn--hero:focus-visible {
	background: #fff; color: var(--provn-header-bg);
	outline: none;
}
.provn-btn--donate,
a.provn-btn--donate {
	background: var(--provn-accent); color: #fff !important;
	border-color: var(--provn-accent);
}
.provn-btn--donate:hover,
a.provn-btn--donate:hover { opacity: .88; }
.provn-btn--large  { padding: 16px 40px; font-size: 1.15rem; }
.provn-btn--small  { padding: 6px 14px; font-size: 0.85rem; }

/* ── Front-end admin bar ────────────────────────────────────── */
.provn-admin-bar {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	height:          40px;
	padding:         0 1.25rem;
	background:      #1a237e;
	color:           #fff;
	font-size:       0.8rem;
	gap:             1rem;
	position:        sticky;
	top:             0;
	z-index:         101;
}
.admin-bar .provn-admin-bar { top: 32px; }
@media (max-width: 782px) {
	.admin-bar .provn-admin-bar { top: 46px; }
}
.provn-admin-bar__context {
	font-weight: 600;
	white-space: nowrap;
	overflow:    hidden;
	text-overflow: ellipsis;
}
.provn-admin-bar__links {
	display:     flex;
	align-items: center;
	gap:         0.25rem;
	flex-shrink: 0;
}
.provn-admin-bar__link {
	color:           rgba(255,255,255,0.85);
	text-decoration: none;
	padding:         0 0.65rem;
	height:          40px;
	line-height:     40px;
	display:         inline-block;
	transition:      background 0.15s, color 0.15s;
	border-radius:   0;
}
.provn-admin-bar__link:hover {
	background: rgba(255,255,255,0.12);
	color:      #fff;
}
.provn-admin-bar__link--dashboard {
	background:    rgba(200,169,81,0.25);
	color:         #c8a951;
	font-weight:   600;
	margin-left:   0.5rem;
	border-radius: 3px;
}
.provn-admin-bar__link--dashboard:hover {
	background: rgba(200,169,81,0.4);
	color:      #e8c96a;
}
@media (max-width: 600px) {
	.provn-admin-bar__context { display: none; }
	.provn-admin-bar          { justify-content: flex-end; }
}

/* ── Navigation ────────────────────────────────────────────── */
.provn-nav {
	position: sticky; top: 0; z-index: 100;
	background: var(--provn-header-bg); color: var(--provn-header-text);
	box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
/* When WP admin bar is visible, push nav below it */
.admin-bar .provn-nav { top: 32px; }
@media (max-width: 782px) {
	.admin-bar .provn-nav { top: 46px; }
}
/* When Provn admin bar is visible, push sticky nav below it */
.provn-campaign--has-admin-bar .provn-nav { top: 40px; }
.admin-bar .provn-campaign--has-admin-bar .provn-nav { top: 72px; }  /* 32 + 40 */
@media (max-width: 782px) {
	.admin-bar .provn-campaign--has-admin-bar .provn-nav { top: 86px; } /* 46 + 40 */
}
.provn-nav__inner {
	max-width: 1100px; margin: 0 auto;
	display: flex; align-items: center; justify-content: space-between;
	padding: 0 24px; height: 64px;
}
.provn-nav__logo {
	color: var(--provn-header-text); text-decoration: none;
	font-weight: 700; font-size: 1.1rem; display: flex; align-items: center; gap: 8px;
	margin-right: 32px;
}
.provn-nav__logo img { height: 40px; width: auto; }
.provn-nav__list {
	display: flex; gap: 4px; align-items: center;
}
.provn-nav__link {
	color: var(--provn-header-text); text-decoration: none;
	padding: 8px 12px; border-radius: 4px; font-size: .9rem;
	transition: background .15s;
}
.provn-nav__link:hover,
.provn-nav__link:focus-visible {
	background: rgba(255,255,255,.15);
}
.provn-nav__link--active {
	background: rgba(255,255,255,.2);
}
.provn-nav__link--dashboard {
	margin-left: auto;
	background: rgba(200,169,81,0.2);
	color: var(--provn-header-text);
	font-weight: 700;
	border: 1px solid rgba(200,169,81,0.5);
	border-radius: 3px;
	padding: 6px 14px;
}
.provn-nav__link--dashboard:hover {
	background: rgba(200,169,81,0.35);
}
.provn-nav__toggle {
	display: none; background: none; border: none;
	color: var(--provn-header-text); font-size: 1.5rem;
	cursor: pointer; padding: 8px;
}

@media (max-width: 768px) {
	.provn-nav__toggle { display: block; }
	.provn-nav__list {
		display: none; position: absolute; top: 64px; left: 0; right: 0;
		flex-direction: column; align-items: stretch;
		background: var(--provn-header-bg); padding: 8px 0;
		box-shadow: 0 4px 8px rgba(0,0,0,.2);
	}
	.provn-nav__list.provn-nav--open { display: flex; }
	.provn-nav__link { padding: 12px 24px; border-radius: 0; }
}

/* ── Hero ──────────────────────────────────────────────────── */
/* Full-width band in header colour — fills gaps left/right of image on wide screens */
.provn-hero-wrap {
	background: var(--provn-header-bg);
	width: 100%;
}
.provn-hero {
	position: relative; overflow: hidden;
	max-width: 1100px; margin: 0 auto;
	min-height: 500px; display: flex; align-items: flex-end;
	color: #fff;
}
/* Image fills the hero box, clipped to content width */
.provn-hero__bg {
	position: absolute; inset: 0; z-index: 0;
}
.provn-hero__bg img {
	width: 100%; height: 100%; object-fit: cover; object-position: center 30%;
	display: block;
}
/* Two-layer scrim — darkens left/bottom where text sits */
.provn-hero__bg::after {
	content: ''; position: absolute; inset: 0;
	background:
		linear-gradient(
			to right,
			rgba(0,0,0,.65) 0%,
			rgba(0,0,0,.45) 50%,
			rgba(0,0,0,.05) 100%
		),
		linear-gradient(
			to bottom,
			rgba(0,0,0,.05) 0%,
			rgba(0,0,0,.25) 50%,
			rgba(0,0,0,.6) 100%
		);
}
/* No-image fallback */
.provn-hero--no-image {
	background: var(--provn-header-bg);
	min-height: 360px;
}
.provn-hero__content {
	position: relative; z-index: 1;
	width: 100%;
	padding: 60px 24px 56px;
	display: flex; flex-direction: column; gap: 14px;
}
.provn-hero__content--with-hs {
	flex-direction: row;
	align-items: flex-end;
	gap: 40px;
}
.provn-hero__text {
	display: flex; flex-direction: column; gap: 14px;
	flex: 1; min-width: 0;
}
.provn-hero__hs-wrap {
	flex-shrink: 0;
	align-self: flex-end;
	width: 220px;
}
.provn-hero__hs {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 8px 8px 0 0;
	object-fit: cover;
	object-position: center top;
	filter: drop-shadow(0 4px 16px rgba(0,0,0,.4));
}
.provn-hero__eyebrow {
	font-size: .9rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
	color: rgba(255,255,255,.8); margin: 0;
	border-bottom: 2px solid var(--provn-accent);
	display: inline-block; padding-bottom: 4px; align-self: flex-start;
}
.provn-hero__name    { font-size: 3rem; font-weight: 800; margin: 0; line-height: 1.05; color: #fff; }
.provn-hero__slogan  { font-size: 1.25rem; font-weight: 400; margin: 0; color: rgba(255,255,255,.9); }
.provn-hero__speech  { margin: 0; color: rgba(255,255,255,.85); font-size: 1.05rem; max-width: 580px; }
.provn-hero__logo    { display: block; max-height: 200px; width: auto; max-width: unset; align-self: flex-start; }
.provn-hero__ctas    { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }

@media (max-width: 768px) {
	.provn-hero { min-height: 380px; }
	.provn-hero__name  { font-size: 2rem; }
	.provn-hero__slogan { font-size: 1.1rem; }
	.provn-hero__content { padding: 40px 20px 44px; }
	.provn-hero__content--with-hs { flex-direction: column-reverse; gap: 20px; }
	.provn-hero__hs-wrap { width: 140px; align-self: center; }
}

/* ── Platform preview / full ───────────────────────────────── */

/* Scroll offset — all section anchors need clearance for the 64px sticky nav.
   admin-bar adds another 32px (desktop) or 46px (mobile). */
#provn-home,
#provn-bio,
#provn-platform,
#provn-donate,
#provn-events,
#provn-news,
#provn-endorsements,
#provn-get-involved {
	scroll-margin-top: 72px; /* 64px nav + 8px breathing room */
}
.admin-bar #provn-home,
.admin-bar #provn-bio,
.admin-bar #provn-platform,
.admin-bar #provn-donate,
.admin-bar #provn-events,
.admin-bar #provn-news,
.admin-bar #provn-endorsements,
.admin-bar #provn-get-involved {
	scroll-margin-top: 104px; /* 64px nav + 32px admin bar + 8px breathing room */
}
@media (max-width: 782px) {
	.admin-bar #provn-home,
	.admin-bar #provn-bio,
	.admin-bar #provn-platform,
	.admin-bar #provn-donate,
	.admin-bar #provn-events,
	.admin-bar #provn-news,
	.admin-bar #provn-endorsements,
	.admin-bar #provn-get-involved {
		scroll-margin-top: 118px; /* 64px nav + 46px admin bar + 8px breathing room */
	}
}

.provn-platform-preview { background: var(--provn-body-bg); } /* multi-page preview strip */

.provn-platform-freeform { max-width: 720px; margin: 0 auto; font-size: 1rem; line-height: 1.75; color: #333; }
.provn-platform-freeform p { margin: 0 0 1.25em; }
.provn-platform-freeform p:last-child { margin-bottom: 0; }

.provn-platform-grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 24px;
}
.provn-platform-card {
	background: #fff; border: 1px solid #e0e0e0; border-radius: 8px;
	padding: 24px; border-left: 4px solid var(--provn-accent);
}
.provn-platform-card__title   { font-size: 1.15rem; font-weight: 700; margin: 0 0 10px; color: var(--provn-header-bg); }
.provn-platform-card__details { list-style: disc; padding-left: 20px; margin: 0; color: #444; }
.provn-platform-card__details li { margin-bottom: 6px; }

/* ── Events ────────────────────────────────────────────────── */
.provn-events { /* background set by .provn-section--light/tint band */ }

.provn-event-card {
	display: flex; gap: 20px; padding: 20px 0;
	border-bottom: 1px solid #e0e0e0; align-items: flex-start;
}
.provn-event-card__img {
	width: 120px; height: 90px; object-fit: cover;
	border-radius: 6px; flex-shrink: 0;
}
.provn-event-card__img--full { width: 220px; height: 165px; }
.provn-event-card__img-spacer { width: 120px; flex-shrink: 0; }
.provn-event-card__img-spacer--full { width: 220px; }
.provn-event-card__body { min-width: 0; }
.provn-event-card__name  { margin: 0 0 4px; font-size: 1.1rem; }
.provn-event-card__name a { color: var(--provn-header-bg); text-decoration: none; }
.provn-event-card__name a:hover { text-decoration: underline; }
@media (max-width: 560px) {
	.provn-event-card { flex-direction: column; }
	.provn-event-card__img,
	.provn-event-card__img--full { width: 100%; height: 180px; }
	.provn-event-card__img-spacer,
	.provn-event-card__img-spacer--full { display: none; }
}
.provn-event-card__dt,
.provn-event-card__location { margin: 0 0 4px; font-size: .9rem; color: #555; }
.provn-event-card__desc  { margin: 8px 0; }

.provn-event-list li:last-child .provn-event-card { border-bottom: none; }

/* ── Single event ──────────────────────────────────────────── */
.provn-event-single__inner { max-width: 760px; }
.provn-event-single__back  { margin: 0 0 20px; }
.provn-event-single__back a{ color: var(--provn-header-bg); text-decoration: none; }
.provn-event-single__back a:hover { text-decoration: underline; }
.provn-event-single__title { margin: 0 0 8px; font-size: 2rem; }
.provn-event-single__dt    { font-size: 1rem; color: #555; margin: 0 0 4px; }
.provn-event-single__location { font-size: .95rem; color: #777; margin: 0 0 20px; }
.provn-event-single__img   { width: 100%; border-radius: 6px; margin: 0 0 24px; display: block; }
.provn-event-single__desc  { color: #333; line-height: 1.7; margin: 0 0 16px; }
.provn-event-single__capacity { color: #666; font-size: .9rem; margin: 0 0 20px; }

/* ── Donate strip ──────────────────────────────────────────── */
.provn-donate-strip { background: var(--provn-header-bg); color: var(--provn-header-text); }
.provn-donate-strip--amounts {
	padding: 32px 0;
}
.provn-donate-strip--amounts .provn-donate__body { text-align: center; }
.provn-donate-strip--amounts .provn-donate__amounts { margin-left: auto; margin-right: auto; }
.provn-donate-strip .provn-section-title { color: var(--provn-header-text); }
.provn-donate-strip--split .provn-donate__heading,
.provn-donate-strip--split .provn-donate__text { color: var(--provn-header-text); }

/* ── Donate section ────────────────────────────────────────── */
.provn-donate { /* background set by .provn-section--light/tint band */ }
.provn-donate__body { margin-top: 16px; }
.provn-section-inner .provn-donate__body { text-align: center; }
.provn-donate__heading { font-size: 1.7rem; font-weight: 800; margin: 0 0 12px; }
.provn-donate__text { font-size: 1.1rem; margin: 0 0 24px; color: #444; }
.provn-donate-strip .provn-donate__text { color: inherit; opacity: .92; }

/* ── Split-pane layout (Donate / Get Involved with an image) ── */
.provn-split-pane {
	display:               grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	align-items:           stretch;
	min-height:            420px;
}
.provn-split-pane--image-right { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
.provn-split-pane--image-right .provn-split-pane__image { order: 2; }
.provn-split-pane--image-right .provn-split-pane__content { order: 1; }
.provn-split-pane__image { position: relative; overflow: hidden; min-height: 280px; }
.provn-split-pane__content {
	display:         flex;
	flex-direction:  column;
	justify-content: center;
	padding:         48px 56px;
}
.provn-split-pane .provn-donate__body,
.provn-split-pane .provn-get-involved__intro { text-align: left; }
@media (max-width: 768px) {
	.provn-split-pane,
	.provn-split-pane--image-right { grid-template-columns: 1fr; min-height: 0; }
	.provn-split-pane--image-right .provn-split-pane__image,
	.provn-split-pane--image-right .provn-split-pane__content { order: initial; }
	.provn-split-pane__image { min-height: 220px; }
	.provn-split-pane__content { padding: 32px 24px; }
}
.provn-donate__amounts {
	display:               grid;
	grid-template-columns: repeat(3, minmax(120px, 160px));
	gap:                   12px;
	justify-content:       center;
	max-width:             560px;
	margin:                0 auto;
}
.provn-donate__amount-btn {
	display:         flex;
	align-items:     center;
	justify-content: center;
	gap:             2px;
	padding:         18px 12px;
	font-size:       1.3rem;
	font-weight:     700;
	color:           #fff !important;
	background:      var(--provn-accent);
	border-radius:   8px;
	text-decoration: none;
	transition:      opacity .15s ease;
}
.provn-donate__amount-btn:hover { opacity: .88; }
.provn-donate__amount-sign { font-size: 0.9rem; font-weight: 600; align-self: flex-start; margin-top: 4px; }
.provn-donate__amount-btn--other { font-size: 0.95rem; text-transform: uppercase; letter-spacing: .02em; }
@media (max-width: 560px) {
	.provn-donate__amounts { grid-template-columns: repeat(2, minmax(110px, 1fr)); }
}

/* ── Endorsements strip ────────────────────────────────────── */
.provn-endorsements-strip { background: #f8f8f8; }
.provn-endorsements-strip__list {
	display: flex; gap: 24px; flex-wrap: wrap; justify-content: center;
}
.provn-endorsements-strip__item {
	display: flex; flex-direction: column; align-items: center; gap: 8px;
	max-width: 140px; text-align: center;
}
.provn-endorsements-strip__img  { width: 60px; height: 60px; object-fit: cover; border-radius: 50%; }
.provn-endorsements-strip__name { font-weight: 700; font-size: .9rem; }
.provn-endorsements-strip__title{ font-size: .8rem; color: #666; }

/* ── Full endorsements ─────────────────────────────────────── */
.provn-endorsements { /* background set by .provn-section--light/tint band */ }
.provn-endorsement-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }
.provn-endorsement-card {
	background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; padding: 24px;
	display: flex; gap: 16px; align-items: flex-start;
}
.provn-endorsement-card__img     { width: 64px; height: 64px; object-fit: cover; border-radius: 50%; flex-shrink: 0; }
.provn-endorsement-card__name    { margin: 0 0 4px; }
.provn-endorsement-card__title   { font-size: .85rem; color: #666; margin: 0 0 8px; }
.provn-endorsement-card__quote   { font-style: italic; margin: 0; border-left: 3px solid var(--provn-accent); padding-left: 12px; }

/* ── Bio ───────────────────────────────────────────────────── */
.provn-bio { /* background set by .provn-section--light/tint band */ }

.provn-bio__single {
	overflow: hidden; /* clear the float */
}
.provn-bio__headshot {
	float:         left;
	width:         42%;
	max-width:     440px;
	margin:        0 48px 32px 0;
	border-radius: 10px;
	box-shadow:    0 4px 20px rgba(0,0,0,0.12);
	overflow:      hidden;
}
.provn-bio__headshot img {
	display: block;
	width:   100%;
	height:  auto;
}
.provn-bio__name {
	font-size:   1.75rem;
	font-weight: 700;
	margin:      0 0 6px;
	color:       var(--provn-header-bg);
}
.provn-bio__role {
	font-size:     0.95rem;
	color:         var(--provn-accent);
	font-weight:   600;
	margin:        0 0 16px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.provn-bio__text {
	line-height: 1.75;
	color:       #333;
	font-size:   1rem;
}
.provn-bio__text p { margin: 0 0 1em; }
.provn-bio__text p:last-child { margin-bottom: 0; }
.provn-bio__text ul { list-style: disc; padding-left: 1.5em; margin: 0 0 1em; }
.provn-bio__text ol { list-style: decimal; padding-left: 1.5em; margin: 0 0 1em; }
.provn-bio__text li { margin-bottom: 0.4em; }

/* Gallery — full-width row below the two-column */
.provn-bio__gallery {
	display:               grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap:                   16px;
	margin-top:            40px;
}
.provn-bio__gallery-img {
	position:      relative;
	width:         100%;
	aspect-ratio:  4 / 3;
	object-fit:    cover;
	border-radius: 8px;
	box-shadow:    0 2px 8px rgba(0,0,0,0.10);
	overflow:      hidden;
}

/* Slate (multi-candidate) */
.provn-bio__slate { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 32px; }
.provn-candidate-card { text-align: center; }
.provn-candidate-card__headshot { position: relative; overflow: hidden; width: 160px; height: 200px; object-fit: cover; border-radius: 8px; margin: 0 auto 16px; }
.provn-candidate-card__name     { font-size: 1.2rem; font-weight: 700; margin: 0 0 12px; }
.provn-candidate-card__bio      { font-size: .95rem; color: #444; text-align: left; }

@media (max-width: 600px) {
	.provn-bio__headshot { float: none; width: 100%; margin: 0 0 20px; }
}

/* ── News ──────────────────────────────────────────────────── */
.provn-news { /* background set by .provn-section--light/tint band */ }

.provn-news-table {
	border: 1px solid #e0e0e0;
	border-radius: 6px;
	overflow: hidden;
	background: #fff;
}
.provn-news-table__head {
	display: flex;
	background: var(--provn-header-bg);
	color: var(--provn-header-text);
	padding: 14px 20px;
	font-size: .8rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.provn-news-table__head-date     { width: 90px; flex-shrink: 0; }
.provn-news-table__row {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	padding: 20px;
	border-bottom: 1px solid #ececec;
	text-decoration: none;
	color: inherit;
}
.provn-news-table__row:last-child { border-bottom: none; }
.provn-news-table__row:hover      { background: #f7f8fb; }
.provn-news-date-badge {
	flex-shrink: 0;
	width: 70px;
	background: var(--provn-header-bg);
	color: #fff;
	border-radius: 4px;
	text-align: center;
	padding: 8px 4px;
	display: flex;
	flex-direction: column;
	line-height: 1.1;
}
.provn-news-date-badge__day { font-size: 1.6rem; font-weight: 700; }
.provn-news-date-badge__mon { font-size: .7rem; font-weight: 700; color: var(--provn-accent); letter-spacing: .04em; }
.provn-news-date-badge__yr  { font-size: .7rem; opacity: .85; }
.provn-news-table__content  { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.provn-news-table__headline { font-size: 1.1rem; font-weight: 700; color: var(--provn-header-bg); }
.provn-news-table__row:hover .provn-news-table__headline { text-decoration: underline; }
.provn-news-table__excerpt  { color: #555; font-size: .95rem; }

/* ── Single news article ───────────────────────────────────── */
.provn-news-article__inner { max-width: 760px; }
.provn-news-article__back  { margin: 0 0 20px; }
.provn-news-article__back a{ color: var(--provn-header-bg); text-decoration: none; }
.provn-news-article__back a:hover { text-decoration: underline; }
.provn-news-article__title { margin: 0 0 8px; font-size: 2rem; }
.provn-news-article__date  { font-size: .9rem; color: #888; margin: 0 0 24px; }
.provn-news-article__img-wrap {
	float:         left;
	width:         50%;
	max-width:     520px;
	margin:        0 36px 24px 0;
	border-radius: 8px;
	overflow:      hidden;
	aspect-ratio:  4 / 3;
}
.provn-news-article__img {
	display: block;
	width:   100%;
	height:  auto;
}
.provn-news-article__body { overflow: visible; }
@media (max-width: 600px) {
	.provn-news-article__img-wrap { float: none; width: 100%; max-width: none; margin: 0 0 20px; }
}
.provn-news-article__body  { color: #333; line-height: 1.7; }
.provn-news-article__body h2, .provn-news-article__body h3 { margin: 1.5em 0 .5em; }
.provn-news-article__body p { margin: 0 0 1em; }

/* ── Get Involved form ─────────────────────────────────────── */
.provn-get-involved { background: var(--provn-header-bg); color: var(--provn-header-text); }
.provn-get-involved .provn-section-title { color: var(--provn-header-text); }
.provn-get-involved__intro  { margin: -16px 0 32px; opacity: .9; font-size: 1.05rem; }

/* Added only when the immediately preceding section also uses the header-bg
   color, so two same-colored sections don't visually merge into one block. */
.provn-section--bg-boundary { border-top: 1px solid rgba(255,255,255,.18); }

.provn-gi-form { max-width: 640px; }
.provn-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.provn-form-field { display: flex; flex-direction: column; gap: 6px; }
.provn-form-field label { font-weight: 600; font-size: .95rem; }
.provn-form-field input[type="text"],
.provn-form-field input[type="email"],
.provn-form-field input[type="tel"] {
	padding: 10px 12px; border: 1px solid rgba(255,255,255,.4);
	border-radius: 4px; font-size: 1rem; background: rgba(255,255,255,.1);
	color: var(--provn-header-text); width: 100%;
}
.provn-form-field input:focus {
	outline: 2px solid var(--provn-accent); outline-offset: 1px;
	background: rgba(255,255,255,.2);
}
.provn-form-optional { font-weight: 400; opacity: .75; font-size: .85rem; }

.provn-gi-roles { border: none; padding: 0; margin: 16px 0; }
.provn-gi-roles legend { font-weight: 600; margin-bottom: 12px; }
.provn-gi-roles__grid { display: flex; flex-wrap: wrap; gap: 10px; }
.provn-gi-roles__item { display: flex; align-items: center; gap: 6px; cursor: pointer; font-size: .95rem; }
.provn-gi-roles__item input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; }

.provn-form-error   { background: #fce8e8; color: #8b0000; padding: 10px 14px; border-radius: 4px; margin: 12px 0; font-size: .95rem; }
.provn-form-success { background: rgba(255,255,255,.2); padding: 16px 20px; border-radius: 4px; font-size: 1.05rem; font-weight: 600; }

.provn-gi-form .provn-btn--primary {
	background: var(--provn-accent); border-color: var(--provn-accent);
	color: #fff; margin-top: 16px;
}
.provn-gi-form .provn-btn--primary:hover { opacity: .88; }

.provn-gi-eligibility {
	font-size:   0.78rem;
	color:       rgba(255,255,255,0.75);
	margin:      16px 0 4px;
	line-height: 1.5;
}

@media (max-width: 600px) {
	.provn-form-row { grid-template-columns: 1fr; }
}

/* ── Footer ────────────────────────────────────────────────── */
.provn-footer { background: var(--provn-header-bg); color: var(--provn-header-text); border-top: 3px solid var(--provn-accent); }
.provn-footer__inner { max-width: 1100px; margin: 0 auto; padding: 32px 24px; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.provn-footer__logo   { max-height: 80px; width: auto; max-width: unset; }
.provn-footer__social { display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; }
.provn-footer__social-link {
	color: var(--provn-header-text); text-decoration: none; opacity: .8;
	font-size: .9rem; padding: 4px 8px; border-radius: 3px;
	transition: opacity .15s, background .15s;
}
.provn-footer__social-link:hover { opacity: 1; background: rgba(255,255,255,.1); }
.provn-footer__attribution  { position: relative; width: 100%; align-self: stretch; padding: 4px 0; }
.provn-footer__paid-for-by  { display: block; width: 100%; font-size: .75rem; opacity: .6; margin: 0; text-align: center; }
.provn-footer__powered-by   { position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: .75rem; opacity: .5; }

/* ── Holding page ──────────────────────────────────────────── */
.provn-campaign--holding { min-height: 50vh; display: flex; align-items: center; justify-content: center; }
.provn-holding { text-align: center; padding: 48px 24px; }
.provn-holding__logo    { max-height: 100px; width: auto; margin: 0 auto 24px; }
.provn-holding__message { font-size: 1.3rem; color: var(--provn-body-text); }

/* ── Registration shortcode ────────────────────────────────── */
.provn-register { max-width: 480px; margin: 48px auto; padding: 0 16px; }
.provn-register--logged-in { text-align: center; padding: 48px 16px; }

.provn-reg-step { background: #fff; border: 1px solid #ddd; border-radius: 6px; padding: 36px 40px; }

.provn-reg-step__title { font-size: 1.5rem; margin: 0 0 8px; color: #1a1a1a; }
.provn-reg-step__intro { font-size: 1rem; color: #555; margin: 0 0 24px; }

.provn-reg-error { background: #fdf0f0; border: 1px solid #e0b0b0; border-radius: 4px; padding: 12px 16px; margin-bottom: 20px; color: #8b0000; font-size: .9rem; }
.provn-reg-error p { margin: 4px 0; }

.provn-reg-field { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.provn-reg-field label { font-size: .9rem; font-weight: 600; color: #333; }
.provn-reg-field__hint { font-size: .8rem; color: #777; }
.provn-reg-field input { border: 1px solid #ccc; border-radius: 4px; padding: 9px 12px; font-size: 1rem; }
.provn-reg-field input:focus { border-color: #1a3a5c; outline: none; box-shadow: 0 0 0 2px rgba(26,58,92,.2); }

.provn-reg-btn {
	display: inline-block; background: #1a3a5c; color: #fff; border: none; border-radius: 4px;
	padding: 11px 22px; font-size: 1rem; font-weight: 600; cursor: pointer;
	text-decoration: none; margin-top: 8px;
	transition: background .15s;
}
.provn-reg-btn:hover { background: #12294a; color: #fff; }

.provn-reg-required-note { font-size: .8rem; color: #777; margin-top: 4px; }
.provn-reg-login-link {
	margin-top: 1.25rem;
	text-align: center;
	font-size:  0.875rem;
	color:      #666;
}
.provn-reg-login-link a { color: #1a237e; text-decoration: underline; }
.provn-reg-login-link a:hover { color: #283593; }

.provn-reg-step--check-email,
.provn-reg-step--welcome { text-align: center; }

.provn-reg-icon { font-size: 3rem; margin-bottom: 16px; }
.provn-reg-icon--success { color: #2e7d32; }

.provn-reg-note { font-size: .85rem; color: #777; margin-top: 24px; }
.provn-reg-note a { color: #1a3a5c; }

.provn-reg-remember { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; font-size: .9rem; }

@media (max-width: 520px) {
	.provn-reg-step { padding: 24px 20px; }
}

/* ── Login shortcode ───────────────────────────────────────── */
.provn-login { max-width: 420px; margin: 48px auto; padding: 0 16px; }
.provn-login__form { background: #fff; border: 1px solid #ddd; border-radius: 6px; padding: 36px 40px; }
.provn-login__error { background: #fdf0f0; border: 1px solid #e0b0b0; border-radius: 4px; padding: 12px 16px; margin-bottom: 20px; color: #8b0000; font-size: .9rem; }
.provn-login__field { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.provn-login__field label { font-size: .9rem; font-weight: 600; color: #333; }
.provn-login__field input { border: 1px solid #ccc; border-radius: 4px; padding: 9px 12px; font-size: 1rem; }
.provn-login__field input:focus { border-color: #1a3a5c; outline: none; box-shadow: 0 0 0 2px rgba(26,58,92,.2); }
.provn-login__remember { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; font-size: .9rem; }
.provn-login__btn {
	width: 100%; display: block; background: #1a3a5c; color: #fff; border: none;
	border-radius: 4px; padding: 11px 22px; font-size: 1rem; font-weight: 600; cursor: pointer;
	transition: background .15s;
}
.provn-login__btn:hover { background: #12294a; }
.provn-login__reset,
.provn-login__register { font-size: .85rem; text-align: center; margin-top: 12px; }
.provn-login__reset a,
.provn-login__register a { color: #1a3a5c; }

@media (max-width: 460px) {
	.provn-login__form { padding: 24px 20px; }
}

/* ── Password show/hide toggle ──────────────────────────────────────────────── */
.provn-reg-password-wrap { position: relative; display: flex; align-items: center; }
.provn-reg-password-wrap .provn-reg-password-input { flex: 1; padding-right: 44px; }
.provn-reg-password-toggle {
	position: absolute; right: 0; top: 0; bottom: 0;
	width: 40px; background: none; border: none; cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	font-size: 1.1rem; color: #666; padding: 0;
}
.provn-reg-password-toggle:hover { color: #1a3a5c; }
.provn-reg-password-toggle:focus-visible { outline: 2px solid #1a3a5c; border-radius: 0 4px 4px 0; }

/* ── Registration page logo header ──────────────────────────────────────────── */
.provn-reg-header {
	text-align: left;
	padding: 24px 0 8px;
	margin-bottom: 8px;
}
.provn-reg-header__logo img {
	height: 36px;
	width: auto;
	display: inline-block;
}

/* ── Registration landing page ───────────────────────────────────────────── */
.provn-reg-step--landing {
	max-width: 480px;
	margin:    0 auto;
}

.provn-reg-landing__login {
	background:    #ffffff;
	border:        1px solid #e0e4f0;
	border-radius: 6px;
	padding:       2rem;
	margin-bottom: 0;
}

.provn-reg-btn--full {
	display:     block;
	width:       100%;
	text-align:  center;
	margin-top:  1rem;
}

.provn-reg-landing__divider {
	display:     flex;
	align-items: center;
	gap:         1rem;
	margin:      1.25rem 0;
	color:       #aaa;
	font-size:   0.82rem;
}

.provn-reg-landing__divider::before,
.provn-reg-landing__divider::after {
	content:    '';
	flex:       1;
	height:     1px;
	background: #e0e4f0;
}

.provn-reg-landing__invite {
	background:    #f8f9ff;
	border:        1px solid #e0e4f0;
	border-radius: 6px;
	padding:       1.5rem 2rem;
}

.provn-reg-landing__invite-title {
	font-size:   1rem;
	font-weight: 700;
	color:       #1a237e;
	margin:      0 0 0.25rem;
}

.provn-reg-btn--secondary {
	background:  #f0f4ff;
	color:       #1a237e;
	border:      1px solid #c8cfe0;
	margin-top:  0.5rem;
}

.provn-reg-btn--secondary:hover { background: #e0e8ff; }
