/* UTL Tools custom overrides extracted from appended style.css rules. */

/* Borrowed exactly from utl_admin_theme/css/component/header.css */

/* UTL colour variables needed by borrowed utl_admin_theme header styles */
:root {
  --utl-primary: #1e3765;
  --utl-secondary: #007894;
  --utl-white: #ffffff;
}

/* University of Toronto Libraries top bar */
.utl-top-bar {
  background-color: var(--utl-primary);
  padding: 0.65rem 0;
}

.utl-top-bar__inner {
  max-width: 1140px;
  padding: 0 1rem;
}

.utl-top-bar__text {
  color: var(--utl-white);
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

/* Site branding: "LIBRARY EDIT" text (replaces logo) */
.site-branding-text {
  font-weight: 700;
  letter-spacing: 0.02em;
}

.site-branding-text__library {
  color: var(--utl-primary);
  font-size: 3rem;
  text-transform: uppercase;
  margin-right: 0.35rem;
}

.site-branding-text__edit {
  color: var(--utl-secondary);
  font-size: 2rem;
  text-transform: uppercase;
}



/* Header tuning for Library Tools */
body,
button,
input,
select,
textarea,
.navbar,
.nav-link,
.site-branding-text,
.utl-top-bar__text {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
}

/* Match the UTL top bar more closely */
.utl-top-bar {
  background-color: var(--utl-primary);
  padding: 0.65rem 0;
}

.utl-top-bar__inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 1rem;
}

.utl-top-bar__text {
  color: var(--utl-white);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* Keep the branding aligned with the site width and add breathing room */
#header .region--header {
  max-width: 1140px;
  margin: 0 auto;
  padding: 1.1rem 1rem 0.5rem;
}

#header .navbar-brand {
  margin: 0;
}

.site-branding-text {
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.site-branding-text:hover,
.site-branding-text:focus {
  text-decoration: none;
}

.site-branding-text__library {
  color: var(--utl-primary);
  font-size: 3rem;
  line-height: 1;
  text-transform: uppercase;
  margin-right: 0.35rem;
}

.site-branding-text__edit {
  color: var(--utl-secondary);
  font-size: 2rem;
  line-height: 1;
  text-transform: uppercase;
}

/* Align nav with the same content width and improve spacing */
#header nav > .container {
  max-width: 1140px;
  padding-left: 1rem;
  padding-right: 1rem;
}

#header .navbar {
  padding-top: 0.25rem;
  padding-bottom: 0.5rem;
}

#header .navbar-nav {
  align-items: center;
}

#header .navbar-nav .nav-item {
  margin-left: 1.25rem;
}

#header .navbar-nav .nav-link {
  font-family: 'Open Sans', Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--utl-primary);
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

/* FINAL UTL Tools header fix */
:root {
  --utl-primary: #1e3765;
  --utl-secondary: #007894;
  --utl-white: #ffffff;
}

html,
body,
button,
input,
select,
textarea,
.navbar,
.nav-link,
.site-branding-text,
.utl-top-bar,
.utl-top-bar__link {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
}

/* Top blue UTL bar */
.utl-top-bar {
  background-color: var(--utl-primary) !important;
  color: var(--utl-white) !important;
  padding: 0.65rem 0 !important;
  min-height: 0 !important;
  display: block !important;
  border: 0 !important;
}

.utl-top-bar__inner {
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
  text-align: left !important;
}

.utl-top-bar__text,
.utl-top-bar__link {
  color: var(--utl-white) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  text-decoration: none !important;
}

.utl-top-bar__link:hover,
.utl-top-bar__link:focus {
  color: var(--utl-white) !important;
  text-decoration: underline !important;
}

/* Remove the accidental red/orange line */
#header,
#header::before,
#header::after,
#header .header,
#header .header::before,
#header .header::after,
#header .region,
#header .region::before,
#header .region::after,
#header nav,
#header nav::before,
#header nav::after,
#header .navbar,
#header .navbar::before,
#header .navbar::after {
  border-top: 0 !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

/* Header brand row */
#header > .region,
#header .region-header,
#header .region--header {
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding: 1.1rem 1rem 0.35rem !important;
  display: block !important;
  background: transparent !important;
}

#header .navbar-brand {
  margin: 0 !important;
  padding: 0 !important;
}

.site-branding-text {
  display: inline-flex !important;
  align-items: baseline !important;
  flex-wrap: wrap !important;
  gap: 0.35rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.site-branding-text:hover,
.site-branding-text:focus {
  text-decoration: none !important;
}

.site-branding-text__library {
  color: var(--utl-primary) !important;
  font-size: 3rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

.site-branding-text__edit {
  color: var(--utl-secondary) !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

/* Navigation row */
#header nav > .container {
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

#header .navbar,
#header nav {
  background: transparent !important;
}

#header .navbar-nav {
  width: 100% !important;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin: 0 !important;
}

#header .navbar-nav .nav-link {
  color: var(--utl-primary) !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
}
/* END FINAL UTL Tools header fix */


/* Align UTL top bar text with Library Tools branding */
.utl-top-bar__inner {
  max-width: none !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 1rem !important;
  text-align: left !important;
}

.utl-top-bar__link,
.utl-top-bar__text {
  display: inline-block !important;
  margin-left: 0 !important;
}

/* Site-wide font override */
html,
body,
body *,
button,
input,
select,
textarea {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
}

/* Align header text with 20px left spacing */
.utl-top-bar__inner {
  padding-left: 20px !important;
}

#header > .region,
#header .region-header,
#header .region--header,
#header nav > .container {
  padding-left: 20px !important;
}

/* Align header text with 20px left spacing */
.utl-top-bar__inner {
  padding-left: 20px !important;
}

#header > .region,
#header .region-header,
#header .region--header,
#header nav > .container {
  padding-left: 20px !important;
}

/* Final header spacing and typography tuning */
.utl-top-bar__inner {
  max-width: none !important;
  margin: 0 !important;
  padding-left: 100px !important;
  padding-right: 1rem !important;
  text-align: left !important;
}

.utl-top-bar__link,
.utl-top-bar__text {
  text-transform: uppercase !important;
  font-size: 0.78rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  color: #ffffff !important;
  text-decoration: none !important;
}

#header > .region,
#header .region-header,
#header .region--header {
  padding-left: 100px !important;
  padding-right: 1rem !important;
  max-width: none !important;
  margin: 0 !important;
}

#header .navbar-brand {
  padding-left: 0 !important;
  margin-left: 0 !important;
}

.site-branding-text__library {
  font-size: 2.75rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em !important;
}

.site-branding-text__edit {
  font-size: 1.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
}

/* Move Library Tools branding in from the left */
#header .navbar-brand,
.navbar-brand:has(.site-branding-text),
.site-branding-text {
  margin-left: 100px !important;
}

/* Final alignment correction: do not double-indent Library Tools */
.utl-top-bar__inner,
#header > .region,
#header .region-header,
#header .region--header,
#header nav > .container {
  padding-left: 100px !important;
  padding-right: 100px !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

#header .navbar-brand,
.navbar-brand:has(.site-branding-text),
.site-branding-text {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Repair Library Tools header alignment */
.utl-top-bar__inner {
  padding-left: 100px !important;
  padding-right: 100px !important;
  text-align: left !important;
}

.site-branding-text {
  display: inline-flex !important;
  padding-left: 100px !important;
  margin-left: 0 !important;
}

#header .navbar-brand {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* UTL footer block */
.utl-footer {
  font-family: "Open Sans", "Helvetica Neue", Arial, sans-serif !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent;
  position: relative;
  z-index: 2;
}

.utl-footer * {
  box-sizing: border-box;
}

.utl-footer-fullbleed {
  position: relative;
  left: 50%;
  right: 50%;
  width: 100vw;
  margin-left: -50vw;
  margin-right: -50vw;
}

.utl-footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 100px;
}

.utl-footer-top {
  background: #1f3a66;
  padding: 56px 0 36px;
  overflow: hidden;
}

.utl-footer-col {
  float: left;
  width: 33.3333%;
  padding-right: 32px;
}

.utl-footer-col:last-child {
  padding-right: 0;
}

.utl-footer-col-title {
  margin: 0 0 18px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
  letter-spacing: 0.01em;
}

.utl-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.utl-footer-list li {
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.45;
  color: #ffffff;
}

.utl-footer a {
  color: #ffffff !important;
  text-decoration: none !important;
  background: transparent !important;
}

.utl-footer a:hover,
.utl-footer a:focus {
  color: #ffffff !important;
  text-decoration: underline !important;
  text-underline-offset: 0.18em;
}

.utl-footer-list a {
  font-size: 14px !important;
  line-height: 1.45;
  font-weight: 400;
}

.utl-footer-divider {
  clear: both;
  border: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.18);
  margin: 34px 0 26px;
}

.utl-footer-logo {
  text-align: center;
  padding-bottom: 6px;
}

.utl-footer-logo img {
  max-width: 260px;
  width: 100%;
  height: auto;
  border: 0 !important;
  box-shadow: none !important;
}

.utl-footer-bottom {
  background: #2b2b2b;
  padding: 14px 0;
}

.utl-footer-bottom-row {
  overflow: hidden;
}

.utl-footer-bottom-links {
  float: left;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.utl-footer-bottom-links a {
  font-size: 14px;
  font-weight: 600;
}

.utl-footer-bottom-links .sep {
  margin: 0 6px;
  opacity: 0.7;
  color: #ffffff;
  user-select: none;
}

.utl-footer-copyright {
  float: right;
  margin: 0;
  font-size: 14px;
  line-height: 1.2;
  color: #ffffff;
  opacity: 0.95;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .utl-footer-container {
    padding: 0 24px;
  }

  .utl-footer-col {
    float: none;
    width: 100%;
    padding-right: 0;
    margin-bottom: 28px;
  }

  .utl-footer-col-title {
    font-size: 19px;
  }

  .utl-footer-bottom-links,
  .utl-footer-copyright {
    float: none;
    display: block;
    text-align: center;
    white-space: normal;
  }

  .utl-footer-bottom-links {
    margin-bottom: 8px;
  }
}

/* UTL footer block */
.utl-footer {
  font-family: "Open Sans", "Helvetica Neue", Arial, sans-serif !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent;
  position: relative;
  z-index: 2;
}

.utl-footer * {
  box-sizing: border-box;
}

.utl-footer-fullbleed {
  position: relative;
  left: 50%;
  right: 50%;
  width: 100vw;
  margin-left: -50vw;
  margin-right: -50vw;
}

.utl-footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 100px;
}

.utl-footer-top {
  background: #1f3a66;
  padding: 56px 0 36px;
  overflow: hidden;
}

.utl-footer-col {
  float: left;
  width: 33.3333%;
  padding-right: 32px;
}

.utl-footer-col:last-child {
  padding-right: 0;
}

.utl-footer-col-title {
  margin: 0 0 18px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
}

.utl-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.utl-footer-list li {
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.45;
  color: #ffffff;
}

.utl-footer a {
  color: #ffffff !important;
  text-decoration: none !important;
  background: transparent !important;
}

.utl-footer a:hover,
.utl-footer a:focus {
  text-decoration: underline !important;
  text-underline-offset: 0.18em;
}

.utl-footer-divider {
  clear: both;
  border: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.18);
  margin: 34px 0 26px;
}

.utl-footer-logo {
  text-align: center;
  padding-bottom: 6px;
}

.utl-footer-logo img {
  max-width: 260px;
  width: 100%;
  height: auto;
  border: 0 !important;
  box-shadow: none !important;
}

.utl-footer-bottom {
  background: #2b2b2b;
  padding: 14px 0;
}

.utl-footer-bottom-row {
  overflow: hidden;
}

.utl-footer-bottom-links {
  float: left;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.utl-footer-bottom-links .sep {
  margin: 0 6px;
  opacity: 0.7;
  color: #ffffff;
}

.utl-footer-copyright {
  float: right;
  margin: 0;
  font-size: 14px;
  line-height: 1.2;
  color: #ffffff;
  opacity: 0.95;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .utl-footer-container {
    padding: 0 24px;
  }

  .utl-footer-col {
    float: none;
    width: 100%;
    padding-right: 0;
    margin-bottom: 28px;
  }

  .utl-footer-bottom-links,
  .utl-footer-copyright {
    float: none;
    display: block;
    text-align: center;
    white-space: normal;
  }

  .utl-footer-bottom-links {
    margin-bottom: 8px;
  }
}

/* Content typography refresh: closer to library.utoronto.ca */
main,
#main-wrapper,
#main,
.main-content,
.region-content {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
}

/* Main content width and breathing room */
#main-wrapper .container,
main .container {
  max-width: 980px;
}

/* Page titles */
main h1,
#main h1,
.region-content h1,
.page-title {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 1.25rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid #9cc9df;
}

/* Section headings */
main h2,
#main h2,
.region-content h2 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1.45rem;
  font-weight: 600;
  line-height: 1.3;
  margin-top: 2rem;
  margin-bottom: 0.85rem;
}

