/*
 Theme Name:   Bittner WI
 Theme URI:    https://wordpress.org/themes/twentyninteen/
 Description:  Custom theme built for bittner-wi
 Author:       
 Template:     twentynineteen
 Version:      1.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  bittner-wi
*/

/* ========= COLOR REFERENCES ========= */
:root {
  --bg: #f4f4f4;
  --red: #d60812;
  --blue: #0a4486;
  --black: #1a1818;
}

/* ==================================== */

/* ======== TABLE OF CONTENTS =========
	1. TYPOGRAPHY
	2. GLOBAL
	3. MAIN CONTENT
	- 3a. Landing Page
	- 3a. About Page
/* ==================================== */

/* ------------------------------ 
    1. Start Typography
------------------------------ */
h1,
h2,
h3,
h4,
h5,
h6,
a,
ul,
.btn,
button {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizelegibility;
  margin: 0;
}

.d1 {
  font-size: clamp(64px, 8vw, 120px);
  line-height: 1;
}

h1,
.h1 {
  font-size: clamp(44px, 5.5vw, 68px);
  line-height: 1;
}

h2,
.h2 {
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1;
}

h3,
.h3 {
  font-size: 26px;
  line-height: 1.25;
}

h4,
.h4 {
  font-size: 16px;
}

p,
.p {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizelegibility;
  line-height: 2;
  color: var(--black);
}

small {
  font-size: 12px;
  line-height: 1.33;
}

a,
.anchor-theme {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizelegibility;
  text-decoration: none !important;
  transition: none;
  /* color: white; */
  border: none;
  background: none;
}

a:hover,
a:focus,
.anchor-theme:hover,
.anchor-theme:focus {
  font-weight: 700;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

.menu {
  display: flex;
  list-style: none;
}

.menu-item {
  padding: 0 10px;
}

.main-menu-more {
  display: none;
}

.nav-link {
  padding: 0.5rem;
}

nav .current-menu-item a {
  font-weight: 700;
  border-bottom: 2px solid var(--secondary);
}

/* ------------------------------ 
    1. End Typography
------------------------------ */

/* ------------------------------ 
    2. Start Global
------------------------------ */
@-ms-viewport {
  width: device-width;
}

html {
  font-size: 16px;
}

body {
  font-size: 16px;
  /* Adjust this on mobile to globally change P-tags :NOT H-tags) */
  color: var(--gray);
}

header {
  position: absolute;
  z-index: 3;
  width: 100%;
  top: 0;
  left: 0;
}

.ls-100 {
  letter-spacing: 0.1em;
}

.white {
  color: white !important;
}

.red {
  color: var(--red) !important;
}

.blue {
  color: var(--blue) !important;
}

.desktop {
  display: block !important;
}

.mobile {
  display: none !important;
}

.fw-400 {
  font-weight: 400;
  /* Regular */
}

.fw-700 {
  font-weight: 700;
  /* Bold */
}

.italic {
  font-style: italic;
}

.normal {
  font-style: normal;
}

section {
  position: relative;
}

img {
  width: 100%;
}

.bg {
  background: var(--bg);
}

.bg-blue {
  background: var(--blue);
}

.bg-white {
  background: var(--white);
}

button:hover,
button:focus {
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}

button:active {
  background-color: #c10912;
}

/* ------------------------------ 
    2. End Global
------------------------------ */

/* ------------------------------ 
    3. Start Main Content
------------------------------ */
/*  - 3a. Landing Page  */
.page-template-page-home .splash {
  background: url("/wp-content/themes/bittner/assets/images/1_hero_bg.jpg")
    no-repeat center center;
  background-size: cover;
  padding-top: 10%;
  padding-bottom: 5%;
  height: 910px;
}

.page-template-page-lp .splash [alt*="logo"] {
  width: 80%;
  padding-top: 30%;
}

input::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: var(--white);
}

input::-moz-placeholder {
  /* Firefox 19+ */
  color: var(--white);
}

input:-ms-input-placeholder {
  /* IE 10+ */
  color: var(--white);
}

