/* ============================================================
   JUSLAW – Jurnal Justice Labora & Law
   Custom CSS for OJS 3.3+
   Design: Premium Institutional Law Journal
   Palette: Deep Crimson · Judicial Black · Burnished Gold · White
   ============================================================ */

/* ── 0. GOOGLE FONTS IMPORT ─────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&family=Source+Serif+4:wght@300;400;600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── 1. CSS VARIABLES ────────────────────────────────────── */
:root {
  --crimson:        #8B0000;
  --crimson-deep:   #6B0000;
  --crimson-light:  #A50000;
  --gold:           #C9A84C;
  --gold-light:     #E2C579;
  --gold-dark:      #A6863A;
  --black:          #0D0D0D;
  --charcoal:       #1A1A1A;
  --ink:            #2C2C2C;
  --slate:          #4A4A4A;
  --silver:         #8A8A8A;
  --mist:           #F2F0EB;
  --parchment:      #FAF8F4;
  --white:          #FFFFFF;
  --border-subtle:  #E0DBD3;
  --shadow-sm:      0 2px 8px rgba(0,0,0,0.08);
  --shadow-md:      0 4px 20px rgba(0,0,0,0.12);
  --shadow-lg:      0 8px 40px rgba(0,0,0,0.18);
  --serif-title:    'Playfair Display', 'Georgia', serif;
  --serif-body:     'Source Serif 4', 'Georgia', serif;
  --sans:           'DM Sans', 'Helvetica Neue', sans-serif;
  --radius:         3px;
  --transition:     all 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── 2. GLOBAL RESET & BASE ──────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink);
  background-color: var(--parchment);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── 3. TOP UTILITY BAR ──────────────────────────────────── */
#navigationUser,
.navigationUser,
.pkp_nav_user {
  background-color: var(--charcoal) !important;
  border-bottom: 1px solid rgba(201,168,76,0.25);
}

#navigationUser li a,
.navigationUser li a,
.pkp_nav_user li a {
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold-light) !important;
  padding: 6px 14px !important;
  transition: var(--transition);
}

#navigationUser li a:hover,
.navigationUser li a:hover {
  color: var(--white) !important;
  background-color: var(--crimson) !important;
}

/* ── 4. HEADER & BANNER ──────────────────────────────────── */
.pkp_structure_head,
#headerNavigationContainer,
header.pkp_structure_head {
  background: transparent !important;
  padding: 0 !important;
}

.pkp_head_wrapper,
#headerWrapper,
.site-header,
header {
  background: linear-gradient(135deg, var(--crimson-deep) 0%, var(--crimson) 55%, var(--charcoal) 100%) !important;
  position: relative;
  overflow: hidden;
  min-height: 160px;
  border-bottom: 4px solid var(--gold) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

/* Atmospheric overlay */
.pkp_head_wrapper::before,
#headerWrapper::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(201,168,76,0.08) 0%, transparent 60%),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 40px,
      rgba(255,255,255,0.015) 40px,
      rgba(255,255,255,0.015) 41px
    );
  pointer-events: none;
  z-index: 0;
}

/* Gold left-side accent line */
.pkp_head_wrapper::after,
#headerWrapper::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  background: linear-gradient(180deg, var(--gold), var(--gold-dark), var(--gold));
}

/* Journal title */
.pkp_site_name,
#pkpHdr .pkp_site_name,
.pkp_site_name a,
.site-name,
h1.pkp_site_name a {
  font-family: var(--serif-title) !important;
  font-size: clamp(1.6rem, 3.2vw, 2.4rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  color: var(--white) !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.5), 0 0 40px rgba(201,168,76,0.2);
  text-decoration: none !important;
  line-height: 1.2 !important;
  position: relative;
  z-index: 1;
}

.pkp_site_name a:hover {
  color: var(--gold-light) !important;
}

/* Subtitle / tagline */
.pkp_site_name + p,
.site-tagline,
.site_summary,
.pkp_header_tagline {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: rgba(201,168,76,0.9) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  position: relative;
  z-index: 1;
}

