/* ╔══════════════════════════════════════════════════════════════╗
   ║  JMMR Website — Premium Design System (OJS 3)              ║
   ║  Version  : 2.0                                            ║
   ║  Features : Dark mode · Glassmorphism · Fluid type          ║
   ║             Micro-interactions · A11y · Print-ready          ║
   ╚══════════════════════════════════════════════════════════════╝ */

/* ═══════════════════════════════════
   §1  DESIGN TOKENS
   ═══════════════════════════════════ */
/* Hide OJS/PKP branding line in footer */
.pkp_brand_footer,
.pkp_branding,
#pkp-branding,
.pkp_structure_footer_wrapper .pkp_brand_footer {
  display: none !important;
}

:root {
  /* ── Fonts ── */
  --jmmr-font:
    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, "Noto Sans", "Liberation Sans", sans-serif;
  --jmmr-heading:
    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --jmmr-mono:
    ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;

  /* ── Fluid type scale (clamp: min, preferred, max) ── */
  --jmmr-text-xs:   clamp(0.694rem, 0.66rem + 0.18vw, 0.80rem);
  --jmmr-text-sm:   clamp(0.800rem, 0.76rem + 0.22vw, 0.90rem);
  --jmmr-text-base: clamp(0.938rem, 0.88rem + 0.28vw, 1.06rem);
  --jmmr-text-lg:   clamp(1.063rem, 0.98rem + 0.38vw, 1.25rem);
  --jmmr-text-xl:   clamp(1.250rem, 1.12rem + 0.60vw, 1.56rem);
  --jmmr-text-2xl:  clamp(1.500rem, 1.30rem + 0.96vw, 2.00rem);
  --jmmr-text-3xl:  clamp(1.875rem, 1.56rem + 1.48vw, 2.625rem);
  --jmmr-text-4xl:  clamp(2.250rem, 1.80rem + 2.10vw, 3.375rem);

  /* ── Spacing scale ── */
  --jmmr-space-1:  4px;
  --jmmr-space-2:  8px;
  --jmmr-space-3:  12px;
  --jmmr-space-4:  16px;
  --jmmr-space-5:  20px;
  --jmmr-space-6:  24px;
  --jmmr-space-8:  32px;
  --jmmr-space-10: 40px;
  --jmmr-space-12: 48px;
  --jmmr-space-16: 64px;

  /* ── Palette — Light ── */
  --jmmr-bg:            #f0f2f8;
  --jmmr-bg-2:          #e8ebf3;
  --jmmr-surface:       #ffffff;
  --jmmr-surface-2:     #f8f9fd;
  --jmmr-surface-glass: rgba(255, 255, 255, 0.72);

  --jmmr-text:          #0c1222;
  --jmmr-text-2:        #1e293b;
  --jmmr-muted:         #475569;
  --jmmr-faint:         #94a3b8;

  --jmmr-border:        rgba(15, 23, 42, 0.08);
  --jmmr-border-strong: rgba(15, 23, 42, 0.15);
  --jmmr-border-focus:  rgba(11, 92, 171, 0.50);

  --jmmr-primary:       #0b5cab;
  --jmmr-primary-light: #e0eef9;
  --jmmr-primary-2:     #094a8c;
  --jmmr-primary-3:     #073b6f;
  --jmmr-accent:        #10b981;
  --jmmr-accent-2:      #059669;
  --jmmr-link:          #0b5cab;
  --jmmr-link-hover:    #094a8c;
  --jmmr-danger:        #ef4444;
  --jmmr-warning:       #f59e0b;
  --jmmr-info:          #3b82f6;
  --jmmr-success:       #10b981;

  /* ── Header ── */
  --jmmr-header-from:   #041e36;
  --jmmr-header-to:     #0a3d6b;

  /* ── Footer ── */
  --jmmr-footer-bg:     #060e1a;

  /* ── Radii ── */
  --jmmr-radius-sm:  8px;
  --jmmr-radius:     14px;
  --jmmr-radius-lg:  20px;
  --jmmr-radius-xl:  28px;
  --jmmr-radius-pill: 9999px;

  /* ── Layered shadows ── */
  --jmmr-shadow-xs:
    0 1px 2px rgba(2, 6, 23, 0.04);
  --jmmr-shadow-sm:
    0 2px 6px rgba(2, 6, 23, 0.05),
    0 1px 2px rgba(2, 6, 23, 0.03);
  --jmmr-shadow:
    0 4px 12px rgba(2, 6, 23, 0.06),
    0 1px 3px  rgba(2, 6, 23, 0.04);
  --jmmr-shadow-md:
    0 8px 24px  rgba(2, 6, 23, 0.07),
    0 2px 6px   rgba(2, 6, 23, 0.04);
  --jmmr-shadow-lg:
    0 16px 40px rgba(2, 6, 23, 0.10),
    0 4px 12px  rgba(2, 6, 23, 0.05);
  --jmmr-shadow-xl:
    0 24px 56px rgba(2, 6, 23, 0.14),
    0 8px 20px  rgba(2, 6, 23, 0.06);
  --jmmr-shadow-glow:
    0 0 0 1px rgba(11, 92, 171, 0.10),
    0 4px 20px rgba(11, 92, 171, 0.12);
  --jmmr-shadow-inner:
    inset 0 2px 4px rgba(2, 6, 23, 0.05);

  /* ── Timing ── */
  --jmmr-ease:     cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --jmmr-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --jmmr-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --jmmr-dur:      0.25s;
  --jmmr-dur-slow: 0.45s;

  /* ── Layout ── */
  --jmmr-max: 1200px;
  --jmmr-max-narrow: 820px;
}