input:-moz-placeholder {
  /* Firefox 18- */
  color: var(--white);
}

.gform_wrapper {
  width: 100%;
  margin: 0 auto;
}

form {
  position: relative;
}

.gform_footer {
  width: fit-content !important;
  position: absolute !important;
  right: 0;
  top: 95px;
}

.gform_confirmation_message {
  color: white;
  text-align: center;
  margin-bottom: 30px;
}

/*  - 3b. About Page  */
.page-template-page-about .splash {
  background: url("/wp-content/uploads/sites/43/2021/12/2_hero.jpg") no-repeat
    center center;
  background-size: cover;
  padding-bottom: 5%;
}

.page-template-page-about h1 {
  padding-top: 30%;
}

.page-template-page-about .splash p {
  width: 70%;
}

.page-template-page-about .splash #signature {
  font-family: adobe-handwriting-ernie, sans-serif;
  font-size: 24px;
}

.page-template-page-about .map {
  background: url("/wp-content/uploads/sites/43/2021/12/map.svg") no-repeat
    center center;
  background-size: cover;
}

.page-template-page-about .body img {
  height: 364px;
  object-fit: cover;
}

/* ------------------------------ 
    3. End Main Content
------------------------------ */

.site-header {
  padding: 8px 12px;
}

.header-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
}

.header-left {
  display: flex;
  justify-content: flex-start;
}

.header-logo {
  display: flex;
  justify-content: center;
}

.header-logo img {
  max-width: 186px;
  height: auto;
  display: block;
}

.header-right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 18px;
}

.header-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
  width: 100%;
}

.header-left {
  justify-self: start;
}

.header-logo {
  justify-self: center;
}

.header-right {
  justify-self: end;
  margin-left: auto;
}

.main-navigation ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 0;
  padding: 0;
}

.main-navigation a {
  color: #353535;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  font-family: "early-sans-variable", sans-serif !important;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  text-decoration: underline;
}

.social-icons {
  display: flex;
  align-items: center;
  gap: 8px;
}

.social-icons a {
  color: #003b73;
  font-size: 17px;
  text-decoration: none;
}

.donate-btn {
  background: #d02c2f;
  color: #fff;
  padding: 8px 32px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  line-height: 1.5;
}

.donate-btn:hover {
  color: #fff;
  background: #c92325;
}

nav .current-menu-item a {
  font-weight: 700;
  border-bottom: 3px solid #d02c2f;
}

.social-icons {
  display: flex;
  align-items: center;
  gap: 8px;
}

.social-icons img {
  width: 24px;
  height: 24px;
  display: block;
}

.early {
  font-family: "early-sans-variable", sans-serif;
}

.dm {
  font-family: "DM Serif Text", serif;
}

.text-blue {
  color: #002e6d;
}

.text-red {
  color: #d02c2f;
}

.f-400 {
  font-weight: 400;
}

.f-500 {
  font-weight: 500;
}

.f-600 {
  font-weight: 600;
}

.f-700 {
  font-weight: 700;
}

.f-800 {
  font-weight: 800;
}

.f-900 {
  font-weight: 900;
}

.h-810 {
  height: 810px;
}

.uppercase {
  text-transform: uppercase;
}

.letter-spacing-50 {
  letter-spacing: 24px;
}

.gform_wrapper.gravity-theme .gform_fields {
  display: grid !important;
  grid-template-columns: 2fr 1fr !important;
  gap: 8px !important;
  align-items: center !important;
}

.gform_wrapper.gravity-theme .gfield--type-name {
  grid-column: 1 !important;
}

.gform_wrapper.gravity-theme .gfield--type-email {
  grid-column: 2 !important;
}

.gform_wrapper.gravity-theme .gfield--type-phone {
  grid-column: 3 / -1 !important;
}

.gform_wrapper.gravity-theme .gfield--type-consent {
  /* grid-column: 1 / -1 !important;
  align-self: start; */
  width: 100%;
}

.gform_wrapper.gravity-theme .gfield--type-consent .ginput_container_consent,
.gform_wrapper .ginput_container_consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  text-align: left;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
}