main h3,
#main h3,
.region-content h3 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.35;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

main h4,
#main h4,
.region-content h4 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 1.25rem;
  margin-bottom: 0.4rem;
}

/* Body copy */
main p,
#main p,
.region-content p,
main li,
#main li,
.region-content li {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 0.98rem;
  font-weight: 400;
  line-height: 1.65;
  color: #2f343a;
}

main p,
#main p,
.region-content p {
  margin-bottom: 1rem;
}

main ul,
main ol,
#main ul,
#main ol,
.region-content ul,
.region-content ol {
  padding-left: 1.35rem;
  margin-bottom: 1.25rem;
}

/* Links inside content */
main a,
#main a,
.region-content a {
  color: #007894;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

main a:hover,
main a:focus,
#main a:hover,
#main a:focus,
.region-content a:hover,
.region-content a:focus {
  color: #1e3765;
}

/* Make long text/list-heavy content feel less cramped */
.region-content .field,
.region-content .node__content,
.region-content .view-content {
  max-width: 920px;
}

/* Light card/search-box treatment like the newer site */
.region-content .well,
.region-content .card,
.region-content .panel,
.region-content .form-wrapper,
.region-content .views-exposed-form {
  border: 1px solid #d6dde3;
  background: #f7f8f9;
  border-radius: 0;
  padding: 1.25rem;
  box-shadow: none;
}

/* Accordions/details, if present */
.region-content details,
.region-content .details-wrapper {
  border-color: #cfd6dc;
}

.region-content summary,
.region-content .card-header,
.region-content .panel-heading {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-weight: 600;
}

/* Content typography refresh: closer to library.utoronto.ca */
main,
#main-wrapper,
#main,
.main-content,
.region-content {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
}

/* Main content width and breathing room */
#main-wrapper .container,
main .container {
  max-width: 980px;
}

/* Page titles */
main h1,
#main h1,
.region-content h1,
.page-title {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 1.25rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid #9cc9df;
}

/* Section headings */
main h2,
#main h2,
.region-content h2 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1.45rem;
  font-weight: 600;
  line-height: 1.3;
  margin-top: 2rem;
  margin-bottom: 0.85rem;
}

main h3,
#main h3,
.region-content h3 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.35;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

main h4,
#main h4,
.region-content h4 {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 1.25rem;
  margin-bottom: 0.4rem;
}

/* Body copy */
main p,
#main p,
.region-content p,
main li,
#main li,
.region-content li {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 0.98rem;
  font-weight: 400;
  line-height: 1.65;
  color: #2f343a;
}

main p,
#main p,
.region-content p {
  margin-bottom: 1rem;
}

main ul,
main ol,
#main ul,
#main ol,
.region-content ul,
.region-content ol {
  padding-left: 1.35rem;
  margin-bottom: 1.25rem;
}

/* Links inside content */
main a,
#main a,
.region-content a {
  color: #007894;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

main a:hover,
main a:focus,
#main a:hover,
#main a:focus,
.region-content a:hover,
.region-content a:focus {
  color: #1e3765;
}

/* Make long text/list-heavy content feel less cramped */
.region-content .field,
.region-content .node__content,
.region-content .view-content {
  max-width: 920px;
}

/* Light card/search-box treatment like the newer site */
.region-content .well,
.region-content .card,
.region-content .panel,
.region-content .form-wrapper,
.region-content .views-exposed-form {
  border: 1px solid #d6dde3;
  background: #f7f8f9;
  border-radius: 0;
  padding: 1.25rem;
  box-shadow: none;
}

/* Accordions/details, if present */
.region-content details,
.region-content .details-wrapper {
  border-color: #cfd6dc;
}

.region-content summary,
.region-content .card-header,
.region-content .panel-heading {
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  color: #2f343a;
  font-weight: 600;
}

/* APC Discounts view: publisher cards */
.view-oa-agreements-apc-discounts .view-content.row {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.25rem;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.view-oa-agreements-apc-discounts .publishers.views-row {
  background: #ffffff;
  border: 1px solid #d6dde3;
  border-radius: 10px;
  padding: 1.25rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.view-oa-agreements-apc-discounts .publishers.views-row:hover {
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.10);
  transform: translateY(-2px);
}

.view-oa-agreements-apc-discounts .views-field-title h2 {
  margin-top: 0;
  margin-bottom: 0.85rem;
  font-size: 1.15rem;
  line-height: 1.3;
}

.view-oa-agreements-apc-discounts .views-field-title h2 a {
  color: #007894;
  text-decoration: none;
}

.view-oa-agreements-apc-discounts .views-field-title h2 a:hover,
.view-oa-agreements-apc-discounts .views-field-title h2 a:focus {
  color: #1e3765;
  text-decoration: underline;
}

.view-oa-agreements-apc-discounts .publishers.views-row .views-field {
  margin-bottom: 0.6rem;
}

.view-oa-agreements-apc-discounts .publishers.views-row .views-field:last-child {
  margin-bottom: 0;
}

.view-oa-agreements-apc-discounts .publishers.views-row .field-content,
.view-oa-agreements-apc-discounts .publishers.views-row p {
  font-size: 0.92rem;
  line-height: 1.55;
}

.view-oa-agreements-apc-discounts .publishers.views-row b {
  color: #1e3765;
  font-weight: 700;
}

@media (max-width: 700px) {
  .view-oa-agreements-apc-discounts .view-content.row {
    grid-template-columns: 1fr;
  }
}

/* APC Discounts page: use more available screen width */
.page-view-oa-agreements-apc-discounts #main,
.page-view-oa-agreements-apc-discounts #main-wrapper .container,
.page-view-oa-agreements-apc-discounts main .container {
  max-width: 1440px !important;
  width: calc(100% - 160px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Give the card grid more room */
.view-oa-agreements-apc-discounts .view-content.row {
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 1.5rem;
}

/* Keep intro/search content aligned with the wider card grid */
.page-view-oa-agreements-apc-discounts .main-content,
.page-view-oa-agreements-apc-discounts .region-content {
  width: 100% !important;
}

@media (max-width: 900px) {
  .page-view-oa-agreements-apc-discounts #main,
  .page-view-oa-agreements-apc-discounts #main-wrapper .container,
  .page-view-oa-agreements-apc-discounts main .container {
    width: calc(100% - 32px) !important;
  }

  .view-oa-agreements-apc-discounts .view-content.row {
    grid-template-columns: 1fr;
  }
}

/* APC Discounts intro notes: soft emphasis block */
#block-libtools-bootstrap-publishersblock .field--name-body {
  background: #f3f8fa;
  border-left: 5px solid #9cc9df;
  padding: 1.25rem 1.5rem;
  margin: 1.5rem 0 2rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
}

/* Undo previous card/grid treatment if present */
#block-libtools-bootstrap-publishersblock .field--name-body ul {
  display: block !important;
  list-style: disc !important;
  margin: 0 !important;
  padding-left: 1.35rem !important;
}

#block-libtools-bootstrap-publishersblock .field--name-body li {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 0 0.75rem !important;
  font-size: 0.95rem;
  line-height: 1.55;
  color: #2f343a;
}

#block-libtools-bootstrap-publishersblock .field--name-body li:last-child {
  margin-bottom: 0 !important;
}

#block-libtools-bootstrap-publishersblock .field--name-body li::before {
  content: none !important;
}

/* SciFree journal search: modern full-width search bar */
#scfsearchform {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  width: 100% !important;
  max-width: 860px !important;
  margin: 1rem 0 1.5rem !important;
}

#scfsearchparam {
  width: 100% !important;
  height: 52px !important;
  padding: 0 3.25rem 0 1.1rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  background: #ffffff !important;
  color: #2f343a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.4 !important;
}

#scfsearchparam::placeholder {
  color: #5f6368 !important;
  font-weight: 400 !important;
}

#scfsearchparam:focus {
  outline: 2px solid #9cc9df !important;
  outline-offset: 2px !important;
  border-color: #007894 !important;
}

#scfsearch {
  position: absolute !important;
  right: 0.55rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 40px !important;
  height: 40px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #1e3765 !important;
  font-size: 0 !important;
  cursor: pointer !important;
}

#scfsearch::before {
  content: "⌕";
  display: block;
  font-size: 1.65rem;
  line-height: 40px;
  text-align: center;
  color: #1e3765;
}

#scfsearch:hover,
#scfsearch:focus {
  background: #eef6f8 !important;
  outline: none !important;
}

#scfsearch:focus-visible {
  outline: 2px solid #007894 !important;
  outline-offset: 2px !important;
}

/* Publisher OA agreement detail pages */
.node--type-publisher-oa-agreements .node__content {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 1.25rem;
  margin-top: 1.5rem;
}

/* Intro/body text spans full width */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  grid-column: 1 / -1;
  max-width: 900px;
  font-size: 1rem;
  line-height: 1.6;
  color: #2f343a;
}

/* Default field box style */
.node--type-publisher-oa-agreements .node__content > .field {
  background: #f5f5f5;
  border: 1px solid #d6dde3;
  border-radius: 12px;
  padding: 1.25rem;
  box-shadow: none;
}

/* Long-form fields should be wider */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles {
  grid-column: span 2;
  border-left: 5px solid #6d247a;
}

/* Compact facts */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual,
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  border-left: 5px solid #007894;
}

/* Labels */
.node--type-publisher-oa-agreements .field__label {
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.8rem;
  font-weight: 700 !important;
  letter-spacing: 0.06em;
  line-height: 1.3;
  margin-bottom: 0.65rem;
  text-transform: uppercase;
}

/* Field content */
.node--type-publisher-oa-agreements .field__item,
.node--type-publisher-oa-agreements .field__items,
.node--type-publisher-oa-agreements .field__item p {
  color: #2f343a;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.96rem;
  line-height: 1.6;
}

.node--type-publisher-oa-agreements .field__item p:last-child {
  margin-bottom: 0;
}

/* Make the main short values feel like stats */
.node--type-publisher-oa-agreements .field--name-field-discount-amount .field__item,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa .field__item,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual .field__item {
  color: #1a1a1a;
  font-size: 1.35rem;
  font-weight: 600;
  line-height: 1.3;
}

/* Eligibility values as pills */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__item {
  display: inline-flex;
  align-items: center;
  width: auto;
  background: #007894;
  color: #ffffff;
  border-radius: 999px;
  padding: 0.3rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Responsive */
@media (max-width: 1000px) {
  .node--type-publisher-oa-agreements .node__content {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }

  .node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
  .node--type-publisher-oa-agreements .field--name-field-eligible-titles {
    grid-column: 1 / -1;
  }
}

@media (max-width: 700px) {
  .node--type-publisher-oa-agreements .node__content {
    grid-template-columns: 1fr;
  }
}

/* APC Discounts cards: make whole card clickable via the title link */
.view-oa-agreements-apc-discounts .publishers.views-row {
  position: relative;
  cursor: pointer;
}

.view-oa-agreements-apc-discounts .views-field-title h2 a::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: 10px;
}

/* Keep visible focus style on the card when the title link receives focus */
.view-oa-agreements-apc-discounts .publishers.views-row:has(.views-field-title h2 a:focus-visible) {
  outline: 3px solid #007894;
  outline-offset: 3px;
}

/* Keep text selectable/visible above the card background */
.view-oa-agreements-apc-discounts .publishers.views-row .views-field {
  position: relative;
}

/* Publisher detail page: body intro should not be a card */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  grid-column: 1 / -1 !important;
  max-width: 900px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 0.75rem !important;
  box-shadow: none !important;
}

.node--type-publisher-oa-agreements .node__content > .field--name-body .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-body p {
  font-size: 1rem !important;
  line-height: 1.6 !important;
  color: #2f343a !important;
}

/* Publisher detail page: refine hierarchy */

/* Use a 12-column grid so we can control prominence */
.node--type-publisher-oa-agreements .node__content {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: 1.25rem !important;
  align-items: stretch !important;
}

/* Body intro: full-width, not a card */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  grid-column: 1 / -1 !important;
  max-width: none !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 0.5rem !important;
  box-shadow: none !important;
}

.node--type-publisher-oa-agreements .node__content > .field--name-body p {
  max-width: 980px !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
}

/* Small summary facts */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  grid-column: span 4 !important;
  min-height: 120px !important;
  background: #f5f5f5 !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 12px !important;
  padding: 1.1rem !important;
}

/* Make summary values clear but not huge */
.node--type-publisher-oa-agreements .field--name-field-discount-amount .field__item,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa .field__item,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual .field__item {
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  color: #1a1a1a !important;
}

/* Prominent information cards */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  grid-column: span 6 !important;
  background: #ffffff !important;
  border: 1px solid #d6dde3 !important;
  border-top: 5px solid #007894 !important;
  border-radius: 12px !important;
  padding: 1.35rem !important;
  min-height: 180px !important;
}

/* Eligibility pills can sit full-width beneath the main info */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  grid-column: 1 / -1 !important;
  background: #f5f5f5 !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 12px !important;
  padding: 1.25rem !important;
}