/* ═══════════════════════════════════
   §2  DARK MODE
   ═══════════════════════════════════ */
@media (prefers-color-scheme: dark) {
  :root {
    --jmmr-bg:            #0b1120;
    --jmmr-bg-2:          #0f172a;
    --jmmr-surface:       #151d2e;
    --jmmr-surface-2:     #1a2438;
    --jmmr-surface-glass: rgba(21, 29, 46, 0.78);

    --jmmr-text:          #e8edf5;
    --jmmr-text-2:        #cbd5e1;
    --jmmr-muted:         #94a3b8;
    --jmmr-faint:         #64748b;

    --jmmr-border:        rgba(226, 232, 240, 0.08);
    --jmmr-border-strong: rgba(226, 232, 240, 0.14);
    --jmmr-border-focus:  rgba(59, 130, 246, 0.50);

    --jmmr-primary:       #3b82f6;
    --jmmr-primary-light: rgba(59, 130, 246, 0.12);
    --jmmr-primary-2:     #2563eb;
    --jmmr-primary-3:     #1d4ed8;
    --jmmr-link:          #60a5fa;
    --jmmr-link-hover:    #93bbfd;

    --jmmr-header-from:   #060c18;
    --jmmr-header-to:     #0c1628;
    --jmmr-footer-bg:     #050a14;

    --jmmr-shadow-xs:  0 1px 2px rgba(0, 0, 0, 0.18);
    --jmmr-shadow-sm:  0 2px 6px rgba(0, 0, 0, 0.20), 0 1px 2px rgba(0, 0, 0, 0.14);
    --jmmr-shadow:     0 4px 12px rgba(0, 0, 0, 0.24), 0 1px 3px rgba(0, 0, 0, 0.16);
    --jmmr-shadow-md:  0 8px 24px rgba(0, 0, 0, 0.28), 0 2px 6px rgba(0, 0, 0, 0.18);
    --jmmr-shadow-lg:  0 16px 40px rgba(0, 0, 0, 0.34), 0 4px 12px rgba(0, 0, 0, 0.20);
    --jmmr-shadow-xl:  0 24px 56px rgba(0, 0, 0, 0.40), 0 8px 20px rgba(0, 0, 0, 0.22);
    --jmmr-shadow-glow:
      0 0 0 1px rgba(59, 130, 246, 0.15),
      0 4px 20px rgba(59, 130, 246, 0.10);
  }
}


/* ═══════════════════════════════════
   §3  RESET & BASE
   ═══════════════════════════════════ */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--jmmr-font);
  font-size: var(--jmmr-text-base);
  line-height: 1.7;
  background: var(--jmmr-bg);
  color: var(--jmmr-text);
  overflow-x: hidden;
}

/* ── Selection ── */
::selection {
  background: var(--jmmr-primary);
  color: #fff;
}

/* ── Focus ring (accessible & pretty) ── */
:focus-visible {
  outline: 2px solid var(--jmmr-border-focus);
  outline-offset: 3px;
  border-radius: var(--jmmr-radius-sm);
}

/* ── Skip-to-content (a11y) ── */
.skip-to-content {
  position: absolute;
  left: -9999px;
  top: var(--jmmr-space-4);
  z-index: 10000;
  padding: var(--jmmr-space-3) var(--jmmr-space-6);
  background: var(--jmmr-primary);
  color: #fff;
  border-radius: var(--jmmr-radius);
  font-weight: 700;
}
.skip-to-content:focus {
  left: var(--jmmr-space-4);
}

/* ── Links ── */
a {
  color: var(--jmmr-link);
  text-decoration: none;
  transition: color var(--jmmr-dur) var(--jmmr-ease);
}
a:hover {
  color: var(--jmmr-link-hover);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
}

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--jmmr-heading);
  color: var(--jmmr-text);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -0.02em;
}
h1 { font-size: var(--jmmr-text-3xl); }
h2 { font-size: var(--jmmr-text-2xl); }
h3 { font-size: var(--jmmr-text-xl);  }
h4 { font-size: var(--jmmr-text-lg);  }

