/**
 * Modern Professional Theme for OJS
 * Child theme of Default Theme
 * Designed for PT Emerging MD Trends Journal
 */

/* ============================================================
   CSS Custom Properties (Design Tokens)
   ============================================================ */
:root {
  --color-primary:       #223559;
  --color-primary-dark:  #182947;
  --color-primary-light: #354b6a;
  --color-accent:        #c7ae68;
  --color-accent-light:  #d8c490;
  --color-surface:       #ffffff;
  --color-surface-alt:   #f5f0e6;
  --color-border:        #d7cebc;
  --color-text:          #102142;
  --color-text-muted:    #6f736f;
  --color-text-inverse:  #ffffff;

  --shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md:   0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:   0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);
  --shadow-hover:0 12px 24px rgba(24,41,71,.18);

  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   16px;

  --transition: all .2s ease;
}

/* ============================================================
   Global Reset & Typography
   ============================================================ */
html, body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: var(--color-text) !important;
  background: var(--color-surface-alt) !important;
  -webkit-font-smoothing: antialiased;
}

a {
  color: var(--color-primary) !important;
  text-decoration: none;
  transition: var(--transition);
}
a:hover, a:focus {
  color: var(--color-primary-light) !important;
  text-decoration: underline;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Merriweather', Georgia, serif !important;
  color: var(--color-text) !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

/* ============================================================
   Header / Navigation
   ============================================================ */
.pkp_structure_head {
  background: linear-gradient(90deg, var(--color-primary-dark) 0%, var(--color-primary) 58%, var(--color-primary-light) 82%, #8c8b75 100%) !important;
  border-bottom: 3px solid var(--color-accent) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.2) !important;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.pkp_structure_head.has_header_logo_banner {
  background:
    linear-gradient(180deg, rgba(15, 33, 64, .05) 0%, rgba(15, 33, 64, .16) 100%),
    var(--header-logo-url) center 1.45rem / min(calc(100% - 2rem), 1360px) auto no-repeat,
    linear-gradient(90deg, var(--color-primary-dark) 0%, var(--color-primary) 58%, var(--color-primary-light) 82%, #8c8b75 100%) !important;
}

/* Journal name text */
.pkp_site_name .is_text {
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1.25rem !important;
  letter-spacing: -.01em;
  color: var(--color-text-inverse) !important;
}

/* Logo image */
.pkp_site_name .is_img img {
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.2));
}

.has_site_logo .pkp_head_wrapper {
  padding-top: 2.25rem !important;
}

.pkp_structure_head.has_header_logo_banner .pkp_head_wrapper {
  padding-top: 1.15rem !important;
}

.has_site_logo .pkp_site_name_wrapper {
  display: flex;
  align-items: center;
  min-height: 132px;
}

.pkp_structure_head.has_header_logo_banner .pkp_site_name_wrapper {
  min-height: 118px;
}

.has_site_logo .pkp_site_name {
  display: flex;
  align-items: center;
  min-height: 120px;
  width: 100%;
}

.pkp_structure_head.has_header_logo_banner .pkp_site_name {
  min-height: 108px;
}

.has_site_logo .pkp_site_name .is_img {
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.has_site_logo .pkp_site_name .is_img img {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: 140px !important;
  height: auto;
  object-fit: contain;
}

.pkp_structure_head.has_header_logo_banner .pkp_site_name .is_img {
  visibility: hidden;
}

.has_site_logo .pkp_navigation_primary_row {
  margin-top: .35rem;
}

.pkp_structure_head.has_header_logo_banner .pkp_navigation_primary_row,
.pkp_structure_head.has_header_logo_banner .pkp_navigation_primary_wrapper,
.pkp_structure_head.has_header_logo_banner .pkp_site_nav_menu,
.pkp_structure_head.has_header_logo_banner .pkp_navigation_user_wrapper {
  background: transparent !important;
}

.pkp_structure_head.has_header_logo_banner .pkp_navigation_user_wrapper {
  top: .5rem !important;
  left: auto !important;
  right: 1.25rem !important;
  transform: none !important;
  width: auto !important;
  max-width: calc(100% - 2.5rem);
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.pkp_structure_head.has_header_logo_banner .pkp_navigation_primary_row {
  margin-top: 0;
  border-top: 1px solid rgba(245, 240, 230, .12);
}

.pkp_structure_head.has_header_logo_banner .pkp_navigation_search_wrapper,
.pkp_structure_head.has_header_logo_banner .pkp_navigation_user {
  border-top: none !important;
}

/* Primary navigation links */
.pkp_navigation_primary > li > a {
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
  font-size: .875rem !important;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: rgba(255,255,255,.9) !important;
  padding: .5rem .75rem !important;
  border-radius: var(--radius-sm) !important;
  border-bottom: 2px solid transparent !important;
  transition: var(--transition) !important;
}
.pkp_navigation_primary > li > a:hover,
.pkp_navigation_primary > li > a:focus {
  color: #ffffff !important;
  background: rgba(255,255,255,.12) !important;
  border-bottom-color: var(--color-accent) !important;
  text-decoration: none !important;
}

/* Dropdown menus */
.pkp_nav_list ul {
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-lg) !important;
  border: 1px solid var(--color-border) !important;
  overflow: hidden;
}
.pkp_nav_list ul a {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  color: var(--color-text) !important;
  padding: .6rem 1rem !important;
  transition: var(--transition) !important;
}
.pkp_nav_list ul a:hover,
.pkp_nav_list ul a:focus {
  background: var(--color-surface-alt) !important;
  color: var(--color-primary) !important;
  border-left-color: var(--color-primary) !important;
}

/* User nav */
.pkp_navigation_user {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: .55rem;
}

.pkp_navigation_user > li {
  margin: 0 !important;
}

.pkp_navigation_user a {
  color: rgba(255,255,255,.9) !important;
  font-size: .8125rem !important;
}
.pkp_navigation_user a:hover {
  color: #fff !important;
}

.pkp_navigation_user > li > a {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: .42rem .95rem !important;
  border-radius: 999px !important;
  border: 1px solid rgba(245, 240, 230, .24) !important;
  background: rgba(255,255,255,.08) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 16px rgba(10, 18, 34, .14);
  font-weight: 600 !important;
  letter-spacing: .01em;
  text-decoration: none !important;
}

.pkp_navigation_user > li > a:hover,
.pkp_navigation_user > li > a:focus {
  color: #fff !important;
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(245, 240, 230, .36) !important;
  transform: translateY(-1px);
  text-decoration: none !important;
}

.pkp_navigation_user > li:first-child > a {
  border-color: rgba(199, 174, 104, .55) !important;
  color: #f5f0e6 !important;
}

.pkp_navigation_user > li:last-child > a {
  background: linear-gradient(135deg, rgba(245, 240, 230, .96) 0%, rgba(221, 204, 155, .95) 100%) !important;
  border-color: rgba(199, 174, 104, .7) !important;
  color: var(--color-primary-dark) !important;
  box-shadow: 0 10px 24px rgba(10, 18, 34, .18);
}

.pkp_navigation_user > li:last-child > a:hover,
.pkp_navigation_user > li:last-child > a:focus {
  color: var(--color-primary-dark) !important;
  background: linear-gradient(135deg, rgba(255, 247, 225, .98) 0%, rgba(214, 191, 132, .98) 100%) !important;
}

/* Search wrapper in nav */
.pkp_navigation_search_wrapper a {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
}

/* ============================================================
   Layout & Content
   ============================================================ */
.pkp_structure_content {
  background: var(--color-surface-alt) !important;
  padding-top: 2rem !important;
  padding-bottom: 3rem !important;
}

.pkp_structure_main {
  background: var(--color-surface) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-md) !important;
  border: 1px solid var(--color-border) !important;
  padding: 2rem 2.5rem !important;
}

@media (min-width: 992px) {
  .pkp_structure_content.has_sidebar {
    display: flex !important;
    align-items: flex-start !important;
    gap: 1.5rem !important;
  }

  .pkp_structure_content.has_sidebar .pkp_structure_main {
    float: none !important;
    flex: 1 1 auto !important;
    width: calc(100% - 300px - 1.5rem) !important;
    min-width: 0 !important;
  }

  .pkp_structure_content.has_sidebar .pkp_structure_sidebar {
    float: none !important;
    flex: 0 0 300px !important;
    width: 300px !important;
    margin: 0 !important;
  }
}

/* Remove the old hard borders between main and content */
.pkp_structure_main:before,
.pkp_structure_main:after {
  display: none !important;
}

/* Headings in main content */
.pkp_structure_main h1 {
  font-size: 1.875rem !important;
  color: var(--color-primary-dark) !important;
  border-bottom: 3px solid var(--color-accent) !important;
  padding-bottom: .75rem !important;
  margin-bottom: 1.5rem !important;
}
.pkp_structure_main h2 {
  font-size: 1.375rem !important;
  color: var(--color-primary) !important;
  margin-top: 2rem !important;
}
.pkp_structure_main h3 {
  font-size: 1.125rem !important;
  color: var(--color-text) !important;
}

/* ============================================================
   Sidebar
   ============================================================ */
.pkp_structure_sidebar {
  background: transparent !important;
}

.pkp_block {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  margin-bottom: 1.25rem !important;
  overflow: hidden;
}

.pkp_block .title {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%) !important;
  color: var(--color-text-inverse) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: .8125rem !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  padding: .75rem 1rem !important;
  margin: 0 !important;
}

.pkp_block .content {
  padding: 1rem !important;
}

.pkp_block ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.pkp_block ul li {
  padding: .3rem 0 !important;
  border-bottom: 1px solid var(--color-border) !important;
  font-size: .875rem !important;
}
.pkp_block ul li:last-child {
  border-bottom: none !important;
}
.pkp_block ul li a {
  color: var(--color-primary) !important;
  font-weight: 500 !important;
}
.pkp_block ul li a:hover {
  color: var(--color-primary-light) !important;
}

.sidebar_cta_block__text {
  margin: 0 0 .9rem 0;
  color: var(--color-text-muted);
  font-size: .87rem;
  line-height: 1.6;
}

.sidebar_cta_block__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .55rem .9rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  color: var(--color-text-inverse) !important;
  font-size: .82rem;
  font-weight: 600;
  text-decoration: none !important;
  box-shadow: var(--shadow-sm);
}