.pkp_head_wrapper .container,
#pkpHdr .container,
.pkp_site_name_wrapper {
  padding: 32px 40px 28px !important;
  position: relative;
  z-index: 1;
}

/* ── 5. PRIMARY NAVIGATION ───────────────────────────────── */
.pkp_navigation_primary,
nav.pkp_navigation_primary,
#navigationPrimary,
.pkp_nav_primary {
  background-color: var(--charcoal) !important;
  border-top: none !important;
  border-bottom: 2px solid var(--gold) !important;
  padding: 0 !important;
  box-shadow: 0 3px 12px rgba(0,0,0,0.3);
}

.pkp_navigation_primary ul,
#navigationPrimary ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}

.pkp_navigation_primary > ul > li > a,
#navigationPrimary > ul > li > a,
.pkp_nav_primary li a {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  padding: 14px 20px !important;
  display: block;
  text-decoration: none !important;
  transition: var(--transition);
  border-bottom: 3px solid transparent;
  position: relative;
}

.pkp_navigation_primary > ul > li > a:hover,
#navigationPrimary > ul > li > a:hover {
  color: var(--gold-light) !important;
  background-color: rgba(255,255,255,0.05) !important;
  border-bottom-color: var(--gold) !important;
}

.pkp_navigation_primary > ul > li.current > a,
#navigationPrimary > ul > li.is-active > a {
  color: var(--gold) !important;
  border-bottom-color: var(--gold) !important;
}

/* Dropdowns */
.pkp_navigation_primary .sub-nav,
#navigationPrimary .dropdown-menu,
.pkp_nav_primary .dropdown-menu {
  background-color: var(--charcoal) !important;
  border: 1px solid rgba(201,168,76,0.3) !important;
  border-top: 2px solid var(--gold) !important;
  border-radius: 0 0 var(--radius) var(--radius) !important;
  box-shadow: var(--shadow-lg) !important;
  min-width: 200px;
}

.pkp_navigation_primary .sub-nav li a,
#navigationPrimary .dropdown-menu li a {
  font-size: 12px !important;
  padding: 9px 18px !important;
  color: rgba(255,255,255,0.8) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  transition: var(--transition);
}

.pkp_navigation_primary .sub-nav li a:hover,
#navigationPrimary .dropdown-menu li a:hover {
  background-color: var(--crimson) !important;
  color: var(--white) !important;
}

/* ── 6. MAIN CONTENT AREA ────────────────────────────────── */
.pkp_structure_content,
main.pkp_structure_content,
#pkpMain,
.pkp_page_content {
  background-color: var(--parchment);
  padding-top: 40px;
  padding-bottom: 60px;
}

.pkp_structure_content .container,
#pkpMain .container {
  max-width: 1200px;
}

/* ── 7. HEADINGS ─────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif-title);
  color: var(--black);
  line-height: 1.25;
}

h1 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; }
h2 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 600; }
h4 { font-size: 1.05rem; font-weight: 600; font-family: var(--sans); }

/* Page title with crimson accent */
.page-header,
.pkp_page_header,
h1.page_title {
  font-family: var(--serif-title) !important;
  font-size: clamp(1.5rem, 2.8vw, 2rem) !important;
  color: var(--crimson) !important;
  font-weight: 700 !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid var(--border-subtle) !important;
  margin-bottom: 28px !important;
  position: relative;
}

h1.page_title::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 70px;
  height: 2px;
  background: var(--gold);
}

/* Block / widget headings */
.pkp_block h2,
.pkp_block h3,
.block-title,
.widget-title {
  font-family: var(--serif-title) !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  color: var(--charcoal) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  padding-bottom: 8px !important;
  border-bottom: 2px solid var(--border-subtle) !important;
  margin-bottom: 16px !important;
  position: relative;
}

.pkp_block h2::before,
.pkp_block h3::before,
.block-title::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 36px;
  height: 2px;
  background: var(--gold);
}