p, li {
  color: var(--jmmr-text-2);
  line-height: 1.78;
  font-size: var(--jmmr-text-base);
}
small,
.text-muted {
  color: var(--jmmr-muted);
  font-size: var(--jmmr-text-sm);
}

/* ── Custom scrollbar ── */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: var(--jmmr-bg);
}
::-webkit-scrollbar-thumb {
  background: var(--jmmr-faint);
  border-radius: var(--jmmr-radius-pill);
  border: 2px solid var(--jmmr-bg);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--jmmr-muted);
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--jmmr-faint) var(--jmmr-bg);
}


/* ═══════════════════════════════════
   §4  LAYOUT WRAPPERS
   ═══════════════════════════════════ */
.pkp_structure_content,
.pkp_structure_main,
.pkp_structure_body {
  background: transparent;
}

.pkp_structure_content .container,
.pkp_structure_main .container,
.pkp_page_index .container,
.pkp_page_issue .container,
.pkp_page_article .container,
.pkp_page_about .container {
  max-width: var(--jmmr-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--jmmr-space-5);
  padding-right: var(--jmmr-space-5);
}


/* ═══════════════════════════════════
   §5  HEADER & TOPBAR
   ═══════════════════════════════════ */
.pkp_structure_head {
  position: relative;
  background:
    radial-gradient(ellipse 70% 100% at 20% 0%,
      rgba(59, 130, 246, 0.10), transparent 60%),
    radial-gradient(ellipse 50% 120% at 85% 50%,
      rgba(16, 185, 129, 0.06), transparent 50%),
    linear-gradient(180deg,
      var(--jmmr-header-from) 0%,
      var(--jmmr-header-to) 100%);
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  z-index: 100;
}

/* Subtle grain texture overlay */
.pkp_structure_head::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  background-repeat: repeat;
  pointer-events: none;
  z-index: 0;
}

.pkp_structure_head > * {
  position: relative;
  z-index: 1;
}

/* ── Site name ── */
.pkp_site_name {
  padding: var(--jmmr-space-5) 0;
}
.pkp_site_name a {
  color: #fff !important;
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: var(--jmmr-text-xl);
  transition: opacity var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_site_name a:hover {
  opacity: 0.88;
  text-decoration: none;
}
.pkp_site_name .is_img img {
  max-height: 58px;
  width: auto;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.20));
  transition: transform var(--jmmr-dur-slow) var(--jmmr-ease-spring);
}
.pkp_site_name .is_img img:hover {
  transform: scale(1.03);
}

/* ═══════════════════════════════════
   §6  PRIMARY NAVIGATION
   ═══════════════════════════════════ */
.pkp_navigation_primary {
  display: flex;
  flex-wrap: wrap;
  gap: var(--jmmr-space-1);
}

.pkp_navigation_primary > li > a {
  position: relative;
  color: rgba(255, 255, 255, 0.88) !important;
  font-weight: 650;
  font-size: var(--jmmr-text-sm);
  padding: var(--jmmr-space-2) var(--jmmr-space-4);
  border-radius: var(--jmmr-radius-sm);
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    color var(--jmmr-dur) var(--jmmr-ease),
    transform var(--jmmr-dur) var(--jmmr-ease-spring);
  letter-spacing: 0.01em;
}
.pkp_navigation_primary > li > a:hover,
.pkp_navigation_primary > li > a:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  color: #fff !important;
  text-decoration: none;
  transform: translateY(-1px);
}

/* Active nav indicator */
.pkp_navigation_primary > li.current > a {
  background: rgba(255, 255, 255, 0.14);
  color: #fff !important;
}
.pkp_navigation_primary > li.current > a::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
  width: 18px;
  height: 2.5px;
  background: var(--jmmr-accent);
  border-radius: var(--jmmr-radius-pill);
}