.sidebar_cta_block__button:hover,
.sidebar_cta_block__button:focus {
  color: var(--color-text-inverse) !important;
  text-decoration: none !important;
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px);
}

.editorial_contact_block__list {
  list-style: none;
  margin: 0 0 1rem 0;
  padding: 0;
}

.editorial_contact_block__list li {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding: .5rem 0;
  border-bottom: 1px solid var(--color-border) !important;
}

.editorial_contact_block__list li:last-child {
  border-bottom: none !important;
}

.editorial_contact_block__label {
  color: var(--color-text-muted);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.editorial_contact_block__value {
  color: var(--color-text) !important;
  font-size: .88rem;
  line-height: 1.5;
  word-break: break-word;
}

.block_user_profile .content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.user_profile_block__header {
  display: flex;
  align-items: center;
  gap: .85rem;
}

.user_profile_block__avatar {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  flex-shrink: 0;
  object-fit: cover;
  border: 2px solid rgba(15, 76, 129, .12);
  box-shadow: var(--shadow-sm);
}

.user_profile_block__avatar_placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  color: var(--color-text-inverse);
  font-weight: 700;
  letter-spacing: .06em;
}

.user_profile_block__identity {
  min-width: 0;
}

.user_profile_block__name {
  color: var(--color-primary-dark);
  font-size: .95rem;
  font-weight: 700;
  line-height: 1.35;
}

.user_profile_block__meta {
  margin-top: .15rem;
  color: var(--color-text-muted);
  font-size: .8rem;
  word-break: break-word;
}

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

.user_profile_block__details li {
  display: flex;
  flex-direction: column;
  gap: .18rem;
  padding: .55rem 0;
  border-top: 1px solid var(--color-border);
}

.user_profile_block__details li:first-child {
  border-top: 0;
  padding-top: 0;
}

.user_profile_block__label {
  color: var(--color-text-muted);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.user_profile_block__value {
  color: var(--color-text);
  font-size: .86rem;
  line-height: 1.5;
  word-break: break-word;
}

.user_profile_block__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.user_profile_block__guest_text {
  margin: 0;
  color: var(--color-text-muted);
  font-size: .88rem;
  line-height: 1.65;
}

.user_profile_block__actions_guest a {
  flex: 1 1 140px;
}

.user_profile_block__login_panel {
  flex: 1 1 180px;
}

.user_profile_block__login_panel summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  width: 100%;
  padding: .45rem .8rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-alt);
  color: var(--color-primary) !important;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  list-style: none;
}

.user_profile_block__login_panel summary::-webkit-details-marker {
  display: none;
}

.user_profile_block__login_panel[open] {
  width: 100%;
}

.user_profile_block__login_panel[open] summary {
  border-color: var(--color-primary-light);
  background: rgba(53, 75, 106, .08);
  margin-bottom: .8rem;
}

.user_profile_block__login_form {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  padding: .95rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .88);
}

.user_profile_block__login_form label {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.user_profile_block__form_label {
  color: var(--color-text);
  font-size: .78rem;
  font-weight: 600;
}

.user_profile_block__login_form input {
  width: 100%;
  min-height: 38px;
  padding: .55rem .75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--color-text);
  font-size: .85rem;
  box-sizing: border-box;
}

.user_profile_block__login_form input:focus {
  outline: none;
  border-color: var(--color-primary-light);
  box-shadow: 0 0 0 3px rgba(34, 53, 89, .08);
}

.user_profile_block__form_links {
  display: flex;
  justify-content: flex-end;
}

.user_profile_block__form_links a {
  font-size: .78rem;
}

.user_profile_block__login_form button {
  min-height: 38px;
  padding: .55rem .85rem;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  color: var(--color-text-inverse);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
}

.user_profile_block__login_form button:hover,
.user_profile_block__login_form button:focus {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
}

.user_profile_block__actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: .45rem .8rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-alt);
  color: var(--color-primary) !important;
  font-size: .8rem;
  font-weight: 600;
  text-decoration: none !important;
}

.user_profile_block__actions a:hover,
.user_profile_block__actions a:focus {
  border-color: var(--color-primary-light);
  background: rgba(26, 107, 181, .08);
}

@media (max-width: 768px) {
  .pkp_structure_head.has_header_logo_banner .pkp_site_nav_menu,
  .pkp_structure_head.has_header_logo_banner .pkp_site_nav_menu.pkp_site_nav_menu--isOpen {
    position: relative !important;
    z-index: 20 !important;
    margin: .6rem .75rem .85rem !important;
    padding: .65rem .75rem .85rem !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(24, 41, 71, .96) !important;
    border: 1px solid rgba(215, 206, 188, .18) !important;
    box-shadow: 0 14px 30px rgba(10, 18, 34, .28) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_navigation_primary_row,
  .pkp_structure_head.has_header_logo_banner .pkp_navigation_primary_wrapper {
    background: transparent !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_navigation_primary > li > a,
  .pkp_structure_head.has_header_logo_banner .pkp_navigation_user a,
  .pkp_structure_head.has_header_logo_banner .pkp_search {
    color: #fff !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_nav_list > li {
    display: block !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_nav_list ul {
    margin-top: .35rem !important;
    background: rgba(255, 255, 255, .96) !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_navigation_user_wrapper {
    top: .4rem !important;
    right: .85rem !important;
    max-width: calc(100% - 1.7rem);
  }

  .pkp_structure_head.has_header_logo_banner {
    background:
      linear-gradient(180deg, rgba(15, 33, 64, .06) 0%, rgba(15, 33, 64, .18) 100%),
      var(--header-logo-url) center .9rem / calc(100% - 1.5rem) auto no-repeat,
      linear-gradient(90deg, var(--color-primary-dark) 0%, var(--color-primary) 58%, var(--color-primary-light) 82%, #8c8b75 100%) !important;
  }

  .has_site_logo .pkp_head_wrapper {
    padding-top: .5rem !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_head_wrapper {
    padding-top: .4rem !important;
  }

  .has_site_logo .pkp_site_name_wrapper {
    min-height: 72px;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_site_name_wrapper,
  .pkp_structure_head.has_header_logo_banner .pkp_site_name {
    min-height: 74px;
  }

  .has_site_logo .pkp_site_name {
    min-height: 64px;
  }

  .has_site_logo .pkp_site_name .is_img img {
    width: auto;
    max-width: calc(100vw - 5rem);
    max-height: 64px !important;
  }

  .pkp_structure_head.has_header_logo_banner .pkp_site_name .is_img {
    visibility: hidden;
  }

  .user_profile_block__header {
    align-items: flex-start;
  }

  .user_profile_block__actions a {
    width: 100%;
  }
}

/* ============================================================
   Article Summaries / Listings
   ============================================================ */
.obj_article_summary {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.25rem !important;
  transition: var(--transition) !important;
  position: relative;
}
.obj_article_summary:hover {
  box-shadow: var(--shadow-hover) !important;
  border-color: var(--color-primary-light) !important;
  transform: translateY(-2px);
}

.obj_article_summary .title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  margin-bottom: .5rem !important;
}
.obj_article_summary .title a {
  color: var(--color-primary-dark) !important;
}
.obj_article_summary .title a:hover {
  color: var(--color-primary) !important;
  text-decoration: underline !important;
}

.obj_article_summary .authors {
  color: var(--color-text-muted) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  margin-bottom: .5rem !important;
}

.obj_article_summary .abstract {
  color: var(--color-text-muted) !important;
  font-size: .875rem !important;
  line-height: 1.6 !important;
}

/* Galley links (PDF, HTML buttons) */
.obj_galley_link {
  display: inline-flex !important;
  align-items: center !important;
  gap: .3rem !important;
  padding: .35rem .85rem !important;
  border-radius: var(--radius-sm) !important;
  font-size: .8125rem !important;
  font-weight: 600 !important;
  font-family: 'Inter', sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  transition: var(--transition) !important;
  border: 2px solid var(--color-primary) !important;
  color: var(--color-primary) !important;
  background: transparent !important;
  margin-right: .4rem !important;
  margin-top: .75rem !important;
  text-decoration: none !important;
}
.obj_galley_link:hover {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  text-decoration: none !important;
}
.obj_galley_link.pdf {
  border-color: #dc2626 !important;
  color: #dc2626 !important;
}
.obj_galley_link.pdf:hover {
  background: #dc2626 !important;
  color: #fff !important;
}

/* ============================================================
   Issue Table of Contents
   ============================================================ */
.obj_issue_toc {
  background: transparent !important;
}

.obj_issue_toc .section {
  margin-bottom: 2rem !important;
}

.obj_issue_toc .section_title {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--color-text-muted) !important;
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
  margin-bottom: 1rem !important;
}

/* ============================================================
   Issue Archive
   ============================================================ */
.obj_issue_summary {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.25rem !important;
  transition: var(--transition) !important;
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
}
.obj_issue_summary:hover {
  box-shadow: var(--shadow-hover) !important;
  transform: translateY(-1px);
}

.obj_issue_summary .title a {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
}
.obj_issue_summary .title a:hover {
  color: var(--color-primary) !important;
}

.obj_issue_summary .cover {
  flex-shrink: 0 !important;
  border-radius: var(--radius-sm) !important;
  overflow: hidden;
  box-shadow: var(--shadow-md) !important;
}

/* ============================================================
   Article Detail Page
   ============================================================ */
.obj_article_details {
  line-height: 1.7 !important;
}

.obj_article_details .title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
  line-height: 1.3 !important;
  margin-bottom: 1rem !important;
}

.obj_article_details .authors {
  color: var(--color-text-muted) !important;
  font-size: .9375rem !important;
  font-weight: 500 !important;
  margin-bottom: 1.25rem !important;
}

.obj_article_details .abstract {
  background: var(--color-surface-alt) !important;
  border-left: 4px solid var(--color-primary) !important;
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
  padding: 1.25rem 1.5rem !important;
  margin: 1.5rem 0 !important;
  font-size: .9375rem !important;
  line-height: 1.7 !important;
  color: var(--color-text) !important;
}

.obj_article_details .abstract h2 {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--color-primary) !important;
  margin-top: 0 !important;
  margin-bottom: .5rem !important;
  border: none !important;
}

/* Keywords */
.obj_article_details .keywords {
  margin: 1rem 0 !important;
}
.obj_article_details .keywords span {
  display: inline-block !important;
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 999px !important;
  padding: .2rem .75rem !important;
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin: .2rem .15rem !important;
  font-weight: 500 !important;
}

/* DOI / metadata */
.obj_article_details .doi,
.obj_article_details .published,
.obj_article_details .section {
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  margin: .35rem 0 !important;
}

/* ============================================================
   Buttons & Forms
   ============================================================ */
.pkp_button,
.pkp_form .button,
a.cmp_download_link,
input[type="submit"],
button[type="submit"] {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: .875rem !important;
  border-radius: var(--radius-md) !important;
  padding: .6rem 1.5rem !important;
  letter-spacing: .02em !important;
  transition: var(--transition) !important;
  cursor: pointer !important;
}

.pkp_button_primary,
input[type="submit"].button_primary {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%) !important;
  color: var(--color-text-inverse) !important;
  border: none !important;
  box-shadow: var(--shadow-md) !important;
}
.pkp_button_primary:hover {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%) !important;
  box-shadow: var(--shadow-lg) !important;
  transform: translateY(-1px);
}

/* Search form */
.pkp_search .pkp_search_form input[type="text"] {
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .5rem 1rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  transition: var(--transition) !important;
}
.pkp_search .pkp_search_form input[type="text"]:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(15,76,129,.15) !important;
}