/* ── 8. ABOUT / HOMEPAGE BLOCKS ──────────────────────────── */
.pkp_block_description,
.pkp_block.pkp_block_journal_description,
.homepage .pkp_block {
  background-color: var(--white) !important;
  border: 1px solid var(--border-subtle) !important;
  border-left: 4px solid var(--crimson) !important;
  border-radius: var(--radius) !important;
  padding: 28px 32px !important;
  margin-bottom: 28px !important;
  box-shadow: var(--shadow-sm) !important;
  transition: var(--transition);
}

.homepage .pkp_block:hover {
  box-shadow: var(--shadow-md) !important;
}

/* ── 9. ARTICLE CARDS ─────────────────────────────────────── */
.obj_article_summary,
.article-summary,
.pkp_article_summary,
.article_summary,
li.obj_article_summary {
  background: var(--white) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: var(--radius) !important;
  padding: 22px 26px !important;
  margin-bottom: 18px !important;
  box-shadow: var(--shadow-sm) !important;
  transition: var(--transition) !important;
  position: relative;
  overflow: hidden;
}

.obj_article_summary::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--crimson), var(--gold-dark));
  border-radius: 2px 0 0 2px;
}

.obj_article_summary:hover {
  border-color: var(--gold-dark) !important;
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px);
}

/* Article title in listing */
.obj_article_summary .title,
.obj_article_summary h3 a,
.article_summary .title a,
.article-title a {
  font-family: var(--serif-title) !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  color: var(--crimson) !important;
  text-decoration: none !important;
  line-height: 1.4 !important;
  transition: var(--transition) !important;
  display: block;
  margin-bottom: 6px;
}

.obj_article_summary .title a:hover {
  color: var(--gold-dark) !important;
}

/* Authors */
.obj_article_summary .authors,
.article_summary .authors {
  font-family: var(--sans) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: var(--slate) !important;
  font-style: normal !important;
  margin-bottom: 4px !important;
}

/* Metadata */
.obj_article_summary .pkp_doi,
.obj_article_summary .pages {
  font-size: 11.5px !important;
  color: var(--silver) !important;
  font-family: var(--sans) !important;
}

/* Galley / download buttons */
.obj_article_summary .galleys_links a,
.galleys_links a,
.obj_galley_link a {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--white) !important;
  background-color: var(--crimson) !important;
  border: 1px solid var(--crimson) !important;
  border-radius: var(--radius) !important;
  padding: 5px 14px !important;
  text-decoration: none !important;
  display: inline-block;
  margin-right: 6px !important;
  margin-top: 8px !important;
  transition: var(--transition) !important;
}

.obj_article_summary .galleys_links a:hover,
.galleys_links a:hover {
  background-color: var(--gold-dark) !important;
  border-color: var(--gold-dark) !important;
}

.obj_galley_link.pdf a {
  background-color: var(--charcoal) !important;
  border-color: var(--charcoal) !important;
}

.obj_galley_link.pdf a:hover {
  background-color: var(--crimson) !important;
  border-color: var(--crimson) !important;
}

/* ── 10. ISSUE ARCHIVE ────────────────────────────────────── */
.obj_issue_summary,
.issue_summary {
  background: var(--white) !important;
  border: 1px solid var(--border-subtle) !important;
  border-top: 3px solid var(--crimson) !important;
  border-radius: var(--radius) !important;
  padding: 22px 26px !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-sm) !important;
  transition: var(--transition);
}

.obj_issue_summary:hover {
  box-shadow: var(--shadow-md) !important;
}

.obj_issue_summary .title a {
  font-family: var(--serif-title) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--crimson) !important;
  text-decoration: none !important;
}

.obj_issue_summary .title a:hover {
  color: var(--gold-dark) !important;
}

.obj_issue_summary .series {
  font-size: 11px !important;
  color: var(--gold-dark) !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}

/* ── 11. ARTICLE DETAIL PAGE ─────────────────────────────── */
.obj_article_details {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  padding: 36px 40px !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid var(--border-subtle) !important;
}