.gform_wrapper.gravity-theme .gfield--type-consent input[type="checkbox"] {
  flex: 0 0 auto;
  margin-top: 3px;
}

.gform_wrapper.gravity-theme .gfield--type-submit {
  grid-column: 2 / -1 !important;
  width: 40px !important;
}

.gform_wrapper.gravity-theme .ginput_complex {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

.gform_wrapper .gfield_consent_label {
  color: #fff;
  font-size: clamp(11px, 2.5vw, 13px);
  line-height: 1.45;
  font-weight: 400;
  text-align: left;
  flex: 1;
  min-width: 0;
}

.gform_wrapper .gfield_consent_label a {
  color: #fff;
}

.gform_wrapper.gravity-theme .gfield--type-submit .gform-button,
.gform_wrapper.gravity-theme .gfield--type-submit input[type="submit"] {
  width: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  padding: 0 !important;
  border-radius: 50% !important;
}

.gfield:nth-child(2),
.gfield:nth-child(3),
.ginput_container,
.name_first input,
.name_last input {
  margin: 0 !important;
}

.ginput_container_email input {
  width: 100% !important;
  background: rgba(255, 255, 255, 1) !important;
}

.name_first input,
.name_last input,
.ginput_container input {
  color: #353535;
  border: 1px solid var(--tertiary);
  border-radius: 999px !important;
  padding: 8px 16px !important;
  font-family: "Figtree", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  background: rgba(255, 255, 255, 1) !important;
}

.name_first input:hover,
.name_last input:hover,
.ginput_container input:hover,
.name_first input:focus,
.name_last input:focus,
.ginput_container input:focus {
  color: #353535;
  border-radius: 999px !important;
}

.name_first input:active,
.name_last input:active,
.ginput_container input:active,
.name_first input:focus-visible,
.name_last input:focus-visible,
.ginput_container input:focus-visible {
  color: #353535;
  border-radius: 999px !important;

  outline: var(--tertiary) auto 1px;
}

.gform-button {
  height: 38px !important;
  box-sizing: border-box !important;
  border: 1px solid var(--tertiary);
  border-radius: 9999999999px;
  background-color: #002e6d;
  color: white;
  font-family: "early-sans-variable", sans-serif !important;
  font-size: 16px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: 0.5px;
  width: 40px !important;
  height: 40px !important;
}

.btn-primary {
  border: none;
  border-radius: 60px;
  background-color: var(--primary) !important;
  font-family: "early-sans-variable", sans-serif !important;
  font-size: 24px;
  font-style: normal;
  font-weight: 900;
}

.gform_confirmation_message {
  color: white;
  margin-bottom: 20px;
}

.gform_button,
.gform-button {
  font-family: matrix-ii, serif;
  font-weight: 800;
  color: white;
  border: none;
  border-radius: 50px;
  background: #002e6d !important;
  padding: 0 36px;
  max-width: 172px;
  width: 100%;
}

.bg-red {
  background-color: #d02c2f;
}

.form-wrapper {
  padding: 24px 24px;
}

hr.body-hr {
  width: 140px;
  height: 3px;
  background-color: #002e6d;
  border: 0;
  opacity: 1;
}

.fs-20 {
  font-size: 20px;
  line-height: 1.35;
}

.text-gray {
  color: #353535;
}

.bg-light-gray {
  background: #e5e5e5;
}

.work-card {
  position: relative;
  background: #002e6d;
  min-height: 176px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 20px 20px;
  text-align: center;
  width: 306px;
}

.work-card p {
  font-family: "early-sans-variable", sans-serif !important;

  color: white;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
}

.work-check {
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 48px;
  background-color: white;
  border-radius: 999px;
}

.mobile-nav-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.mobile-social-icons {
  display: flex;
  justify-content: center;
  gap: 12px;
}

.mobile-social-icons img {
  width: 24px;
  height: 24px;
}

.mobile-donate-btn {
  display: inline-block !important;
}

.footer-logo {
  display: flex;
  justify-content: center;
}

.footer-logo img {
  max-width: 469px;
  height: auto;
  display: block;
}

.underline {
  text-decoration: underline !important;
}

.meet-splash {
  background-image: url("/wp-content/themes/bittner/assets/images/2_hero_bg.jpg");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  padding-top: 120px;
}

.meet-subtitle {
  color: #fff;
  font-size: 26px;
  line-height: 1.15;
  font-weight: 400;
}

.meet-subtitle span {
  color: #d02c2f;
  padding: 0 12px;
}

.hero-2-fg {
  max-width: 555px;
}

.body-2-img {
  max-height: 366px;
  width: auto;
}

.px-custom-2 {
  padding-top: 120px;
  padding-left: 150px;
  padding-right: 150px;
}

body.page-template-page-meet-barb .main-navigation a {
  color: #fff !important;
}

body.page-template-page-meet-barb .mobile-menu-toggle span {
  background: #fff !important;
}

body.page-template-page-privacypolicy header {
  position: relative;
}

body.page-template-page-terms header {
  position: relative;
}

body.page-template-page-issues .splash {
  overflow-x: hidden;
}

body.page-template-page-issues .splash .issues-hero-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
  margin: 0 auto;
}

