/*direct edit css*/
.t4Edit-page {
    text-decoration: none !important;
    color: white !important;
}
.t4Edit-page:hover { color: white !important; }

.accent-top-right.accent-flush-right:after { right: 0rem !important; }

/*general content links*/
.wysiwyg-styles *:not([class]) > a:not([class]) {
  text-decoration: underline !important;
  text-decoration-thickness: 2px;
}
.wsywig-styles *:not([class]) > a:not([class]):hover {
  color: #00bed6 !important;
  text-decoration-thickness: 2px;
}
footer .wsywig-styles w*:not([class]) > a:not([class]) { 
  text-decoration-color: white !important;
  text-decoration-thickness: 2px;
}
footer .wsywig-styles *:not([class]) > a:not([class]):hover { 
  text-decoration-color: #00bed6 !important;
  text-decoration-thickness: 2px;
}

/*right column links*/
.usca-main-grid .flex.gap-4.flex-col a.usca-link-reset  {
  text-decoration: underline !important;
  text-decoration-thickness: 2px;
}
.usca-main-grid .flex.gap-4.flex-col a.usca-link-reset:hover {
  color: #00bed6 !important;
  text-decoration-thickness: 2px;
}

/*breadcrumbs fix*/

/* =========================================================
   USCA Standard Tables (locked-down version)
   - fixed layout for consistent columns
   - striped rows
   - vertical + horizontal dividers
   - no hover effect
   - no outer border
   - normalized spacing inside cells
   - built to survive TinyMCE chaos
   ========================================================= */

:root {
  --usca-table-border: rgba(0, 35, 65, 0.14);
  --usca-table-border-strong: rgba(0, 35, 65, 0.22);
  --usca-table-head-bg: #002341;   /* Midnight */
  --usca-table-head-text: #ffffff;
  --usca-table-row-alt: #f5f9fc;   /* soft sky tint */
  --usca-table-text: #002341;
  --usca-table-caption: #44546a;
  --usca-table-cell-pad-y: 1rem;
  --usca-table-cell-pad-x: 1rem;
}

/* Standardized content tables */
.wysiwyg-styles table,
.wsywig-styles table,
.usca-main-grid table,
table.table {
  width: 100%;
  max-width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  border-spacing: 0;
  display: table !important;
  background: #ffffff;
  color: var(--usca-table-text);
  margin: 1rem 0 1.5rem;
}

/* Optional opt-out for weird legacy cases */
table.table-no-autostyle,
table.table-no-autostyle * {
  all: revert;
}

/* Captions */
.wysiwyg-styles table caption,
.wsywig-styles table caption,
.usca-main-grid table caption,
table.table caption {
  caption-side: top;
  text-align: left;
  font-family: "ff-good-web-pro", sans-serif;
  font-weight: 600;
  color: var(--usca-table-caption);
  margin-bottom: 0.75rem;
}

/* Header */
.wysiwyg-styles table thead th,
.wsywig-styles table thead th,
.usca-main-grid table thead th,
table.table thead th {
  background: var(--usca-table-head-bg);
  color: var(--usca-table-head-text);
  font-family: "ff-good-web-pro-wide", sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-align: left;
  vertical-align: top;
  padding: var(--usca-table-cell-pad-y) var(--usca-table-cell-pad-x);
  border-bottom: 1px solid var(--usca-table-border-strong);
  white-space: normal;
  overflow-wrap: anywhere;
}

/* Header column dividers */
.wysiwyg-styles table thead th + th,
.wsywig-styles table thead th + th,
.usca-main-grid table thead th + th,
table.table thead th + th {
  border-left: 1px solid rgba(255, 255, 255, 0.18);
}