/* ============================================================
   Homepage / Journal Index
   ============================================================ */
.page_index .description {
  font-size: 1rem !important;
  line-height: 1.7 !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 1.5rem !important;
}

/* Current issue highlight box */
.page_index .current_issue_title {
  font-family: 'Merriweather', Georgia, serif !important;
}

/* Homepage announcements */
.obj_announcement_summary {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1.25rem 1.5rem !important;
  margin-bottom: 1rem !important;
  transition: var(--transition) !important;
}
.obj_announcement_summary:hover {
  box-shadow: var(--shadow-md) !important;
  border-color: var(--color-primary-light) !important;
}
.obj_announcement_summary .title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
}
.obj_announcement_summary .title a {
  color: var(--color-primary-dark) !important;
}

/* ============================================================
   Breadcrumb
   ============================================================ */
.cmp_breadcrumbs {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 1.25rem !important;
  padding: .5rem .75rem !important;
  background: var(--color-surface-alt) !important;
  border-radius: var(--radius-sm) !important;
  border: 1px solid var(--color-border) !important;
}
.cmp_breadcrumbs a {
  color: var(--color-primary) !important;
  font-weight: 500 !important;
}
.cmp_breadcrumbs li:not(:last-child)::after {
  content: '›';
  margin: 0 .4rem;
  color: var(--color-border);
}

/* ============================================================
   Pagination
   ============================================================ */
.pkp_navigation_public,
.cmp_pagination {
  display: flex !important;
  gap: .375rem !important;
  flex-wrap: wrap !important;
  margin: 1.5rem 0 !important;
}

.pkp_navigation_public a,
.cmp_pagination a,
.pkp_navigation_public span,
.cmp_pagination span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 2.25rem !important;
  height: 2.25rem !important;
  padding: 0 .75rem !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  transition: var(--transition) !important;
}
.pkp_navigation_public a:hover,
.cmp_pagination a:hover {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-color: var(--color-primary) !important;
  text-decoration: none !important;
}
.pkp_navigation_public .current,
.cmp_pagination .current {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-color: var(--color-primary) !important;
}

/* ============================================================
   Footer
   ============================================================ */
.pkp_structure_footer_wrapper {
  background: var(--color-text) !important;
  border-top: 3px solid var(--color-accent) !important;
  margin-top: 2rem !important;
}

.pkp_structure_footer {
  padding: 2.5rem 0 1.5rem !important;
}

.pkp_footer_content {
  color: rgba(255,255,255,.75) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  line-height: 1.6 !important;
  padding: 1rem 1.5rem !important;
}
.pkp_footer_content a {
  color: var(--color-accent-light) !important;
}
.pkp_footer_content a:hover {
  color: #fff !important;
}

.pkp_brand_footer {
  border-top: 1px solid rgba(255,255,255,.1) !important;
  padding: 1rem 1.5rem !important;
  margin-top: .5rem !important;
}
.pkp_brand_footer a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .8rem 1rem;
  border-radius: var(--radius-md);
  background: rgba(245, 240, 230, .96);
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  opacity: 1;
  transition: var(--transition);
}
.pkp_brand_footer a:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
}

.pkp_brand_footer img {
  display: block;
  max-height: 72px;
  width: auto;
  filter: contrast(1.08) saturate(.95);
}

/* ============================================================
   Login / Register Pages — Full Modern Redesign
   ============================================================ */

