/* Font Awesome utility class */
.font-awesome {
  font-family: var(--font-awesome);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

/* Font Awesome with custom weight */
.font-awesome--weight-300 {
  font-family: var(--font-awesome);
  font-weight: 300;
}
.font-awesome--weight-400 {
  font-family: var(--font-awesome);
  font-weight: 400;
}
.font-awesome--weight-700 {
  font-family: var(--font-awesome);
  font-weight: 700;
}
.font-awesome--weight-900 {
  font-family: var(--font-awesome);
  font-weight: 900;
}

/* Font Awesome Duotone utility class */
.font-awesome-duotone {
  font-family: var(--font-awesome-duotone);
  font-weight: 900;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

/* Font Awesome Brands utility class */
.font-awesome-brands {
  font-family: var(--font-awesome-brands);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

/* Example typeface utility classes */
.typeface-serif {
  font-family: var(--serif);
}
.typeface-sans-serif {
  font-family: var(--sans-serif);
}
@media print, screen and (min-width: 48.0625em) {
  .h1,
  h1 {
    font-size: 3rem;
  }
  .h2,
  h2 {
    font-size: 2.25rem;
  }
  .h3,
  h3 {
    font-size: 1.5625rem;
  }
  .intro-text {
    font-size: 1.25rem;
  }
  .small-text {
    font-size: 1rem;
    line-height: 1.4;
  }
}

/* Intro Text */

@media print, screen and (min-width: 48.0625em) {
  .intro-text {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}

.intro-text {
  font-family: var(--sans-serif);
  font-size: 1.125rem;
  font-weight: 200;
  line-height: 1.7;
}
.caption {
  font-family: var(--sans-serif);
  font-size: 1rem;
  font-style: italic;
}

.small-text {
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.3;
}

@media print, screen and (min-width: 64.0625em) {
  .intro-text {
    font-size: 1.4375rem;
  }
}

@media print, screen and (min-width: 64.0625em) {
  .h2,
  h2 {
    font-size: 2.75rem;
  }
}
/* Headings */
h1 {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.375rem;
}
@media print, screen and (min-width: 48.0625em) {
  h1 {
    font-size: 3rem;
    line-height: 1.05;
  }
}
@media print, screen and (min-width: 64.0625em) {
  h1,
  .h1 {
    font-size: 4.75rem;
  }
}

h2 {
  font-family: var(--serif);
  font-size: 1.5625rem;
  font-weight: 600;
  line-height: 1.15;
  margin-bottom: 0;
}
@media print, screen and (min-width: 48.0625em) {
  h2 {
    font-size: 2.25rem;
  }
}
@media print, screen and (min-width: 64.0625em) {
  h2,
  .h2 {
    letter-spacing: -0.03125rem;
    font-size: 2.75rem;
  }
}

h3 {
  font-family: var(--serif);
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.1;
}
@media print, screen and (min-width: 48.0625em) {
  h3 {
    font-size: 1.5625rem;
  }
}

h4 {
  text-transform: uppercase;
  font-family: var(--sans-serif);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.1;
}
@media print, screen and (min-width: 48.0625em) {
  h4 {
    font-size: 1rem;
  }
}

h5 {
  font-family: var(--sans-serif);
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.1;
  text-transform: none;
}

h6 {
  font-family: var(--sans-serif);
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.1;
  text-transform: none;
}

/* Paragraphs */
p,
.typeface-sans-serif {
  font-family: var(--sans-serif);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.625;
}
@media print, screen and (min-width: 64.0625em) {
  p,
  .p {
    font-size: 1.125rem;
  }
}

/* Caption */
.caption {
  font-size: 1rem;
  font-style: italic;
  line-height: 1.25;
  font-family: var(--sans-serif);
}

.photo-wall--set figcaption blockquote {
  margin: 16px 0 0 0;
  padding: 0;
  border-left: none;
  color: var(--white);
  font-style: normal;
}

.photo-wall--set figcaption {
  font-style: normal;
}
figcaption {
  font-size: 1rem;
  font-style: italic;
  line-height: 1.25;
  font-family: var(--sans-serif);
  caption-side: bottom;
  color: var(--gray--dark);
}
/* Eyebrow */
.eyebrow,
.overline {
  font-size: 1rem;
  text-transform: uppercase;
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: 1.4px;
}

/* Small Text */
.small-text {
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.3;
}
@media print, screen and (min-width: 48.0625em) {
  .small-text {
    font-size: 1rem;
    line-height: 1.4;
  }
}

/* Stat */
.stat {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 3.75rem;
  color: var(--secondary--fuchsia);
  line-height: 1;
}
@media print, screen and (min-width: 48.0625em) {
  .stat {
    font-size: 5rem;
    line-height: 0.9;
  }
}
/* Reset list margins and paddings */
ol,
ul,
li {
  margin: 0;
  padding: 0;
}

/* WYSIWYG list items use paragraph typeface */
.wysiwyg li {
  font-family: var(--sans-serif);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.625;
}

/* Ordered List */
ol {
  margin-top: var(--spacing--medium);
  padding-left: 0;
  list-style: none;
  counter-reset: li;
}

ol > li {
  position: relative;
  padding-left: var(--spacing--medium);
  counter-increment: li;
}

ol > li li,
ol > li li:first-child {
  margin-top: var(--spacing--2xsmall);
}

ol > li::before {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  content: counter(li) ".";
  color: var(--text-color);
  font-size: 1rem;
  font-weight: 500;
}

/* Unordered Lists with custom bullet */
.wysiwyg ul > li,
.section--wysiwyg ul > li {
  position: relative;
  padding-left: 1.875rem;
  list-style: none;
}
.wysiwyg ul > li::before,
.section--wysiwyg ul > li::before {
  position: absolute;
  top: -3px;
  left: 0;
  content: url("/themes/custom/holyoke/assets/img/bullet.svg");
}

/* WYSIWYG clearfix and list padding */
.wysiwyg::after {
  content: "";
  display: table;
  clear: both;
}
.wysiwyg ol,
.wysiwyg ul {
  padding-left: var(--spacing--2xsmall);
}

/* Comma-separated list utility */
.list--comma-separate ul {
  display: inline-block;
  margin: 0;
  padding: 0;
  list-style: none;
  font-family: var(--sans-serif);
}
.list--comma-separate li {
  display: inline-block;
}
.list--comma-separate li:not(:last-child) {
  margin-right: 0.25em;
}
.list--comma-separate li:nth-last-child(n + 2):after {
  content: ",";
}

/* Eyebrow utility */
.eyebrow,
.overline {
  font-family: var(--sans-serif);
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.4px;
}

/* Link styles */
a {
  text-decoration: none;
  color: var(--link-color);
}
a:hover {
  text-decoration: underline;
}

/* Emphasis and strong */
em {
  font-style: italic;
}
b,
strong {
  font-weight: 700;
}

/* Blockquote styles */
@media print, screen and (min-width: 48.0625em) {
  blockquote {
    padding-left: 3.125rem;
  }
}
/* Blockquote */
@media print, screen and (min-width: 48.0625em) {
  blockquote {
    margin-top: 2.5rem;
    padding-left: 3.125rem;
  }
}
blockquote {
  clear: both;
  padding-left: 1.875rem;
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
  border-left: 5px solid var(--accent-green);
  position: relative;
  margin: 0 auto;
}
blockquote p {
  font-family: var(--serif);
  font-size: 1.125rem;
  line-height: 1.666;
  font-style: italic;
}
blockquote.align-left,
blockquote.align-right {
  max-width: 27.03125em;
}
@media print, screen and (min-width: 75em) {
  blockquote.align-left {
    float: left;
    border-left: 0;
    border-right: 5px solid var(--accent-green);
    margin-left: -6.25em;
    margin-right: 4.375em;
    padding-right: var(--spacing--large);
    padding-left: 0;
    text-align: right;
  }
  blockquote.align-right {
    float: right;
    margin-left: 4.375em;
  }
}
@media print, screen and (min-width: 64.0625em) {
  blockquote.align-right {
    float: right;
    margin-left: 70px;
  }
}
@media print, screen and (min-width: 64.0625em) {
  blockquote.align-left,
  blockquote.align-right {
    max-width: 432.5px;
  }
}
@media print, screen and (min-width: 48.0625em) {
  blockquote p {
    font-size: 1.875rem;
    line-height: 1.633;
  }
}
[type="text"],
[type="password"],
[type="date"],
[type="datetime"],
[type="datetime-local"],
[type="month"],
[type="week"],
[type="email"],
[type="number"],
[type="search"],
[type="tel"],
[type="time"],
[type="url"],
[type="color"],
[type="file"],
[type="image"],
[type="submit"],
button,
textarea,
select,
fieldset {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  margin: 0;
  border-color: inherit;
  border-radius: 0;
  font-family: var(--sans-serif);
  -webkit-transition:
    color 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97),
    background 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97),
    border 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97);
  transition:
    color 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97),
    background 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97),
    border 0.5s cubic-bezier(0.82, 0.06, 0.14, 0.97);
  border-width: 0.1875rem;
  border-style: solid;
  color: var(--text-color);
  display: inline-block;
  position: relative;
  z-index: 2;
  line-height: 1.1;
  letter-spacing: 0.0625rem;
  text-decoration: none;
  margin-right: 0.3125rem;
  margin-bottom: 0.3125rem;
  text-transform: uppercase;
  font-weight: 500;
  font-size: 0.875rem;
  padding: 0.9375rem 1.875rem 0.85rem;
}
[type="text"],
[type="password"],
[type="date"],
[type="datetime"],
[type="datetime-local"],
[type="month"],
[type="week"],
[type="email"],
[type="number"],
[type="search"],
[type="tel"],
[type="time"],
[type="url"],
[type="color"],
[type="file"],
[type="image"],
textarea {
  border: 1px solid var(--white);
  -webkit-box-shadow: 0 0 0.25rem rgba(0, 0, 0, 0.11);
  box-shadow: 0 0 0.25rem rgba(0, 0, 0, 0.11);
  color: var(--black);
  text-transform: none;
  background: var(--white);
  padding: 1.25rem 1.875rem 1.1875rem;
  margin: 0;
  margin-bottom: 0px;
}