/* Body cells */
.wysiwyg-styles table td,
.wysiwyg-styles table th,
.wsywig-styles table td,
.wsywig-styles table th,
.usca-main-grid table td,
.usca-main-grid table th,
table.table td,
table.table th {
  width: auto !important;
  padding: var(--usca-table-cell-pad-y) var(--usca-table-cell-pad-x);
  vertical-align: top;
  text-align: left;
  border-bottom: 1px solid var(--usca-table-border);
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Vertical lines between columns */
.wysiwyg-styles table td + td,
.wysiwyg-styles table th + th,
.wsywig-styles table td + td,
.wsywig-styles table th + th,
.usca-main-grid table td + td,
.usca-main-grid table th + th,
table.table td + td,
table.table th + th {
  border-left: 1px solid var(--usca-table-border);
}

/* Striped body rows */
.wysiwyg-styles table tbody tr:nth-child(even),
.wsywig-styles table tbody tr:nth-child(even),
.usca-main-grid table tbody tr:nth-child(even),
table.table tbody tr:nth-child(even) {
  background: var(--usca-table-row-alt);
}

/* Body row headers */
.wysiwyg-styles table tbody th,
.wsywig-styles table tbody th,
.usca-main-grid table tbody th,
table.table tbody th {
  font-weight: 700;
}

/* Remove bottom border on final row */
.wysiwyg-styles table tbody tr:last-of-type td,
.wysiwyg-styles table tbody tr:last-of-type th,
.wsywig-styles table tbody tr:last-of-type td,
.wsywig-styles table tbody tr:last-of-type th,
.usca-main-grid table tbody tr:last-of-type td,
.usca-main-grid table tbody tr:last-of-type th,
table.table tbody tr:last-of-type td,
table.table tbody tr:last-of-type th {
  border-bottom: 0;
}

/* Normalize inner spacing so editors stop accidentally making rows look random */
.wysiwyg-styles table td > :first-child,
.wysiwyg-styles table th > :first-child,
.wsywig-styles table td > :first-child,
.wsywig-styles table th > :first-child,
.usca-main-grid table td > :first-child,
.usca-main-grid table th > :first-child,
table.table td > :first-child,
table.table th > :first-child {
  margin-top: 0 !important;
}

.wysiwyg-styles table td > :last-child,
.wysiwyg-styles table th > :last-child,
.wsywig-styles table td > :last-child,
.wsywig-styles table th > :last-child,
.usca-main-grid table td > :last-child,
.usca-main-grid table th > :last-child,
table.table td > :last-child,
table.table th > :last-child {
  margin-bottom: 0 !important;
}

/* Normalize paragraphs/lists inside cells */
.wysiwyg-styles table td p,
.wysiwyg-styles table th p,
.wsywig-styles table td p,
.wsywig-styles table th p,
.usca-main-grid table td p,
.usca-main-grid table th p,
table.table td p,
table.table th p {
  margin: 0 0 0.75rem 0;
}

.wysiwyg-styles table td p:last-child,
.wysiwyg-styles table th p:last-child,
.wsywig-styles table td p:last-child,
.wsywig-styles table th p:last-child,
.usca-main-grid table td p:last-child,
.usca-main-grid table th p:last-child,
table.table td p:last-child,
table.table th p:last-child {
  margin-bottom: 0;
}

.wysiwyg-styles table td ul,
.wysiwyg-styles table td ol,
.wysiwyg-styles table th ul,
.wysiwyg-styles table th ol,
.wsywig-styles table td ul,
.wsywig-styles table td ol,
.wsywig-styles table th ul,
.wsywig-styles table th ol,
.usca-main-grid table td ul,
.usca-main-grid table td ol,
.usca-main-grid table th ul,
.usca-main-grid table th ol,
table.table td ul,
table.table td ol,
table.table th ul,
table.table th ol {
  margin: 0.25rem 0 0.75rem 1.25rem;
  padding: 0;
}

.wysiwyg-styles table td ul:last-child,
.wysiwyg-styles table td ol:last-child,
.wysiwyg-styles table th ul:last-child,
.wysiwyg-styles table th ol:last-child,
.wsywig-styles table td ul:last-child,
.wsywig-styles table td ol:last-child,
.wsywig-styles table th ul:last-child,
.wsywig-styles table th ol:last-child,
.usca-main-grid table td ul:last-child,
.usca-main-grid table td ol:last-child,
.usca-main-grid table th ul:last-child,
.usca-main-grid table th ol:last-child,
table.table td ul:last-child,
table.table td ol:last-child,
table.table th ul:last-child,
table.table th ol:last-child {
  margin-bottom: 0;
}

/* Kill mystery spacing gremlins */
.wysiwyg-styles table td br:only-child,
.wysiwyg-styles table th br:only-child,
.wsywig-styles table td br:only-child,
.wsywig-styles table th br:only-child,
.usca-main-grid table td br:only-child,
.usca-main-grid table th br:only-child,
table.table td br:only-child,
table.table th br:only-child {
  display: none;
}

/* Links inside tables */
.wysiwyg-styles table a,
.wsywig-styles table a,
.usca-main-grid table a,
table.table a {
  color: #002341;
  text-decoration-thickness: 2px;
}

.wysiwyg-styles table a:hover,
.wsywig-styles table a:hover,
.usca-main-grid table a:hover,
table.table a:hover {
  color: #00bed6;
}

/* Optional compact variant */
table.table-compact td,
table.table-compact th {
  padding: 0.65rem 0.75rem;
}

/* Mobile: keep the structure but allow horizontal scroll */
@media (max-width: 820px) {
  .wysiwyg-styles table,
  .wsywig-styles table,
  .usca-main-grid table,
  table.table {
    display: block !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
  
/* =========================================================
   Formstack / embedded widget table escape hatch
   Undo USCA table styling without nuking Formstack layout
========================================================= */

table.usca-embed-table {
  width: 100% !important;
  max-width: 100% !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  table-layout: auto !important;
  border: 0 !important;
  background: transparent !important;
}

table.usca-embed-table caption {
  caption-side: top !important;
  padding: 0 0 1rem !important;
  color: inherit !important;
  background: transparent !important;
  font: inherit !important;
  text-align: center !important;
}

table.usca-embed-table thead,
table.usca-embed-table tbody,
table.usca-embed-table tr {
  background: transparent !important;
  border: 0 !important;
}

table.usca-embed-table th,
table.usca-embed-table td {
  background: transparent !important;
  color: inherit !important;
  border: 0 !important;
  padding: 0.5rem !important;
  font: inherit !important;
  line-height: 1.4 !important;
  text-align: inherit !important;
  vertical-align: middle !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  white-space: normal !important;
}

table.usca-embed-table th {
  font-weight: 600 !important;
}

table.usca-embed-table input {
  margin: 0 !important;
}

/*program search hide clear filter*/
span.hide { display: none; }

/*events calendar*/
.no-bullet { list-style: none; }
.event-item {}
.event-date-box { display: inline-flex; }
.date-stamp { width: 100%; }
td a.ajax-load-link { text-align: center !important; }
td.thismonth { padding: 0.5em !important; text-align: center !important; }
td.fillday { padding: 0.5em !important; text-align: center !important; }
#current_month { text-align: center !important; }
.event-search-bar { width: 100%; }
.event-search-form { margin-bottom: 1em; }

/*two html boxes*/
.two-html-boxes ul { list-style: none; margin: 0; padding: 0; }
.two-html-boxes ul li { padding-left: 0.25rem; }
.two-html-boxes ul li a {
  border: 2px solid;
  border-radius: 0;
  font-family: "ff-good-web-pro-wide", sans-serif;
  font-weight: 600;
  text-transform: none;
  padding: 1rem 1.8rem;
  border-width: 2px;
  border-style: solid;
  filter: drop-shadow(1px 2px 3px rgba(0, 0, 0, 0.15));
  position: relative;
  display: inline-block;
  margin-bottom: 1em;
  text-decoration: none;
}
.two-html-boxes ul li a:before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(110deg, transparent 10%, rgba(255, 255, 255, 0.3) 20%, transparent);
  background-size: 200%;
  background-position: 100%;
  mix-blend-mode: screen;
  position: absolute; inset: 0;
}
.two-html-boxes ul li a:hover:before {
  background-position: -100%;
  transition: 0.2s linear;
}
.two-html-boxes ul li a:hover {
  filter: drop-shadow(0px 1px 8px rgba(0, 0, 0, 0.2));
}

/*three link box*/
.three-link-box ul { list-style: none; margin: 0; padding: 0; }
.three-link-box ul li { padding-left: 0.25rem; }
.three-link-box ul li a {
  border: 2px solid;
  border-radius: 0;
  font-family: "ff-good-web-pro-wide", sans-serif;
  font-weight: 600;
  text-transform: none;
  padding: 1rem 1.8rem;
  border-width: 2px;
  border-style: solid;
  filter: drop-shadow(1px 2px 3px rgba(0, 0, 0, 0.15));
  position: relative;
  display: inline-block;
  margin-bottom: 1em;
  text-decoration: none;
}
.three-link-box ul li a:before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(110deg, transparent 10%, rgba(255, 255, 255, 0.3) 20%, transparent);
  background-size: 200%;
  background-position: 100%;
  mix-blend-mode: screen;
  position: absolute; inset: 0;
}
.three-link-box ul li a:hover:before {
  background-position: -100%;
  transition: 0.2s linear;
}
.three-link-box ul li a:hover {
  filter: drop-shadow(0px 1px 8px rgba(0, 0, 0, 0.2));
}

.usca-map-image { width: 100%; height: 100%; object-fit: cover; }

/*news rows */
.pagination-news-rows {
  line-height: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.pagination-news-rows span,
.pagination-news-rows a {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.25rem; padding: 1rem 2rem; text-align: center;
  font-family: "ff-good-web-pro", sans-serif; font-weight: 700;
  text-decoration: none; line-height: 1.2;
  transition: all 0.3s cubic-bezier(.4,0,.2,1);
  background-color: #b2ddff; color: #002341;
  border-top-left-radius: 0.75rem; border-bottom-right-radius: 0.75rem;
}
/* Hover */
.pagination-news-rows a:hover {
  background-color: #d72fa8; color: #ffffff;
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
/* Active press */
.pagination-news-rows a:active {
  transform: translateY(2px) scale(0.98);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  background-color: #d72fa8; color: #ffffff;
}
/* Current */
.pagination-news-rows span {
  background-color: #d72fa8;
  color: #ffffff;
  transform: scale(1.06);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.news-rows-wrapper {
  display: grid; grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 1rem; padding-left: 0;
}
.news-row-slide { margin: 0 auto; width: 80vw; }
.news-row-image { width: 100%; }

@media (min-width: 820px) {
  .news-rows-wrapper {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem; padding-left: 0;
  }
  .news-row-slide { margin: 0 auto; width: 100%; }
}

/*copyright width*/
.copyright-limit { width: 80%; }

.hover-box-link { cursor: pointer !important; }

/*news banner text fix*/
.usca-news .usca-hero-wrapper .usca-hero-wrapper-container .usca-deco-rule { margin: 0 auto !important; }
.usca-news .usca-hero-wrapper .usca-hero-wrapper-container { width: 100% !important; }
@media (min-width: 820px) {
  .usca-news .usca-hero-wrapper .usca-hero-wrapper-container { width: 80% !important; }
}

/*fix connect pre footer*/
@media (max-width: 820px) {
  .usca-connect-content { width: 100vw !important; }
  .usca-connect-bg-image { width: 95vw !important; }
}

/*new section margin*/
.usca-new-section { margin-top: 2rem !important; }
@media (min-width: 820px) {
  .usca-new-section { margin-top: 3rem !important; }
  .usca-new-section.mt-32 { margin-top: 4rem !important; }
}
.usca-hero-wrapper { margin-bottom: 1rem !important; }
@media (min-width: 820px) {
  .usca-hero-wrapper { margin-bottom: 3rem !important; }
  .md\:-mt-12 { margin-top: -3rem; }
}

/*for minus margins different breakpoints*/
.homepage-wrapper { min-height: 100vh !important; }
.alphabet-anchor { display: block; font-size: 1em; font-style: bold; }

/* --- Fix for underlines on program listings --- */
#search-results a.usca-academic-card,
#search-results a.usca-academic-card:link,
#search-results a.usca-academic-card:visited,
#search-results a.usca-academic-card:hover {
  text-decoration: none !important;
}
#search-results a.usca-academic-card .usca-academic-name,
#search-results a.usca-academic-card .usca-academic-degree {
  text-decoration: none;
}

/* ===== Pagination (unchanged behavior, centered) ===== */
.program-pagination .program-search.pagination-box {
  display: flex; justify-content: center !important; align-items: center;
  width: 100%; margin-top: 0.25rem;
}
.program-pagination .pagination-pages { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.pagination-btn, .pagination-current {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.25rem; padding: 0.75rem 1.25rem; text-align: center;
  font-family: "ff-good-web-pro", sans-serif; font-weight: 700; line-height: 1.1;
  text-decoration: none; background-color: #b2ddff; color: #002341; border: none;
  border-top-left-radius: 0.75rem; border-bottom-right-radius: 0.75rem;
  transition: all .3s cubic-bezier(.4,0,.2,1); min-height: 44px;
}
.pagination-btn:hover, .pagination-btn:focus {
  background-color: #d72fa8; color: #ffffff;
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 4px 10px rgba(0,0,0,.15);
}
.pagination-btn:active {
  background-color: #d72fa8; color: #ffffff;
  transform: translateY(2px) scale(.98);
  box-shadow: 0 2px 6px rgba(0,0,0,.1);
}
.pagination-current {
  background-color: #d72fa8; color: #ffffff;
  transform: scale(1.06);
  box-shadow: 0 4px 10px rgba(0,0,0,.2);
}
/* Results line above buttons */
#searchPaginate .pagination-results {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 0.5rem 1rem; margin-top: 0.25rem;
}
#searchPaginate .pagination-results .results {
  margin-right: 0; font-family: "ff-good-web-pro", sans-serif; color: #002341;
}
#searchPaginate .pagination-results select { height: 44px; padding: 0 0.5rem; }
.program-search.pagination-box { margin-top: 2rem; margin-bottom: 0.75rem; }
.program-search.pagination-box .pagination-pages { line-height: 1; gap: 0.75rem; }
.program-pagination { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; margin-top: 1rem; text-align: center; }
.program-pagination .pagination-meta {
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  gap: 0.4rem 0.75rem; font-family: "ff-good-web-pro", sans-serif;
  font-size: 0.875rem; line-height: 1.3; color: #002341; margin: 0;
}
.program-pagination .pagination-meta .results { margin: 0; }
.program-pagination .pagination-meta select { height: 36px; padding: 0 0.5rem; font-size: 0.875rem; margin-left: 0.25rem; }
.program-pagination .pagination-box { justify-content: center; margin-top: 0.25rem; }
.program-pagination .pagination-pages { gap: 0.5rem; }
.program-pagination .pagination-meta .per-page-label {
  font-size: 0.875rem; color: #002341; font-family: "ff-good-web-pro", sans-serif; margin-left: 0.5rem;
}
@media (max-width: 820px) {
  .program-search.pagination-box { flex-direction: column; align-items: center; margin-top: 0.5rem; }
  .program-search.pagination-box .pagination-pages { margin-top: 2rem; margin-bottom: 1rem; }
  .pagination-btn { padding: 0.75rem 1rem; }
}
@media (max-width: 640px) {
  .program-pagination { gap: 0.6rem; }
  .program-pagination .pagination-meta { font-size: 0.8125rem; }
  .program-pagination .pagination-meta select { height: 34px; font-size: 0.8125rem; }
}

/* Fix overflow in mobile (PSRR-20461) */
@media screen and (max-width: 450px) { footer .whitespace-nowrap { white-space: normal; } }
@media screen and (max-width: 819px) {
  .usca-main-grid {
    grid-template-rows: auto minmax(0, 1fr);
    grid-template-columns: minmax(0, 1fr);
  }
}
@media screen and (max-width: 600px) { .usca-new-section p span { overflow-wrap: anywhere; } }
table.table {
  max-width: calc(100vw - 5rem);
  overflow-x: auto;
  display: inline-block !important;
}

/* tiny mce buttons styles */
.usca-button-transparent-general-content a { text-decoration: none; }
.usca-button-blue-general-content a { text-decoration: none; }

/* Transparent Button (synced with buttons_transparent_updated.css) */

/* Primary transparent button */
a.usca-button-transparent-general-content,
a span.usca-button-transparent-general-content,
.usca-button-transparent-general-content a {
border: 2px solid #b7bdc7;
  border-radius: 15px 0 15px 0;
  background-color: transparent;
  color: #002341;
  font-family: "ff-good-web-pro-wide", sans-serif;
  font-weight: 600;
  text-transform: none;
  padding: 1rem 1.8rem;
  box-shadow: 0 1px 0 rgba(0,0,0,0.06);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  text-decoration: none;
}

.usca-button-transparent-general-content a:before,
.usca-button-transparent-general-content a:after {
  content: none;
}

a.usca-button-transparent-general-content:hover,
a span.usca-button-transparent-general-content:hover,
.usca-button-transparent-general-content a:hover,
a.usca-button-transparent-general-content:focus-visible,
a span.usca-button-transparent-general-content:focus-visible,
.usca-button-transparent-general-content a:focus-visible {
border-color: #002341;
  background-color: #ffffff;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  outline: none;
}

/* Transparent button -2 variant (legacy performance-friendly) */
.usca-button-transparent-general-content-2:not(p),
p.usca-button-transparent-general-content-2 a {
border: 2px solid #b7bdc7;
  border-radius: 15px 0 15px 0;
  background-color: transparent;
  color: #002341;
  font-family: "ff-good-web-pro-wide", sans-serif;
  font-weight: 600;
  text-transform: none;
  font-size: 0.9rem;
  padding: 15px 25px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.06);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  text-decoration: none;
  cursor: pointer;
  overflow: hidden;
}