/* Dropdown menus (primary nav) */
.pkp_navigation_primary ul {
  background: #ffffff !important; /* force white */
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius);
  box-shadow: var(--jmmr-shadow-lg);
  padding: var(--jmmr-space-2);
  min-width: 200px;
  animation: jmmrDropIn var(--jmmr-dur) var(--jmmr-ease-out);
}
.pkp_navigation_primary ul a {
  color: #0c1222 !important; /* force dark text */
  padding: var(--jmmr-space-2) var(--jmmr-space-3);
  border-radius: var(--jmmr-radius-sm);
  font-weight: 550;
  display: block;
  transition: background var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_navigation_primary ul a:hover {
  background: var(--jmmr-primary-light);
  text-decoration: none;
}

@keyframes jmmrDropIn {
  from {
    opacity: 0;
    transform: translateY(-6px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ── Search + user nav icons (TOP BAR ONLY, not dropdown items) ── */
.pkp_navigation_search_wrapper > a,
.pkp_navigation_user_wrapper > a,
.pkp_navigation_user_wrapper > ul > li > a {
  color: rgba(255, 255, 255, 0.88) !important;
  transition:
    color var(--jmmr-dur) var(--jmmr-ease),
    transform var(--jmmr-dur) var(--jmmr-ease-spring);
}
.pkp_navigation_search_wrapper > a:hover,
.pkp_navigation_user_wrapper > a:hover,
.pkp_navigation_user_wrapper > ul > li > a:hover {
  color: #fff !important;
  transform: translateY(-1px);
}

/* ── FIX: USER DROPDOWN (wael menu) ── */
.pkp_navigation_user_wrapper li ul {
  background: #ffffff !important; /* white menu background */
  border: 1px solid rgba(15, 23, 42, 0.12) !important;
  border-radius: var(--jmmr-radius) !important;
  box-shadow: var(--jmmr-shadow-lg) !important;
  padding: var(--jmmr-space-2) !important;
  min-width: 200px !important;
}

/* Force ALL text inside user dropdown to be dark */
.pkp_navigation_user_wrapper li ul,
.pkp_navigation_user_wrapper li ul * {
  color: #0c1222 !important;
  text-shadow: none !important;
}

/* User dropdown item styling */
.pkp_navigation_user_wrapper li ul a,
.pkp_navigation_user_wrapper li ul button {
  background: transparent !important;
  display: block !important;
  padding: var(--jmmr-space-2) var(--jmmr-space-3) !important;
  border-radius: var(--jmmr-radius-sm) !important;
  text-decoration: none !important;
}

/* Hover state for user dropdown */
.pkp_navigation_user_wrapper li ul a:hover,
.pkp_navigation_user_wrapper li ul button:hover {
  background: var(--jmmr-primary-light) !important;
  color: #0c1222 !important;
}

/* ── Search box ── */
.pkp_search button,
.pkp_search input[type="text"] {
  border-radius: var(--jmmr-radius) !important;
  border: 1px solid var(--jmmr-border-strong);
  transition:
    border-color var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_search input[type="text"]:focus {
  border-color: var(--jmmr-border-focus);
  box-shadow: var(--jmmr-shadow-glow);
}

/* ═══════════════════════════════════
   §7  MAIN CONTENT AREA
   ═══════════════════════════════════ */
.pkp_structure_main {
  padding-top: var(--jmmr-space-8);
  padding-bottom: var(--jmmr-space-10);
}

.pkp_structure_main .page {
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-lg);
  box-shadow: var(--jmmr-shadow);
  padding: var(--jmmr-space-8);
  animation: jmmrFadeUp 0.5s var(--jmmr-ease-out) both;
}

@keyframes jmmrFadeUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/* ═══════════════════════════════════
   §8  HERO SECTION
   ═══════════════════════════════════ */
.jmmr-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--jmmr-radius-xl);
  background:
    radial-gradient(
      ellipse 1000px 350px at 8% -10%,
      rgba(11, 92, 171, 0.16), transparent 55%
    ),
    radial-gradient(
      ellipse 800px 300px at 92% 60%,
      rgba(16, 185, 129, 0.10), transparent 50%
    ),
    radial-gradient(
      ellipse 600px 350px at 50% 100%,
      rgba(59, 130, 246, 0.06), transparent 50%
    ),
    linear-gradient(
      175deg,
      var(--jmmr-surface) 0%,
      var(--jmmr-surface-2) 100%
    );
  border: 1px solid var(--jmmr-border);
  padding: var(--jmmr-space-10) var(--jmmr-space-8);
  margin: 0 0 var(--jmmr-space-6) 0;
  box-shadow: var(--jmmr-shadow);
  transition: box-shadow var(--jmmr-dur-slow) var(--jmmr-ease);
}
.jmmr-hero:hover {
  box-shadow: var(--jmmr-shadow-md);
}

/* Decorative grid dots */
.jmmr-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle 1px, var(--jmmr-border-strong) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: 0.40;
  pointer-events: none;
}

/* Decorative accent corner */
.jmmr-hero::after {
  content: "";
  position: absolute;
  top: -60px;
  right: -60px;
  width: 200px;
  height: 200px;
  background: var(--jmmr-primary);
  opacity: 0.04;
  border-radius: 50%;
  filter: blur(50px);
  pointer-events: none;
}

.jmmr-hero > * {
  position: relative;
  z-index: 1;
}

/* ── Badge / label above title ── */
.jmmr-hero .jmmr-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  background: var(--jmmr-primary-light);
  color: var(--jmmr-primary);
  font-size: var(--jmmr-text-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--jmmr-radius-pill);
  border: 1px solid rgba(11, 92, 171, 0.12);
  margin-bottom: var(--jmmr-space-4);
}
.jmmr-hero .jmmr-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  background: var(--jmmr-accent);
  border-radius: 50%;
  animation: jmmrPulse 2s ease-in-out infinite;
}