/* Labels */
.node--type-publisher-oa-agreements .field__label {
  color: #1e3765 !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  line-height: 1.35 !important;
  margin-bottom: 0.65rem !important;
  text-transform: uppercase !important;
}

/* More prominent body copy inside the main info cards */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles .field__item,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible .field__item,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles p,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible p,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered p {
  font-size: 0.98rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
}

/* Eligibility values as pills */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__items {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__item {
  display: inline-flex !important;
  width: auto !important;
  background: #007894 !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  padding: 0.3rem 0.7rem !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

/* Responsive */
@media (max-width: 1000px) {
  .node--type-publisher-oa-agreements .field--name-field-discount-amount,
  .node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
  .node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
    grid-column: span 6 !important;
  }

  .node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
  .node--type-publisher-oa-agreements .field--name-field-eligible-titles,
  .node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
  .node--type-publisher-oa-agreements .field--name-field-who-is-covered {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 700px) {
  .node--type-publisher-oa-agreements .field--name-field-discount-amount,
  .node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
  .node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
    grid-column: 1 / -1 !important;
  }
}

/* Publisher detail page: refine hierarchy */

/* Use a 12-column grid so we can control prominence */
.node--type-publisher-oa-agreements .node__content {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: 1.25rem !important;
  align-items: stretch !important;
}

/* Body intro: full-width, not a card */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  grid-column: 1 / -1 !important;
  max-width: none !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 0.5rem !important;
  box-shadow: none !important;
}

.node--type-publisher-oa-agreements .node__content > .field--name-body p {
  max-width: 980px !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
}

/* Small summary facts */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  grid-column: span 4 !important;
  min-height: 120px !important;
  background: #f5f5f5 !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 12px !important;
  padding: 1.1rem !important;
}

/* Make summary values clear but not huge */
.node--type-publisher-oa-agreements .field--name-field-discount-amount .field__item,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa .field__item,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual .field__item {
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  color: #1a1a1a !important;
}

/* Prominent information cards */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  grid-column: span 6 !important;
  background: #ffffff !important;
  border: 1px solid #d6dde3 !important;
  border-top: 5px solid #007894 !important;
  border-radius: 12px !important;
  padding: 1.35rem !important;
  min-height: 180px !important;
}

/* Eligibility pills can sit full-width beneath the main info */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  grid-column: 1 / -1 !important;
  background: #f5f5f5 !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 12px !important;
  padding: 1.25rem !important;
}

/* Labels */
.node--type-publisher-oa-agreements .field__label {
  color: #1e3765 !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  line-height: 1.35 !important;
  margin-bottom: 0.65rem !important;
  text-transform: uppercase !important;
}

/* More prominent body copy inside the main info cards */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles .field__item,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible .field__item,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles p,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible p,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered p {
  font-size: 0.98rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
}

/* Eligibility values as pills */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__items {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__item {
  display: inline-flex !important;
  width: auto !important;
  background: #007894 !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  padding: 0.3rem 0.7rem !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

/* Responsive */
@media (max-width: 1000px) {
  .node--type-publisher-oa-agreements .field--name-field-discount-amount,
  .node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
  .node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
    grid-column: span 6 !important;
  }

  .node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali,
  .node--type-publisher-oa-agreements .field--name-field-eligible-titles,
  .node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
  .node--type-publisher-oa-agreements .field--name-field-who-is-covered {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 700px) {
  .node--type-publisher-oa-agreements .field--name-field-discount-amount,
  .node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
  .node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
    grid-column: 1 / -1 !important;
  }
}

/* Publisher detail: make "How do I apply this deal" an explanatory section below body */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali {
  order: 2 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  box-shadow: none !important;
  min-height: 0 !important;
}

/* Body stays first and full-width */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 1 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
}

/* Summary cards come after the explanatory text */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  order: 3 !important;
}

/* Other larger info cards follow */
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  order: 4 !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  order: 5 !important;
}

/* Section heading treatment instead of card label */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__label {
  color: #1e3765 !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  text-transform: none !important;
  margin: 0 0 0.75rem !important;
  padding-bottom: 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
  display: inline-block !important;
}

/* Section body text */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p {
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
  max-width: 900px !important;
}

/* Publisher detail: make "How do I apply this deal" an explanatory section below body */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali {
  order: 2 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  box-shadow: none !important;
  min-height: 0 !important;
}

/* Body stays first and full-width */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 1 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
}

/* Summary cards come after the explanatory text */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  order: 3 !important;
}

/* Other larger info cards follow */
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  order: 4 !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  order: 5 !important;
}

/* Section heading treatment instead of card label */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__label {
  color: #1e3765 !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  text-transform: none !important;
  margin: 0 0 0.75rem !important;
  padding-bottom: 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
  display: inline-block !important;
}

/* Section body text */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p {
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
  max-width: 900px !important;
}

/* Publisher detail: make "How do I apply this deal" an explanatory section below body */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali {
  order: 2 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  box-shadow: none !important;
  min-height: 0 !important;
}

/* Body stays first and full-width */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 1 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
}

/* Summary cards come after the explanatory text */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  order: 3 !important;
}

/* Other larger info cards follow */
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  order: 4 !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  order: 5 !important;
}

/* Section heading treatment instead of card label */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__label {
  color: #1e3765 !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  text-transform: none !important;
  margin: 0 0 0.75rem !important;
  padding-bottom: 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
  display: inline-block !important;
}

/* Section body text */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p {
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #2f343a !important;
  max-width: 900px !important;
}

/* Publisher detail: take "How do I apply this deal" out of card styling */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali {
  order: 2 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;

  background: transparent !important;
  border: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  min-height: 0 !important;
}

/* Keep body first */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 1 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
}

/* Make the label look like a normal section heading */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__label {
  display: block !important;
  color: #1e3765 !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  line-height: 1.35 !important;
  margin: 0 0 0.75rem !important;
  padding: 0 0 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
}

/* Make the content read as body copy, not metadata */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p {
  max-width: 900px !important;
  color: #2f343a !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
}

/* Publisher detail: take "How do I apply this deal" out of card styling */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali {
  order: 2 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;

  background: transparent !important;
  border: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  min-height: 0 !important;
}

/* Keep body first */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 1 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
}

/* Make the label look like a normal section heading */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__label {
  display: block !important;
  color: #1e3765 !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  line-height: 1.35 !important;
  margin: 0 0 0.75rem !important;
  padding: 0 0 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
}

/* Make the content read as body copy, not metadata */
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .field--name-field-approval-process-uoft-vali p {
  max-width: 900px !important;
  color: #2f343a !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
}

/* FINAL publisher detail ordering:
   body intro first, "How do I apply this deal" second, cards after.
*/

/* Make sure the node content uses ordering */
.node--type-publisher-oa-agreements .node__content {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: 1.25rem !important;
  align-items: start !important;
}

/* Intro/body text first */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  order: 10 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 0 0.25rem !important;
  box-shadow: none !important;
}

/* "How do I apply this deal" below the body, not in a card */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal {
  order: 20 !important;
  grid-column: 1 / -1 !important;
  max-width: 980px !important;

  background: transparent !important;
  border: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  min-height: 0 !important;
}

/* Its label becomes a real section heading */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label {
  display: block !important;
  color: #1e3765 !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  text-transform: none !important;

  margin: 0 0 0.75rem !important;
  padding: 0 0 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
}

/* Its text behaves like body copy */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal p {
  max-width: 900px !important;
  color: #2f343a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
}

/* Put the smaller summary fields after the body + how-to section */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  order: 30 !important;
  grid-column: span 4 !important;
}

/* Put the remaining info sections after the summary cards */
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  order: 40 !important;
  grid-column: span 6 !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  order: 50 !important;
  grid-column: 1 / -1 !important;
}

/* FINAL publisher detail sizing: calmer labels, values, and card text */

.node--type-publisher-oa-agreements .node__content {
  gap: 1rem !important;
}

/* All publisher detail cards */
.node--type-publisher-oa-agreements .node__content > .field:not(.field--name-body):not(.field--name-field-approval-process-uoft-vali) {
  padding: 1.15rem 1.25rem !important;
  border-radius: 10px !important;
}

/* Small summary cards */
.node--type-publisher-oa-agreements .field--name-field-discount-amount,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual {
  min-height: 105px !important;
}

/* Labels: less tiny, less shouty */
.node--type-publisher-oa-agreements .field__label {
  color: #1e3765 !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.045em !important;
  line-height: 1.35 !important;
  margin-bottom: 0.65rem !important;
  text-transform: uppercase !important;
}

/* Summary values */
.node--type-publisher-oa-agreements .field--name-field-discount-amount .field__item,
.node--type-publisher-oa-agreements .field--name-field-discount-or-funding-availa .field__item,
.node--type-publisher-oa-agreements .field--name-field-license-end-date-textual .field__item {
  font-size: 1.08rem !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  color: #1a1a1a !important;
}

/* Larger info cards: less oversized text */
.node--type-publisher-oa-agreements .field--name-field-eligible-titles,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered {
  min-height: 0 !important;
  border-top-width: 4px !important;
}

.node--type-publisher-oa-agreements .field--name-field-eligible-titles .field__item,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible .field__item,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered .field__item,
.node--type-publisher-oa-agreements .field--name-field-eligible-titles p,
.node--type-publisher-oa-agreements .field--name-field-what-journals-are-eligible p,
.node--type-publisher-oa-agreements .field--name-field-who-is-covered p {
  font-size: 0.93rem !important;
  line-height: 1.55 !important;
  color: #2f343a !important;
}

/* Eligibility card and pills */
.node--type-publisher-oa-agreements .field--name-field-who-is-eligible {
  padding: 1rem 1.25rem !important;
}

.node--type-publisher-oa-agreements .field--name-field-who-is-eligible .field__item {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  padding: 0.28rem 0.65rem !important;
}

/* Links inside cards */
.node--type-publisher-oa-agreements .node__content a {
  color: #007894 !important;
  text-decoration-thickness: 1px !important;
  text-underline-offset: 0.15em !important;
}

/* Publisher detail page: fix uneven right margin / content width */
body.node--type-publisher-oa-agreements #main,
body.node--type-publisher-oa-agreements #main-wrapper .container,
body.node--type-publisher-oa-agreements main .container {
  max-width: 1180px !important;
  width: calc(100% - 160px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Make publisher content use the same width as the cards/notice */
.node--type-publisher-oa-agreements .node__content {
  width: 100% !important;
}

/* Body intro should use the full content width, not a narrow measure */
.node--type-publisher-oa-agreements .node__content > .field--name-body {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;
}

.node--type-publisher-oa-agreements .node__content > .field--name-body p {
  max-width: none !important;
}

/* "How do I apply this deal" should align with the same full width */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;
}

.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal p {
  max-width: none !important;
}

/* Make the section heading underline feel intentional, not arbitrarily short */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label {
  width: 100% !important;
  max-width: none !important;
}

/* Mobile */
@media (max-width: 900px) {
  body.node--type-publisher-oa-agreements #main,
  body.node--type-publisher-oa-agreements #main-wrapper .container,
  body.node--type-publisher-oa-agreements main .container {
    width: calc(100% - 32px) !important;
  }
}

/* APC listing page: clean up journal search area */

/* Remove the old grey boxed treatment around the search text and form */
.page-view-oa-agreements-apc-discounts .field__item:has(#scfsearchform),
.page-view-oa-agreements-apc-discounts .content:has(#scfsearchform),
.page-view-oa-agreements-apc-discounts .block:has(#scfsearchform) {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* Intro text above search */
.page-view-oa-agreements-apc-discounts .search-text,
.page-view-oa-agreements-apc-discounts .journal-search-text,
.page-view-oa-agreements-apc-discounts #block-libtools-bootstrap-publishersblock + .block .field--name-body {
  max-width: 1180px !important;
  margin: 1.25rem auto 0.75rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  color: #2f343a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.55 !important;
}

/* Search form itself */
.page-view-oa-agreements-apc-discounts #scfsearchform {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: 1180px !important;
  margin: 0.75rem auto 1.75rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Search input */
.page-view-oa-agreements-apc-discounts #scfsearchparam {
  width: 100% !important;
  height: 54px !important;
  padding: 0 3.5rem 0 1.2rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  box-shadow: none !important;
  color: #1a1a1a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.4 !important;
}

.page-view-oa-agreements-apc-discounts #scfsearchparam::placeholder {
  color: #5f6368 !important;
  font-weight: 400 !important;
}

.page-view-oa-agreements-apc-discounts #scfsearchparam:focus {
  border-color: #007894 !important;
  outline: 2px solid #9cc9df !important;
  outline-offset: 2px !important;
}

/* Search icon button */
.page-view-oa-agreements-apc-discounts #scfsearch {
  position: absolute !important;
  right: 0.5rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 42px !important;
  height: 42px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