.usca-button-transparent-general-content-2:not(p) a,
p.usca-button-transparent-general-content-2 a a {
  display: inline-flex;
  color: inherit;
  text-decoration: none;
}

.usca-button-transparent-general-content-2:not(p):before,
p.usca-button-transparent-general-content-2 a:before {
  content: none;
}

.usca-button-transparent-general-content-2:not(p):hover,
.usca-button-transparent-general-content-2:not(p):focus-visible,
p.usca-button-transparent-general-content-2 a:hover,
p.usca-button-transparent-general-content-2 a:focus-visible {
border-color: #002341;
  background-color: #ffffff;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  outline: none;
}


/* USCA Standard Button - No Animation */
a.usca-btn-standard-general-content,
a span.usca-btn-standard-general-content,
.usca-btn-standard-general-content a {
  border: 2px solid transparent; border-radius: 0;
  font-family: "ff-good-web-pro-wide", sans-serif !important; font-weight: 600 !important;
  text-transform: none; font-size: 0.9rem !important;
  padding: 15px 25px; border-width: 2px; border-style: solid;
  filter: drop-shadow(1px 2px 3px rgba(0, 0, 0, 0.05));
  position: relative; align-items: center; gap: 0.25rem;
  text-decoration: none !important; display: inline-flex; cursor: pointer; overflow: hidden;
  transition: all 0.3s ease;
}
a.usca-btn-standard-general-content:hover,
a span.usca-btn-standard-general-content:hover,
.usca-btn-standard-general-content a:hover {
  filter: drop-shadow(0px 1px 8px rgba(0, 0, 0, 0.2));
  text-decoration: none !important;
}