@keyframes jmmrPulse {
  0%, 100% { opacity: 1; transform: scale(1);   }
  50%      { opacity: 0.5; transform: scale(1.4); }
}

.jmmr-hero h1 {
  margin: 0 0 var(--jmmr-space-3) 0;
  font-size: var(--jmmr-text-3xl);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.15;
  background: linear-gradient(
    135deg,
    var(--jmmr-text) 0%,
    var(--jmmr-muted) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.jmmr-hero p {
  margin: 0 0 var(--jmmr-space-6) 0;
  color: var(--jmmr-muted);
  font-size: var(--jmmr-text-lg);
  max-width: 640px;
  line-height: 1.7;
}

.jmmr-hero .jmmr-actions {
  display: flex;
  gap: var(--jmmr-space-3);
  flex-wrap: wrap;
  align-items: center;
}

/* ── Stat chips ── */
.jmmr-hero .jmmr-stats {
  display: flex;
  gap: var(--jmmr-space-6);
  margin-top: var(--jmmr-space-8);
  padding-top: var(--jmmr-space-6);
  border-top: 1px solid var(--jmmr-border);
}
.jmmr-hero .jmmr-stat {
  display: flex;
  flex-direction: column;
}
.jmmr-hero .jmmr-stat-value {
  font-size: var(--jmmr-text-2xl);
  font-weight: 900;
  color: var(--jmmr-primary);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.jmmr-hero .jmmr-stat-label {
  font-size: var(--jmmr-text-xs);
  color: var(--jmmr-faint);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: 2px;
}


/* ═══════════════════════════════════
   §9  BUTTONS
   ═══════════════════════════════════ */
.jmmr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--jmmr-space-2);
  padding: 11px 22px;
  border-radius: var(--jmmr-radius);
  border: 1px solid var(--jmmr-border-strong);
  background: var(--jmmr-surface);
  color: var(--jmmr-text);
  font-weight: 700;
  font-size: var(--jmmr-text-sm);
  text-decoration: none !important;
  cursor: pointer;
  white-space: nowrap;
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease),
    transform var(--jmmr-dur) var(--jmmr-ease-spring),
    border-color var(--jmmr-dur) var(--jmmr-ease);
  user-select: none;
}
.jmmr-btn:hover {
  box-shadow: var(--jmmr-shadow-md);
  transform: translateY(-2px);
}
.jmmr-btn:active {
  transform: translateY(0px) scale(0.98);
  box-shadow: var(--jmmr-shadow-sm);
}