.page-view-oa-agreements-apc-discounts #scfsearch::before {
  content: "";
  display: block;
  width: 21px;
  height: 21px;
  margin: 10px auto;
  background-color: #1e3765;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l.27.27h.79l5 4.99-1.49 1.49-4.99-5v-.79l-.27-.27A6.5 6.5 0 1 1 9.5 3Zm0 2A4.5 4.5 0 1 0 14 9.5 4.5 4.5 0 0 0 9.5 5Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l.27.27h.79l5 4.99-1.49 1.49-4.99-5v-.79l-.27-.27A6.5 6.5 0 1 1 9.5 3Zm0 2A4.5 4.5 0 1 0 14 9.5 4.5 4.5 0 0 0 9.5 5Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.page-view-oa-agreements-apc-discounts #scfsearch:hover,
.page-view-oa-agreements-apc-discounts #scfsearch:focus {
  background: #eef6f8 !important;
}

.page-view-oa-agreements-apc-discounts #scfsearch:focus-visible {
  outline: 2px solid #007894 !important;
  outline-offset: 2px !important;
}

/* Remove extra grey treatment if this form is being affected by old views-exposed-form CSS */
.page-view-oa-agreements-apc-discounts .views-exposed-form:has(#scfsearchform) {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

/* FINAL fix: align "How do I apply this deal" with body/cards */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;

  background: transparent !important;
  border: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 0 2rem 0 !important;
  min-height: 0 !important;
}

/* Remove inherited card padding from inner content too */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__item {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Keep the heading full-width but aligned */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label {
  width: 100% !important;
  padding-bottom: 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
}

/* Keep paragraph aligned with heading */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal p {
  margin-left: 0 !important;
  padding-left: 0 !important;
  max-width: none !important;
}

/* FINAL fix: align "How do I apply this deal" with body/cards */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;

  background: transparent !important;
  border: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 0 2rem 0 !important;
  min-height: 0 !important;
}

/* Remove inherited card padding from inner content too */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__item {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Keep the heading full-width but aligned */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label {
  width: 100% !important;
  padding-bottom: 0.45rem !important;
  border-bottom: 3px solid #007894 !important;
}

/* Keep paragraph aligned with heading */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali p,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal p {
  margin-left: 0 !important;
  padding-left: 0 !important;
  max-width: none !important;
}

/* APC listing page: clarify external journal search vs local publisher browse */

/* Wrap the external journal search as its own section */
.page-view-oa-agreements-apc-discounts #scfsearchform {
  max-width: 1180px !important;
  margin: 0.75rem auto 2.25rem !important;
  padding-top: 2.25rem !important;
  position: relative !important;
}

/* Label the search task */
.page-view-oa-agreements-apc-discounts #scfsearchform::before {
  content: "Search journals";
  position: absolute;
  top: 0;
  left: 0;
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.3;
}

/* External search helper text */
.page-view-oa-agreements-apc-discounts #scfsearchform::after {
  content: "This searches an external journal lookup tool. Use it to check a journal title, subject area, publisher, or ISSN.";
  display: block;
  margin-top: 0.6rem;
  color: #4d4d4d;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.9rem;
  line-height: 1.5;
}

/* Make the search input feel connected to the heading/helper */
.page-view-oa-agreements-apc-discounts #scfsearchparam {
  margin-top: 0.25rem !important;
}

/* Add a browse heading before the publisher card grid */
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts::before {
  content: "Browse publisher agreements";
  display: block;
  max-width: 1180px;
  margin: 2rem auto 0.35rem;
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Reframe the existing instruction text under the browse heading */
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .view-header,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .views-header {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
  color: #2f343a;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.55;
}

/* HARD FIX: align "How do I apply this deal" with the body text */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal {
  position: relative !important;
  left: -1.25rem !important;
  width: calc(100% + 1.25rem) !important;
  max-width: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}

/* Keep the heading underline full width after shifting left */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__label,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__label {
  margin-left: 0 !important;
  padding-left: 0 !important;
  width: 100% !important;
}

/* Keep the paragraph aligned with the heading */
.node--type-publisher-oa-agreements .node__content > .field--name-field-approval-process-uoft-vali > .field__item,
.node--type-publisher-oa-agreements .node__content > .field--name-field-how-do-i-apply-this-deal > .field__item {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* APC listing page: cleaner search/browse language */

/* Search section heading */
.page-view-oa-agreements-apc-discounts #scfsearchform::before {
  content: "Find a journal discount" !important;
  position: absolute;
  top: 0;
  left: 0;
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Search helper text */
.page-view-oa-agreements-apc-discounts #scfsearchform::after {
  content: "Search by journal title, publisher, subject area, or ISSN." !important;
  display: block;
  margin-top: 0.6rem;
  color: #4d4d4d;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.9rem;
  line-height: 1.5;
}

/* Browse section heading */
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts::before {
  content: "Browse publisher agreements" !important;
  display: block;
  max-width: 1180px;
  margin: 2rem auto 0.35rem;
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Replace/remove awkward old view header copy */
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .view-header,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .views-header {
  font-size: 0 !important;
  line-height: 0 !important;
  margin: 0 auto 0.75rem !important;
  max-width: 1180px !important;
}

.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .view-header::after,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .views-header::after {
  content: "Select a publisher to view eligibility, coverage, discount details, and instructions.";
  display: block;
  color: #2f343a;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.55;
}

/* FINAL APC listing header/search cleanup */

/* Stop older generated/pseudo copy from showing */
.page-view-oa-agreements-apc-discounts #scfsearchform::before,
.page-view-oa-agreements-apc-discounts #scfsearchform::after,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts::before,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .view-header::after,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .views-header::after {
  content: none !important;
  display: none !important;
}

/* Restore actual view header content */
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .view-header,
.page-view-oa-agreements-apc-discounts .view-oa-agreements-apc-discounts .views-header {
  font-size: 1rem !important;
  line-height: 1.55 !important;
  margin: 0 auto 1.5rem !important;
  max-width: 1180px !important;
  color: #2f343a !important;
}

/* Intro paragraph */
.apc-intro {
  max-width: 1180px;
  margin: 0 auto 1.5rem;
}

.apc-intro p {
  margin: 0;
  color: #2f343a;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.apc-intro a,
.apc-journal-search a,
.apc-browse-intro a {
  color: #007894;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

/* Journal search section */
.apc-journal-search {
  max-width: 1180px;
  margin: 0 auto 2rem;
  padding: 1.35rem 1.5rem 1.5rem;
  background: #f3f8fa;
  border-left: 5px solid #9cc9df;
}

.apc-journal-search .search-text {
  position: static !important;
  display: block !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
}

.apc-journal-search h2,
.apc-browse-intro h2 {
  margin: 0 0 0.5rem;
  color: #1e3765;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.35;
}

.apc-journal-search p,
.apc-browse-intro p {
  margin: 0;
  color: #2f343a;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.98rem;
  line-height: 1.55;
}

/* SciFree injected search form */
.apc-journal-search #scfsearchform,
.page-view-oa-agreements-apc-discounts #scfsearchform {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 1rem 0 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* SciFree search input */
.apc-journal-search #scfsearchparam,
.page-view-oa-agreements-apc-discounts #scfsearchparam {
  width: 100% !important;
  height: 54px !important;
  padding: 0 3.5rem 0 1.2rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  box-shadow: none !important;
  color: #1a1a1a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.4 !important;
}

.apc-journal-search #scfsearchparam::placeholder {
  color: #5f6368 !important;
  font-weight: 400 !important;
}

.apc-journal-search #scfsearchparam:focus,
.page-view-oa-agreements-apc-discounts #scfsearchparam:focus {
  border-color: #007894 !important;
  outline: 2px solid #9cc9df !important;
  outline-offset: 2px !important;
}

/* Search button as icon button */
.apc-journal-search #scfsearch,
.page-view-oa-agreements-apc-discounts #scfsearch {
  position: absolute !important;
  right: 0.5rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 42px !important;
  height: 42px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

.apc-journal-search #scfsearch::before,
.page-view-oa-agreements-apc-discounts #scfsearch::before {
  content: "";
  display: block;
  width: 21px;
  height: 21px;
  margin: 10px auto;
  background-color: #1e3765;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l.27.27h.79l5 4.99-1.49 1.49-4.99-5v-.79l-.27-.27A6.5 6.5 0 1 1 9.5 3Zm0 2A4.5 4.5 0 1 0 14 9.5 4.5 4.5 0 0 0 9.5 5Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l.27.27h.79l5 4.99-1.49 1.49-4.99-5v-.79l-.27-.27A6.5 6.5 0 1 1 9.5 3Zm0 2A4.5 4.5 0 1 0 14 9.5 4.5 4.5 0 0 0 9.5 5Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.apc-journal-search #scfsearch:hover,
.apc-journal-search #scfsearch:focus,
.page-view-oa-agreements-apc-discounts #scfsearch:hover,
.page-view-oa-agreements-apc-discounts #scfsearch:focus {
  background: #eef6f8 !important;
}

/* Browse intro before cards */
.apc-browse-intro {
  max-width: 1180px;
  margin: 2rem auto 1rem;
  padding-top: 1.25rem;
  border-top: 1px solid #d6dde3;
}

/* Hide old exposed form if it appears on this page */
.page-view-oa-agreements-apc-discounts .views-exposed-form {
  display: none !important;
}

/* FINAL APC listing: stronger headings, no blue search box */

/* Remove the blue notice-box treatment */
.apc-journal-search {
  max-width: 1180px !important;
  margin: 2rem auto 2.25rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

/* Stronger section headings */
.apc-journal-search h2,
.apc-browse-intro h2 {
  display: inline-block !important;
  position: relative !important;
  margin: 0 0 1rem !important;
  padding-bottom: 0.45rem !important;
  color: #1e3765 !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

.apc-journal-search h2::after,
.apc-browse-intro h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 120px;
  height: 3px;
  background: #007894;
}

/* Intro text under headings */
.apc-journal-search p,
.apc-browse-intro p {
  max-width: 980px !important;
  margin: 0 0 1rem !important;
  color: #2f343a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
}

/* Search form should sit as its own clean element, not inside a coloured panel */
.apc-journal-search #scfsearchform,
.page-view-oa-agreements-apc-discounts #scfsearchform {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: 1180px !important;
  margin: 1.25rem 0 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Keep the input clean and modern */
.apc-journal-search #scfsearchparam,
.page-view-oa-agreements-apc-discounts #scfsearchparam {
  width: 100% !important;
  height: 54px !important;
  padding: 0 3.5rem 0 1.2rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  box-shadow: none !important;
  color: #1a1a1a !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: 1rem !important;
}

/* Browse section spacing */
.apc-browse-intro {
  max-width: 1180px !important;
  margin: 2.75rem auto 1.25rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid #d6dde3 !important;
}

/* FINAL: page title treatment closer to main library site */

/* Page title block spacing */
.block-page-title-block,
.region-content > h1:first-child,
main h1.page-title,
main .page-title {
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Main page titles */
main h1,
main h1.page-title,
.page-title,
.block-page-title-block h1 {
  color: #1e3765 !important;
  font-family: "Open Sans", Arial, Helvetica, sans-serif !important;
  font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.015em !important;
  margin: 0 0 1.5rem !important;
  padding: 0 0 0.85rem !important;
  border-bottom: 1px solid #d6dde3 !important;
  position: relative !important;
}

/* Teal accent under page titles */
main h1::after,
main h1.page-title::after,
.page-title::after,
.block-page-title-block h1::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 120px;
  height: 3px;
  background: #007894;
}

/* Publisher agreement pages: add small page-type label above title */
body.node--type-publisher-oa-agreements .block-page-title-block h1::before,
body.node--type-publisher-oa-agreements main h1::before {
  content: "Publisher agreement";
  display: block;
  margin-bottom: 0.55rem;
  color: #4d4d4d;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.3;
  text-transform: uppercase;
}

/* APC listing page: page title spacing */
body.page-view-oa-agreements-apc-discounts .block-page-title-block h1::before,
body.page-view-oa-agreements-apc-discounts main h1::before {
  content: "Open access publishing";
  display: block;
  margin-bottom: 0.55rem;
  color: #4d4d4d;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.3;
  text-transform: uppercase;
}

/* Avoid making admin tabs look like page headings */
main .tabs h1,
main nav h1,
.toolbar h1 {
  color: inherit !important;
  font-size: inherit !important;
  border-bottom: 0 !important;
}

main .tabs h1::after,
main nav h1::after,
.toolbar h1::after {
  content: none !important;
}

@media (max-width: 900px) {
  .block-page-title-block,
  .region-content > h1:first-child,
  main h1.page-title,
  main .page-title {
    max-width: none !important;
  }

  main h1,
  main h1.page-title,
  .page-title,
  .block-page-title-block h1 {
    font-size: 1.75rem !important;
  }
}

/* APC listing page title eyebrow */
body.page-view-oa-agreements-apc-discounts .block-page-title-block h1::before,
body.page-view-oa-agreements-apc-discounts main h1::before {
  content: "Scholarly Communications and Copyright" !important;
}