/*new fixes for rebrand*/
@media (min-width: 700px) { .smed\:grid-cols-3#card-container { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.usca-new-section .md\:container { margin: 0 auto; }
@media (min-width: 700px) { .smed\:flex-row { flex-direction: row; } }
@media (min-width: 820px) { .md\:w-auto { width: auto; } }
@media (min-width: 700px) { .smed\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* ===== Program Search: controls wrapper ===== */
.program-search .search-controls,
#searchoptionsGeneric,
#searchOptions,
#programSearchControls,
#program-search .filters {
  background: #00bed6;            /* Poolside */
  padding: 1rem 1.25rem;
  border-top-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

/* Mega-search input (matches header mega menu) */
.program-search .search-input-wrapper{
  position:relative; display:flex; align-items:stretch;
  background:#fff; border:2px solid #002341; border-radius:15px 0 15px 0;
  overflow:hidden; box-shadow:0 4px 16px rgba(0,0,0,.12);
}
.program-search .search-input-wrapper:focus-within{
  border-color:#ff0039; box-shadow:0 0 0 3px rgba(255,0,57,.12);
}
.program-search .main-search-input{
  flex:1; padding:16px 20px; padding-right:64px; border:0; outline:0;
  background:transparent; color:#002341; font-weight:500; font-size:16px;
}
.program-search .main-search-input::placeholder{ color:rgba(0,35,65,.55); }
.program-search .search-submit-btn{
  position:absolute; right:0; top:0; bottom:0; width:56px;
  display:flex; align-items:center; justify-content:center;
  background:#ff0039; border:3px solid #ff0039; border-radius:0 0 13px 0; cursor:pointer;
}
.program-search .search-submit-btn svg{ color:#fff; }

/* Inputs/selects inside the search area (fallbacks) */
.program-search .search-controls input[type="text"],
.program-search .search-controls input[type="search"],
.program-search .search-controls select {
  border: 2px solid #002341; background: #ffffff; color: #002341;
  padding: .75rem 1rem; min-height: 44px;
  border-top-left-radius: 0.9rem; border-bottom-right-radius: 0.9rem;
  outline: none; transition: box-shadow .2s ease, transform .2s ease;
}
.program-search .search-controls input:focus,
.program-search .search-controls select:focus {
  box-shadow: 0 0 0 3px rgba(215,47,168,.35);
  transform: translateY(-1px);
}

/* Buttons in search area */
.program-search .search-controls .usca-btn { border-radius: 15px 0 15px 0; }
.program-search .search-controls .toggle,
.program-search .search-controls .filter-btn,
.program-search .search-controls .apply-filter {
  background-color: #002341; color: #ffffff; border-color: #002341;
}
.program-search .search-controls .search-submit,
.program-search .search-controls .btn-search {
  background-color: #ff0039; color: #ffffff; border-color: #ff0039;
}

/* ACTIVE FILTER CHIPS (applied filters list) */
.program-search #searchoptions-filters .active-filter,
.program-search #searchoptions-filters .clear-filters,
.program-search #searchoptions-filters .usca-btn {
  background:#FFB500 !important;
  color:#002341 !important;
  border-color:#FFB500 !important;
}

/* ===== Program cards: Goldenrod classic ===== */
#search-results a.usca-academic-card,
#search-results .usca-academic-card {
  display:block;
  background:#FFB500;          /* Goldenrod */
  color:#002341;               /* Midnight text */
  text-decoration:none;
  border:0;
  border-radius:1rem;
  padding:1.25rem 1.25rem;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
  transition:transform .18s ease, box-shadow .18s ease, color .18s ease, background-color .18s ease;
  background-image:none;
}
#search-results .usca-academic-card * { color:inherit; }

/* Hover = lift only */
#search-results a.usca-academic-card:hover,
#search-results .usca-academic-card:hover {
  transform:translateY(-3px);
  box-shadow:0 12px 26px rgba(0,0,0,.20);
}