/* Primary CTA */
.jmmr-btn.primary {
  background: linear-gradient(
    180deg,
    var(--jmmr-primary) 0%,
    var(--jmmr-primary-2) 100%
  );
  border-color: rgba(255, 255, 255, 0.10);
  color: #fff;
  box-shadow:
    var(--jmmr-shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.jmmr-btn.primary:hover {
  background: linear-gradient(
    180deg,
    var(--jmmr-primary-2) 0%,
    var(--jmmr-primary-3) 100%
  );
  box-shadow:
    var(--jmmr-shadow-lg),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

/* Success / accent */
.jmmr-btn.success {
  background: linear-gradient(
    180deg,
    var(--jmmr-accent) 0%,
    var(--jmmr-accent-2) 100%
  );
  border-color: rgba(255, 255, 255, 0.10);
  color: #fff;
  box-shadow:
    var(--jmmr-shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.jmmr-btn.success:hover {
  filter: brightness(1.06);
}

/* Ghost / outline */
.jmmr-btn.ghost {
  background: transparent;
  border-color: transparent;
  color: var(--jmmr-primary);
}
.jmmr-btn.ghost:hover {
  background: var(--jmmr-primary-light);
  border-color: rgba(11, 92, 171, 0.12);
  box-shadow: none;
  transform: translateY(0);
}

/* Small */
.jmmr-btn.sm {
  padding: 7px 14px;
  font-size: var(--jmmr-text-xs);
  border-radius: var(--jmmr-radius-sm);
}

/* Icon-only */
.jmmr-btn.icon-only {
  width: 40px;
  height: 40px;
  padding: 0;
}

/* OJS native buttons */
button,
.pkp_button,
input[type="submit"] {
  border-radius: var(--jmmr-radius) !important;
  font-weight: 700;
  font-family: var(--jmmr-font);
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease),
    transform var(--jmmr-dur) var(--jmmr-ease-spring);
}
button:hover,
.pkp_button:hover,
input[type="submit"]:hover {
  transform: translateY(-1px);
  box-shadow: var(--jmmr-shadow-sm);
}
button:active,
.pkp_button:active,
input[type="submit"]:active {
  transform: translateY(0) scale(0.98);
}

.pkp_button_primary {
  background: linear-gradient(
    180deg,
    var(--jmmr-primary) 0%,
    var(--jmmr-primary-2) 100%
  ) !important;
  border-color: var(--jmmr-primary) !important;
  color: #fff !important;
  box-shadow:
    var(--jmmr-shadow-xs),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
}
.pkp_button_primary:hover {
  background: linear-gradient(
    180deg,
    var(--jmmr-primary-2) 0%,
    var(--jmmr-primary-3) 100%
  ) !important;
  border-color: var(--jmmr-primary-2) !important;
}


/* ═══════════════════════════════════
   §10  SIDEBAR BLOCKS
   ═══════════════════════════════════ */
.pkp_structure_sidebar .pkp_block {
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-lg);
  padding: var(--jmmr-space-5);
  box-shadow: var(--jmmr-shadow-sm);
  margin-bottom: var(--jmmr-space-4);
  transition:
    box-shadow var(--jmmr-dur-slow) var(--jmmr-ease),
    transform var(--jmmr-dur-slow) var(--jmmr-ease);
}
.pkp_structure_sidebar .pkp_block:hover {
  box-shadow: var(--jmmr-shadow);
  transform: translateY(-2px);
}

.pkp_structure_sidebar .pkp_block .title {
  font-weight: 800;
  font-size: var(--jmmr-text-sm);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--jmmr-muted);
  border-bottom: 2px solid var(--jmmr-border);
  padding-bottom: var(--jmmr-space-3);
  margin-bottom: var(--jmmr-space-4);
  display: flex;
  align-items: center;
  gap: var(--jmmr-space-2);
}
.pkp_structure_sidebar .pkp_block .title::before {
  content: "";
  width: 3px;
  height: 16px;
  background: var(--jmmr-primary);
  border-radius: var(--jmmr-radius-pill);
  flex-shrink: 0;
}

.pkp_structure_sidebar .pkp_block ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.pkp_structure_sidebar .pkp_block ul li {
  margin-bottom: var(--jmmr-space-1);
}
.pkp_structure_sidebar .pkp_block ul li a {
  display: block;
  padding: var(--jmmr-space-2) var(--jmmr-space-3);
  border-radius: var(--jmmr-radius-sm);
  font-weight: 550;
  font-size: var(--jmmr-text-sm);
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    color var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_structure_sidebar .pkp_block ul li a:hover {
  background: var(--jmmr-primary-light);
  text-decoration: none;
}


/* ═══════════════════════════════════
   §11  ISSUE TOC & ARTICLE CARDS
   ═══════════════════════════════════ */
.obj_issue_toc .heading,
.obj_issue_summary .title {
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: var(--jmmr-text-xl);
}

.obj_article_summary {
  position: relative;
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-lg);
  padding: var(--jmmr-space-5) var(--jmmr-space-6);
  margin: var(--jmmr-space-4) 0;
  transition:
    box-shadow var(--jmmr-dur-slow) var(--jmmr-ease),
    transform var(--jmmr-dur-slow) var(--jmmr-ease),
    border-color var(--jmmr-dur) var(--jmmr-ease);
}
.obj_article_summary:hover {
  box-shadow: var(--jmmr-shadow-md);
  transform: translateY(-3px);
  border-color: var(--jmmr-border-strong);
}

/* Left accent bar on hover */
.obj_article_summary::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) scaleY(0);
  width: 3.5px;
  height: 40%;
  background: linear-gradient(
    180deg,
    var(--jmmr-primary),
    var(--jmmr-accent)
  );
  border-radius: 0 var(--jmmr-radius-pill) var(--jmmr-radius-pill) 0;
  transition: transform var(--jmmr-dur-slow) var(--jmmr-ease-spring);
}
.obj_article_summary:hover::before {
  transform: translateY(-50%) scaleY(1);
}

.obj_article_summary .title a {
  font-weight: 800;
  font-size: var(--jmmr-text-lg);
  text-decoration: none;
  color: var(--jmmr-text);
  transition: color var(--jmmr-dur) var(--jmmr-ease);
  line-height: 1.35;
}
.obj_article_summary:hover .title a {
  color: var(--jmmr-primary);
}
.obj_article_summary .meta {
  color: var(--jmmr-muted);
  font-size: var(--jmmr-text-sm);
  margin-top: var(--jmmr-space-2);
}