/* Header: hide Library Tools branding unless user is authenticated */
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) #block-libtools-bootstrap-sitebranding,
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) .navbar-brand {
  display: none !important;
}

/* Header: reduce excessive vertical spacing */
#header,
header[role="banner"] {
  margin-bottom: 2rem !important;
}

#header .region-header,
#header .region--header,
header[role="banner"] .region-header,
header[role="banner"] .region--header {
  min-height: 0 !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Branding spacing when logged in */
body.user-logged-in .site-branding-text {
  margin-bottom: 2rem !important;
}

/* Primary navigation should not be pushed far down */
#navbar-main,
#CollapsingNavbar,
.navbar,
nav[role="navigation"] {
  margin-top: 0 !important;
}

/* On anonymous/public view, pull content up once branding is hidden */
body:not(.user-logged-in) main,
body:not(.user-logged-in) #main,
body:not(.user-logged-in) #main-wrapper {
  margin-top: 2rem !important;
}

/* FINAL header spacing reset */

/* Top blue institutional bar */
.utl-top-bar {
  margin: 0 !important;
}

/* Do not let the header reserve a giant empty area */
header[role="banner"],
#header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
}

/* Collapse empty header/branding regions */
header[role="banner"] .region-header,
header[role="banner"] .region--header,
#header .region-header,
#header .region--header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide Library Tools branding for public/anonymous users and collapse its space */
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) #block-libtools-bootstrap-sitebranding,
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) #block-libtools-bootstrap-site-branding {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* For logged-in users, keep Library Tools but remove the giant gap below it */
body.user-logged-in .navbar-brand,
body.user-logged-in .site-branding-text {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Primary nav should sit close to the brand/top bar */
.navbar,
nav.navbar,
#navbar-main,
#CollapsingNavbar {
  min-height: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 1.25rem !important;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

/* Remove giant space before main content */
main,
#main,
#main-wrapper,
.main-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Page title should start closer to the header */
.block-page-title-block,
.region-content > .block-page-title-block,
main .block-page-title-block {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* If the branding block is empty/hidden, collapse the nav container around it */
body:not(.user-logged-in) header[role="banner"] nav,
body:not(.user-logged-in) #header nav {
  margin-top: 0 !important;
}

/* FINAL header spacing reset */

/* Top blue institutional bar */
.utl-top-bar {
  margin: 0 !important;
}

/* Do not let the header reserve a giant empty area */
header[role="banner"],
#header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
}

/* Collapse empty header/branding regions */
header[role="banner"] .region-header,
header[role="banner"] .region--header,
#header .region-header,
#header .region--header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide Library Tools branding for public/anonymous users and collapse its space */
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) #block-libtools-bootstrap-sitebranding,
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) #block-libtools-bootstrap-site-branding {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* For logged-in users, keep Library Tools but remove the giant gap below it */
body.user-logged-in .navbar-brand,
body.user-logged-in .site-branding-text {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Primary nav should sit close to the brand/top bar */
.navbar,
nav.navbar,
#navbar-main,
#CollapsingNavbar {
  min-height: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 1.25rem !important;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

/* Remove giant space before main content */
main,
#main,
#main-wrapper,
.main-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Page title should start closer to the header */
.block-page-title-block,
.region-content > .block-page-title-block,
main .block-page-title-block {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* If the branding block is empty/hidden, collapse the nav container around it */
body:not(.user-logged-in) header[role="banner"] nav,
body:not(.user-logged-in) #header nav {
  margin-top: 0 !important;
}

/* FINAL header spacing reset */

/* Top blue institutional bar */
.utl-top-bar {
  margin: 0 !important;
}

/* Do not let the header reserve a giant empty area */
header[role="banner"],
#header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
}

/* Collapse empty header/branding regions */
header[role="banner"] .region-header,
header[role="banner"] .region--header,
#header .region-header,
#header .region--header {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide Library Tools branding for public/anonymous users and collapse its space */
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) #block-libtools-bootstrap-sitebranding,
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) #block-libtools-bootstrap-site-branding {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* For logged-in users, keep Library Tools but remove the giant gap below it */
body.user-logged-in .navbar-brand,
body.user-logged-in .site-branding-text {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Primary nav should sit close to the brand/top bar */
.navbar,
nav.navbar,
#navbar-main,
#CollapsingNavbar {
  min-height: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 1.25rem !important;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

/* Remove giant space before main content */
main,
#main,
#main-wrapper,
.main-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Page title should start closer to the header */
.block-page-title-block,
.region-content > .block-page-title-block,
main .block-page-title-block {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* If the branding block is empty/hidden, collapse the nav container around it */
body:not(.user-logged-in) header[role="banner"] nav,
body:not(.user-logged-in) #header nav {
  margin-top: 0 !important;
}

/* Final public header fix: remove empty generated main navbar */
#navbar-main,
nav#navbar-main.navbar,
.navbar#navbar-main {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Remove extra header gap caused by the empty navbar area */
#header,
header[role="banner"] {
  margin-bottom: 1.5rem !important;
  padding-bottom: 0 !important;
}

#main-wrapper,
#main,
main.main-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* FINAL header visibility:
   - Public users: hide Library Tools branding and empty navbar
   - Logged-in users: show Library Tools branding and navbar
*/

/* Public / anonymous users */
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) #navbar-main {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Logged-in users */
body.user-logged-in #block-libtools-bootstrap-branding,
body.user-logged-in .block-system-branding-block,
body.user-logged-in .navbar-brand,
body.user-logged-in .site-branding-text {
  display: flex !important;
  visibility: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

/* Restore navbar for logged-in users */
body.user-logged-in #navbar-main {
  display: flex !important;
  visibility: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  margin: 0 0 1.25rem !important;
  padding: 0.5rem 100px !important;
  border: 0 !important;
  overflow: visible !important;
}

/* Keep public pages from reserving empty header space */
body:not(.user-logged-in) #header,
body:not(.user-logged-in) header[role="banner"] {
  margin-bottom: 1.5rem !important;
  padding-bottom: 0 !important;
}

/* FINAL logged-in header spacing: prevent Library Tools from overlapping nav */

/* The branding block itself should stack normally */
body.user-logged-in #block-libtools-bootstrap-branding,
body.user-logged-in .block-system-branding-block {
  display: block !important;
  visibility: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  margin: 0 0 1.25rem 0 !important;
  padding: 0 !important;
  clear: both !important;
}

/* The actual Library Tools wordmark can stay flex */
body.user-logged-in .navbar-brand {
  display: flex !important;
  visibility: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  margin: 0 !important;
  padding: 1.5rem 100px 0.75rem 100px !important;
  clear: both !important;
}

/* Keep the text itself clean */
body.user-logged-in .site-branding-text {
  display: inline-flex !important;
  visibility: visible !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

/* Logged-in navbar sits below branding, not on top of it */
body.user-logged-in #navbar-main {
  display: flex !important;
  position: relative !important;
  clear: both !important;
  width: 100% !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0.6rem 100px !important;
  z-index: 1 !important;
}

/* Branding should sit above the nav layer */
body.user-logged-in #block-libtools-bootstrap-branding {
  position: relative !important;
  z-index: 2 !important;
}

/* FINAL logged-in Library Tools alignment */
body.user-logged-in #block-libtools-bootstrap-branding {
  display: block !important;
  width: 100% !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
}

/* Match the top-bar/content left gutter */
body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand {
  display: flex !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 1.5rem 100px 0.75rem 100px !important;
  align-items: center !important;
}

/* Do not double-indent the Library Tools text */
body.user-logged-in #block-libtools-bootstrap-branding .site-branding-text,
body.user-logged-in #block-libtools-bootstrap-branding .site-branding-text__library,
body.user-logged-in #block-libtools-bootstrap-branding .site-branding-text__edit {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Keep the logged-in nav aligned to the same gutter */
body.user-logged-in #navbar-main {
  padding-left: 100px !important;
  padding-right: 100px !important;
}

/* Mobile gutter */
@media (max-width: 900px) {
  body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand,
  body.user-logged-in #navbar-main {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}

/* Publisher agreement breadcrumb/back link */
.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb {
  grid-column: 1 / -1;
  width: 100%;
  margin: 0 0 1.25rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.92rem;
  line-height: 1.5;
}

.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb li {
  color: #4d4d4d;
}

.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb li + li::before {
  content: "›";
  margin-right: 0.35rem;
  color: #6b7280;
}

.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb a:hover,
.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb a:focus {
  color: #007894;
}

/* Publisher agreement: simple back link below page title */
.node--type-publisher-oa-agreements .publisher-agreement-breadcrumb {
  display: none !important;
}

.node--type-publisher-oa-agreements .publisher-agreement-back-link {
  width: 100%;
  max-width: 1180px;
  margin: -0.75rem auto 1.5rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

.node--type-publisher-oa-agreements .publisher-agreement-back-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.node--type-publisher-oa-agreements .publisher-agreement-back-link a:hover,
.node--type-publisher-oa-agreements .publisher-agreement-back-link a:focus {
  color: #007894;
}

/* Move publisher agreement back link above the page title */
.publisher-agreement-title-back-link {
  display: none;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link {
  display: block;
  max-width: 1180px;
  margin: 0 auto 0.75rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a:hover,
body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a:focus {
  color: #007894;
}

/* Hide the older in-body back link if it still exists in the node template */
body.page-node-type-publisher-oa-agreements .node__content .publisher-agreement-back-link,
body.page-node-type-publisher-oa-agreements article .publisher-agreement-back-link {
  display: none !important;
}

/* Move publisher agreement back link above the page title */
.publisher-agreement-title-back-link {
  display: none;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link {
  display: block;
  max-width: 1180px;
  margin: 0 auto 0.75rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a:hover,
body.page-node-type-publisher-oa-agreements .publisher-agreement-title-back-link a:focus {
  color: #007894;
}

/* Hide the older in-body back link if it still exists in the node template */
body.page-node-type-publisher-oa-agreements .node__content .publisher-agreement-back-link,
body.page-node-type-publisher-oa-agreements article .publisher-agreement-back-link {
  display: none !important;
}

/* Publisher agreement back link moved above page title */
.publisher-agreement-back-link--above-title {
  display: block !important;
  max-width: 1180px;
  margin: 0 auto 0.75rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

.publisher-agreement-back-link--above-title a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.publisher-agreement-back-link--above-title a:hover,
.publisher-agreement-back-link--above-title a:focus {
  color: #007894;
}

/* Definitive publisher agreement title back link */
#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link {
  display: block !important;
  max-width: 1180px;
  margin: 0 auto 0.75rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a:hover,
#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a:focus {
  color: #007894;
}

/* Hide the older node-content back link */
.publisher-agreement-back-link {
  display: none !important;
}

/* Definitive publisher agreement title back link */
#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link {
  display: block !important;
  max-width: 1180px;
  margin: 0 auto 0.75rem;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a:hover,
#block-libtools-bootstrap-page-title .publisher-agreement-title-back-link a:focus {
  color: #007894;
}

/* Hide the older node-content back link */
.publisher-agreement-back-link {
  display: none !important;
}

/* Publisher agreement: bottom return link */
.publisher-agreement-title-back-link,
.publisher-agreement-back-link {
  display: none !important;
}

.publisher-agreement-bottom-link {
  max-width: 1180px;
  margin: 2.5rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid #d6dde3;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
}

.publisher-agreement-bottom-link a {
  color: #1e3765;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.publisher-agreement-bottom-link a:hover,
.publisher-agreement-bottom-link a:focus {
  color: #007894;
}

/* Sticky U of T Libraries top bar */
.utl-top-bar {
  position: sticky;
  top: 0;
  z-index: 1030;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

/* Account for Drupal admin toolbar when logged in */
body.toolbar-fixed .utl-top-bar {
  top: 39px;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px;
}

/* Sticky logged-in header stack */

/* Keep the U of T Libraries bar sticky for everyone */
.utl-top-bar {
  position: sticky !important;
  top: 0 !important;
  z-index: 1040 !important;
}

/* Logged-in Library Tools header + nav sticks below the blue top bar */
body.user-logged-in #header,
body.user-logged-in header[role="banner"] {
  position: sticky !important;
  top: 38px !important;
  z-index: 1035 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

/* Prevent weird spacing while sticky */
body.user-logged-in #block-libtools-bootstrap-branding {
  background: #ffffff !important;
}

body.user-logged-in #navbar-main {
  background: #ffffff !important;
  margin-bottom: 0 !important;
}

/* Drupal admin toolbar offsets */
body.toolbar-fixed .utl-top-bar {
  top: 39px !important;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px !important;
}

body.user-logged-in.toolbar-fixed #header,
body.user-logged-in.toolbar-fixed header[role="banner"] {
  top: 77px !important;
}

body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open #header,
body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open header[role="banner"] {
  top: 117px !important;
}

/* Final sticky header behaviour:
   - Blue U of T Libraries bar is sticky
   - LIBRARY TOOLS wordmark is sticky for logged-in users
   - Logged-in nav is not sticky
*/

/* Make sure the full header/nav wrapper itself is not sticky */
body.user-logged-in #header,
body.user-logged-in header[role="banner"] {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Blue institutional bar sticky */
.utl-top-bar {
  position: sticky !important;
  top: 0 !important;
  z-index: 1040 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
}

/* LIBRARY TOOLS sticky for logged-in users only */
body.user-logged-in #block-libtools-bootstrap-branding {
  position: sticky !important;
  top: 38px !important;
  z-index: 1035 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06) !important;
}

/* Keep the nav normal / non-sticky */
body.user-logged-in #navbar-main {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  box-shadow: none !important;
}

/* Drupal admin toolbar offsets */
body.toolbar-fixed .utl-top-bar {
  top: 39px !important;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px !important;
}

body.user-logged-in.toolbar-fixed #block-libtools-bootstrap-branding {
  top: 77px !important;
}

body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open #block-libtools-bootstrap-branding {
  top: 117px !important;
}

/* FINAL sticky behaviour reset:
   Keep the sticky pieces stable by making the logged-in header stick as one unit.
*/

/* Blue institutional bar sticks for everyone */
.utl-top-bar {
  position: sticky !important;
  top: 0 !important;
  z-index: 1040 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
}

/* For logged-in users, make the whole Library Tools header stick together */
body.user-logged-in #header,
body.user-logged-in header[role="banner"] {
  position: sticky !important;
  top: 38px !important;
  z-index: 1035 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

/* Do NOT make individual inner pieces sticky */
body.user-logged-in #block-libtools-bootstrap-branding,
body.user-logged-in #navbar-main {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  box-shadow: none !important;
}

/* Keep the branding/nav aligned inside the sticky header */
body.user-logged-in #block-libtools-bootstrap-branding {
  background: #ffffff !important;
  margin-bottom: 0 !important;
}

body.user-logged-in #navbar-main {
  margin-bottom: 0 !important;
}