.obj_article_details h1.page_title {
  font-family: var(--serif-title) !important;
  font-size: clamp(1.4rem, 2.5vw, 1.9rem) !important;
  font-weight: 700 !important;
  color: var(--charcoal) !important;
  line-height: 1.3 !important;
  margin-bottom: 16px !important;
  border-bottom: none !important;
}

.obj_article_details h1.page_title::after {
  display: none;
}

.obj_article_details .authors {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: var(--slate) !important;
  margin-bottom: 20px !important;
}

/* Abstract */
.obj_article_details .abstract {
  background: var(--mist) !important;
  border-left: 4px solid var(--crimson) !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
  padding: 20px 24px !important;
  margin: 24px 0 !important;
}

.obj_article_details .abstract h3,
.obj_article_details .abstract h2 {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--crimson) !important;
  margin-bottom: 10px !important;
}

.obj_article_details .abstract p {
  font-family: var(--serif-body) !important;
  font-size: 14.5px !important;
  line-height: 1.8 !important;
  color: var(--ink) !important;
}

/* Keywords */
.obj_article_details .keywords {
  font-size: 12.5px !important;
  color: var(--slate) !important;
}

.obj_article_details .keywords span {
  display: inline-block;
  background: var(--mist) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: 2px !important;
  padding: 2px 10px !important;
  margin: 2px 4px 2px 0 !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
  transition: var(--transition);
}

.obj_article_details .keywords span:hover {
  background: var(--crimson) !important;
  color: var(--white) !important;
  border-color: var(--crimson) !important;
}

/* DOI */
.doi, .pkp_doi {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  color: var(--slate) !important;
  background: var(--mist) !important;
  padding: 4px 10px !important;
  border-radius: var(--radius) !important;
  display: inline-block !important;
}

/* ── 12. SIDEBAR BLOCKS ──────────────────────────────────── */
.pkp_block {
  background: var(--white) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: var(--radius) !important;
  margin-bottom: 22px !important;
  overflow: hidden;
  box-shadow: var(--shadow-sm) !important;
}

.pkp_block .title,
.pkp_block h2 {
  background: linear-gradient(135deg, var(--charcoal), var(--ink)) !important;
  color: var(--white) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 10px 16px !important;
  margin: 0 !important;
  border-bottom: 2px solid var(--gold) !important;
}

.pkp_block .title::before,
.pkp_block h2::before {
  display: none !important;
}

.pkp_block .content {
  padding: 16px !important;
}

.pkp_block a {
  color: var(--crimson) !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
}

.pkp_block a:hover {
  color: var(--gold-dark) !important;
  text-decoration: underline !important;
}

/* ── 13. BUTTONS ─────────────────────────────────────────── */
.btn,
button,
input[type="submit"],
input[type="button"],
.pkp_button,
a.pkp_button {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: var(--radius) !important;
  padding: 9px 22px !important;
  transition: var(--transition) !important;
  cursor: pointer;
  text-decoration: none !important;
  display: inline-block;
}

.btn-primary,
.pkp_button,
input[type="submit"] {
  background-color: var(--crimson) !important;
  border: 1px solid var(--crimson) !important;
  color: var(--white) !important;
}

.btn-primary:hover,
.pkp_button:hover,
input[type="submit"]:hover {
  background-color: var(--crimson-deep) !important;
  border-color: var(--gold-dark) !important;
  box-shadow: 0 0 0 2px rgba(201,168,76,0.3) !important;
  color: var(--white) !important;
}

.btn-default,
.btn-secondary {
  background-color: transparent !important;
  border: 1px solid var(--crimson) !important;
  color: var(--crimson) !important;
}

.btn-default:hover,
.btn-secondary:hover {
  background-color: var(--crimson) !important;
  color: var(--white) !important;
}

.more,
a.read_more,
.read_more_link {
  font-family: var(--sans) !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--crimson) !important;
  text-decoration: none !important;
  border-bottom: 1.5px solid var(--gold) !important;
  padding-bottom: 2px !important;
  transition: var(--transition) !important;
}

.more:hover,
a.read_more:hover {
  color: var(--gold-dark) !important;
  border-bottom-color: var(--crimson) !important;
}