/* --- Override fixed container width so background spans full page --- */
.pkp_page_login .pkp_structure_content,
.pkp_page_register .pkp_structure_content {
  width: 100% !important;
  max-width: 100% !important;
  min-height: calc(100vh - 80px) !important;
  background: linear-gradient(135deg, #0d3d6e 0%, #0f4c81 45%, #1a6fb5 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(2.25rem, 4vw, 4rem) 1.5rem !important;
  box-sizing: border-box !important;
  position: relative !important;
  overflow: visible !important;
}

/* Decorative glow circles */
.pkp_page_login .pkp_structure_content::before,
.pkp_page_register .pkp_structure_content::before {
  content: '' !important;
  position: absolute !important;
  top: -10% !important; right: -5% !important;
  width: 40vw !important; height: 40vw !important;
  background: radial-gradient(circle, rgba(255,255,255,.07) 0%, transparent 65%) !important;
  border-radius: 50% !important;
  pointer-events: none !important;
  z-index: 0 !important;
}
.pkp_page_login .pkp_structure_content::after,
.pkp_page_register .pkp_structure_content::after {
  content: '' !important;
  position: absolute !important;
  bottom: -8% !important; left: -3% !important;
  width: 35vw !important; height: 35vw !important;
  background: radial-gradient(circle, rgba(255,255,255,.05) 0%, transparent 65%) !important;
  border-radius: 50% !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

/* --- Reset pkp_structure_main: strip float, fixed widths, and border pseudo-elements --- */
.pkp_page_login .pkp_structure_main,
.pkp_page_register .pkp_structure_main {
  float: none !important;
  width: 520px !important;
  max-width: calc(100vw - 3rem) !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  z-index: 1 !important;
  flex-shrink: 0 !important;
}
/* Hide default theme vertical border lines on login/register */
.pkp_page_login .pkp_structure_main::before,
.pkp_page_login .pkp_structure_main::after,
.pkp_page_register .pkp_structure_main::before,
.pkp_page_register .pkp_structure_main::after {
  display: none !important;
}

/* Hide sidebar on auth pages */
.pkp_page_login .pkp_structure_sidebar,
.pkp_page_register .pkp_structure_sidebar {
  display: none !important;
}

/* Hide breadcrumbs on auth pages */
.pkp_page_login .cmp_breadcrumbs,
.pkp_page_register .cmp_breadcrumbs {
  display: none !important;
}

/* --- White login card --- */
.pkp_page_login .page,
.pkp_page_register .page {
  background: #fff !important;
  border: 1px solid rgba(255,255,255,.45) !important;
  border-radius: 20px !important;
  box-shadow: 0 24px 64px rgba(2, 24, 47, .35), 0 8px 22px rgba(2, 24, 47, .2) !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Accent stripe at top of card */
.pkp_page_login .page::before,
.pkp_page_register .page::before {
  content: '' !important;
  display: block !important;
  height: 5px !important;
  background: linear-gradient(90deg, #0d3d6e, #2196f3, #0d3d6e) !important;
  width: 100% !important;
}

/* Inner card padding wrapper — use h1 + form inside .page */
.pkp_page_login .page h1,
.pkp_page_register .page h1 {
  font-family: 'Inter', sans-serif !important;
  font-size: 1.9rem !important;
  font-weight: 700 !important;
  color: #0d3d6e !important;
  text-align: center !important;
  margin: 2.25rem 2.75rem .4rem !important;
  letter-spacing: -.02em !important;
  line-height: 1.2 !important;
}

/* Asterisk note */
.pkp_page_login .page > p,
.pkp_page_register .page > p {
  font-size: .92rem !important;
  color: #6b7280 !important;
  text-align: center !important;
  margin: 0 2.75rem 1.6rem !important;
  font-family: 'Inter', sans-serif !important;
}

/* --- Form wrapper --- */
.pkp_page_login .cmp_form,
.pkp_page_register .cmp_form {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 2.75rem 2.75rem !important;
  box-sizing: border-box !important;
}

.pkp_page_login .cmp_form.login,
.pkp_page_register .cmp_form.register,
.page_login .login,
.page_register .register {
  width: 100% !important;
  max-width: none !important;
}

/* Strip fieldset styling — must be full-width */
.pkp_page_login .cmp_form fieldset,
.pkp_page_register .cmp_form fieldset {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  box-sizing: border-box !important;
}

/* --- Field groups --- */
.pkp_page_login .cmp_form .username,
.pkp_page_login .cmp_form .password,
.pkp_page_register .cmp_form .fields > div:not(.buttons):not(.remember) {
  display: block !important;
  width: 100% !important;
  margin-bottom: 1.4rem !important;
  position: relative !important;
  box-sizing: border-box !important;
  float: none !important;
}
/* Also ensure .buttons and .remember are full-width */
.pkp_page_login .cmp_form .buttons,
.pkp_page_login .cmp_form .remember {
  float: none !important;
  clear: both !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* --- Labels: OJS uses <span class="label"> not <label> --- */
.pkp_page_login .cmp_form span.label,
.pkp_page_register .cmp_form span.label {
  font-family: 'Inter', sans-serif !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  color: #1f2937 !important;
  display: block !important;
  margin-bottom: .5rem !important;
  letter-spacing: .01em !important;
  text-transform: none !important;
}
/* Also cover real <label> elements (register page may have them) */
.pkp_page_login .cmp_form label,
.pkp_page_register .cmp_form label {
  font-family: 'Inter', sans-serif !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  color: #1f2937 !important;
  letter-spacing: .01em !important;
  text-transform: none !important;
}

/* --- Input fields --- */
.pkp_page_login .cmp_form input[type="text"],
.pkp_page_login .cmp_form input[type="email"],
.pkp_page_login .cmp_form input[type="password"],
.pkp_page_register .cmp_form input[type="text"],
.pkp_page_register .cmp_form input[type="email"],
.pkp_page_register .cmp_form input[type="password"] {
  display: block !important;
  width: 100% !important;
  padding: 1rem 1.05rem !important;
  border: 2px solid #dbe4ee !important;
  border-radius: 12px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important;
  color: #111827 !important;
  background: #ffffff !important;
  transition: border-color .2s, box-shadow .2s, background .2s, transform .15s !important;
  box-sizing: border-box !important;
  -webkit-box-sizing: border-box !important;
}
.pkp_page_login .cmp_form input::placeholder,
.pkp_page_register .cmp_form input::placeholder {
  color: #94a3b8 !important;
}
.pkp_page_login .cmp_form input[type="text"]:focus,
.pkp_page_login .cmp_form input[type="email"]:focus,
.pkp_page_login .cmp_form input[type="password"]:focus,
.pkp_page_register .cmp_form input[type="text"]:focus,
.pkp_page_register .cmp_form input[type="email"]:focus,
.pkp_page_register .cmp_form input[type="password"]:focus {
  border-color: #0f4c81 !important;
  background: #fff !important;
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(15,76,129,.14) !important;
  transform: translateY(-1px) !important;
}

/* --- Forgot password link --- */
.pkp_page_login .cmp_form .password a {
  display: inline-flex !important;
  align-items: center !important;
  margin-top: .55rem !important;
  font-size: .9rem !important;
  color: #0f4c81 !important;
  text-decoration: none !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
}
.pkp_page_login .cmp_form .password a:hover {
  text-decoration: underline !important;
  color: #1a6fb5 !important;
}

/* --- Remember me row --- */
.pkp_page_login .cmp_form .remember {
  display: flex !important;
  align-items: center !important;
  gap: .7rem !important;
  margin-bottom: 1.9rem !important;
}
.pkp_page_login .cmp_form .remember input[type="checkbox"] {
  width: 1.1rem !important;
  height: 1.1rem !important;
  accent-color: #0f4c81 !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}
.pkp_page_login .cmp_form .remember span.label,
.pkp_page_login .cmp_form .remember label {
  font-size: .95rem !important;
  color: #475569 !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  margin: 0 !important;
  display: inline !important;
}

/* --- Buttons column --- */
.pkp_page_login .cmp_form .buttons,
.pkp_page_register .cmp_form .buttons {
  display: flex !important;
  flex-direction: column !important;
  gap: .9rem !important;
  width: 100% !important;
}

/* Login / submit button */
.pkp_page_login .cmp_form .buttons button.submit,
.pkp_page_login .cmp_form .buttons input[type="submit"],
.pkp_page_register .cmp_form .buttons button[type="submit"],
.pkp_page_register .cmp_form .buttons input[type="submit"] {
  display: block !important;
  width: 100% !important;
  min-height: 52px !important;
  padding: .95rem 1.5rem !important;
  background: linear-gradient(135deg, #0b3f73 0%, #165d9d 52%, #1f79c1 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
  cursor: pointer !important;
  transition: filter .2s, transform .15s, box-shadow .2s !important;
  box-shadow: 0 4px 16px rgba(15,76,129,.38) !important;
  box-sizing: border-box !important;
  text-align: center !important;
}
.pkp_page_login .cmp_form .buttons button.submit:hover,
.pkp_page_login .cmp_form .buttons input[type="submit"]:hover,
.pkp_page_register .cmp_form .buttons button[type="submit"]:hover {
  filter: brightness(1.06) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 22px rgba(15,76,129,.48) !important;
}
.pkp_page_login .cmp_form .buttons button.submit:active {
  transform: translateY(0) !important;
}

/* "or" divider */
.pkp_page_login .cmp_form .buttons::before {
  content: 'OR' !important;
  display: block !important;
  text-align: center !important;
  font-size: .72rem !important;
  color: #94a3b8 !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: .18em !important;
  margin: .1rem 0 .2rem !important;
}

/* Register link — outlined secondary */
.pkp_page_login .cmp_form .buttons a.register {
  display: block !important;
  width: 100% !important;
  min-height: 50px !important;
  padding: .85rem 1.5rem !important;
  text-align: center !important;
  background: #f8fafc !important;
  border: 1.5px solid #dbe4ee !important;
  border-radius: 12px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .96rem !important;
  font-weight: 600 !important;
  color: #374151 !important;
  text-decoration: none !important;
  transition: border-color .2s, background .2s, color .2s !important;
  box-sizing: border-box !important;
}
.pkp_page_login .cmp_form .buttons a.register:hover {
  border-color: #0f4c81 !important;
  color: #0f4c81 !important;
  background: #eef5fb !important;
}

.pkp_page_login .pkp_form_error,
.pkp_page_register .pkp_form_error {
  margin-bottom: 1rem !important;
  padding: .85rem 1rem !important;
  border: 1px solid #fecaca !important;
  border-radius: 10px !important;
  background: #fef2f2 !important;
  color: #991b1b !important;
  font-size: .9rem !important;
  line-height: 1.45 !important;
}

/* --- Responsive --- */
@media (max-width: 520px) {
  .pkp_page_login .cmp_form,
  .pkp_page_register .cmp_form {
    padding: 0 1.35rem 1.6rem !important;
  }
  .pkp_page_login .page h1,
  .pkp_page_register .page h1 {
    margin: 1.6rem 1.35rem .35rem !important;
    font-size: 1.45rem !important;
  }
  .pkp_page_login .page > p,
  .pkp_page_register .page > p {
    font-size: .88rem !important;
    margin: 0 1.35rem 1.2rem !important;
  }
}

.pkp_form fieldset {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1.25rem !important;
  margin-bottom: 1rem !important;
}

.pkp_form label {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  display: block !important;
  margin-bottom: .35rem !important;
}

.pkp_form input[type="text"],
.pkp_form input[type="email"],
.pkp_form input[type="password"],
.pkp_form textarea,
.pkp_form select {
  width: 100% !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .55rem .9rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9375rem !important;
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  transition: var(--transition) !important;
  box-sizing: border-box !important;
}
.pkp_form input[type="text"]:focus,
.pkp_form input[type="email"]:focus,
.pkp_form input[type="password"]:focus,
.pkp_form textarea:focus,
.pkp_form select:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(15,76,129,.12) !important;
}

/* ============================================================
   Notifications / Alerts
   ============================================================ */
.pkp_notification {
  border-radius: var(--radius-md) !important;
  padding: .875rem 1.25rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9rem !important;
  margin-bottom: 1rem !important;
  border-left-width: 4px !important;
}

/* ============================================================
   Mobile navigation toggle button
   ============================================================ */
.pkp_site_nav_toggle {
  background: rgba(255,255,255,.15) !important;
  border: 1px solid rgba(255,255,255,.3) !important;
  border-radius: var(--radius-sm) !important;
  color: #fff !important;
  transition: var(--transition) !important;
}
.pkp_site_nav_toggle:hover {
  background: rgba(255,255,255,.25) !important;
}

/* ============================================================
   Utility classes override
   ============================================================ */
.label {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* ============================================================
   Responsive tweaks
   ============================================================ */
@media (max-width: 767px) {
  .pkp_structure_main {
    border-radius: var(--radius-md) !important;
    padding: 1.25rem 1rem !important;
  }
  .obj_article_summary {
    padding: 1rem !important;
  }
  .obj_article_details .title {
    font-size: 1.375rem !important;
  }
  .pkp_structure_head {
    position: relative !important;
  }
}

@media (min-width: 992px) {
  .pkp_structure_content {
    padding-top: 2.5rem !important;
    padding-bottom: 4rem !important;
  }
}

/* ============================================================
   Homepage / indexJournal
   ============================================================ */

/* Hero banner image */
.homepage_image {
  margin: 0 0 2rem !important;
  padding: 1.25rem !important;
  overflow: hidden !important;
  border-radius: var(--radius-lg) !important;
  max-height: none !important;
  background: linear-gradient(145deg, #f8f4ea 0%, #eef4fb 55%, #f3efe4 100%) !important;
  border: 1px solid rgba(177, 151, 88, .22) !important;
  display: flex !important;
  justify-content: center !important;
}
.homepage_image img {
  width: auto !important;
  max-width: min(100%, 560px) !important;
  max-height: 820px !important;
  height: auto !important;
  object-fit: contain !important;
  aspect-ratio: auto !important;
  border-radius: var(--radius-md) !important;
  box-shadow: 0 18px 40px rgba(14, 32, 61, .12) !important;
  border: 1px solid rgba(22, 43, 73, .08) !important;
  background: #fff !important;
}

/* About section on homepage */
.homepage_about {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1.5rem !important;
  margin-bottom: 2rem !important;
}
.homepage_about h2 {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--color-primary) !important;
  margin-top: 0 !important;
  margin-bottom: .75rem !important;
  border: none !important;
}

.journal_profile {
  display: grid !important;
  gap: 1.25rem !important;
}

.homepage_profile {
  margin: 0 !important;
}

.journal_profile__eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  color: var(--color-primary) !important;
}

.journal_profile__title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: clamp(1.6rem, 2.5vw, 2.3rem) !important;
  line-height: 1.25 !important;
  color: var(--color-primary-dark) !important;
  margin: 0 !important;
}

.journal_profile__lead,
.journal_profile__summary {
  font-size: .98rem !important;
  line-height: 1.8 !important;
  color: var(--color-text) !important;
  margin: 0 !important;
}

.journal_profile__meta {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)) !important;
  gap: 1rem !important;
}

.journal_profile__meta_item {
  background: #fff !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.05rem !important;
  box-shadow: var(--shadow-sm) !important;
}

.journal_profile__meta_label {
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .09em !important;
  color: var(--color-text-muted) !important;
  margin-bottom: .45rem !important;
}

.journal_profile__meta_value,
.journal_profile__meta_value a {
  color: var(--color-primary-dark) !important;
  font-size: .93rem !important;
  font-weight: 600 !important;
  line-height: 1.6 !important;
  text-decoration: none !important;
}

.journal_profile__meta_value a:hover {
  color: var(--color-primary) !important;
}

.journal_profile__indexing_wrap {
  display: grid !important;
  gap: .75rem !important;
}

.journal_profile__indexing_label {
  font-family: 'Inter', sans-serif !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--color-text-muted) !important;
}

.journal_profile__indexing {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .65rem !important;
}

.journal_profile__indexing span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 36px !important;
  padding: .45rem .9rem !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, rgba(28, 62, 112, .08) 0%, rgba(201, 175, 96, .18) 100%) !important;
  border: 1px solid rgba(28, 62, 112, .12) !important;
  color: var(--color-primary-dark) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .86rem !important;
  font-weight: 600 !important;
}