/* Pressed/selected */
#search-results a.usca-academic-card:active,
#search-results .usca-academic-card:active,
#search-results a.usca-academic-card.is-selected,
#search-results .usca-academic-card.is-selected,
#search-results a.usca-academic-card[aria-current="true"],
#search-results .usca-academic-card[aria-current="true"]{
  background:#002341; color:#fff;
  transform:translateY(0);
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}

/* Focus ring */
#search-results a.usca-academic-card:focus-visible,
#search-results .usca-academic-card:focus-visible{
  outline:3px solid #d72fa8;
  outline-offset:3px;
  border-radius:1rem;
}

/* Normalize legacy .blue skin if emitted by template */
#search-results a.usca-academic-card.blue {
  background:#FFB500; color:#002341; border:0; background-image:none;
}

/* === PROGRAM SEARCH INPUT – CLEAN FOCUS RING, NO RAISE === */
.program-search .search-controls input[type="text"],
.program-search .search-controls input[type="search"],
.program-search .search-controls input[type="search"]:not([class]) {
  border: 0 !important;           /* nuke all strokes */
  box-shadow: none !important;    /* no default shadow */
  outline: none;
}

/* Focus state: fire-red halo, no translate/raise */
.program-search .search-controls input[type="text"]:focus,
.program-search .search-controls input[type="search"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(228, 1, 67, 0.6) !important; /* fire red */
  transform: none !important;      /* kill the “raised up” effect */
}

/* Just in case any generic transform sneaks in */
.program-search .search-controls input[type="text"]:active,
.program-search .search-controls input[type="search"]:active {
  transform: none !important;
}


/* === PROGRAM CARDS – SUBTLE, NO SHADOWS =================== */

/* Base card */
#search-results a.usca-academic-card,
#search-results .usca-academic-card {
  display: block;
  background: #ffffff !important;      /* white by default */
  color: #002341 !important;           /* midnight text */
  text-decoration: none !important;
  border-radius: 0.5rem !important;    /* softer radius */
  border: 1px solid #e5e7eb !important;/* light gray stroke */
  padding: 1.25rem 1.25rem !important;
  box-shadow: none !important;         /* absolutely no shadow */
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}

/* Kill any legacy corner pseudo-elements */
#search-results a.usca-academic-card::before,
#search-results a.usca-academic-card::after {
  content: none !important;
}

/* Inner text should follow the card color */
#search-results a.usca-academic-card * {
  color: inherit !important;
}

/* Hover: subtle Sky background, still Midnight text, no shadow */
#search-results a.usca-academic-card:hover,
#search-results a.usca-academic-card:focus {
  background: #b2ddff !important;      /* USCA Sky */
  border-color: #b2ddff !important;
  color: #002341 !important;
  box-shadow: none !important;
  transform: none !important;          /* no lift */
}

/* Active/selected: keep behavior simple & flat */
#search-results a.usca-academic-card:active,
#search-results a.usca-academic-card.is-selected,
#search-results a.usca-academic-card.selected,
#search-results a.usca-academic-card[aria-current="true"],
#search-results a.usca-academic-card[data-selected="true"] {
  background: #b2ddff !important;      /* same as hover to keep it calm */
  border-color: #002341 !important;    /* subtle emphasis */
  color: #002341 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Accessible focus ring (on top of the flat style) */
#search-results a.usca-academic-card:focus-visible {
  outline: 3px solid #d72fa8 !important;  /* Orchid focus ring */
  outline-offset: 3px !important;
}

:root {
  --midnight: #002341;
  --logo-red: #e32429; /* standard USCA logo red */
}

/* =====================================
   DEFAULT LOGO COLORS (no hero override)
   ===================================== *


/* Default logo: red BG, white mark */
.logo-bg {
  fill: var(--logo-red); /* keep the red */
  stroke: var(--logo-red);
  stroke-width: 4px;               /* try 3–4px, tweak to taste */
  paint-order: stroke fill;        /* draw stroke under fill to avoid halos */
  vector-effect: non-scaling-stroke; /* keeps stroke looking consistent */
}

.logo-mark {
  fill: #ffffff;
}
        
/* Fire-red, Orchid, Sky heroes → Midnight logo with Midnight stroke */
body:has(.blue-section-with-image[data-hero-scheme="fire-red"]) .logo-bg,
body:has(.image-hero[data-hero-scheme="fire-red"]) .logo-bg,
body:has(.blue-section-with-image[data-hero-scheme="orchid"]) .logo-bg,
body:has(.image-hero[data-hero-scheme="orchid"]) .logo-bg,
body:has(.blue-section-with-image[data-hero-scheme="sky"]) .logo-bg,
body:has(.image-hero[data-hero-scheme="sky"]) .logo-bg {
    fill: var(--midnight); /* keep the red */
  stroke: var(--midnight);         /* Midnight outline */
  stroke-width: 4px;               /* try 3–4px, tweak to taste */
  paint-order: stroke fill;        /* draw stroke under fill to avoid halos */
  vector-effect: non-scaling-stroke; /* keeps stroke looking consistent */
}

/* =====================================
   Programs/Profiles/News Nav Bar Jumper
   ===================================== *

/* Prevent “flash” on Programs pages that have a slot */
html.has-programs-nav-slot nav.department-nav {
  opacity: 0;
  pointer-events: none;
}

html.has-programs-nav-moved nav.department-nav {
  opacity: 1;
  pointer-events: auto;
  transition: opacity 120ms ease;
}

/* Let grid children shrink (prevents clipping in tight layouts) */
.usca-main-grid > * {
  min-width: 0;
}

/* =========================================================
   Secondary/Tertiary Quick Links
   - styles standalone links like dept-nav dropdown buttons
   - removes giant gaps caused by <p>/<li> margins
   - works whether links have classes or not
   ========================================================= */

.usca-card.secondary-card .usca-card-content,
.usca-card.simple-card .usca-card-content {
  --ql-text: #002341;
  --ql-border: #d8dee6;
  --ql-hover-bg: #FFB500;
  --ql-hover-border: #FFB500;
  --ql-hover-text: #002341;
  --ql-gap: 10px;
}

/* 1) Kill default “paragraph gap” ONLY when the <p> is basically just a link */
.usca-card.secondary-card .usca-card-content p:has(> a),
.usca-card.simple-card .usca-card-content p:has(> a),
.usca-card.secondary-card .usca-card-content p:has(> ss-link),
.usca-card.simple-card .usca-card-content p:has(> ss-link) {
  margin: 0 0 var(--ql-gap) 0 !important;
}