/* Drupal admin toolbar offsets */
body.toolbar-fixed .utl-top-bar {
  top: 39px !important;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px !important;
}

body.user-logged-in.toolbar-fixed #header,
body.user-logged-in.toolbar-fixed header[role="banner"] {
  top: 77px !important;
}

body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open #header,
body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open header[role="banner"] {
  top: 117px !important;
}

/* Compact sticky logged-in header */

/* Keep the whole logged-in header sticky, but reduce its height */
body.user-logged-in #header,
body.user-logged-in header[role="banner"] {
  position: sticky !important;
  top: 38px !important;
  z-index: 1035 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

/* Compact LIBRARY TOOLS wordmark area */
body.user-logged-in #block-libtools-bootstrap-branding {
  margin: 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
}

body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand {
  padding: 0.45rem 100px 0.25rem 100px !important;
  min-height: 0 !important;
}

/* Smaller sticky wordmark */
body.user-logged-in .site-branding-text__library {
  font-size: 2rem !important;
  line-height: 1.1 !important;
}

body.user-logged-in .site-branding-text__edit {
  font-size: 1.35rem !important;
  line-height: 1.1 !important;
}

/* Compact logged-in nav row */
body.user-logged-in #navbar-main {
  margin: 0 !important;
  padding: 0.2rem 100px 0.35rem 100px !important;
  min-height: 0 !important;
  line-height: 1.2 !important;
}

/* Compact nav links/buttons inside the logged-in nav */
body.user-logged-in #navbar-main a,
body.user-logged-in #navbar-main .nav-link,
body.user-logged-in #navbar-main button {
  padding-top: 0.25rem !important;
  padding-bottom: 0.25rem !important;
  line-height: 1.2 !important;
}

/* Admin toolbar offsets */
body.user-logged-in.toolbar-fixed #header,
body.user-logged-in.toolbar-fixed header[role="banner"] {
  top: 77px !important;
}

body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open #header,
body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open header[role="banner"] {
  top: 117px !important;
}

@media (max-width: 900px) {
  body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand,
  body.user-logged-in #navbar-main {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}

/* FINAL reset: only the blue U of T Libraries bar is sticky */

/* Blue institutional bar sticks */
.utl-top-bar {
  position: sticky !important;
  top: 0 !important;
  z-index: 1040 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
}

/* Account for Drupal admin toolbar */
body.toolbar-fixed .utl-top-bar {
  top: 39px !important;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px !important;
}

/* Library Tools header should NOT be sticky */
body.user-logged-in #header,
body.user-logged-in header[role="banner"],
body.user-logged-in #block-libtools-bootstrap-branding,
body.user-logged-in #navbar-main {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  box-shadow: none !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

/* Restore normal Library Tools spacing */
body.user-logged-in #block-libtools-bootstrap-branding {
  display: block !important;
  width: 100% !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  background: #ffffff !important;
}

body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand {
  display: flex !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 1.5rem 100px 0.75rem 100px !important;
  align-items: center !important;
}

/* Restore normal wordmark size */
body.user-logged-in .site-branding-text__library {
  font-size: 3rem !important;
  line-height: 1.1 !important;
}

body.user-logged-in .site-branding-text__edit {
  font-size: 2rem !important;
  line-height: 1.1 !important;
}

/* Logged-in nav scrolls normally */
body.user-logged-in #navbar-main {
  display: flex !important;
  visibility: visible !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0.6rem 100px !important;
  background: transparent !important;
}

/* Keep public users from seeing the empty nav/branding */
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) #navbar-main {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

@media (max-width: 900px) {
  body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand,
  body.user-logged-in #navbar-main {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}

/* FINAL logged-in compact sticky header with hamburger nav */

/* Blue institutional bar stays sticky */
.utl-top-bar {
  position: sticky !important;
  top: 0 !important;
  z-index: 1050 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
}

/* Logged-in header becomes one compact sticky row */
body.user-logged-in #header,
body.user-logged-in header[role="banner"] {
  position: sticky !important;
  top: 38px !important;
  z-index: 1045 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  width: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0.65rem 100px !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
  overflow: visible !important;
}

/* Hide old top header/nav region if present */
body.user-logged-in #navbar-top {
  display: none !important;
}

/* Branding sits on the left */
body.user-logged-in #block-libtools-bootstrap-branding {
  display: block !important;
  flex: 0 0 auto !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  position: static !important;
  box-shadow: none !important;
}

body.user-logged-in #block-libtools-bootstrap-branding .navbar-brand {
  display: flex !important;
  align-items: baseline !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.user-logged-in .site-branding-text {
  display: inline-flex !important;
  align-items: baseline !important;
  margin: 0 !important;
  padding: 0 !important;
  text-decoration: none !important;
}

body.user-logged-in .site-branding-text__library {
  font-size: 2.1rem !important;
  line-height: 1.1 !important;
  font-weight: 600 !important;
}

body.user-logged-in .site-branding-text__edit {
  font-size: 1.45rem !important;
  line-height: 1.1 !important;
  font-weight: 500 !important;
}

/* Navbar becomes a hamburger control on the right */
body.user-logged-in #navbar-main {
  display: flex !important;
  flex: 0 0 auto !important;
  align-items: center !important;
  justify-content: flex-end !important;
  width: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  position: static !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Force hamburger to show on desktop too */
body.user-logged-in #navbar-main .navbar-toggler {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  margin: 0 !important;
  padding: 0.55rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  color: #1e3765 !important;
  cursor: pointer !important;
}

/* Make sure the toggler icon is visible */
body.user-logged-in #navbar-main .navbar-toggler-icon {
  width: 1.35rem !important;
  height: 1.35rem !important;
}

/* Override navbar-expand-lg so menu is collapsed unless opened */
body.user-logged-in #navbar-main #CollapsingNavbar.collapse:not(.show) {
  display: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.collapse.show,
body.user-logged-in #navbar-main #CollapsingNavbar.collapsing {
  display: block !important;
}

/* Dropdown panel */
body.user-logged-in #navbar-main #CollapsingNavbar {
  position: absolute !important;
  top: calc(100% - 0.25rem) !important;
  right: 100px !important;
  left: auto !important;
  width: min(360px, calc(100vw - 2rem)) !important;
  max-height: calc(100vh - 130px) !important;
  overflow-y: auto !important;
  padding: 0.75rem !important;
  background: #ffffff !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 10px !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14) !important;
}

/* Stack nav links vertically inside dropdown */
body.user-logged-in #navbar-main #CollapsingNavbar .navbar-nav,
body.user-logged-in #navbar-main #CollapsingNavbar ul {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  gap: 0.15rem !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar li {
  width: 100% !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar a,
body.user-logged-in #navbar-main #CollapsingNavbar .nav-link {
  display: block !important;
  width: 100% !important;
  padding: 0.65rem 0.75rem !important;
  color: #1e3765 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar a:hover,
body.user-logged-in #navbar-main #CollapsingNavbar a:focus,
body.user-logged-in #navbar-main #CollapsingNavbar .nav-link:hover,
body.user-logged-in #navbar-main #CollapsingNavbar .nav-link:focus {
  background: #f3f8fa !important;
  color: #007894 !important;
  text-decoration: underline !important;
}

/* Public users still do not see Library Tools or empty nav */
body:not(.user-logged-in) #block-libtools-bootstrap-branding,
body:not(.user-logged-in) .block-system-branding-block,
body:not(.user-logged-in) .navbar-brand,
body:not(.user-logged-in) .site-branding-text,
body:not(.user-logged-in) #navbar-main {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Drupal admin toolbar offsets */
body.toolbar-fixed .utl-top-bar {
  top: 39px !important;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .utl-top-bar {
  top: 79px !important;
}

body.user-logged-in.toolbar-fixed #header,
body.user-logged-in.toolbar-fixed header[role="banner"] {
  top: 77px !important;
}

body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open #header,
body.user-logged-in.toolbar-fixed.toolbar-horizontal.toolbar-tray-open header[role="banner"] {
  top: 117px !important;
}

@media (max-width: 900px) {
  body.user-logged-in #header,
  body.user-logged-in header[role="banner"] {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  body.user-logged-in #navbar-main #CollapsingNavbar {
    right: 24px !important;
  }
}

/* APC cards: indicate full-card click target */
.view-oa-agreements-apc-discounts .publishers.views-row {
  cursor: pointer;
}

.view-oa-agreements-apc-discounts .publishers.views-row:focus {
  outline: 3px solid #007894;
  outline-offset: 3px;
}

/* Logged-in hamburger menu: show submenu items inside the panel */

/* Treat nested dropdowns/submenus as expanded sections inside the hamburger panel */
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar ul ul,
body.user-logged-in #navbar-main #CollapsingNavbar .menu-level-1,
body.user-logged-in #navbar-main #CollapsingNavbar .menu-level-2 {
  display: block !important;
  position: static !important;
  float: none !important;
  transform: none !important;
  inset: auto !important;
  min-width: 0 !important;
  width: 100% !important;
  margin: 0.25rem 0 0.75rem 0.75rem !important;
  padding: 0.25rem 0 0.25rem 0.75rem !important;
  background: transparent !important;
  border: 0 !important;
  border-left: 3px solid #d6dde3 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Top-level items become section labels */
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-toggle,
body.user-logged-in #navbar-main #CollapsingNavbar .nav-link.dropdown-toggle {
  font-weight: 700 !important;
  color: #1a1a1a !important;
}

/* Hide Bootstrap caret because submenus are already expanded */
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-toggle::after {
  display: none !important;
}

/* Submenu links are slightly smaller/indented */
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-menu a,
body.user-logged-in #navbar-main #CollapsingNavbar ul ul a,
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-item {
  display: block !important;
  width: 100% !important;
  padding: 0.45rem 0.65rem !important;
  color: #1e3765 !important;
  font-size: 0.92rem !important;
  line-height: 1.35 !important;
  white-space: normal !important;
  border-radius: 6px !important;
  background: transparent !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-menu a:hover,
body.user-logged-in #navbar-main #CollapsingNavbar ul ul a:hover,
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-item:hover,
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-menu a:focus,
body.user-logged-in #navbar-main #CollapsingNavbar ul ul a:focus,
body.user-logged-in #navbar-main #CollapsingNavbar .dropdown-item:focus {
  background: #f3f8fa !important;
  color: #007894 !important;
  text-decoration: underline !important;
}

/* Keep the hamburger panel readable with nested content */
body.user-logged-in #navbar-main #CollapsingNavbar {
  width: min(420px, calc(100vw - 2rem)) !important;
  max-height: calc(100vh - 130px) !important;
  overflow-y: auto !important;
}