body.page-template-page-issues .splash .row {
  --bs-gutter-x: clamp(1rem, 2vw, 2rem);
  row-gap: 1.5rem;
}

body.page-template-page-issues .issues-cards {
  background: #e5e6e6;
}

body.page-template-page-issues .issues-cards .row {
  align-items: stretch;
}

body.page-template-page-issues .issues-cards .row > [class*="col-"] {
  display: flex;
}

body.page-template-page-issues .issue-card {
  display: flex;
  width: 100%;
  height: 100%;
  min-height: 172px;
  background: #f7f7f7;
}

body.page-template-page-issues .issue-card-icon {
  width: 172px;
  background: #292b3f;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

body.page-template-page-issues .issue-card-icon img {
  width: 120px;
  height: 120px;
}

body.page-template-page-issues .issue-card-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

body.page-template-page-issues .issue-card-title {
  background: #d02c2f;
  font-family: "early-sans-variable", sans-serif !important;
  color: #fff;
  font-weight: 700;
  font-size: 20px;
  padding: 18px 24px;
  min-height: 76px;
  display: flex;
  align-items: center;
}

body.page-template-page-issues .issue-card ul {
  list-style: none;
  padding: 18px 24px;
  margin: 0;
  flex: 1;
}

body.page-template-page-issues .issue-card li {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 16px;
  line-height: 1.5;
  font-family: "early-sans-variable", sans-serif !important;
  color: #353535;
  margin-bottom: 8px;
}

body.page-template-page-issues .issue-card li:last-child {
  margin-bottom: 0;
}

body.page-template-page-issues .issue-card li img {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.bg {
  background-color: #e5e6e6;
}

.bg {
  background-color: #e5e6e6;
}

.pt-custom-1 {
  padding-top: 6rem;
}

.join-splash {
  background-image: url("/wp-content/themes/bittner/assets/images/4_hero_bg.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  padding-top: 120px;
}

body.page-template-page-join .join-form-wrap {
  display: grid;
  grid-template-columns: 38% 62%;
  max-width: 1120px;
  margin: 0 auto;
  background: #003b7a;
  position: relative;
  top: -170px;
}

body.page-template-page-join .join-form-callout {
  background: #d9272e;
  color: #fff;
  padding: 14px 28px;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

body.page-template-page-join .join-form-callout h2 {
  font-family: "DM Serif Text", serif;
  font-style: italic;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.05;
  font-weight: 400 !important;
  margin: 0 0 18px;
}

body.page-template-page-join .join-form-callout h3 {
  font-family: "early-sans-variable", sans-serif !important;

  font-size: clamp(42px, 5vw, 70px);
  line-height: 1.03;
  font-weight: 700;
  margin: 0;
}

body.page-template-page-join #gform_wrapper_2 {
  padding: 38px 34px 28px;
}

body.page-template-page-join #gform_wrapper_2 .gform_fields {
  row-gap: 12px;
}

body.page-template-page-join #gform_wrapper_2 input,
body.page-template-page-join #gform_wrapper_2 select,
body.page-template-page-join #gform_wrapper_2 textarea {
  width: 100%;
  border: 0;
  border-radius: 18px;
  background: #e5e6e6 !important;
  min-height: 42px;
  font-size: 16px;
  line-height: 1.5;
  color: #353535;

  padding: 10px 16px;
  font-family: "early-sans-variable", sans-serif !important;
}

body.page-template-page-join #gform_wrapper_2 textarea {
  height: 120px;
  border-radius: 12px;
  color: #353535;
  font-family: "early-sans-variable", sans-serif !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_container_address {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_container_address span {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: unset !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_address_line_1 {
  grid-column: 1 / 3 !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_address_line_2 {
  grid-column: 3 / 5 !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_address_city {
  grid-column: 1 / 3 !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_address_state {
  grid-column: 3 / 4 !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_address_zip {
  grid-column: 4 / 5 !important;
}

body.page-template-page-join #gform_wrapper_2 .gfield_label {
  color: #e5e6e6;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  font-family: "early-sans-variable", sans-serif !important;
}

body.page-template-page-join #gform_wrapper_2 .gfield_checkbox {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px 24px;
}

body.page-template-page-join #gform_wrapper_2 .gchoice {
  display: flex;
  align-items: center;
  gap: 8px;
}

body.page-template-page-join #gform_wrapper_2 .gchoice input {
  width: auto;
  min-height: auto;
  padding: 0;
}

body.page-template-page-join #gform_wrapper_2 .gchoice label {
  color: #e5e6e6;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  font-family: "early-sans-variable", sans-serif !important;
}

body.page-template-page-join #gform_wrapper_2 .gform_footer {
  display: flex;
  justify-content: center;
  padding: 12px 0 0;
  margin: 0;
}

body.page-template-page-join #gform_wrapper_2 .gform_button {
  background: #d9272e !important;
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-width: 360px;
  font-weight: 700;
}