/* 2) Same idea for lists */
.usca-card.secondary-card .usca-card-content ul,
.usca-card.simple-card .usca-card-content ul,
.usca-card.secondary-card .usca-card-content ol,
.usca-card.simple-card .usca-card-content ol {
  margin: 0 0 var(--ql-gap) 0 !important;
  padding-left: 0 !important;
}

.usca-card.secondary-card .usca-card-content li,
.usca-card.simple-card .usca-card-content li {
  margin: 0 0 var(--ql-gap) 0 !important;
  list-style: none !important;
}

/* 3) Style “standalone” links (direct child of p/li or direct child of content area) */
.usca-card.secondary-card .usca-card-content > a,
.usca-card.simple-card .usca-card-content > a,
.usca-card.secondary-card .usca-card-content p > a,
.usca-card.simple-card .usca-card-content p > a,
.usca-card.secondary-card .usca-card-content li > a,
.usca-card.simple-card .usca-card-content li > a,
.usca-card.secondary-card .usca-card-content > ss-link,
.usca-card.simple-card .usca-card-content > ss-link,
.usca-card.secondary-card .usca-card-content p > ss-link,
.usca-card.simple-card .usca-card-content p > ss-link,
.usca-card.secondary-card .usca-card-content li > ss-link,
.usca-card.simple-card .usca-card-content li > ss-link {
  display: flex !important;
  align-items: center;
  justify-content: center; /* center like your quick links screenshot */
  width: 100% !important;
  box-sizing: border-box;

  padding: 10px 12px !important;

  font-family: "ff-good-web-pro-wide", sans-serif !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  font-size: 0.75rem !important;
  line-height: 1.2 !important;

  background: transparent !important;
  color: var(--ql-text) !important;
  border: 1px solid var(--ql-border) !important;
  border-radius: 0 !important;

  text-decoration: none !important;

  box-shadow: none !important;
  filter: none !important;

  transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

/* 4) Hover/focus */
.usca-card.secondary-card .usca-card-content > a:hover,
.usca-card.simple-card .usca-card-content > a:hover,
.usca-card.secondary-card .usca-card-content p > a:hover,
.usca-card.simple-card .usca-card-content p > a:hover,
.usca-card.secondary-card .usca-card-content li > a:hover,
.usca-card.simple-card .usca-card-content li > a:hover,
.usca-card.secondary-card .usca-card-content > ss-link:hover,
.usca-card.simple-card .usca-card-content > ss-link:hover,
.usca-card.secondary-card .usca-card-content p > ss-link:hover,
.usca-card.simple-card .usca-card-content p > ss-link:hover,
.usca-card.secondary-card .usca-card-content li > ss-link:hover,
.usca-card.simple-card .usca-card-content li > ss-link:hover {
  background-color: var(--ql-hover-bg) !important;
  border-color: var(--ql-hover-border) !important;
  color: var(--ql-hover-text) !important;
}

.usca-card.secondary-card .usca-card-content a:focus-visible,
.usca-card.simple-card .usca-card-content a:focus-visible,
.usca-card.secondary-card .usca-card-content ss-link:focus-visible,
.usca-card.simple-card .usca-card-content ss-link:focus-visible {
  outline: 2px solid #00bed6 !important;
  outline-offset: 2px !important;
}

/* 5) TinyMCE nested span weirdness: <a><span class="...">Text</span></a> */
.usca-card.secondary-card .usca-card-content a > span,
.usca-card.simple-card .usca-card-content a > span {
  display: contents;
}
/* Force uppercase for Quick Links in Secondary / Tertiary cards
   (handles <a>, <ss-link>, AND inner wrappers like <span>) */
.usca-card.secondary-card .usca-card-content :is(a, ss-link),
.usca-card.simple-card .usca-card-content :is(a, ss-link),
.usca-card.secondary-card .usca-card-content :is(a, ss-link) *,
.usca-card.simple-card .usca-card-content :is(a, ss-link) * {
  text-transform: uppercase !important;
  letter-spacing: 0.04em; /* optional but matches nav dropdown feel */
}

/* =========================================
   Right-column (secondary/tertiary) button patch
   Handles:
   1) <span class="btn"><a class="btn">...</a></span>
   2) random <br> gaps between buttons
   3) forces consistent compact button styling + uppercase
========================================= */

/* 1) Kill the TinyMCE line-break gap between buttons in these card areas */
.usca-card-content p > br {
  display: none !important;
}

/* 2) Make wrapper spans “not a box” so only the <a> draws the button */
.usca-card-content span.usca-button-transparent-general-content {
  display: contents;
}

@supports not (display: contents) {
  .usca-card-content span.usca-button-transparent-general-content {
    display: inline;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }
}

/* 3) Ensure BOTH patterns behave the same:
   - <a class="usca-button-transparent-general-content">
   - <span class="..."><a class="..."></a></span>
*/
.usca-card-content a.usca-button-transparent-general-content,
.usca-card-content span.usca-button-transparent-general-content > a.usca-button-transparent-general-content {
  display: flex !important;
  width: 100%;
  box-sizing: border-box;
  margin: 0 0 14px 0;           /* <-- controls the “gap between buttons” */
  text-transform: uppercase !important;
}

/* Optional: if the last button has extra space under it */
.usca-card-content a.usca-button-transparent-general-content:last-child,
.usca-card-content span.usca-button-transparent-general-content:last-child > a.usca-button-transparent-general-content {
  margin-bottom: 0;
}

/* =========================================================
   Secondary/Tertiary right-column: force compact link-button style
   Fixes inconsistent overrides caused by:
   - <span class="btn"><a class="btn">...</a></span>
   - legacy transparent button rules winning the cascade
========================================================= */

/* 0) TinyMCE BR spacing nuker (keep if you liked the spacing fix) */
.usca-card.secondary-card .usca-card-content p > br,
.usca-card.simple-card    .usca-card-content p > br {
  display: none !important;
}

/* 1) Wrapper spans should never look like a button */
.usca-card.secondary-card .usca-card-content span.usca-button-transparent-general-content,
.usca-card.simple-card    .usca-card-content span.usca-button-transparent-general-content {
  display: contents;
}

@supports not (display: contents) {
  .usca-card.secondary-card .usca-card-content span.usca-button-transparent-general-content,
  .usca-card.simple-card    .usca-card-content span.usca-button-transparent-general-content {
    display: inline !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }
}

/* 2) Force the compact “dropdown-button” look on ALL matching anchors */
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content,
.usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content > a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content > a.usca-button-transparent-general-content {
  /* layout */
  display: flex !important;
  width: 100% !important;
  box-sizing: border-box !important;

  /* spacing (controls the gap between buttons) */
  margin: 0 0 14px 0 !important;

  /* compact button styling (mirrors dept-nav dropdown vibe) */
  padding: 10px 14px !important;
  min-height: 40px !important;

  border: 2px solid #cbd5e1 !important; /* light stroke */
  border-radius: 0 !important;           /* dropdown style = square */

  background: transparent !important;
  box-shadow: none !important;
  filter: none !important;

  /* type */
  font-family: "ff-good-web-pro-wide", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  line-height: 1.2 !important;

  /* alignment — change to flex-start if you want left-aligned like dropdowns */
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
}

.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content:hover,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content:hover,
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content:focus-visible,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content:focus-visible,
.usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content:hover > a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content:hover > a.usca-button-transparent-general-content {
  background: #ffffff !important;
  border-color: #00bed6 !important;
}
  
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content {
  transition: background-color .2s ease, border-color .2s ease, transform .2s ease !important;
}


/* 4) If your legacy transparent buttons have shimmer/pseudo elements, kill them here */
.usca-card.secondary-card .usca-card-content a.usca-button-transparent-general-content::before,
.usca-card.secondary-card .usca-card-content a.usca-button-transparent-general-content::after,
.usca-card.simple-card    .usca-card-content a.usca-button-transparent-general-content::before,
.usca-card.simple-card    .usca-card-content a.usca-button-transparent-general-content::after {
  content: none !important;
}

/* 5) Avoid extra paragraph spacing creating “mystery gaps” */
.usca-card.secondary-card .usca-card-content p,
.usca-card.simple-card    .usca-card-content p {
  margin: 0 !important;
}

/* =========================================================
   Secondary/Tertiary right-column: unify ALL “button-like” links
   Targets:
   - a.usca-button-transparent-general-content
   - <span class="..."><a class="...">...</a></span>
   - legacy .usca-btn (poolside/goldenrod/etc) inside these boxes
========================================================= */

/* 0) TinyMCE BR spacing nuker */
.usca-card.secondary-card .usca-card-content p > br,
.usca-card.simple-card    .usca-card-content p > br {
  display: none !important;
}

/* 1) Wrapper spans should never look like a button */
.usca-card.secondary-card .usca-card-content span.usca-button-transparent-general-content,
.usca-card.simple-card    .usca-card-content span.usca-button-transparent-general-content {
  display: contents;
}

@supports not (display: contents) {
  .usca-card.secondary-card .usca-card-content span.usca-button-transparent-general-content,
  .usca-card.simple-card    .usca-card-content span.usca-button-transparent-general-content {
    display: inline !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }
}

/* 2) Base “compact dropdown-button” look for ALL button-like anchors in these boxes */
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content,
.usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content > a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content > a.usca-button-transparent-general-content,

/* ALSO pull legacy styled buttons into the same look */
.usca-card.secondary-card-instance .usca-card-content a.usca-btn,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-btn {
  /* layout */
  display: flex !important;
  width: 100% !important;
  box-sizing: border-box !important;

  /* spacing (controls the gap between buttons) */
  margin: 0 0 14px 0 !important;

  /* compact button styling */
  padding: 10px 14px !important;
  min-height: 40px !important;

  border: 2px solid #cbd5e1 !important;
  border-radius: 0 !important;

  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;

  /* type */
  font-family: "ff-good-web-pro-wide", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  line-height: 1.2 !important;

  /* alignment */
  justify-content: center !important;  /* switch to flex-start if desired */
  align-items: center !important;
  text-align: center !important;

  /* smoothness */
  transition: background-color .2s ease,
              border-color .2s ease,
              color .2s ease,
              transform .2s ease !important;
}

/* 3) Hover/focus states (consistent for both link types + legacy .usca-btn) */
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content:hover,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content:hover,
.usca-card.secondary-card-instance .usca-card-content a.usca-button-transparent-general-content:focus-visible,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-button-transparent-general-content:focus-visible,
.usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content:hover > a.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content:hover > a.usca-button-transparent-general-content,

.usca-card.secondary-card-instance .usca-card-content a.usca-btn:hover,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-btn:hover,
.usca-card.secondary-card-instance .usca-card-content a.usca-btn:focus-visible,
.usca-card.tertiary-card-instance  .usca-card-content a.usca-btn:focus-visible {
  background: #ffffff !important;
  border-color: #00bed6 !important;
}

/* 4) Kill legacy shimmer/pseudo elements that can cause “why is this one weird” */
.usca-card.secondary-card .usca-card-content a::before,
.usca-card.secondary-card .usca-card-content a::after,
.usca-card.simple-card    .usca-card-content a::before,
.usca-card.simple-card    .usca-card-content a::after {
  content: none !important;
}

/* 5) Avoid paragraph spacing creating “mystery gaps” */
.usca-card.secondary-card .usca-card-content p,
.usca-card.simple-card    .usca-card-content p {
  margin: 0 !important;
}

/* Optional: if lists are used in these areas, keep list items from adding extra spacing */
.usca-card.secondary-card .usca-card-content li,
.usca-card.simple-card    .usca-card-content li {
  margin: 0 !important;
}

/* =========================================================
   PATCH: handle <a><span class="usca-button-transparent-general-content">Text</span></a>
   (class on span, not the anchor)
========================================================= */

/* Style the anchor like the other compact buttons when it contains the span */
.usca-card.secondary-card-instance .usca-card-content a:has(> span.usca-button-transparent-general-content),
.usca-card.tertiary-card-instance  .usca-card-content a:has(> span.usca-button-transparent-general-content) {
  /* same “dropdown-button” look */
  display: flex !important;
  width: 100% !important;
  box-sizing: border-box !important;

  margin: 0 0 14px 0 !important;

  padding: 10px 14px !important;
  min-height: 40px !important;

  border: 2px solid #cbd5e1 !important;
  border-radius: 0 !important;

  background: transparent !important;
  box-shadow: none !important;
  filter: none !important;

  font-family: "ff-good-web-pro-wide", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  line-height: 1.2 !important;

  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;

  transition: background-color .2s ease, border-color .2s ease, transform .2s ease !important;
}

/* Hover/focus to match the others */
.usca-card.secondary-card-instance .usca-card-content a:has(> span.usca-button-transparent-general-content):hover,
.usca-card.tertiary-card-instance  .usca-card-content a:has(> span.usca-button-transparent-general-content):hover,
.usca-card.secondary-card-instance .usca-card-content a:has(> span.usca-button-transparent-general-content):focus-visible,
.usca-card.tertiary-card-instance  .usca-card-content a:has(> span.usca-button-transparent-general-content):focus-visible {
  background: #ffffff !important;
  border-color: #00bed6 !important;
}

/* Make the inner span behave like plain text (no margins/borders/blocks) */
.usca-card.secondary-card-instance .usca-card-content a > span.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content a > span.usca-button-transparent-general-content {
  display: inline !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  text-transform: inherit !important;
  font: inherit !important;
  letter-spacing: inherit !important;
  color: inherit !important;
}

/* Fallback: when a span has the class, style the parent anchor */
.usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content,
.usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content {
  display: contents;
}

/* If display:contents isn't supported, at least strip visuals off the span */
@supports not (display: contents) {
  .usca-card.secondary-card-instance .usca-card-content span.usca-button-transparent-general-content,
  .usca-card.tertiary-card-instance  .usca-card-content span.usca-button-transparent-general-content {
    display: inline !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }
}

/* =========================================================
   WYSIWYG heading stacking (tuned)
   - H2: full-width deco rule (block)
   - H3: shrink-to-text deco rule, but still on its own line
   ========================================================= */

:where(.wysiwyg-styles, .wsywig-styles, .wsyiwig-styles, .wsyiwyg-styles){
  display: block !important;
}

/* Default: headings stack and behave normally */
:where(.wysiwyg-styles, .wsywig-styles, .wsyiwig-styles, .wsyiwyg-styles)
:is(h1,h2,h3,h4,h5,h6){
  display: block !important;
  max-width: 100% !important;
  clear: both !important;
  flex: 0 0 100% !important;
}

/* H2: keep full width (you like this look) */
:where(.wysiwyg-styles, .wsywig-styles, .wsyiwig-styles, .wsyiwyg-styles)
h2.usca-deco-rule{
  width: 100% !important;
}

/* H3: shrink-to-text, but still force a new line */
:where(.wysiwyg-styles, .wsywig-styles, .wsyiwig-styles, .wsyiwyg-styles)
h3.usca-deco-rule{
  display: inline-block !important; /* shrink-wrap to text */
  width: auto !important;           /* undo the 100% */
  max-width: 100% !important;
  clear: both !important;           /* ensures it starts a new line */
}

/* If any parent is flex, make H3 occupy the whole row but keep shrink-wrapped content */
:where(.wysiwyg-styles, .wsywig-styles, .wsyiwig-styles, .wsyiwyg-styles)
h3.usca-deco-rule{
  flex-basis: 100% !important;      /* new row */
  align-self: flex-start !important;
}
  
/* =========================================================
   Cookie Banner
   ========================================================= */

.usca-cookie-banner {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  z-index: 9999;
  width: min(92vw, 520px);
  pointer-events: none;
}

.usca-cookie-banner__panel {
  pointer-events: auto;
  background: #f2f2f2;
  border-radius: 20px 0 20px 0;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.15);
  padding: 16px 18px;
}