/* Section headings in TOC */
.obj_issue_toc .section > .title {
  display: flex;
  align-items: center;
  gap: var(--jmmr-space-3);
  font-size: var(--jmmr-text-lg);
  font-weight: 800;
  margin: var(--jmmr-space-8) 0 var(--jmmr-space-4) 0;
  padding-bottom: var(--jmmr-space-3);
  border-bottom: 2px solid var(--jmmr-border);
}
.obj_issue_toc .section > .title::before {
  content: "";
  width: 4px;
  height: 20px;
  background: var(--jmmr-primary);
  border-radius: var(--jmmr-radius-pill);
  flex-shrink: 0;
}


/* ═══════════════════════════════════
   §12  ARTICLE DETAIL PAGE
   ═══════════════════════════════════ */
.pkp_page_article .obj_article_details {
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-lg);
  padding: var(--jmmr-space-8);
  box-shadow: var(--jmmr-shadow);
}

/* Title */
.pkp_page_article .obj_article_details .page_title {
  font-size: var(--jmmr-text-3xl);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin-bottom: var(--jmmr-space-4);
}

/* Authors */
.pkp_page_article .obj_article_details .authors {
  color: var(--jmmr-muted);
  font-size: var(--jmmr-text-base);
  line-height: 1.6;
}
.pkp_page_article .obj_article_details .authors .name {
  font-weight: 700;
  color: var(--jmmr-text-2);
}

/* DOI / metadata chips */
.pkp_page_article .obj_article_details .doi,
.pkp_page_article .obj_article_details .item.doi {
  display: inline-flex;
  align-items: center;
  gap: var(--jmmr-space-2);
  padding: var(--jmmr-space-2) var(--jmmr-space-4);
  background: var(--jmmr-primary-light);
  border: 1px solid rgba(11, 92, 171, 0.10);
  border-radius: var(--jmmr-radius-pill);
  font-size: var(--jmmr-text-sm);
  font-weight: 600;
  margin-top: var(--jmmr-space-4);
}
.pkp_page_article .obj_article_details .doi a {
  color: var(--jmmr-primary);
}

/* Abstract */
.pkp_page_article .obj_article_details .abstract {
  position: relative;
  border-top: 2px solid var(--jmmr-border);
  margin-top: var(--jmmr-space-6);
  padding-top: var(--jmmr-space-6);
}
.pkp_page_article .obj_article_details .abstract .label {
  font-size: var(--jmmr-text-sm);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--jmmr-muted);
  margin-bottom: var(--jmmr-space-3);
}
.pkp_page_article .obj_article_details .abstract p {
  color: var(--jmmr-text-2);
  line-height: 1.85;
  max-width: var(--jmmr-max-narrow);
}

/* Keywords */
.pkp_page_article .obj_article_details .keywords {
  margin-top: var(--jmmr-space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--jmmr-space-2);
}
.pkp_page_article .obj_article_details .keywords .value span,
.pkp_page_article .obj_article_details .keywords .keyword {
  display: inline-flex;
  padding: 4px 12px;
  background: var(--jmmr-surface-2);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-pill);
  font-size: var(--jmmr-text-xs);
  font-weight: 600;
  color: var(--jmmr-muted);
  transition: all var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_page_article .obj_article_details .keywords .value span:hover,
.pkp_page_article .obj_article_details .keywords .keyword:hover {
  background: var(--jmmr-primary-light);
  border-color: rgba(11, 92, 171, 0.14);
  color: var(--jmmr-primary);
}

/* Galleys / download buttons */
.pkp_page_article .obj_galley_link {
  display: inline-flex;
  align-items: center;
  gap: var(--jmmr-space-2);
  padding: 10px 20px;
  background: linear-gradient(
    180deg,
    var(--jmmr-primary) 0%,
    var(--jmmr-primary-2) 100%
  );
  color: #fff !important;
  border-radius: var(--jmmr-radius);
  font-weight: 700;
  font-size: var(--jmmr-text-sm);
  text-decoration: none !important;
  border: 1px solid rgba(255, 255, 255, 0.10);
  box-shadow:
    var(--jmmr-shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease),
    transform var(--jmmr-dur) var(--jmmr-ease-spring);
}
.pkp_page_article .obj_galley_link:hover {
  background: linear-gradient(
    180deg,
    var(--jmmr-primary-2) 0%,
    var(--jmmr-primary-3) 100%
  );
  box-shadow: var(--jmmr-shadow-md);
  transform: translateY(-2px);
}
.pkp_page_article .obj_galley_link:active {
  transform: translateY(0) scale(0.98);
}