@media (max-width: 767px) {
  .homepage_image {
    padding: .85rem !important;
  }

  .homepage_image img {
    max-width: 100% !important;
    max-height: none !important;
  }

  .journal_profile__meta {
    grid-template-columns: 1fr !important;
  }
}

/* Current issue section on homepage */
.current_issue {
  margin-top: 2rem !important;
}
.current_issue > h2 {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--color-text-muted) !important;
  margin-top: 0 !important;
  margin-bottom: .5rem !important;
  padding-bottom: .5rem !important;
  border-bottom: 2px solid var(--color-border) !important;
}
.current_issue_title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.375rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
  margin-bottom: 1.5rem !important;
}

/* "View all issues" link */
.read_more {
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
  margin-top: 1.25rem !important;
  padding: .55rem 1.25rem !important;
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
  box-shadow: var(--shadow-sm) !important;
}
.read_more:hover {
  background: var(--color-primary-dark) !important;
  color: var(--color-text-inverse) !important;
  text-decoration: none !important;
  box-shadow: var(--shadow-md) !important;
}
.read_more::after {
  content: '→' !important;
}

/* Additional homepage content */
.additional_content {
  margin-top: 2rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid var(--color-border) !important;
  line-height: 1.75 !important;
}

/* Feature cards grid */
.homepage_cards {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: 1rem !important;
  margin-bottom: 2rem !important;
}
.hcard {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 1.5rem 1.25rem !important;
  text-align: center !important;
  transition: var(--transition) !important;
}
.hcard:hover {
  box-shadow: var(--shadow-md) !important;
  border-color: var(--color-primary-light) !important;
  transform: translateY(-3px) !important;
}
.hcard_icon {
  font-size: 2rem !important;
  margin-bottom: .75rem !important;
  line-height: 1 !important;
}
.hcard h3 {
  font-family: 'Inter', sans-serif !important;
  font-size: .9375rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
  margin: 0 0 .5rem !important;
  border: none !important;
}
.hcard p {
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* Call for Papers banner */
.homepage_cfp {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 60%, var(--color-primary-light) 100%) !important;
  border-radius: var(--radius-lg) !important;
  padding: 2.5rem 2rem !important;
  text-align: center !important;
  color: var(--color-text-inverse) !important;
  position: relative !important;
  overflow: hidden !important;
}
.homepage_cfp::before {
  content: '' !important;
  position: absolute !important;
  top: -50% !important;
  right: -10% !important;
  width: 300px !important;
  height: 300px !important;
  background: rgba(255,255,255,.05) !important;
  border-radius: 50% !important;
}
.cfp_inner {
  position: relative !important;
  z-index: 1 !important;
}
.homepage_cfp h2 {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin: 0 0 .75rem !important;
  border: none !important;
  padding: 0 !important;
}
.homepage_cfp p {
  font-size: .9375rem !important;
  color: rgba(255,255,255,.85) !important;
  max-width: 560px !important;
  margin: 0 auto 1.5rem !important;
  line-height: 1.7 !important;
}
.homepage_cfp--sidebar {
  margin-bottom: 1.25rem !important;
  padding: 1.5rem 1.25rem !important;
  text-align: left !important;
}
.homepage_cfp--sidebar::before {
  top: -35% !important;
  right: -45% !important;
  width: 220px !important;
  height: 220px !important;
}
.homepage_cfp--sidebar h2 {
  font-size: 1.2rem !important;
  margin-bottom: .65rem !important;
}
.homepage_cfp--sidebar p {
  max-width: none !important;
  margin: 0 0 1rem !important;
  font-size: .875rem !important;
}
.homepage_cfp--sidebar .cfp_btn {
  width: 100% !important;
  justify-content: center !important;
  padding-inline: 1rem !important;
}
.cfp_btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: .5rem !important;
  background: var(--color-accent) !important;
  color: var(--color-text) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  font-size: .9375rem !important;
  padding: .75rem 2rem !important;
  border-radius: var(--radius-md) !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.2) !important;
}
.cfp_btn:hover {
  background: var(--color-accent-light) !important;
  color: var(--color-text) !important;
  text-decoration: none !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 16px rgba(0,0,0,.25) !important;
}

/* ============================================================
   Article Summary — complete overhaul
   ============================================================ */
.obj_article_summary {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 1.5rem !important;
  margin-bottom: 1rem !important;
  transition: var(--transition) !important;
  position: relative !important;
}
.obj_article_summary:hover {
  box-shadow: var(--shadow-hover) !important;
  border-color: var(--color-primary-light) !important;
  transform: translateY(-2px) !important;
}

/* Article title in listing */
.obj_article_summary .title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  margin: 0 0 .5rem !important;
}
.obj_article_summary .title a {
  color: var(--color-primary-dark) !important;
}
.obj_article_summary .title a:hover {
  color: var(--color-primary) !important;
  text-decoration: underline !important;
}
/* Subtitle in article summary */
.obj_article_summary .title .subtitle {
  display: block !important;
  font-size: .9rem !important;
  font-weight: 400 !important;
  color: var(--color-text-muted) !important;
  margin-top: .25rem !important;
}

/* Meta (authors, pages, date) */
.obj_article_summary .meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .5rem 1rem !important;
  margin-bottom: .75rem !important;
}
.obj_article_summary .meta .authors {
  color: var(--color-text-muted) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
}
.obj_article_summary .meta .pages {
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  font-family: 'Inter', sans-serif !important;
  background: var(--color-surface-alt) !important;
  padding: .1rem .5rem !important;
  border-radius: var(--radius-sm) !important;
  border: 1px solid var(--color-border) !important;
}
.obj_article_summary .meta .published {
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  font-family: 'Inter', sans-serif !important;
}

/* Cover image in article summary */
.obj_article_summary .cover {
  float: right !important;
  margin: 0 0 1rem 1.25rem !important;
  border-radius: var(--radius-sm) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-md) !important;
  max-width: 90px !important;
}
.obj_article_summary .cover img {
  display: block !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Galley links list in summary */
.obj_article_summary .galleys_links {
  list-style: none !important;
  padding: 0 !important;
  margin: .75rem 0 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .4rem !important;
}
.obj_article_summary .galleys_links li {
  padding: 0 !important;
  border: none !important;
}

/* ============================================================
   Issue TOC — full styling
   ============================================================ */
.obj_issue_toc .heading {
  margin-bottom: 1.5rem !important;
  padding-bottom: 1rem !important;
  border-bottom: 2px solid var(--color-border) !important;
}
.obj_issue_toc .heading .cover {
  float: right !important;
  margin: 0 0 1rem 1.5rem !important;
  border-radius: var(--radius-sm) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-md) !important;
  max-width: 120px !important;
}
.obj_issue_toc .heading .cover img {
  display: block !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.obj_issue_toc .heading .description {
  color: var(--color-text-muted) !important;
  font-size: .9375rem !important;
  line-height: 1.7 !important;
}
.obj_issue_toc .heading .published {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  margin-top: .75rem !important;
}
.obj_issue_toc .heading .published .label {
  font-weight: 600 !important;
}

/* Pub ID (DOI etc) in issue heading */
.obj_issue_toc .heading .pub_id {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  margin-top: .5rem !important;
}
.obj_issue_toc .heading .pub_id .type {
  font-weight: 600 !important;
}

/* Full-issue galley download area */
.obj_issue_toc .galleys {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.25rem !important;
  margin-bottom: 1.5rem !important;
}
.obj_issue_toc .galleys h2,
.obj_issue_toc .galleys h3 {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--color-text-muted) !important;
  margin: 0 0 .75rem !important;
}
.obj_issue_toc .galleys .galleys_links {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .5rem !important;
}
.obj_issue_toc .galleys .galleys_links li {
  padding: 0 !important;
  border: none !important;
}

/* Sections container */
.obj_issue_toc .sections {
  margin-top: 1rem !important;
}
.obj_issue_toc .section {
  margin-bottom: 2rem !important;
}
.obj_issue_toc .section h2,
.obj_issue_toc .section h3 {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--color-text-muted) !important;
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
  margin-bottom: 1rem !important;
}

/* Article list in TOC */
.obj_issue_toc .cmp_article_list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.obj_issue_toc .cmp_article_list li {
  padding: 0 !important;
  border: none !important;
}

/* Issue archive list */
.page_issue_archive .issues_archive {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.page_issue_archive .issues_archive > li {
  padding: 0 !important;
  border: none !important;
}

/* ============================================================
   Article Detail Page — Full Layout
   ============================================================ */

/* Title & subtitle */
.obj_article_details .page_title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
  line-height: 1.3 !important;
  margin-top: 0 !important;
  margin-bottom: .75rem !important;
  border: none !important;
  padding: 0 !important;
}
.obj_article_details .subtitle {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.2rem !important;
  font-weight: 400 !important;
  font-style: italic !important;
  color: var(--color-text-muted) !important;
  margin-top: -.5rem !important;
  margin-bottom: 1rem !important;
}

/* 2-column layout: main + sidebar */
.obj_article_details .row {
  display: flex !important;
  gap: 2rem !important;
  align-items: flex-start !important;
  flex-wrap: wrap !important;
}
.obj_article_details .main_entry {
  flex: 1 1 60% !important;
  min-width: 0 !important;
}
.obj_article_details .entry_details {
  flex: 0 0 240px !important;
  width: 240px !important;
}

/* Generic item + label/value pattern */
.obj_article_details .item {
  margin-bottom: 1.5rem !important;
  padding-bottom: 1.5rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}
.obj_article_details .item:last-child {
  border-bottom: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.obj_article_details .sub_item {
  margin-bottom: .75rem !important;
}
.obj_article_details .sub_item:last-child {
  margin-bottom: 0 !important;
}

/* Label (section headings within article detail) */
.obj_article_details .label {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--color-primary) !important;
  margin-bottom: .4rem !important;
  display: block !important;
}
.obj_article_details .value {
  color: var(--color-text) !important;
  font-size: .9375rem !important;
  line-height: 1.6 !important;
}