/* Custom logged-in hamburger panel state.
   Do not rely on Bootstrap .show for this menu. */

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel {
  display: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel.is-open {
  display: block !important;
}

/* Prevent Bootstrap dropdown positioning inside the custom hamburger panel */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-menu {
  display: block !important;
  position: static !important;
  float: none !important;
  transform: none !important;
  margin: 0.25rem 0 0.75rem 0.75rem !important;
  padding: 0.25rem 0 0.25rem 0.75rem !important;
  border: 0 !important;
  border-left: 3px solid #d6dde3 !important;
  box-shadow: none !important;
  background: transparent !important;
}

/* Top-level dropdown toggles are headings in this panel */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-toggle {
  pointer-events: auto !important;
  font-weight: 700 !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-toggle::after {
  display: none !important;
}

/* Fix logged-in hamburger panel rendering */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel {
  display: none !important;
  position: absolute !important;
  top: calc(100% + 0.5rem) !important;
  right: 100px !important;
  left: auto !important;
  width: min(420px, calc(100vw - 2rem)) !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: calc(100vh - 160px) !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  padding: 1rem !important;
  background: #ffffff !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14) !important;
  flex-basis: auto !important;
  flex-grow: 0 !important;
  transition: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel.is-open {
  display: block !important;
  height: auto !important;
  visibility: visible !important;
}

/* Force menu contents to stack vertically */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .navbar-nav,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel ul {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0.25rem !important;
  list-style: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel a,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .nav-link,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-item {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: break-word !important;
  padding: 0.55rem 0.65rem !important;
}

/* Nested menus should be visible and indented, not Bootstrap-positioned */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel ul ul {
  display: block !important;
  position: static !important;
  float: none !important;
  transform: none !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0.25rem 0 0.75rem 0.75rem !important;
  padding: 0.25rem 0 0.25rem 0.75rem !important;
  border: 0 !important;
  border-left: 3px solid #d6dde3 !important;
  box-shadow: none !important;
  background: transparent !important;
}

@media (max-width: 900px) {
  body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel {
    right: 24px !important;
  }
}

/* Logged-in hamburger menu: collapse submenus until top-level item is clicked */

/* Later override for earlier expanded-submenu rules */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown:not(.is-section-open) > .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li:not(.is-section-open) > ul {
  display: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown.is-section-open > .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li.is-section-open > ul {
  display: block !important;
}

/* Make top-level expandable items feel clickable */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-toggle {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  cursor: pointer !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-toggle::after {
  display: inline-block !important;
  margin-left: 0.5rem !important;
  content: "▾" !important;
  border: 0 !important;
  font-size: 0.85rem !important;
  transform: rotate(-90deg);
  transition: transform 0.15s ease;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .is-section-open > .dropdown-toggle::after {
  transform: rotate(0deg);
}

/* Fix logged-in hamburger panel alignment */

/* Hide Drupal contextual links inside the hamburger panel */
body.user-logged-in #navbar-main #CollapsingNavbar .contextual,
body.user-logged-in #navbar-main #CollapsingNavbar .contextual-region > .contextual,
body.user-logged-in #navbar-main #CollapsingNavbar .contextual-links,
body.user-logged-in #navbar-main #CollapsingNavbar .contextual .trigger {
  display: none !important;
  visibility: hidden !important;
}

/* Make the hamburger panel a clean vertical menu */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel {
  text-align: left !important;
  width: min(420px, calc(100vw - 2rem)) !important;
  right: 24px !important;
  left: auto !important;
  padding: 1rem !important;
  overflow-x: hidden !important;
}

/* Reset layout wrappers inside the menu block */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .region,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .block,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .content,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel nav,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .navbar-nav,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .menu {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  float: none !important;
}

/* Force all top-level menu items to stack */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .nav-item,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .menu-item {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  float: none !important;
}

/* Top-level links / toggles */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel > ul > li > a,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .nav-item > .nav-link,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .menu-item > a {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0.7rem 0.75rem !important;
  color: #1e3765 !important;
  font-weight: 700 !important;
  text-align: left !important;
  white-space: normal !important;
  border-radius: 6px !important;
}

/* Submenus: collapsed by default, left aligned when open */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown:not(.is-section-open) > .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .menu-item:not(.is-section-open) > ul,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li:not(.is-section-open) > ul {
  display: none !important;
}

body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown.is-section-open > .dropdown-menu,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .menu-item.is-section-open > ul,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel li.is-section-open > ul {
  display: block !important;
  position: static !important;
  width: 100% !important;
  margin: 0.25rem 0 0.75rem 0.75rem !important;
  padding: 0.25rem 0 0.25rem 0.75rem !important;
  border-left: 3px solid #d6dde3 !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Keep submenu links compact */
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel .dropdown-menu a,
body.user-logged-in #navbar-main #CollapsingNavbar.libtools-hamburger-panel ul ul a {
  display: block !important;
  width: 100% !important;
  padding: 0.45rem 0.65rem !important;
  font-size: 0.92rem !important;
  font-weight: 600 !important;
  text-align: left !important;
}

/* Fisher collection and finding aid pages */

/* Shared Fisher grid */
.path-finding-aids,
.path-print-and-manuscript-collections {
  --fisher-grid-width: 1128px;
  --fisher-grid-pad: 32px;
}

/* Remove logged-out blank space caused by hidden Library Tools nav/header wrappers */
body:not(.user-logged-in).path-finding-aids #main-wrapper,
body:not(.user-logged-in).path-print-and-manuscript-collections #main-wrapper,
body:not(.user-logged-in).path-finding-aids #main,
body:not(.user-logged-in).path-print-and-manuscript-collections #main,
body:not(.user-logged-in).path-finding-aids #content,
body:not(.user-logged-in).path-print-and-manuscript-collections #content {
  margin-top: 0 !important;
}

body:not(.user-logged-in).path-finding-aids #main-wrapper,
body:not(.user-logged-in).path-print-and-manuscript-collections #main-wrapper {
  padding-top: 1rem !important;
}

body.user-logged-in.path-finding-aids #main-wrapper,
body.user-logged-in.path-print-and-manuscript-collections #main-wrapper {
  padding-top: 2rem !important;
}

body:not(.user-logged-in) #navbar-main,
body:not(.user-logged-in) #navbar-main *,
body:not(.user-logged-in) #CollapsingNavbar {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Align major Fisher page sections */
.path-finding-aids .fisher-title-eyebrow,
.path-print-and-manuscript-collections .fisher-title-eyebrow,
.path-finding-aids #block-libtools-bootstrap-page-title,
.path-print-and-manuscript-collections #block-libtools-bootstrap-page-title,
.path-finding-aids .view-header,
.path-print-and-manuscript-collections .view-header,
.path-finding-aids .fisher-result-summary,
.path-print-and-manuscript-collections .fisher-result-summary,
.path-finding-aids .view-filters,
.path-print-and-manuscript-collections .view-filters,
.path-finding-aids .view-display-id-attachment_1,
.path-print-and-manuscript-collections .view-display-id-attachment_1,
.path-finding-aids .view-content,
.path-print-and-manuscript-collections .view-content,
.path-finding-aids nav[aria-label="Page navigation"],
.path-print-and-manuscript-collections nav[aria-label="Page navigation"],
.path-finding-aids nav[aria-label="pagination-heading"],
.path-print-and-manuscript-collections nav[aria-label="pagination-heading"] {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: var(--fisher-grid-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--fisher-grid-pad) !important;
  padding-right: var(--fisher-grid-pad) !important;
}

/* Fisher title eyebrow */
.fisher-title-eyebrow {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin: 0 auto 0.25rem !important;
  color: #4d4d4d !important;
  font-size: 0.82rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  line-height: 1.35 !important;
  text-transform: uppercase !important;
}

.fisher-title-eyebrow span {
  margin-right: 0.5rem !important;
}

.fisher-title-eyebrow a {
  color: #007894 !important;
  font-weight: 400 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  text-decoration: underline !important;
  text-underline-offset: 0.18em !important;
}

.fisher-title-eyebrow a::after {
  content: " →";
}

.fisher-title-eyebrow a:hover,
.fisher-title-eyebrow a:focus {
  color: #005f75 !important;
  text-decoration-thickness: 2px !important;
}

.fisher-title-eyebrow a:focus-visible {
  outline: 3px solid #007894 !important;
  outline-offset: 3px !important;
  border-radius: 2px !important;
}

/* Page title */
.path-finding-aids #block-libtools-bootstrap-page-title,
.path-print-and-manuscript-collections #block-libtools-bootstrap-page-title {
  margin-bottom: 1.75rem !important;
}

.path-finding-aids h1.title,
.path-print-and-manuscript-collections h1.title {
  color: #1e3765 !important;
  font-size: clamp(1.75rem, 3vw, 2.35rem) !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  margin: 0 !important;
  padding-bottom: 0.75rem !important;
  border-bottom: 1px solid #d6dde3 !important;
  position: relative !important;
}

.path-finding-aids h1.title::after,
.path-print-and-manuscript-collections h1.title::after {
  content: "" !important;
  position: absolute !important;
  bottom: -2px !important;
  left: 0 !important;
  width: 120px !important;
  height: 4px !important;
  background: #007894 !important;
}

/* Intro/header */
.path-finding-aids .view-header,
.path-print-and-manuscript-collections .view-header {
  margin-bottom: 0 !important;
}

.path-finding-aids .view-header p,
.path-print-and-manuscript-collections .view-header p {
  max-width: 900px !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
}

/* Result summary */
.path-finding-aids .fisher-result-summary,
.path-print-and-manuscript-collections .fisher-result-summary {
  display: block !important;
  margin-top: 2rem !important;
  margin-bottom: 0.75rem !important;
  color: #333333 !important;
  font-size: 0.98rem !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
}

/* Search */
.path-finding-aids .view-filters,
.path-print-and-manuscript-collections .view-filters {
  margin-top: 0 !important;
  margin-bottom: 1.25rem !important;
}

.path-finding-aids .views-exposed-form,
.path-print-and-manuscript-collections .views-exposed-form {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
}

.path-finding-aids .views-exposed-form > .form-row,
.path-print-and-manuscript-collections .views-exposed-form > .form-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
}

.path-finding-aids .views-exposed-form fieldset.form-group,
.path-print-and-manuscript-collections .views-exposed-form fieldset.form-group,
.path-finding-aids .views-exposed-form .form-actions,
.path-print-and-manuscript-collections .views-exposed-form .form-actions {
  min-width: 0 !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.path-finding-aids .views-exposed-form .form-actions,
.path-print-and-manuscript-collections .views-exposed-form .form-actions {
  display: flex !important;
  align-items: stretch !important;
}

.path-finding-aids .views-exposed-form label,
.path-print-and-manuscript-collections .views-exposed-form label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
}

.path-finding-aids .views-exposed-form input.form-control,
.path-print-and-manuscript-collections .views-exposed-form input.form-control {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: none !important;
  min-height: 54px !important;
  margin: 0 !important;
  padding: 0.8rem 1rem !important;
  background: #ffffff !important;
  border: 1px solid #b9c7d3 !important;
  border-right: 0 !important;
  border-radius: 12px 0 0 12px !important;
  color: #1a1a1a !important;
  font-size: 1rem !important;
  box-shadow: none !important;
}

.path-finding-aids .views-exposed-form input.form-control:focus,
.path-print-and-manuscript-collections .views-exposed-form input.form-control:focus {
  border-color: #007894 !important;
  outline: 3px solid rgba(0, 120, 148, 0.18) !important;
  outline-offset: 0 !important;
}

/* Search/reset icon buttons */
.path-finding-aids .views-exposed-form .form-submit,
.path-print-and-manuscript-collections .views-exposed-form .form-submit {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 54px !important;
  min-width: 54px !important;
  height: 54px !important;
  min-height: 54px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #007894 !important;
  border: 1px solid #007894 !important;
  color: #ffffff !important;
  font-size: 0 !important;
  line-height: 1 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.path-finding-aids .views-exposed-form .form-submit::before,
.path-print-and-manuscript-collections .views-exposed-form .form-submit::before {
  content: "" !important;
  display: block !important;
  width: 20px !important;
  height: 20px !important;
  background-color: currentColor !important;
}

.path-finding-aids .views-exposed-form .form-submit:not([name="reset"])::before,
.path-print-and-manuscript-collections .views-exposed-form .form-submit:not([name="reset"])::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l4.45 4.44-1.24 1.24-4.44-4.45A6.5 6.5 0 1 1 9.5 3Zm0 1.75a4.75 4.75 0 1 0 0 9.5 4.75 4.75 0 0 0 0-9.5Z'/%3E%3C/svg%3E") center / 20px 20px no-repeat !important;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.5 3a6.5 6.5 0 0 1 5.17 10.44l4.45 4.44-1.24 1.24-4.44-4.45A6.5 6.5 0 1 1 9.5 3Zm0 1.75a4.75 4.75 0 1 0 0 9.5 4.75 4.75 0 0 0 0-9.5Z'/%3E%3C/svg%3E") center / 20px 20px no-repeat !important;
}

.path-finding-aids .views-exposed-form .form-submit[name="reset"]::before,
.path-print-and-manuscript-collections .views-exposed-form .form-submit[name="reset"]::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5V2L7.75 6.25 12 10.5V7a5 5 0 1 1-4.64 6.85H5.52A6.75 6.75 0 1 0 12 5Z'/%3E%3C/svg%3E") center / 20px 20px no-repeat !important;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5V2L7.75 6.25 12 10.5V7a5 5 0 1 1-4.64 6.85H5.52A6.75 6.75 0 1 0 12 5Z'/%3E%3C/svg%3E") center / 20px 20px no-repeat !important;
}