/* ── 14. FORMS ────────────────────────────────────────────── */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
select,
textarea {
  border: 1px solid var(--border-subtle) !important;
  border-radius: var(--radius) !important;
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
  color: var(--ink) !important;
  background: var(--white) !important;
  padding: 9px 14px !important;
  transition: var(--transition) !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
select:focus,
textarea:focus {
  border-color: var(--crimson) !important;
  box-shadow: 0 0 0 3px rgba(139,0,0,0.1) !important;
  outline: none !important;
}

/* ── 15. PAGINATION ───────────────────────────────────────── */
.pagination,
.pkp_pagination {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: 32px !important;
}

.pagination li a,
.pagination li span,
.pkp_pagination a {
  font-family: var(--sans) !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--crimson) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: var(--radius) !important;
  padding: 7px 14px !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
}

.pagination li.active a,
.pagination li.active span {
  background-color: var(--crimson) !important;
  color: var(--white) !important;
  border-color: var(--crimson) !important;
}

.pagination li a:hover {
  background-color: var(--mist) !important;
  border-color: var(--crimson) !important;
}

/* ── 16. BREADCRUMBS ──────────────────────────────────────── */
.pkp_navigation_breadcrumbs,
.breadcrumb,
ol.breadcrumb {
  background: transparent !important;
  padding: 8px 0 16px !important;
  font-size: 12px !important;
  color: var(--silver) !important;
  font-family: var(--sans) !important;
}

.breadcrumb li a {
  color: var(--crimson) !important;
  text-decoration: none !important;
}

.breadcrumb li a:hover {
  color: var(--gold-dark) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--gold) !important;
  content: "›" !important;
}

/* ── 17. ANNOUNCEMENTS ────────────────────────────────────── */
.obj_announcement_summary,
.announcement_summary {
  background: var(--white) !important;
  border: 1px solid var(--border-subtle) !important;
  border-top: 3px solid var(--gold-dark) !important;
  border-radius: var(--radius) !important;
  padding: 20px 24px !important;
  margin-bottom: 16px !important;
  box-shadow: var(--shadow-sm) !important;
}

.obj_announcement_summary .title a {
  font-family: var(--serif-title) !important;
  color: var(--charcoal) !important;
  font-weight: 600 !important;
}

.obj_announcement_summary .date {
  font-size: 11.5px !important;
  color: var(--gold-dark) !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

/* ── 18. TABLES ───────────────────────────────────────────── */
table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
}

table th {
  background: var(--charcoal) !important;
  color: var(--gold-light) !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-size: 11.5px !important;
  padding: 11px 14px !important;
  text-align: left !important;
}

table td {
  padding: 10px 14px !important;
  border-bottom: 1px solid var(--border-subtle) !important;
  color: var(--ink) !important;
}

table tr:nth-child(even) td {
  background: var(--mist) !important;
}

table tr:hover td {
  background: rgba(139,0,0,0.04) !important;
}

/* ── 19. FOOTER ───────────────────────────────────────────── */
.pkp_structure_footer,
footer.pkp_structure_footer,
#pkpFooter,
footer {
  background: linear-gradient(135deg, var(--black) 0%, var(--charcoal) 100%) !important;
  border-top: none !important;
  padding: 0 !important;
  margin-top: 0 !important;
}

/* Tricolor separator bar */
.pkp_structure_footer::before,
footer::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--crimson) 0%, var(--gold) 50%, var(--crimson) 100%);
}

.pkp_structure_footer .pkp_footer_content,
.pkp_structure_footer .container,
footer .container {
  padding: 36px 40px 28px !important;
}

.pkp_structure_footer *,
footer * {
  color: rgba(255,255,255,0.65) !important;
  font-family: var(--sans) !important;
  font-size: 12.5px !important;
}

.pkp_structure_footer a,
footer a {
  color: var(--gold-light) !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
}

.pkp_structure_footer a:hover,
footer a:hover {
  color: var(--white) !important;
}

.pkp_structure_footer .pkp_site_name,
footer .pkp_site_name {
  font-family: var(--serif-title) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--white) !important;
  margin-bottom: 6px !important;
}