/* Authors section */
.obj_article_details .item.authors {
  border-bottom: 1px solid var(--color-border) !important;
  padding-bottom: 1.25rem !important;
  margin-bottom: 1.25rem !important;
}
.obj_article_details .authors ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .5rem 1.5rem !important;
}
.obj_article_details .authors li {
  padding: 0 !important;
  border: none !important;
}
.obj_article_details .authors .name {
  font-weight: 600 !important;
  font-size: .9375rem !important;
  color: var(--color-text) !important;
  display: block !important;
}
.obj_article_details .authors .affiliation {
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  font-style: italic !important;
  display: block !important;
}
.obj_article_details .authors .userGroup {
  display: inline-block !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  color: var(--color-primary) !important;
  background: rgba(15,76,129,.08) !important;
  padding: .1rem .5rem !important;
  border-radius: 999px !important;
  margin-top: .2rem !important;
}
.obj_article_details .authors .orcid {
  display: flex !important;
  align-items: center !important;
  gap: .3rem !important;
  font-size: .8125rem !important;
  margin-top: .15rem !important;
}
.obj_article_details .authors .orcid a {
  color: #a6ce39 !important;
}
.obj_article_details .authors .orcid img {
  width: 16px !important;
  height: 16px !important;
  box-shadow: none !important;
}

/* DOI section */
.obj_article_details .item.doi .label,
.obj_article_details .item.doi h2 {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--color-primary) !important;
  margin-bottom: .3rem !important;
}
.obj_article_details .item.doi .value a {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  word-break: break-all !important;
}

/* Keywords — styled as pill tags */
.obj_article_details .item.keywords .value {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .3rem !important;
}
.obj_article_details .item.keywords .value::before {
  content: none !important;
}

/* Abstract */
.obj_article_details .item.abstract {
  background: var(--color-surface-alt) !important;
  border-left: 4px solid var(--color-primary) !important;
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
  padding: 1.25rem 1.5rem !important;
  border-bottom: none !important;
  margin-bottom: 1.5rem !important;
}
.obj_article_details .item.abstract .label,
.obj_article_details .item.abstract h2 {
  color: var(--color-primary) !important;
  margin-bottom: .5rem !important;
}
.obj_article_details .item.abstract .value,
.obj_article_details .item.abstract p {
  line-height: 1.75 !important;
  font-size: .9375rem !important;
}

/* Author biographies */
.obj_article_details .item.author_bios .authors {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.obj_article_details .item.author_bios .authors .sub_item {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.25rem !important;
  margin-bottom: .75rem !important;
}
.obj_article_details .item.author_bios .authors .sub_item .label {
  font-size: .875rem !important;
  font-weight: 600 !important;
  color: var(--color-primary-dark) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin-bottom: .4rem !important;
}
.obj_article_details .item.author_bios .authors .sub_item .value {
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
}

/* References */
.obj_article_details .item.references .value {
  font-size: .875rem !important;
  line-height: 1.7 !important;
}
.obj_article_details .item.references .value p {
  margin: .5rem 0 !important;
  padding-left: 1.5rem !important;
  text-indent: -1.5rem !important;
  color: var(--color-text-muted) !important;
}

/* Downloads chart */
.obj_article_details .item.downloads_chart {
  margin-top: 1rem !important;
}
.obj_article_details .item.downloads_chart canvas {
  max-height: 200px !important;
}

/* Data availability */
.obj_article_details .item.dataAvailability {
  background: #f0fdf4 !important;
  border: 1px solid #bbf7d0 !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.25rem !important;
}
.obj_article_details .item.dataAvailability .label,
.obj_article_details .item.dataAvailability h2 {
  color: #166534 !important;
}

/* — Entry details sidebar — */
.obj_article_details .entry_details .item {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem !important;
  margin-bottom: .75rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Cover image in detail sidebar */
.obj_article_details .item.cover_image img {
  width: 100% !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--shadow-md) !important;
}

/* Galley links in detail sidebar */
.obj_article_details .item.galleys .galleys_links {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .4rem !important;
}
.obj_article_details .item.galleys .galleys_links li {
  padding: 0 !important;
  border: none !important;
}
.obj_article_details .item.galleys .obj_galley_link {
  width: 100% !important;
  justify-content: center !important;
  border-radius: var(--radius-md) !important;
  padding: .5rem 1rem !important;
}

/* Supplementary galleys */
.obj_article_details .item.galleys .supplementary_galleys_links {
  list-style: none !important;
  padding: 0 !important;
  margin: .5rem 0 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .3rem !important;
}

/* Published date in detail sidebar */
.obj_article_details .item.published .value {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
}

/* Versions list */
.obj_article_details .sub_item.versions ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: .875rem !important;
}
.obj_article_details .sub_item.versions ul li {
  padding: .2rem 0 !important;
  border: none !important;
}

/* Issue info box in sidebar */
.obj_article_details .item.issue .sub_item .label,
.obj_article_details .item.issue .sub_item h2 {
  margin-bottom: .2rem !important;
}
.obj_article_details .item.issue .title {
  font-weight: 600 !important;
  font-size: .875rem !important;
}

/* Copyright / License */
.obj_article_details .item.copyright .label,
.obj_article_details .item.copyright h2 {
  margin-bottom: .5rem !important;
}
.obj_article_details .item.copyright img {
  box-shadow: none !important;
  border-radius: 0 !important;
  margin-top: .5rem !important;
}
.obj_article_details .item.copyright p {
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin: .25rem 0 !important;
}

/* Versions notice */
.cmp_notification.notice {
  background: var(--color-surface-alt) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary-dark) !important;
}

/* Galley link — HTML variant */
.obj_galley_link.html {
  border-color: #0891b2 !important;
  color: #0891b2 !important;
}
.obj_galley_link.html:hover {
  background: #0891b2 !important;
  color: #fff !important;
}

/* Responsive: stack 2-column on mobile */
@media (max-width: 767px) {
  .obj_article_details .row {
    flex-direction: column !important;
  }
  .obj_article_details .entry_details {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
  .obj_article_details .item.galleys .obj_galley_link {
    width: auto !important;
  }
  .homepage_image {
    margin: -1.25rem -1rem 1.5rem !important;
  }
}

/* ============================================================
   Search Page
   ============================================================ */
.page_search h1 {
  color: var(--color-primary-dark) !important;
}

.page_search .search_input {
  display: flex !important;
  gap: .5rem !important;
  margin-bottom: 1.5rem !important;
}

.page_search .search_input input[type="text"].query {
  flex: 1 !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .65rem 1rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important;
  transition: var(--transition) !important;
}
.page_search .search_input input[type="text"].query:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(15,76,129,.12) !important;
}

.page_search .search_advanced {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1.25rem !important;
  margin-bottom: 1.5rem !important;
}
.page_search .search_advanced legend {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--color-primary) !important;
  padding: 0 .5rem !important;
}
.page_search .date_range {
  display: flex !important;
  gap: 1.5rem !important;
  flex-wrap: wrap !important;
  margin-bottom: 1rem !important;
}
.page_search .date_range fieldset {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: .75rem 1rem !important;
}
.page_search .date_range legend {
  font-size: .8rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--color-text-muted) !important;
}
.page_search select {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: .25rem .5rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  margin: 0 .2rem !important;
}
.page_search .author {
  margin-top: .75rem !important;
}
.page_search .author label.label {
  display: block !important;
  margin-bottom: .35rem !important;
}
.page_search .author input[type="text"] {
  width: 100% !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .5rem .9rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9375rem !important;
  transition: var(--transition) !important;
}
.page_search .author input[type="text"]:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
}

/* Search results */
.page_search .search_results .obj_article_summary {
  border-left: 3px solid var(--color-primary-light) !important;
}

/* ============================================================
   Table Styles (for article body content)
   ============================================================ */
.pkp_structure_main table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 1.5rem 0 !important;
  font-size: .9rem !important;
  font-family: 'Inter', sans-serif !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-sm) !important;
}
.pkp_structure_main table th {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  font-weight: 600 !important;
  padding: .75rem 1rem !important;
  text-align: left !important;
  font-size: .8125rem !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.pkp_structure_main table td {
  padding: .65rem 1rem !important;
  border-bottom: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  vertical-align: top !important;
}
.pkp_structure_main table tr:last-child td {
  border-bottom: none !important;
}
.pkp_structure_main table tr:nth-child(even) td {
  background: var(--color-surface-alt) !important;
}
.pkp_structure_main table tr:hover td {
  background: rgba(15,76,129,.04) !important;
}

/* ============================================================
   General Form (.cmp_form)
   ============================================================ */
.cmp_form fieldset.fields {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.25rem !important;
}
.cmp_form fieldset.fields legend {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--color-primary) !important;
  padding: 0 .5rem !important;
}
.cmp_form .username,
.cmp_form .password,
.cmp_form .email,
.cmp_form .givenName,
.cmp_form .familyName {
  margin-bottom: 1rem !important;
}
.cmp_form label {
  display: block !important;
}
.cmp_form label .label {
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  margin-bottom: .4rem !important;
}
.cmp_form input[type="text"],
.cmp_form input[type="email"],
.cmp_form input[type="password"] {
  width: 100% !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .6rem .9rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9375rem !important;
  color: var(--color-text) !important;
  transition: var(--transition) !important;
  box-sizing: border-box !important;
}
.cmp_form input:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(15,76,129,.12) !important;
}
.cmp_form .required {
  color: #dc2626 !important;
}
.cmp_form .submit {
  margin-top: 1.25rem !important;
}
.cmp_form input[type="submit"],
.cmp_form button[type="submit"] {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%) !important;
  color: var(--color-text-inverse) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  padding: .7rem 2rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9375rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
  box-shadow: var(--shadow-md) !important;
}
.cmp_form input[type="submit"]:hover,
.cmp_form button[type="submit"]:hover {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Forgot password link */
.cmp_form .forgot_password {
  font-size: .875rem !important;
  margin-top: .5rem !important;
  display: block !important;
}

/* ============================================================
   Notification / Alert Boxes (.cmp_notification)
   ============================================================ */
.cmp_notification {
  border-radius: var(--radius-md) !important;
  padding: .875rem 1.25rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .9rem !important;
  margin: 1rem 0 !important;
  border-left: 4px solid !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: .75rem !important;
}
.cmp_notification.warning {
  background: #fffbeb !important;
  border-color: #f59e0b !important;
  color: #92400e !important;
}
.cmp_notification.success {
  background: #f0fdf4 !important;
  border-color: #22c55e !important;
  color: #166534 !important;
}
.cmp_notification.error {
  background: #fef2f2 !important;
  border-color: #ef4444 !important;
  color: #991b1b !important;
}
.cmp_notification.information {
  background: #eff6ff !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary-dark) !important;
}

/* ============================================================
   Skip-to-content accessibility nav
   ============================================================ */
.cmp_skip_to_content a {
  position: absolute !important;
  left: -9999px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}
.cmp_skip_to_content a:focus {
  position: fixed !important;
  top: .5rem !important;
  left: .5rem !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  background: var(--color-accent) !important;
  color: var(--color-text) !important;
  padding: .5rem 1rem !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  z-index: 9999 !important;
}

/* ============================================================
   Active navigation item
   ============================================================ */
.pkp_navigation_primary > li.current > a,
.pkp_navigation_primary > li.active > a {
  border-bottom-color: var(--color-accent) !important;
  color: #ffffff !important;
  background: rgba(255,255,255,.12) !important;
}

/* ============================================================
   Editorial Team page
   ============================================================ */
.pkp_page_editorialTeam .page,
.pkp_page_about .page {
  line-height: 1.7 !important;
}
.pkp_page_editorialTeam h2,
.pkp_page_about h2 {
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
  margin-top: 2rem !important;
}

/* ============================================================
   Contact page
   ============================================================ */
.pkp_page_contact .page {
  max-width: 640px !important;
}
.pkp_page_contact .contact_item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 1rem !important;
  padding: 1rem 0 !important;
  border-bottom: 1px solid var(--color-border) !important;
  font-size: .9375rem !important;
}
.pkp_page_contact .contact_item:last-child {
  border-bottom: none !important;
}