.usca-cookie-banner__top {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.usca-cookie-banner__icon {
  font-size: 1.6rem;
  line-height: 1;
  flex-shrink: 0;
}

.usca-cookie-banner__message {
  font-family: "ff-good-web-pro", sans-serif;
  font-size: 0.95rem;
  line-height: 1.35;
  color: #1d1d1d;
}

.usca-cookie-banner__link {
  display: inline;
  margin-left: 4px;
  font-weight: 600;
  color: #002f6c;
  text-decoration: none;
}

.usca-cookie-banner__link:hover {
  text-decoration: underline;
}

/* Smaller button */
.usca-cookie-banner__button.usca-btn.fire {
  width: 100%;
  min-height: 48px;
  font-size: 1rem;
  padding: 10px 16px;
  border-radius: 12px 0 12px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Optional: make it feel even lighter on desktop */
@media (min-width: 768px) {
  .usca-cookie-banner__panel {
    padding: 14px 16px;
  }

  .usca-cookie-banner__message {
    font-size: 0.9rem;
  }
}

  /* =========================================================
   Inline Message Boxes
   ========================================================= */
  
.usca-message-boxes {
  margin: 1.25rem 0;
}

.usca-message-boxes > * + * {
  margin-top: 0.75rem;
}

.usca-message-box {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
  padding: 0.875rem 1rem;
  border: 1.5px solid;
  border-left-width: 6px;
  border-radius: 6px;
  line-height: 1.45;
}

.usca-message-box__icon {
  flex: 0 0 auto;
  width: 1.25rem;
  min-height: 1.25rem;
  font-size: 1.125rem;
  line-height: 1;
  margin-top: 0.1rem;
}

.usca-message-box__body {
  flex: 1 1 auto;
  min-width: 0;
}

.usca-message-box__title {
  margin: 0 0 0.2rem;
  font-family: "ff-good-web-pro", sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.usca-message-box__content {
  font-size: 0.95rem;
}

.usca-message-box__content > :first-child {
  margin-top: 0;
}

.usca-message-box__content > :last-child {
  margin-bottom: 0;
}

.usca-message-box__content p {
  margin-bottom: 0.35rem;
}

.usca-message-box a {
  font-weight: 600;
  text-decoration: underline;
}

.usca-message-box a:hover,
.usca-message-box a:focus {
  text-decoration: none;
}

/* INFO */
.usca-message-box--info {
  background-color: #B2DDFF;
  border-color: #7fbfe6;
  color: #002341;
}

.usca-message-box--info .usca-message-box__title,
.usca-message-box--info a {
  color: #002341;
}

.usca-message-box--info .usca-message-box__icon::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f05a";
  color: #002341;
}

/* WARNING */
.usca-message-box--warning {
  background-color: #FFB500;
  border-color: #cc9200;
  color: #002341;
}

.usca-message-box--warning .usca-message-box__title,
.usca-message-box--warning a {
  color: #002341;
}

.usca-message-box--warning .usca-message-box__icon::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f071";
  color: #002341;
}

/* SUCCESS */
.usca-message-box--success {
  background-color: #00bed6;
  border-color: #0097ab;
  color: #ffffff;
}

.usca-message-box--success .usca-message-box__title,
.usca-message-box--success a {
  color: #ffffff;
}

.usca-message-box--success .usca-message-box__icon::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f058";
  color: #ffffff;
}

/* IMPORTANT */
.usca-message-box--important {
  background-color: #ee1f40;
  border-color: #b21830;
  color: #ffffff;
}

.usca-message-box--important .usca-message-box__title,
.usca-message-box--important a {
  color: #ffffff;
}

.usca-message-box--important .usca-message-box__icon::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f06a";
  color: #ffffff;
}

/* NOTE */
.usca-message-box--note {
  background-color: #f2f4f7;
  border-color: #c7cdd6;
  color: #002341;
}

.usca-message-box--note .usca-message-box__title,
.usca-message-box--note a {
  color: #002341;
}

.usca-message-box--note .usca-message-box__icon::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f05a";
  color: #002341;
}

@media (max-width: 640px) {
  .usca-message-box {
    gap: 0.75rem;
    padding: 0.8rem 0.9rem;
  }

  .usca-message-box__title {
    font-size: 0.76rem;
  }

  .usca-message-box__content {
    font-size: 0.92rem;
  }
}

/* Standardize ALL USCA button variants to uppercase */
.usca-btn,
[class^="usca-btn-"],
[class*=" usca-btn-"] {
  text-transform: uppercase;
  letter-spacing: 0.04em;
}