/* ============================================================
   VoterFly homepage redesign - hand-written, no build step.
   Loaded on its own; does not depend on saastrend.css.
   ============================================================ */

/* The bundled Font Awesome CSS points at a webfonts folder that does not exist
   relative to its location. Re-declare the @font-face sources against the
   webfonts that do exist at /assets/webfonts/. Loaded after FA, so these win. */
@font-face{ font-family:"Font Awesome 5 Free"; font-style:normal; font-weight:900; font-display:block; src:url("/assets/webfonts/fa-solid-900.woff2") format("woff2"); }
@font-face{ font-family:"Font Awesome 5 Free"; font-style:normal; font-weight:400; font-display:block; src:url("/assets/webfonts/fa-regular-400.woff2") format("woff2"); }
@font-face{ font-family:"Font Awesome 5 Brands"; font-style:normal; font-weight:400; font-display:block; src:url("/assets/webfonts/fa-brands-400.woff2") format("woff2"); }

:root{
	--vf-blue:        #0366D6;
	--vf-blue-deep:   #0079BF;
	--vf-navy:        #0d2540;
	--vf-navy-2:      #123257;
	--vf-green:       #71b72e;
	--vf-ink:         #16202c;
	--vf-slate:       #56657a;
	--vf-line:        #e6ecf2;
	--vf-bg:          #ffffff;
	--vf-bg-soft:     #f5f9fd;
	--vf-radius:      14px;
	--vf-radius-sm:   10px;
	--vf-shadow:      0 18px 40px rgba(13, 37, 64, 0.10);
	--vf-shadow-sm:   0 6px 18px rgba(13, 37, 64, 0.08);
	--vf-maxw:        1160px;
}

*{ box-sizing: border-box; }

html{ scroll-behavior: smooth; }