/* ============================================================
   Issue Cover on Archive
   ============================================================ */
.obj_issue_summary .cover img {
  width: 80px !important;
  border-radius: var(--radius-sm) !important;
  object-fit: cover !important;
}

/* Issue volume/number badge */
.obj_issue_summary .published {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin-top: .35rem !important;
}

/* ============================================================
   Article Details — Extended
   ============================================================ */
/* License badge */
.obj_article_details .license {
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
  background: #f0fdf4 !important;
  border: 1px solid #bbf7d0 !important;
  border-radius: var(--radius-sm) !important;
  padding: .25rem .75rem !important;
  font-size: .8125rem !important;
  color: #166534 !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
  margin: .5rem 0 !important;
}

/* How to cite box */
.obj_article_details .how_to_cite,
.obj_article_details .citation {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.25rem !important;
  margin: 1.25rem 0 !important;
  font-size: .875rem !important;
  line-height: 1.6 !important;
  color: var(--color-text-muted) !important;
}
.obj_article_details .how_to_cite h3,
.obj_article_details .citation h3 {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--color-primary) !important;
  margin-top: 0 !important;
  margin-bottom: .5rem !important;
}

/* Author affiliations */
.obj_article_details .affiliation {
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  font-style: italic !important;
  margin-top: .15rem !important;
}

/* Article metadata section (dates, DOI etc) */
.obj_article_details .article_meta {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 1rem 1.25rem !important;
  margin: 1.25rem 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
  gap: .75rem !important;
}
.obj_article_details .article_meta dt {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--color-text-muted) !important;
  margin-bottom: .15rem !important;
}
.obj_article_details .article_meta dd {
  font-size: .875rem !important;
  color: var(--color-text) !important;
  margin: 0 !important;
}

/* Statistics display (views/downloads) */
.obj_article_details .download_count,
.obj_article_details .view_count {
  display: inline-flex !important;
  align-items: center !important;
  gap: .35rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin-right: 1rem !important;
}

/* ============================================================
   Scroll-to-Top Button
   ============================================================ */
#scroll-to-top {
  position: fixed !important;
  bottom: 2rem !important;
  right: 2rem !important;
  width: 44px !important;
  height: 44px !important;
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: var(--shadow-lg) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(12px) !important;
  transition: opacity .25s, visibility .25s, transform .25s, background .2s !important;
  z-index: 999 !important;
  font-size: 1.125rem !important;
}
#scroll-to-top.visible {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
}
#scroll-to-top:hover {
  background: var(--color-primary-dark) !important;
}

/* ============================================================
   Reading Progress Bar (article pages only)
   ============================================================ */
#reading-progress {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 0% !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%) !important;
  z-index: 9999 !important;
  transition: width .1s linear !important;
}

/* ============================================================
   Smooth scroll behavior (CSS)
   ============================================================ */
html {
  scroll-behavior: smooth !important;
}

/* ============================================================
   Register page extra
   ============================================================ */
.pkp_page_register .page {
  max-width: 560px !important;
  margin: 0 auto !important;
}

/* Privacy checkbox area */
.cmp_form .privacyConsent {
  margin: 1rem 0 !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: .6rem !important;
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  line-height: 1.5 !important;
}
.cmp_form .privacyConsent input[type="checkbox"] {
  margin-top: .2rem !important;
  accent-color: var(--color-primary) !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* ============================================================
   Information pages (Author/Librarian/Reader info)
   ============================================================ */
.pkp_page_information .page {
  line-height: 1.75 !important;
}
.pkp_page_information .page h2 {
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
}

/* ============================================================
   Login Page Refresh
   ============================================================ */
.pkp_page_login .pkp_structure_content {
  background:
    radial-gradient(circle at top right, rgba(199, 174, 104, .18) 0%, transparent 26%),
    radial-gradient(circle at bottom left, rgba(255, 255, 255, .08) 0%, transparent 24%),
    linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 56%, #5e6976 100%) !important;
}

.pkp_page_login .pkp_structure_main {
  width: min(1120px, calc(100vw - 3rem)) !important;
  max-width: min(1120px, calc(100vw - 3rem)) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.pkp_page_login .page.page_auth {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.pkp_page_login .page.page_auth::before {
  display: none !important;
}

.pkp_page_login .auth_shell {
  display: grid;
  grid-template-columns: minmax(320px, 1.05fr) minmax(360px, .95fr);
  min-height: 660px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 26px;
  overflow: hidden;
  background: rgba(255, 255, 255, .08);
  box-shadow: 0 30px 70px rgba(6, 13, 26, .32);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.pkp_page_login .auth_intro {
  position: relative;
  padding: clamp(2rem, 4vw, 3.2rem);
  color: #fff;
  background:
    linear-gradient(180deg, rgba(11, 20, 38, .08) 0%, rgba(11, 20, 38, .28) 100%),
    linear-gradient(135deg, #16284b 0%, #223a63 58%, #3d536f 100%);
}

.pkp_page_login .auth_intro::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(199, 174, 104, .22) 0%, transparent 18%),
    radial-gradient(circle at 18% 86%, rgba(255, 255, 255, .08) 0%, transparent 24%);
  pointer-events: none;
}

.pkp_page_login .auth_intro__inner {
  position: relative;
  z-index: 1;
  max-width: 520px;
}

.pkp_page_login .auth_intro__eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: .35rem .8rem;
  border: 1px solid rgba(245, 240, 230, .18);
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
  color: rgba(245, 240, 230, .92);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pkp_page_login .auth_intro h1 {
  margin: 1.6rem 0 .9rem !important;
  color: #fff !important;
  text-align: left !important;
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: clamp(2.15rem, 4vw, 3.2rem) !important;
  line-height: 1.12 !important;
}

.pkp_page_login .auth_intro__lead {
  margin: 0;
  max-width: 34rem;
  color: rgba(255, 255, 255, .82);
  font-size: 1rem;
  line-height: 1.8;
}

.pkp_page_login .auth_intro__highlights {
  display: grid;
  gap: 1rem;
  margin-top: 2.2rem;
}

.pkp_page_login .auth_intro__item {
  display: grid;
  gap: .35rem;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 16px;
  background: rgba(255, 255, 255, .06);
}

.pkp_page_login .auth_intro__item strong {
  color: #fff;
  font-size: .95rem;
  font-weight: 700;
}

.pkp_page_login .auth_intro__item span {
  color: rgba(245, 240, 230, .78);
  font-size: .88rem;
  line-height: 1.7;
}

.pkp_page_login .auth_panel {
  padding: clamp(1.8rem, 3.2vw, 2.8rem);
  background: linear-gradient(180deg, rgba(255, 255, 255, .98) 0%, rgba(245, 240, 230, .98) 100%);
}

.pkp_page_login .auth_panel__header {
  margin-bottom: 1.4rem;
}

.pkp_page_login .auth_panel__kicker {
  color: var(--color-primary);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pkp_page_login .auth_panel__header h2 {
  margin: .4rem 0 .55rem;
  color: var(--color-primary-dark) !important;
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 2rem !important;
  line-height: 1.2 !important;
}

.pkp_page_login .auth_panel__header p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: .92rem;
  line-height: 1.7;
}

.pkp_page_login .auth_notice {
  margin-bottom: 1rem;
  padding: .95rem 1rem;
  border: 1px solid rgba(53, 75, 106, .14);
  border-radius: 14px;
  background: rgba(53, 75, 106, .06);
  color: var(--color-text);
  font-size: .9rem;
  line-height: 1.6;
}

.pkp_page_login .auth_form {
  padding: 0 !important;
}

.pkp_page_login .auth_form fieldset.fields {
  padding: 1.45rem !important;
  border: 1px solid rgba(34, 53, 89, .08) !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .94) 0%, rgba(249, 246, 239, .96) 100%) !important;
  box-shadow: 0 18px 42px rgba(24, 41, 71, .09) !important;
}

.pkp_page_login .auth_form .username,
.pkp_page_login .auth_form .password,
.pkp_page_login .auth_form .remember,
.pkp_page_login .auth_form .buttons {
  margin-bottom: 1.05rem !important;
}

.pkp_page_login .auth_form .buttons {
  margin-bottom: 0 !important;
}

.pkp_page_login .auth_form span.label,
.pkp_page_login .auth_form label {
  color: var(--color-primary-dark) !important;
  font-size: .77rem !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
}

.pkp_page_login .auth_form input[type="text"],
.pkp_page_login .auth_form input[type="password"],
.pkp_page_login .auth_form input[type="email"] {
  min-height: 54px !important;
  padding: 1rem 1.1rem !important;
  border: 1px solid rgba(34, 53, 89, .12) !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, .96) !important;
  box-shadow: inset 0 1px 2px rgba(16, 33, 66, .03), 0 8px 18px rgba(24, 41, 71, .03);
  color: var(--color-primary-dark) !important;
  font-size: .96rem !important;
}