body.page-template-page-join .gform_footer {
  position: relative !important;
  left: 50% !important;
  top: 0px !important;
  transform: translateX(-50%);
}

body.page-template-page-join #gform_wrapper_2 .gfield {
  grid-column: 1 / -1;
}

body.page-template-page-join #gform_wrapper_2 .ginput_container_address {
  width: 100%;
}

.gform_wrapper.gravity-theme .ginput_complex {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_container_address {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
}

body.page-template-page-join #gform_wrapper_2 .ginput_container_address {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
}

div#field_2_6 {
  margin-top: -8px;
}

body.page-template-page-join #gform_wrapper_2 .gfield_checkbox .gchoice label {
  color: rgba(255, 255, 255, 0.55);
  transition: 0.2s ease;
}

body.page-template-page-join
  #gform_wrapper_2
  .gfield_checkbox
  input[type="checkbox"]:checked
  + label {
  color: #fff;
}

body.page-template-page-join
  #gform_wrapper_2
  .gfield_checkbox
  input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 14px !important;
  height: 14px !important;
  min-width: 14px;
  max-width: 14px;
  min-height: 14px !important;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #fff;
  padding: 0 !important;
  margin: 0;
  position: relative;
}

body.page-template-page-join
  #gform_wrapper_2
  .gfield_checkbox
  input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  background: #003b7a;
}

section.join-form-section.bg.pt-5 {
  max-height: 380px;
}

.election-banner {
  width: 100%;
  overflow: hidden;
  background: #002e6d;
  white-space: nowrap;
  padding: 7px 0;
}

.election-banner-track {
  display: flex;
  width: max-content;
  animation: election-scroll 25s linear infinite;
}

.election-banner-item {
  flex: 0 0 auto;
  color: #fff;
  font-size: 20px;
  line-height: 1;
  padding: 0 26px;
  position: relative;
}

.election-banner-item::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 2px;
  height: 16px;
  background: #d9272e;
  transform: translateY(-50%);
}

@keyframes election-scroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

div#gform_confirmation_wrapper_2 {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

ul#mobile-menu a {
  color: white !important;
}