body{
	margin: 0;
	font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	color: var(--vf-ink);
	background: var(--vf-bg);
	font-size: 17px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4{ font-family: 'Poppins', sans-serif; color: var(--vf-navy); line-height: 1.2; margin: 0 0 .5em; font-weight: 700; }
h1{ font-size: 52px; letter-spacing: -.02em; }
h2{ font-size: 36px; letter-spacing: -.01em; }
h3{ font-size: 21px; }
p{ margin: 0 0 1rem; }
a{ color: var(--vf-blue); text-decoration: none; }
img{ max-width: 100%; height: auto; }

.vf-container{ max-width: var(--vf-maxw); margin: 0 auto; padding: 0 24px; }
.vf-section{ padding: 92px 0; }
.vf-section--tight{ padding: 64px 0; }
.vf-soft{ background: var(--vf-bg-soft); }
.vf-navy{ background: var(--vf-navy); color: #dce6f2; }
.vf-navy h2, .vf-navy h3{ color: #fff; }

.vf-center{ text-align: center; }
.vf-narrow{ max-width: 720px; margin-left: auto; margin-right: auto; }

.vf-eyebrow{
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--vf-blue);
	margin-bottom: 14px;
}
.vf-navy .vf-eyebrow{ color: #7fc1ff; }
.vf-lead{ font-size: 19px; color: var(--vf-slate); }
.vf-navy .vf-lead{ color: #b8c8db; }

/* ---------- Buttons ---------- */
.vf-btn{
	display: inline-flex; align-items: center; gap: 9px;
	font-weight: 600; font-size: 16px;
	padding: 14px 26px; border-radius: 999px;
	border: 1.5px solid transparent; cursor: pointer;
	transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
	white-space: nowrap;
}
.vf-btn:hover{ transform: translateY(-2px); }
.vf-btn-primary{ background: var(--vf-blue); color: #fff; box-shadow: 0 10px 24px rgba(3,102,214,.32); }
.vf-btn-primary:hover{ background: #0356b6; color: #fff; }
.vf-btn-ghost{ background: transparent; color: var(--vf-navy); border-color: var(--vf-line); }
.vf-btn-ghost:hover{ border-color: var(--vf-blue); color: var(--vf-blue); }
.vf-btn-light{ background: #fff; color: var(--vf-navy); }
.vf-btn-light:hover{ background: #eef4fb; color: var(--vf-navy); }
.vf-btn-lg{ padding: 16px 32px; font-size: 17px; }

/* ---------- Header ---------- */
.vf-header{
	position: sticky; top: 0; z-index: 100;
	background: rgba(255,255,255,.86);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--vf-line);
}
.vf-header__inner{ display: flex; align-items: center; justify-content: space-between; height: 74px; }
.vf-header__logo img{ height: 34px; display: block; }
.vf-nav{ display: flex; align-items: center; gap: 30px; }
.vf-nav a.vf-nav__link{ color: var(--vf-ink); font-weight: 500; font-size: 15.5px; }
.vf-nav a.vf-nav__link:hover{ color: var(--vf-blue); }
.vf-header .vf-btn{ padding: 11px 22px; font-size: 15px; }
.vf-menu-toggle{ display: none; background: none; border: 0; font-size: 24px; color: var(--vf-navy); cursor: pointer; }

/* ---------- Hero ---------- */
.vf-hero{ background: linear-gradient(180deg, #ffffff 0%, var(--vf-bg-soft) 100%); overflow: hidden; }
.vf-hero__grid{ display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; padding-top: 84px; padding-bottom: 90px; }
.vf-hero h1 span{ color: var(--vf-blue); }
.vf-hero__cta{ display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.vf-hero__trust{ margin-top: 26px; font-size: 14.5px; color: var(--vf-slate); display: flex; align-items: center; gap: 10px; }
.vf-hero__trust strong{ color: var(--vf-ink); }
.vf-hero__media{ position: relative; }
.vf-hero__media img{ width: 100%; filter: drop-shadow(0 24px 50px rgba(13,37,64,.18)); }

/* ---------- Stat bar ---------- */
.vf-stats{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.vf-stat{ text-align: center; }
.vf-stat__num{ font-size: 44px; font-weight: 700; color: #fff; line-height: 1; letter-spacing: -.02em; }
.vf-stat__num span{ color: var(--vf-green); }
.vf-stat__label{ margin-top: 10px; font-size: 15px; color: #aebfd4; }

/* ---------- Generic card grid ---------- */
.vf-grid-2{ display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
.vf-grid-3{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.vf-card{
	background: #fff; border: 1px solid var(--vf-line); border-radius: var(--vf-radius);
	padding: 32px 30px; box-shadow: var(--vf-shadow-sm); transition: transform .18s ease, box-shadow .18s ease;
}
.vf-card:hover{ transform: translateY(-4px); box-shadow: var(--vf-shadow); }
.vf-card h3{ margin-top: 6px; }
.vf-ico{
	width: 54px; height: 54px; border-radius: 13px; display: inline-flex; align-items: center; justify-content: center;
	font-size: 23px; color: var(--vf-blue); background: rgba(3,102,214,.10); margin-bottom: 6px;
}
.vf-ico--green{ color: var(--vf-green); background: rgba(113,183,46,.12); }

/* ---------- Who it's for ---------- */
.vf-audience{
	display: flex; flex-direction: column; background: #fff; border: 1px solid var(--vf-line);
	border-radius: var(--vf-radius); padding: 36px 34px; box-shadow: var(--vf-shadow-sm); height: 100%; min-width: 0;
}
.vf-audience h3{ display: flex; align-items: center; gap: 12px; }
.vf-audience ul{ list-style: none; padding: 0; margin: 8px 0 26px; }
.vf-audience li{ position: relative; padding-left: 28px; margin-bottom: 11px; color: var(--vf-slate); }
.vf-audience li i{ position: absolute; left: 0; top: 6px; color: var(--vf-green); }
.vf-audience .vf-btn{ margin-top: auto; align-self: flex-start; white-space: normal; }

/* ---------- Steps ---------- */
.vf-steps{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; counter-reset: step; }
.vf-step{ position: relative; padding-top: 8px; }
.vf-step__n{
	width: 46px; height: 46px; border-radius: 50%; background: var(--vf-blue); color: #fff;
	display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 18px; margin-bottom: 16px;
}
.vf-step h3{ font-size: 18px; }

/* ---------- Split feature (nominee) ---------- */
.vf-split{ display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.vf-checklist{ list-style: none; padding: 0; margin: 22px 0 0; }
.vf-checklist li{ position: relative; padding-left: 32px; margin-bottom: 14px; }
.vf-checklist li i{ position: absolute; left: 0; top: 5px; color: var(--vf-green); font-size: 18px; }
.vf-checklist strong{ display: block; color: var(--vf-ink); }
.vf-checklist span{ color: var(--vf-slate); font-size: 15.5px; }

/* ---------- Testimonials ---------- */
.vf-quote{ background: #fff; border: 1px solid var(--vf-line); border-radius: var(--vf-radius); padding: 30px 28px; box-shadow: var(--vf-shadow-sm); }
.vf-quote__stars{ color: #ffb400; margin-bottom: 14px; }
.vf-quote p{ font-size: 16.5px; color: var(--vf-ink); }
.vf-quote__who{ display: flex; align-items: center; gap: 13px; margin-top: 20px; }
.vf-avatar{ width: 46px; height: 46px; border-radius: 50%; background: var(--vf-blue); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; flex-shrink: 0; }
.vf-quote__who b{ display: block; color: var(--vf-navy); }
.vf-quote__who small{ color: var(--vf-slate); }
.vf-placeholder{ outline: 2px dashed #c7d6e6; outline-offset: 4px; }
.vf-placeholder-tag{ display: inline-block; font-size: 11.5px; letter-spacing: 1px; text-transform: uppercase; color: #8aa0b8; background: #eef4fb; padding: 3px 9px; border-radius: 6px; margin-bottom: 12px; }
.vf-quotes{ column-count: 3; column-gap: 26px; }
.vf-quotes .vf-quote{ break-inside: avoid; margin: 0 0 26px; }
.vf-quote p.vf-quote__title{ font-weight: 600; color: var(--vf-navy); margin: 0 0 9px; }
.vf-quotes .vf-quote p{ font-size: 15.5px; line-height: 1.6; }

/* ---------- Case study / results ---------- */
.vf-results{ display: grid; grid-template-columns: .9fr 1.1fr; gap: 50px; align-items: center; }
.vf-results video{ width: 100%; border-radius: var(--vf-radius); box-shadow: var(--vf-shadow); display: block; }
.vf-results__stats{ display: flex; gap: 30px; margin: 18px 0 22px; flex-wrap: wrap; }
.vf-results__stats div b{ font-size: 32px; color: var(--vf-blue); display: block; line-height: 1; }
.vf-results__stats div span{ font-size: 14px; color: var(--vf-slate); }

/* ---------- Product tour ---------- */
.vf-shots{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.vf-shots img{ border-radius: var(--vf-radius); box-shadow: var(--vf-shadow-sm); border: 1px solid var(--vf-line); }

/* ---------- Logos ---------- */
.vf-logos{ display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; }
.vf-logos a{ flex: 0 1 170px; display: flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--vf-line); border-radius: var(--vf-radius); padding: 10px; min-height: 100px; transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease; }
.vf-logos a:hover{ box-shadow: var(--vf-shadow); transform: translateY(-3px); border-color: var(--vf-blue); }
.vf-logos img{ max-height: 78px; max-width: 100%; width: auto; transition: filter .18s ease; }
.vf-logos a:hover img{ filter: saturate(1.12) contrast(1.06); }
.vf-logos .vf-more{ flex: 0 1 170px; display: flex; align-items: center; justify-content: center; min-height: 100px; padding: 10px; border-radius: var(--vf-radius); border: 1px dashed rgba(3,102,214,.45); background: rgba(3,102,214,.05); color: var(--vf-blue); font-weight: 600; font-size: 15px; text-align: center; }

/* ---------- FAQ ---------- */
.vf-faq{ max-width: 820px; margin: 0 auto; }
.vf-faq__item{ border: 1px solid var(--vf-line); border-radius: var(--vf-radius-sm); background: #fff; margin-bottom: 14px; overflow: hidden; }
.vf-faq__q{ width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 20px 24px; font-size: 17px; font-weight: 600; color: var(--vf-navy); display: flex; justify-content: space-between; align-items: center; gap: 16px; font-family: inherit; }
.vf-faq__q i{ transition: transform .2s ease; color: var(--vf-blue); flex: 0 0 auto; }
.vf-faq__item.open .vf-faq__q i{ transform: rotate(45deg); }
.vf-faq__a{ max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.vf-faq__a p{ padding: 0 24px 20px; margin: 0; color: var(--vf-slate); }

/* ---------- Final CTA ---------- */
.vf-cta-band{ background: linear-gradient(135deg, var(--vf-navy) 0%, var(--vf-navy-2) 100%); border-radius: 22px; padding: 60px; text-align: center; }
.vf-cta-band h2{ color: #fff; }
.vf-cta-band .vf-lead{ color: #c4d4e6; }

/* ---------- Contact ---------- */
.vf-form{ max-width: 560px; margin: 0 auto; }
.vf-form label{ display: block; font-weight: 600; font-size: 14px; margin-bottom: 7px; color: var(--vf-navy); }
.vf-form input, .vf-form textarea{ width: 100%; padding: 13px 16px; border: 1px solid var(--vf-line); border-radius: var(--vf-radius-sm); font-family: inherit; font-size: 16px; margin-bottom: 18px; background: #fff; }
.vf-form input:focus, .vf-form textarea:focus{ outline: none; border-color: var(--vf-blue); box-shadow: 0 0 0 3px rgba(3,102,214,.14); }
.vf-form textarea{ min-height: 130px; resize: vertical; }
.vf-hp{ position: absolute; left: -9000px; width: 1px; height: 1px; overflow: hidden; }
.vf-form__ok{ display: none; text-align: center; background: #eafaf0; border: 1px solid #bfe9cf; color: #1c6b3c; padding: 18px; border-radius: var(--vf-radius-sm); }

/* ---------- Footer ---------- */
.vf-footer{ background: #0a1c30; color: #9fb3c8; padding: 64px 0 30px; }
.vf-footer__grid{ display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; }
.vf-footer img{ height: 34px; margin-bottom: 16px; }
.vf-footer h4{ color: #fff; font-size: 15px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.vf-footer ul{ list-style: none; padding: 0; margin: 0; }
.vf-footer li{ margin-bottom: 10px; }
.vf-footer a{ color: #9fb3c8; font-size: 15px; }
.vf-footer a:hover{ color: #fff; }
.vf-footer__bar{ border-top: 1px solid rgba(255,255,255,.10); margin-top: 44px; padding-top: 22px; text-align: center; font-size: 14px; color: #74879c; }

/* ---------- Reveal on scroll (gated behind .vf-js so content stays visible if JS fails) ---------- */
.vf-reveal{ transition: opacity .6s ease, transform .6s ease; }
.vf-js .vf-reveal{ opacity: 0; transform: translateY(22px); }
.vf-js .vf-reveal.is-in{ opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
	h1{ font-size: 40px; } h2{ font-size: 30px; }
	.vf-hero__grid{ grid-template-columns: 1fr; gap: 36px; padding-top: 56px; padding-bottom: 64px; }
	.vf-hero__media{ order: -1; max-width: 460px; }
	.vf-stats{ grid-template-columns: repeat(3, 1fr); gap: 36px 20px; }
	.vf-grid-2, .vf-grid-3, .vf-steps, .vf-split, .vf-results, .vf-shots{ grid-template-columns: 1fr; }
	.vf-audience .vf-btn{ align-self: stretch; justify-content: center; text-align: center; }
	.vf-quotes{ column-count: 2; }
	.vf-shots{ grid-template-columns: repeat(2, 1fr); }
	.vf-results__media{ order: -1; }
	.vf-nav{ display: none; }
	.vf-nav.is-open{ display: flex; position: absolute; top: 74px; left: 0; right: 0; flex-direction: column; gap: 0; background: #fff; border-bottom: 1px solid var(--vf-line); padding: 12px 24px 22px; }
	.vf-nav.is-open a.vf-nav__link{ padding: 12px 0; border-bottom: 1px solid var(--vf-line); }
	.vf-menu-toggle{ display: block; }
	.vf-header .vf-btn{ display: none; }
	.vf-footer__grid{ grid-template-columns: 1fr 1fr; }
	.vf-cta-band{ padding: 44px 26px; }
	.vf-section{ padding: 64px 0; }
}
@media (max-width: 560px){
	h1{ font-size: 33px; } h2{ font-size: 26px; }
	body{ font-size: 16px; }
	.vf-stats{ grid-template-columns: 1fr; }
	.vf-shots{ grid-template-columns: 1fr 1fr; }
	.vf-logos a, .vf-logos .vf-more{ flex-basis: calc(50% - 8px); }
	.vf-footer__grid{ grid-template-columns: 1fr; }
	.vf-quotes{ column-count: 1; }
	.vf-cta-band{ padding: 36px 20px; }
}

/* ---------- Lead-capture landing pages (case studies) ---------- */
.vf-lp-hero{ background: linear-gradient(135deg, var(--vf-navy) 0%, var(--vf-navy-2) 100%); padding: 60px 0 88px; }
.vf-lp-hero .vf-eyebrow{ color: #7fc1ff; }
.vf-lp-hero h1{ color: #fff; }
.vf-lp-hero .vf-lead{ color: #c4d4e6; }
.vf-lp-grid{ display: grid; grid-template-columns: 1.05fr .95fr; gap: 52px; align-items: center; }
.vf-lp-list{ list-style: none; padding: 0; margin: 26px 0 0; }
.vf-lp-list li{ position: relative; padding-left: 32px; margin-bottom: 13px; color: #dce6f2; font-size: 16px; line-height: 1.5; }
.vf-lp-list li i{ position: absolute; left: 0; top: 5px; color: var(--vf-green); font-size: 18px; }
.vf-lp-card{ background: #fff; border-radius: var(--vf-radius); padding: 34px 32px; box-shadow: 0 24px 60px rgba(0,0,0,.28); }
.vf-lp-card h3{ margin-top: 0; }
.vf-lp-sub{ color: var(--vf-slate); margin-bottom: 22px; }
.vf-lp-nospam{ font-size: 13px; color: var(--vf-slate); margin-top: 14px; text-align: center; }
.vf-lp-success{ display: none; text-align: center; }
.vf-lp-check{ font-size: 52px; color: var(--vf-green); }
@media (max-width: 980px){
	.vf-lp-grid{ grid-template-columns: 1fr; gap: 34px; }
	.vf-lp-hero{ padding: 48px 0 64px; }
}

/* ---------- Accessibility: skip link + keyboard focus ---------- */
.vf-skip{ position: absolute; left: 8px; top: -52px; z-index: 200; background: var(--vf-blue); color: #fff; padding: 10px 16px; border-radius: var(--vf-radius-sm); font-weight: 500; transition: top .15s ease; }
.vf-skip:focus{ top: 8px; }
a:focus-visible, button:focus-visible, .vf-btn:focus-visible, .vf-faq__q:focus-visible{ outline: 3px solid rgba(3, 102, 214, 0.55); outline-offset: 2px; }