.pkp_page_login .auth_form input[type="text"]:focus,
.pkp_page_login .auth_form input[type="password"]:focus,
.pkp_page_login .auth_form input[type="email"]:focus {
  border-color: rgba(34, 53, 89, .34) !important;
  background: #fff !important;
  box-shadow: 0 0 0 4px rgba(34, 53, 89, .07) !important;
  transform: none !important;
}

.pkp_page_login .auth_form .password a {
  display: inline-flex !important;
  align-items: center !important;
  margin-top: .7rem !important;
  color: var(--color-primary) !important;
  font-size: .82rem !important;
  font-weight: 600 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
}

.pkp_page_login .auth_form .remember {
  display: flex !important;
  align-items: center !important;
  padding: .95rem 1rem !important;
  border: 1px solid rgba(199, 174, 104, .16) !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, rgba(247, 243, 232, .86) 0%, rgba(244, 238, 225, .72) 100%) !important;
}

.pkp_page_login .auth_form .remember span.label,
.pkp_page_login .auth_form .remember label {
  color: var(--color-text-muted) !important;
  font-size: .88rem !important;
  font-weight: 500 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
}

.pkp_page_login .auth_form .remember input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  accent-color: var(--color-primary) !important;
}

.pkp_page_login .auth_form .buttons::before {
  content: 'New to this journal?' !important;
  margin: .2rem 0 .55rem !important;
  color: var(--color-text-muted) !important;
  font-size: .82rem !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
  text-transform: none !important;
}

.pkp_page_login .auth_form .buttons button.submit,
.pkp_page_login .auth_form .buttons input[type="submit"] {
  min-height: 56px !important;
  border-radius: 20px !important;
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 62%, var(--color-primary-light) 100%) !important;
  box-shadow: 0 18px 34px rgba(24, 41, 71, .24) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
}

.pkp_page_login .auth_form .buttons a.register {
  min-height: 54px !important;
  border-radius: 20px !important;
  background: rgba(255, 255, 255, .76) !important;
  border: 1px solid rgba(34, 53, 89, .12) !important;
  color: var(--color-primary-dark) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7) !important;
  font-weight: 700 !important;
}

.pkp_page_login .auth_form .buttons a.register:hover {
  background: rgba(255, 255, 255, .96) !important;
  border-color: rgba(34, 53, 89, .22) !important;
  transform: translateY(-1px) !important;
}

.pkp_page_login .pkp_form_error {
  border: 1px solid rgba(185, 28, 28, .14) !important;
  border-radius: 14px !important;
  background: rgba(254, 242, 242, .9) !important;
}

@media (max-width: 980px) {
  .pkp_page_login .pkp_structure_main {
    width: min(760px, calc(100vw - 2rem)) !important;
    max-width: min(760px, calc(100vw - 2rem)) !important;
  }

  .pkp_page_login .auth_shell {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .pkp_page_login .auth_intro {
    padding-bottom: 1.6rem;
  }

  .pkp_page_login .auth_intro__highlights {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .pkp_page_login .pkp_structure_content {
    padding: 1.2rem .85rem 1.8rem !important;
  }

  .pkp_page_login .pkp_structure_main {
    width: calc(100vw - 1.7rem) !important;
    max-width: calc(100vw - 1.7rem) !important;
  }

  .pkp_page_login .auth_shell {
    border-radius: 22px;
  }

  .pkp_page_login .auth_intro,
  .pkp_page_login .auth_panel {
    padding: 1.35rem;
  }

  .pkp_page_login .auth_intro h1 {
    font-size: 2rem !important;
  }

  .pkp_page_login .auth_panel__header h2 {
    font-size: 1.6rem !important;
  }

  .pkp_page_login .auth_form fieldset.fields {
    padding: 1rem !important;
    border-radius: 16px !important;
  }
}

.pkp_page_login .page_lost_password .auth_panel__header p {
  max-width: 32rem;
}

.pkp_page_login.pkp_op_requestResetPassword .pkp_structure_sidebar {
  display: none !important;
}

.pkp_page_login.pkp_op_requestResetPassword .pkp_structure_main {
  width: min(1040px, calc(100vw - 3rem)) !important;
  max-width: min(1040px, calc(100vw - 3rem)) !important;
}

.pkp_page_login.pkp_op_requestResetPassword .page_message.page_auth_confirmation {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.pkp_page_login.pkp_op_requestResetPassword .page_message.page_auth_confirmation::before {
  display: none !important;
}

.pkp_page_login .auth_panel_confirmation {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.pkp_page_login .auth_notice_success {
  border-color: rgba(52, 117, 77, .16) !important;
  background: rgba(240, 249, 241, .9) !important;
  color: #28543b !important;
}

.pkp_page_login .auth_confirmation_actions {
  display: grid;
  gap: .85rem;
  margin-top: 1.25rem;
}

.pkp_page_login .auth_confirmation_primary,
.pkp_page_login .auth_confirmation_secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: .85rem 1.4rem;
  border-radius: 18px;
  text-decoration: none !important;
  font-weight: 700;
  box-sizing: border-box;
}

.pkp_page_login .auth_confirmation_primary {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 62%, var(--color-primary-light) 100%);
  color: var(--color-text-inverse) !important;
  box-shadow: 0 18px 34px rgba(24, 41, 71, .24);
}

.pkp_page_login .auth_confirmation_primary:hover,
.pkp_page_login .auth_confirmation_primary:focus {
  color: var(--color-text-inverse) !important;
  transform: translateY(-1px);
}

.pkp_page_login .auth_confirmation_secondary {
  border: 1px solid rgba(34, 53, 89, .12);
  background: rgba(255, 255, 255, .82);
  color: var(--color-primary-dark) !important;
}

.pkp_page_login .auth_confirmation_secondary:hover,
.pkp_page_login .auth_confirmation_secondary:focus {
  background: rgba(255, 255, 255, .96);
  border-color: rgba(34, 53, 89, .22);
  transform: translateY(-1px);
}

.pkp_page_login .auth_form_recovery .buttons::before {
  content: 'Need another option?' !important;
}

.pkp_page_login .auth_form_recovery .buttons {
  gap: .75rem !important;
}

.pkp_page_login .auth_form_recovery .buttons a.register {
  display: block !important;
  width: 100% !important;
  min-height: 48px !important;
  padding: .85rem 1.4rem !important;
  border-radius: 999px !important;
  text-align: center !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}

.pkp_page_login .auth_form_recovery .buttons a.register.register_secondary {
  background: rgba(255, 255, 255, .72) !important;
}

/* ============================================================
   Error page
   ============================================================ */
.pkp_page_error .page {
  text-align: center !important;
  padding: 3rem 1rem !important;
}
.pkp_page_error .page h1 {
  font-size: 3rem !important;
  color: var(--color-primary-dark) !important;
  border: none !important;
  padding: 0 !important;
}
.pkp_page_error .page p {
  color: var(--color-text-muted) !important;
  font-size: 1.0625rem !important;
  max-width: 480px !important;
  margin: 0 auto 1.5rem !important;
}

/* ============================================================
   Announcements List
   ============================================================ */
.page_announcements .obj_announcement_summary {
  border-left: 3px solid var(--color-primary-light) !important;
}
.page_announcements .obj_announcement_summary .date {
  font-family: 'Inter', sans-serif !important;
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin-bottom: .35rem !important;
}

/* Full announcement */
.obj_announcement_full .title {
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 1.625rem !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
  line-height: 1.3 !important;
  margin-bottom: .75rem !important;
}
.obj_announcement_full .date {
  font-family: 'Inter', sans-serif !important;
  font-size: .875rem !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 1.25rem !important;
  padding-bottom: .75rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}
.obj_announcement_full .description {
  line-height: 1.75 !important;
}

/* ============================================================
   Privacy & static pages
   ============================================================ */
.pkp_page_privacy .page,
.pkp_page_message .page {
  line-height: 1.75 !important;
}
.pkp_page_privacy .page h2,
.pkp_page_message .page h2 {
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
  margin-top: 2.5rem !important;
}

/* ============================================================
   Image styling in content
   ============================================================ */
.pkp_structure_main img {
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
}
.pkp_structure_main figure {
  margin: 1.5rem 0 !important;
  text-align: center !important;
}
.pkp_structure_main figcaption {
  font-size: .8125rem !important;
  color: var(--color-text-muted) !important;
  margin-top: .5rem !important;
  font-style: italic !important;
}

/* ============================================================
   Blockquote styling
   ============================================================ */
.pkp_structure_main blockquote {
  border-left: 4px solid var(--color-accent) !important;
  margin: 1.5rem 0 !important;
  padding: .75rem 1.25rem !important;
  background: #fffbeb !important;
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
  font-style: italic !important;
  color: var(--color-text-muted) !important;
}

/* ============================================================
   Code blocks in content
   ============================================================ */
.pkp_structure_main code {
  background: var(--color-surface-alt) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: .15rem .4rem !important;
  font-size: .875em !important;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace !important;
  color: var(--color-primary-dark) !important;
}
.pkp_structure_main pre {
  background: #1e293b !important;
  border-radius: var(--radius-md) !important;
  padding: 1.25rem !important;
  overflow-x: auto !important;
  margin: 1.5rem 0 !important;
}
.pkp_structure_main pre code {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  color: #e2e8f0 !important;
  font-size: .875rem !important;
}

/* ============================================================
   Submission info page
   ============================================================ */
.pkp_page_submissions .page {
  line-height: 1.75 !important;
}

/* ============================================================
   User dashboard / profile links
   ============================================================ */
.pkp_navigation_user > li > a {
  padding: .42rem .95rem !important;
  border-radius: 999px !important;
  transition: var(--transition) !important;
}
.pkp_navigation_user > li > a:hover {
  background: rgba(255,255,255,.16) !important;
  text-decoration: none !important;
}

/* ============================================================
   Subscriptions
   ============================================================ */
.pkp_page_subscriptions .page h2 {
  border-bottom: 2px solid var(--color-border) !important;
  padding-bottom: .5rem !important;
}

/* ============================================================
   Print styles
   ============================================================ */
@media print {
  .pkp_structure_head,
  .pkp_structure_sidebar,
  .pkp_structure_footer_wrapper,
  #scroll-to-top,
  #reading-progress {
    display: none !important;
  }
  .pkp_structure_main {
    box-shadow: none !important;
    border: none !important;
  }
  body {
    background: white !important;
  }
}