/* ═══════════════════════════════════
   §13  FORMS & INPUTS
   ═══════════════════════════════════ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea,
select {
  font-family: var(--jmmr-font);
  font-size: var(--jmmr-text-base);
  padding: 10px 14px;
  border: 1.5px solid var(--jmmr-border-strong);
  border-radius: var(--jmmr-radius);
  background: var(--jmmr-surface);
  color: var(--jmmr-text);
  transition:
    border-color var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease);
  width: 100%;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--jmmr-primary);
  box-shadow: var(--jmmr-shadow-glow);
}

textarea {
  resize: vertical;
  min-height: 120px;
}

label {
  font-weight: 700;
  font-size: var(--jmmr-text-sm);
  color: var(--jmmr-text-2);
  margin-bottom: var(--jmmr-space-1);
  display: block;
}

/* Fieldsets */
fieldset {
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius);
  padding: var(--jmmr-space-5);
}
legend {
  font-weight: 800;
  font-size: var(--jmmr-text-sm);
  padding: 0 var(--jmmr-space-2);
}


/* ═══════════════════════════════════
   §14  TABLES
   ═══════════════════════════════════ */
table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius);
  overflow: hidden;
  box-shadow: var(--jmmr-shadow-xs);
}
thead th {
  background: var(--jmmr-surface-2);
  font-weight: 800;
  font-size: var(--jmmr-text-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--jmmr-muted);
  padding: var(--jmmr-space-3) var(--jmmr-space-4);
  border-bottom: 2px solid var(--jmmr-border);
  text-align: left;
}
tbody td {
  padding: var(--jmmr-space-3) var(--jmmr-space-4);
  border-bottom: 1px solid var(--jmmr-border);
  font-size: var(--jmmr-text-sm);
  color: var(--jmmr-text-2);
}
tbody tr:last-child td {
  border-bottom: none;
}
tbody tr {
  transition: background var(--jmmr-dur) var(--jmmr-ease);
}
tbody tr:hover {
  background: var(--jmmr-surface-2);
}


/* ═══════════════════════════════════
   §15  ANNOUNCEMENTS & NOTICES
   ═══════════════════════════════════ */
.obj_announcements .obj_announcement_summary {
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  border-radius: var(--jmmr-radius-lg);
  padding: var(--jmmr-space-5) var(--jmmr-space-6);
  margin-bottom: var(--jmmr-space-4);
  transition:
    box-shadow var(--jmmr-dur-slow) var(--jmmr-ease),
    transform var(--jmmr-dur-slow) var(--jmmr-ease);
}
.obj_announcements .obj_announcement_summary:hover {
  box-shadow: var(--jmmr-shadow-md);
  transform: translateY(-2px);
}
.obj_announcements .obj_announcement_summary .title {
  font-weight: 800;
  font-size: var(--jmmr-text-lg);
}
.obj_announcements .obj_announcement_summary .date {
  font-size: var(--jmmr-text-xs);
  color: var(--jmmr-faint);
  font-weight: 600;
}


/* ═══════════════════════════════════
   §16  PAGINATION
   ═══════════════════════════════════ */
.cmp_pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--jmmr-space-2);
  margin-top: var(--jmmr-space-8);
  padding-top: var(--jmmr-space-6);
  border-top: 1px solid var(--jmmr-border);
}
.cmp_pagination a,
.cmp_pagination .current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--jmmr-space-3);
  border-radius: var(--jmmr-radius);
  font-weight: 700;
  font-size: var(--jmmr-text-sm);
  transition:
    background var(--jmmr-dur) var(--jmmr-ease),
    color var(--jmmr-dur) var(--jmmr-ease),
    box-shadow var(--jmmr-dur) var(--jmmr-ease);
}
.cmp_pagination a {
  background: var(--jmmr-surface);
  border: 1px solid var(--jmmr-border);
  color: var(--jmmr-text-2);
}
.cmp_pagination a:hover {
  background: var(--jmmr-primary-light);
  border-color: rgba(11, 92, 171, 0.15);
  color: var(--jmmr-primary);
  text-decoration: none;
  box-shadow: var(--jmmr-shadow-sm);
}
.cmp_pagination .current {
  background: var(--jmmr-primary);
  color: #fff;
  border: 1px solid var(--jmmr-primary);
  box-shadow: var(--jmmr-shadow-sm);
}


/* ═══════════════════════════════════
   §17  BREADCRUMBS
   ═══════════════════════════════════ */
.pkp_breadcrumb,
.cmp_breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--jmmr-space-1);
  padding: var(--jmmr-space-3) 0;
  font-size: var(--jmmr-text-sm);
  color: var(--jmmr-faint);
  margin-bottom: var(--jmmr-space-4);
}
.pkp_breadcrumb a,
.cmp_breadcrumbs a {
  color: var(--jmmr-muted);
  font-weight: 600;
  transition: color var(--jmmr-dur) var(--jmmr-ease);
}
.pkp_breadcrumb a:hover,
.cmp_breadcrumbs a:hover {
  color: var(--jmmr-primary);
  text-decoration: none;
}
.pkp_breadcrumb .separator,
.cmp_breadcrumbs .separator {
  color: var(--jmmr-faint);
  margin: 0 2px;
  opacity: 0.5;
}