.path-finding-aids .views-exposed-form .form-submit:not([name="reset"]):last-child,
.path-print-and-manuscript-collections .views-exposed-form .form-submit:not([name="reset"]):last-child {
  border-radius: 0 12px 12px 0 !important;
}

.path-finding-aids .views-exposed-form .form-actions:has(.form-submit[name="reset"]) .form-submit:not([name="reset"]),
.path-print-and-manuscript-collections .views-exposed-form .form-actions:has(.form-submit[name="reset"]) .form-submit:not([name="reset"]) {
  border-radius: 0 !important;
}

.path-finding-aids .views-exposed-form .form-submit[name="reset"],
.path-print-and-manuscript-collections .views-exposed-form .form-submit[name="reset"] {
  border-left-color: rgba(255, 255, 255, 0.35) !important;
  border-radius: 0 12px 12px 0 !important;
}

.path-finding-aids .views-exposed-form .form-submit:hover,
.path-print-and-manuscript-collections .views-exposed-form .form-submit:hover,
.path-finding-aids .views-exposed-form .form-submit:focus,
.path-print-and-manuscript-collections .views-exposed-form .form-submit:focus {
  background: #005f75 !important;
  border-color: #005f75 !important;
}

.path-finding-aids .views-exposed-form .form-submit:focus-visible,
.path-print-and-manuscript-collections .views-exposed-form .form-submit:focus-visible {
  outline: 3px solid rgba(0, 120, 148, 0.35) !important;
  outline-offset: 2px !important;
}

/* A-Z */
.path-finding-aids .view-display-id-attachment_1,
.path-print-and-manuscript-collections .view-display-id-attachment_1 {
  margin-bottom: 1.5rem !important;
  border: 0 !important;
}

.fisher-az-nav {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.75rem !important;
  margin: 0.75rem 0 1.5rem !important;
  padding: 0.35rem 0 0.85rem !important;
  border-top: 0 !important;
  border-bottom: 1px solid #d6dde3 !important;
}

.fisher-az-nav__label {
  flex: 0 0 auto !important;
  color: #4d4d4d !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  line-height: 2rem !important;
  text-transform: uppercase !important;
}

.fisher-az-nav__group,
.fisher-az-nav__list {
  display: flex !important;
  flex: 1 1 auto !important;
  flex-wrap: wrap !important;
  gap: 0.25rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.fisher-az-nav__item {
  display: inline-flex !important;
  margin: 0 !important;
  padding: 0 !important;
}

.fisher-az-nav__link {
  display: inline-flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 0.2rem !important;
  min-width: 2.1rem !important;
  min-height: 1.9rem !important;
  padding: 0.25rem 0.4rem !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #1e3765 !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
}

.fisher-az-nav__link:hover,
.fisher-az-nav__link:focus {
  border-color: #007894 !important;
  background: #f3f8fa !important;
  color: #005f75 !important;
  text-decoration: underline !important;
  text-underline-offset: 0.16em !important;
}

.fisher-az-nav__count {
  color: #4d4d4d !important;
  font-size: 0.66rem !important;
  font-weight: 600 !important;
}

.fisher-az-nav__link--disabled {
  color: #777777 !important;
  background: #f5f5f5 !important;
  border-color: #e0e0e0 !important;
  opacity: 0.75 !important;
  cursor: not-allowed !important;
}

.fisher-az-nav__link--disabled .fisher-az-nav__count {
  display: none !important;
}

.fisher-az-nav__link--all {
  min-width: auto !important;
  padding-left: 0.8rem !important;
  padding-right: 0.8rem !important;
  color: #ffffff !important;
  background: #1e3765 !important;
  border-color: #1e3765 !important;
  font-weight: 700 !important;
}

.fisher-az-nav__link--all:hover,
.fisher-az-nav__link--all:focus {
  color: #ffffff !important;
  background: #005f75 !important;
  border-color: #005f75 !important;
}

/* Result cards */
.path-finding-aids .view-content,
.path-print-and-manuscript-collections .view-content {
  border-top: 0 !important;
  padding-top: 0 !important;
}

.path-finding-aids .view-content.row,
.path-print-and-manuscript-collections .view-content.row {
  display: block !important;
}

.path-finding-aids .view-content .item-list > ul,
.path-print-and-manuscript-collections .view-content .item-list > ul {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.path-finding-aids .view-content .item-list > ul > li,
.path-print-and-manuscript-collections .view-content .item-list > ul > li,
.path-finding-aids .views-row,
.path-print-and-manuscript-collections .views-row {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 0 1rem !important;
  padding: 1.35rem 1.5rem !important;
  background: #ffffff !important;
  border: 1px solid #d6dde3 !important;
  border-radius: 14px !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
}

.path-finding-aids .view-content .item-list > ul > li:hover,
.path-print-and-manuscript-collections .view-content .item-list > ul > li:hover,
.path-finding-aids .views-row:hover,
.path-print-and-manuscript-collections .views-row:hover {
  border-color: #b9c7d3 !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08) !important;
}

.path-finding-aids .views-field-title h2,
.path-print-and-manuscript-collections .views-field-title h2 {
  margin: 0 0 0.6rem !important;
  font-size: 1.2rem !important;
  line-height: 1.35 !important;
}

.path-finding-aids .views-field-title a,
.path-print-and-manuscript-collections .views-field-title a {
  color: #007894 !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  text-underline-offset: 0.18em !important;
}

.path-finding-aids .views-field,
.path-print-and-manuscript-collections .views-field {
  max-width: 900px !important;
  color: #333333 !important;
  font-size: 0.96rem !important;
  line-height: 1.55 !important;
}

.path-finding-aids .views-field + .views-field,
.path-print-and-manuscript-collections .views-field + .views-field {
  margin-top: 0.55rem !important;
}

.path-finding-aids .views-field b,
.path-print-and-manuscript-collections .views-field b,
.path-finding-aids .views-label,
.path-print-and-manuscript-collections .views-label {
  color: #1e3765 !important;
  font-weight: 800 !important;
}

/* Pagination alignment */
.path-finding-aids nav[aria-label="pagination-heading"],
.path-print-and-manuscript-collections nav[aria-label="pagination-heading"] {
  margin-top: 1.5rem !important;
}

/* Mobile */
@media (max-width: 760px) {
  .path-finding-aids,
  .path-print-and-manuscript-collections {
    --fisher-grid-pad: 20px;
  }

  .fisher-title-eyebrow span,
  .fisher-title-eyebrow a {
    display: block !important;
  }

  .fisher-title-eyebrow span {
    margin-right: 0 !important;
    margin-bottom: 0.25rem !important;
  }

  .path-finding-aids .views-exposed-form > .form-row,
  .path-print-and-manuscript-collections .views-exposed-form > .form-row {
    display: block !important;
  }

  .path-finding-aids .views-exposed-form input.form-control,
  .path-print-and-manuscript-collections .views-exposed-form input.form-control {
    border-right: 1px solid #b9c7d3 !important;
    border-radius: 12px !important;
  }

  .path-finding-aids .views-exposed-form .form-actions,
  .path-print-and-manuscript-collections .views-exposed-form .form-actions {
    display: flex !important;
    gap: 0.5rem !important;
    margin-top: 0.75rem !important;
  }

  .path-finding-aids .views-exposed-form .form-submit,
  .path-print-and-manuscript-collections .views-exposed-form .form-submit {
    flex: 0 0 54px !important;
    width: 54px !important;
    border-radius: 12px !important;
  }

  .fisher-az-nav {
    display: block !important;
  }

  .fisher-az-nav__label {
    display: block !important;
    margin-bottom: 0.5rem !important;
  }

  .path-finding-aids .view-content .item-list > ul > li,
  .path-print-and-manuscript-collections .view-content .item-list > ul > li,
  .path-finding-aids .views-row,
  .path-print-and-manuscript-collections .views-row {
    padding: 1rem !important;
  }
}

/* Fisher A-Z active state */

/* View all should not always look selected */
.fisher-az-nav__link--all {
  color: #1e3765 !important;
  background: #eef7f9 !important;
  border-color: #b9c7d3 !important;
}

/* Only the current A-Z item should be highlighted */
.fisher-az-nav__link.is-active,
.fisher-az-nav__link[aria-current="page"] {
  color: #ffffff !important;
  background: #1e3765 !important;
  border-color: #1e3765 !important;
  text-decoration: none !important;
}

.fisher-az-nav__link.is-active:hover,
.fisher-az-nav__link[aria-current="page"]:hover,
.fisher-az-nav__link.is-active:focus,
.fisher-az-nav__link[aria-current="page"]:focus {
  color: #ffffff !important;
  background: #005f75 !important;
  border-color: #005f75 !important;
}

/* Disabled letters should never look active */
.fisher-az-nav__link--disabled,
.fisher-az-nav__link--disabled:hover,
.fisher-az-nav__link--disabled:focus {
  color: #777777 !important;
  background: #f5f5f5 !important;
  border-color: #e0e0e0 !important;
  text-decoration: none !important;
}


/* Restore iPad / Special Collections Access page styling */

body.node--type-ipad,
body.node--type-ipad #page-wrapper,
body.node--type-ipad #page,
body.node--type-ipad #main-wrapper,
body.node--type-ipad #main,
body.node--type-ipad #content,
body.node--type-ipad main.main-content,
body.node--type-ipad main.main-content .section,
body.node--type-ipad #block-libtools-bootstrap-content,
body.node--type-ipad #block-libtools-bootstrap-content .content,
body.node--type-ipad article.node--type-ipad,
body.node--type-ipad article.node--type-ipad .node__content {
  background: #1e3765 !important;
  color: #ffffff !important;
}

/* Hide the default Drupal page title on the iPad search page */
body.node--type-ipad #block-libtools-bootstrap-page-title {
  display: none !important;
}

/* Restore readable dark-page text */
body.node--type-ipad #content p,
body.node--type-ipad #content li,
body.node--type-ipad #content label,
body.node--type-ipad #content h1,
body.node--type-ipad #content h2,
body.node--type-ipad #content h3,
body.node--type-ipad #content h4,
body.node--type-ipad #content h5,
body.node--type-ipad #content h6 {
  color: #ffffff !important;
}

/* Links on dark blue */
body.node--type-ipad #content a {
  color: #8ed8e8 !important;
  text-decoration: underline !important;
  text-underline-offset: 0.18em !important;
}

body.node--type-ipad #content a:hover,
body.node--type-ipad #content a:focus {
  color: #ffffff !important;
  text-decoration-thickness: 2px !important;
}

/* Logged-in local task tabs: readable on dark background */
body.node--type-ipad #content .tabs,
body.node--type-ipad #content .tabs-wrapper,
body.node--type-ipad #content .nav-tabs,
body.node--type-ipad #content ul.primary,
body.node--type-ipad #content ul.tabs {
  background: transparent !important;
  border-color: rgba(255, 255, 255, 0.65) !important;
}

body.node--type-ipad #content .tabs a,
body.node--type-ipad #content .nav-tabs a,
body.node--type-ipad #content ul.primary a,
body.node--type-ipad #content ul.tabs a {
  color: #8ed8e8 !important;
  background: transparent !important;
  border-color: rgba(255, 255, 255, 0.65) !important;
}

body.node--type-ipad #content .tabs a.is-active,
body.node--type-ipad #content .nav-tabs a.active,
body.node--type-ipad #content ul.primary a.is-active,
body.node--type-ipad #content ul.tabs a.is-active {
  color: #1e3765 !important;
  background: #ffffff !important;
  border-color: #ffffff !important;
}

/* iPad search input */
body.node--type-ipad #library-search-front {
  min-height: 64px !important;
  padding: 0.85rem 1.5rem !important;
  color: #1a1a1a !important;
  background: #ffffff !important;
  border: 2px solid #9ccfe0 !important;
  border-radius: 999px !important;
  font-size: 1.35rem !important;
  box-shadow: none !important;
}

/* Checkboxes and labels */
body.node--type-ipad #content input[type="checkbox"] {
  accent-color: #007894 !important;
}

body.node--type-ipad #content .filter-label {
  color: #ffffff !important;
  margin-right: 1.5rem !important;
}

/* iPad search button */
body.node--type-ipad #library-search-submit {
  min-height: 56px !important;
  padding: 0.75rem 2rem !important;
  color: #ffffff !important;
  background: #007894 !important;
  border: 2px solid #007894 !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
}

body.node--type-ipad #library-search-submit:hover,
body.node--type-ipad #library-search-submit:focus {
  background: #005f75 !important;
  border-color: #8ed8e8 !important;
}

/* Kiosk page spacing */
body.node--type-ipad #content .section {
  padding: 2rem 3rem 4rem !important;
}