.pkp_structure_footer hr,
footer hr {
  border: none !important;
  border-top: 1px solid rgba(201,168,76,0.2) !important;
  margin: 20px 0 !important;
}

.pkp_structure_footer .copyright,
.pkp_structure_footer .pkp_footer_bottom {
  border-top: 1px solid rgba(201,168,76,0.15) !important;
  padding-top: 16px !important;
  margin-top: 20px !important;
  font-size: 11.5px !important;
  color: rgba(255,255,255,0.45) !important;
}

/* ── 20. TABLE OF CONTENTS ────────────────────────────────── */
.table_of_contents .section {
  margin-bottom: 28px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--border-subtle) !important;
}

.table_of_contents .section_title {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--gold-dark) !important;
  margin-bottom: 14px !important;
}

/* ── 21. NOTIFICATIONS ────────────────────────────────────── */
.pkp_notification,
.notification,
.alert {
  border-radius: var(--radius) !important;
  font-family: var(--sans) !important;
  font-size: 13.5px !important;
  padding: 13px 18px !important;
}

.pkp_notification.notifySuccess,
.alert-success {
  background: rgba(44,120,44,0.08) !important;
  border-left: 4px solid #2c782c !important;
  color: #1a4d1a !important;
}

.pkp_notification.notifyError,
.alert-danger {
  background: rgba(139,0,0,0.08) !important;
  border-left: 4px solid var(--crimson) !important;
  color: var(--crimson-deep) !important;
}

.pkp_notification.notifyWarning,
.alert-warning {
  background: rgba(201,168,76,0.1) !important;
  border-left: 4px solid var(--gold-dark) !important;
  color: #7a5c14 !important;
}

/* ── 22. RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 991px) {
  .pkp_head_wrapper .container,
  #pkpHdr .container {
    padding: 22px 20px 18px !important;
  }

  .pkp_site_name,
  .pkp_site_name a {
    font-size: 1.5rem !important;
  }

  .pkp_navigation_primary > ul > li > a {
    padding: 12px 14px !important;
    font-size: 11px !important;
  }

  .obj_article_details {
    padding: 22px 18px !important;
  }
}

@media (max-width: 767px) {
  .pkp_site_name,
  .pkp_site_name a {
    font-size: 1.25rem !important;
  }

  .pkp_head_wrapper,
  #headerWrapper {
    min-height: 120px;
  }

  .pkp_navigation_primary {
    overflow-x: auto;
  }

  .pkp_navigation_primary ul {
    flex-wrap: nowrap;
    white-space: nowrap;
  }

  .obj_article_summary {
    padding: 16px 18px !important;
  }

  .pkp_structure_footer .container,
  footer .container {
    padding: 24px 20px 20px !important;
  }
}

/* ── 23. GLOBAL LINK & TYPOGRAPHY POLISH ─────────────────── */
a {
  color: var(--crimson);
  text-decoration: none;
  transition: var(--transition);
}

a:hover {
  color: var(--gold-dark);
}

hr {
  border: none;
  border-top: 1px solid var(--border-subtle);
  margin: 28px 0;
}

blockquote {
  border-left: 4px solid var(--gold);
  padding: 12px 20px;
  margin: 20px 0;
  background: var(--mist);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-family: var(--serif-body) !important;
  font-style: italic;
  color: var(--slate);
}

::selection {
  background: var(--crimson);
  color: var(--white);
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--mist); }
::-webkit-scrollbar-thumb { background: var(--crimson); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold-dark); }

a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 2px solid var(--gold) !important;
  outline-offset: 2px !important;
}

/* ── 24. PRINT ────────────────────────────────────────────── */
@media print {
  .pkp_structure_head,
  .pkp_structure_footer,
  .pkp_navigation_primary,
  .pkp_sidebar { display: none !important; }

  body { background: white !important; font-size: 11pt !important; }

  .obj_article_details {
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
  }
}

/* ── END JUSLAW CUSTOM CSS ─── PT. Heli Mitra Akademika ──── */
