/* ==========================================
   GOOGLE FONT IMPORT
   ========================================== */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700;800&family=Merriweather:wght@400;700&display=swap');

/* ==========================================
   THEME TOKENS
   ========================================== */
:root{
  --soj-blue-950: #07273d;
  --soj-blue-900: #0b3c5d;
  --soj-blue-800: #154360;
  --soj-blue-700: #1b4f72;
  --soj-blue-500: #2e86c1;
  --soj-blue-400: #85c1e9;
  --soj-blue-300: #aed6f1;
  --soj-blue-200: #d6eaf8;
  --soj-blue-50:  #f0f7fc;
  --text-900:     #1b2631;
  --text-700:     #34495e;
  --muted-600:    #5d6d7e;
  --white:        #ffffff;
}

/* ==========================================
   GLOBAL FONT & TYPOGRAPHY
   ========================================== */
html, body, p, li, td, th, input, select, textarea,
.pkp_structure_main, .pkp_page_content, .cmp_breadcrumbs,
.pkp_navigation_primary, .pkp_navigation_user, .pkp_footer_content {
  font-family: 'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif !important;
  font-weight: 400;
  line-height: 1.75;
  color: var(--text-900);
  font-size: 15px;
}

/* ==========================================
   HEADINGS (Serif elegance)
   ========================================== */
h1, h2, h3, h4, h5, h6,
.pkp_site_name, .pkp_page_title,
.obj_article_details .title, .obj_article_summary .title a {
  font-family: 'Merriweather', Georgia, 'Times New Roman', serif !important;
  font-weight: 700;
  color: var(--soj-blue-900);
  line-height: 1.4;
  letter-spacing: 0.2px;
  margin-bottom: 0.4em;
}
.obj_article_summary .title a:hover { color: var(--soj-blue-800); text-decoration: none; }
.pkp_navigation_primary ul.dropdown-menu > li a { font-weight:500; letter-spacing: 0px; text-transform:capitalize; font-size:18px; }
.pkp_navigation_user li.profile { margin-top: 7px; font-weight:700; border: 2px solid #fff; border-radius:7px }
@media (max-width: 992px){
  .pkp_navigation_user li.profile { display: inline flow-root list-item; }
}
@media (min-width: 992px){
  .pkp_navigation_primary > li a { font-weight:600; letter-spacing: 1px; text-transform:uppercase; font-size:18px; }
  .pkp_site_name .is_img { outline: none; }
  .pkp_site_name .is_img img { width: 100px;  max-height: inherit;  filter: drop-shadow(0 25px 30px rgba(0, 0, 0, .3)); background: white; border: 7px solid #fff; border-radius: 100%; }
}
.pkp_navigation_user li.profile a { padding: 5px 10px; display: table-cell; }
.pkp_site_nav_toggle { box-shadow: none; }
#customblock-menu p img { max-width: 150px; }

/* ==========================================
   SIDEBAR
   ========================================== */
.sidebar-box {
  width: 250px;
  padding: 10px 12px;
  background-color: var(--soj-blue-50);
  border-radius: 8px;
  border: 1px solid var(--soj-blue-200);
  font-family: 'Geist', sans-serif;
  font-size: 14px;
}
.sidebar-menu { list-style: none; margin: 0; padding: 0; }
.sidebar-menu li { margin-bottom: 10px; }
.sidebar-menu li a{
  display:block; background-color:var(--soj-blue-200); color:#1b4f72;
  text-decoration:none; padding:10px 12px; border-radius:6px;
  font-weight:500; font-family:'Geist',sans-serif;
  transition:background-color .3s ease, color .3s ease;
}
.sidebar-menu li a:hover{ background-color:var(--soj-blue-300); color:var(--soj-blue-800); }
.sidebar-menu li.active a{ background-color:var(--soj-blue-400); font-weight:600; color:var(--soj-blue-900); }

/* ==========================================
   ARTICLE & METADATA
   ========================================== */
.obj_article_summary, .obj_article_details, .pkp_structure_sidebar {
  font-family: 'Geist', sans-serif !important;
}
.obj_article_details .author, .obj_article_details .date, .item .label {
  font-size: 14px; color: var(--text-700);
}

/* ==========================================
   BUTTONS & LINKS
   ========================================== */
.pkp_button, .cmp_button, button, input[type=submit], a.button {
  font-family: 'Geist', sans-serif !important;
  font-weight: 500; border-radius: 6px;
}
a { color: var(--soj-blue-900); text-decoration: none; }
a:hover { color: var(--soj-blue-800); text-decoration: underline; }
a:focus-visible, .pkp_button:focus-visible, button:focus-visible {
  outline: 2px solid var(--soj-blue-500); outline-offset: 2px;
}

/* ==========================================
   FOOTER WRAPPER (Animated Gradient – Teal Premium)
   ========================================== */
.pkp_structure_footer_wrapper {
  background: linear-gradient(
    160deg,
    #129e97 0%,
    #0f6f75 45%,
    #257a84 100%
  );

  background-size: 300% 300%;
  animation: moveGradient 18s ease infinite, fadeIn 0.8s ease-out;

  box-shadow: inset 0 2px 4px rgba(0,0,0,0.15);
}

/* ==========================================
   FOOTER CONTENT (Animated Gradient)
   ========================================== */
.pkp_structure_footer {
  border-top: 3px solid var(--soj-blue-400);
  padding: 32px 20px;

  max-width: 1100px;
  margin: 0 auto;

  /* Grid layout (sesuai struktur kamu) */
  /* display: grid; */
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;

  /* === Animated Gradient Background === */
  /*background: linear-gradient(
    120deg,
    #257a84 0%,
    #129e97 50%,
    #257a84 100%
  );*/
  background: transparent;
  background-size: 300% 300%;
  animation: moveGradient 14s ease infinite, fadeIn 0.8s ease-out;
}

/* Paragraf & teks bawaan OJS */
.pkp_structure_footer .pkp_footer_content p{
  margin: 0 0 8px 0;
  color: #ffffff !important;
  line-height: 1.7;
  font-size: 14px;
}
.pkp_structure_footer .pkp_footer_content strong{
  color: #ffffff;
  font-weight: 600;
}
.pkp_structure_footer .pkp_footer_content a{
  color: var(--soj-blue-300);
  text-decoration: underline;
}
.pkp_structure_footer .pkp_footer_content a:hover{
  color: var(--white);
}

/* Brand OJS/PKP — pastikan muncul */
.pkp_brand_footer{
  display: flex !important;
  justify-content: flex-end;
  align-items: center;
}
.pkp_brand_footer a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  background-color: #fff;
  border-radius: 12px;
}
.pkp_brand_footer img{
  width: 140px;
  height: auto;
  opacity: 0.9;
  filter: none !important; /* jangan invert */
  transition: opacity .3s ease;
}
.pkp_brand_footer img:hover{ opacity: 1; }

/* ==========================================
   RESPONSIVE
   ========================================== */
@media (max-width: 960px){
  .pkp_structure_footer{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .pkp_brand_footer{
    justify-content: center; /* center logo di mobile */
  }
  .pkp_structure_footer { padding: 24px 16px; }
}

/* ==========================================
   VARIAN (optional)
   ========================================== */
/* Light version
.pkp_structure_footer_wrapper {
  background: #f8f9fa;
  border-top: 1px solid var(--soj-blue-200);
}
.pkp_structure_footer .pkp_footer_content p,
.pkp_structure_footer .pkp_footer_content strong { color: #34495e !important; }
.pkp_structure_footer .pkp_footer_content a { color: var(--soj-blue-900); }
.pkp_structure_footer .pkp_footer_content a:hover { color: var(--soj-blue-800); }
*/


/* =========================================================
   AUTH PAGES — Login & Register (Elegan, konsisten SOJ)
   Berlaku untuk:
   - .page_login, .page_register (OJS 3.x)
   - fallback untuk .pkp_page_login / .pkp_page_register
   ========================================================= */

/* Wrapper halaman: center + breathing space */
.page_login .pkp_page_content,
.page_register .pkp_page_content,
.pkp_page_login .pkp_page_content,
.pkp_page_register .pkp_page_content {
  max-width: 720px;
  margin: 32px auto 64px auto;
  padding: 0 16px;
}

/* Kartu/form utama */
.page_login .cmp_form,
.page_register .cmp_form,
.pkp_page_login .cmp_form,
.pkp_page_register .cmp_form,
.page_login .pkp_form,
.page_register .pkp_form {
  background: #ffffff;
  border: 1px solid var(--soj-blue-200);
  border-radius: 14px;
  padding: 28px;
  box-shadow: 0 6px 22px rgba(11, 60, 93, 0.08);
  min-width: 100%;
}

/* Judul form */
.page_login h1, .page_register h1,
.pkp_page_login h1, .pkp_page_register h1 {
  font-family: 'Merriweather', Georgia, serif;
  font-weight: 700;
  color: var(--soj-blue-900);
  font-size: 26px;
  margin: 0 0 16px 0;
}
.page_login .subtitle, .page_register .subtitle {
  color: var(--text-700);
  margin-bottom: 22px;
  font-size: 14.5px;
}

/* Field group / label */
.cmp_form .fields > div,
.pkp_form .fields > div { margin-bottom: 5px; padding-bottom: 0; }

.cmp_form label, .pkp_form label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  color: var(--soj-blue-800);
  font-size: 14px;
}

/* Input, select, textarea */
.cmp_form input[type="text"],
.cmp_form input[type="email"],
.cmp_form input[type="password"],
.cmp_form select,
.cmp_form textarea,
.pkp_form input[type="text"],
.pkp_form input[type="email"],
.pkp_form input[type="password"],
.pkp_form select,
.pkp_form textarea {
  width: 100%;
  height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--soj-blue-200);
  border-radius: 10px;
  background: #fff;
  color: var(--text-900);
  transition: border-color .2s ease, box-shadow .2s ease;
  font-family: 'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
}
.cmp_form textarea, .pkp_form textarea { min-height: 110px; height: auto; }

.cmp_form input:focus,
.cmp_form select:focus,
.cmp_form textarea:focus,
.pkp_form input:focus,
.pkp_form select:focus,
.pkp_form textarea:focus {
  outline: none;
  border-color: var(--soj-blue-400);
  box-shadow: 0 0 0 3px rgba(133, 193, 233, 0.35);
}

/* Placeholder */
.cmp_form ::placeholder, .pkp_form ::placeholder { color: #9aa7b2; }

/* Checkbox/remember me */
.cmp_form .options, .pkp_form .options { margin: 8px 0 16px; }
.cmp_form .options label, .pkp_form .options label {
  font-weight: 500; color: var(--text-700);
}
.cmp_form input[type="checkbox"], .pkp_form input[type="checkbox"] {
  width: 16px; height: 16px; margin-right: 8px; vertical-align: middle;
}

/* Error & help text */
.cmp_form .error, .pkp_form .error,
.cmp_form .pkp_form_error, .pkp_form .pkp_form_error {
  color: #b33939;
  background: #fdecec;
  border: 1px solid #f5b7b1;
  padding: 8px 10px;
  border-radius: 8px;
  margin-top: 6px;
  font-size: 13px;
}
.cmp_form .description, .pkp_form .description {
  color: var(--muted-600);
  font-size: 13px;
  margin-top: 4px;
}

/* Tombol utama */
.cmp_form .buttons, .pkp_form .buttons {
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.cmp_form .buttons .submit,
.pkp_form .buttons .submit,
.cmp_form button[type="submit"],
.pkp_form button[type="submit"],
.cmp_form input[type="submit"],
.pkp_form input[type="submit"] {
  background: var(--soj-blue-800);
  color: #fff;
  border: 1px solid var(--soj-blue-800);
  border-radius: 10px;
  padding: 10px 16px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s ease, transform .05s ease;
}
.cmp_form .buttons .submit:hover,
.pkp_form .buttons .submit:hover,
.cmp_form button[type="submit"]:hover,
.pkp_form button[type="submit"]:hover {
  background: var(--soj-blue-900);
}
.cmp_form .buttons .submit:active,
.pkp_form .buttons .submit:active { transform: translateY(1px); }

/* Tombol sekunder (cancel/link) */
.cmp_form .buttons .cancel,
.pkp_form .buttons .cancel,
.cmp_form .buttons a.button,
.pkp_form .buttons a.button {
  background: #fff;
  color: var(--soj-blue-800);
  border: 1px solid var(--soj-blue-300);
  border-radius: 10px;
  padding: 10px 14px;
  font-weight: 600;
  text-decoration: none;
}
.cmp_form .buttons .cancel:hover,
.pkp_form .buttons .cancel:hover,
.cmp_form .buttons a.button:hover,
.pkp_form .buttons a.button:hover {
  background: var(--soj-blue-50);
}

/* Link bantuan (Lupa password, Login/Register switch) */
.auth-links {
  margin-top: 14px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.auth-links a {
  color: var(--soj-blue-900);
  text-decoration: none;
  font-weight: 600;
}
.auth-links a:hover { text-decoration: underline; color: var(--soj-blue-800); }

/* Pemisah sosial/SSO (opsional) */
.auth-divider {
  position: relative;
  text-align: center;
  margin: 18px 0;
  color: var(--muted-600);
  font-size: 13px;
}
.auth-divider::before,
.auth-divider::after {
  content: "";
  position: absolute;
  top: 50%; width: 40%;
  border-top: 1px solid var(--soj-blue-200);
}
.auth-divider::before { left: 0; }
.auth-divider::after  { right: 0; }

/* Tombol SSO (opsional, jika ada plugin) */
.sso-buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.sso-buttons .btn-sso {
  flex: 1 1 auto;
  min-width: 180px;
  background: #ffffff;
  border: 1px solid var(--soj-blue-300);
  border-radius: 10px;
  padding: 10px 14px;
  font-weight: 600;
  color: var(--soj-blue-900);
  text-align: center;
  text-decoration: none;
  transition: background .2s ease, border-color .2s ease;
}
.sso-buttons .btn-sso:hover {
  background: var(--soj-blue-50);
  border-color: var(--soj-blue-400);
}

/* Responsif kartu */
@media (max-width: 640px) {
  .page_login .cmp_form, .page_register .cmp_form,
  .pkp_page_login .cmp_form, .pkp_page_register .cmp_form,
  .page_login .pkp_form, .page_register .pkp_form {
    padding: 22px;
    border-radius: 12px;
  }
}

/* Fokus aksesibel */
.cmp_form input:focus-visible,
.cmp_form select:focus-visible,
.cmp_form textarea:focus-visible,
.pkp_form input:focus-visible,
.pkp_form select:focus-visible,
.pkp_form textarea:focus-visible {
  outline: 2px solid var(--soj-blue-500);
  outline-offset: 2px;
}

/* Header kecil di atas form (opsional) */
.auth-header {
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--soj-blue-50);
  border: 1px solid var(--soj-blue-200);
  border-radius: 10px;
  color: var(--soj-blue-800);
  font-weight: 600;
}

.page_login .password a {
  display: block;
}

.page_search .submit button::after {
  display: none;
}

.pkp_structure_head {
    /* Gradient bergerak ala Instagram */
    background: linear-gradient(
        120deg,
        #129e97,
        #129e97,
        #257a84
    );
    background-size: 300% 300%;
    animation: moveGradient 10s ease infinite;

    border-bottom: 1px solid #ddd;

    /* Smooth transition opsional */
    transition: opacity 0.4s ease;
}

/* Animasi gradient bergerak */
@keyframes moveGradient {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@media (min-width: 992px) {
  .pkp_site_nav_menu {
    background: transparent;
  }
  .pkp_nav_list ul a {
    color: #257a84!important;
    border-left: none;
    padding-left: .7rem;
  }
  .pkp_navigation_search_wrapper a { 
    font-size: 18px;
  }
}

@media (max-width: 992px) {
  .pkp_site_nav_menu {
    background: #129e97;
  }
}

.cmp_notification {
  border-radius: 12px;
  border-left: none;
}

h1, h2, h3, h4, h5, h6, .pkp_site_name, .pkp_page_title, .obj_article_details .title, .obj_article_summary .title a {
  color: #257a84;
}

.obj_issue_summary .title {
    font-family: 'Merriweather', Georgia, 'Times New Roman', serif !important;
    font-weight: 700;
    text-decoration: none;
    font-size: 18px;
    color: #129e97;
}

.pkp_structure_footer .pkp_footer_content strong {
  font-family: 'Merriweather', Georgia, 'Times New Roman', serif !important;
  font-size: 24px;
}

/* ==========================================
   ISSN BADGE — pojok kanan header (DESKTOP)
   ========================================== */
.pkp_site_name {
  position: relative;
}

/* ISSN text */
.pkp_site_name::after {
  content: "ISSN 3124-3495";
  position: absolute;
  right: 0;
  bottom: 6px;

  font-family: 'Geist', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.5px;

  color: #ffffff;
  background: rgba(0,0,0,0.25);
  backdrop-filter: blur(4px);

  padding: 6px 10px;
  border-radius: 8px;

  box-shadow: 0 4px 14px rgba(0,0,0,.25);
  white-space: nowrap;
}

/* Desktop adjustment */
@media (min-width: 992px) {
  .pkp_site_name::after {
    bottom: 10px;
    right: 10px;
    font-size: 14px;
  }
}

/* ==========================================
   JOURNAL NAME — sebelah logo (DESKTOP)
   ========================================== */
.pkp_site_name .is_img {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  position: relative;
  text-decoration: none;
}

/* Text nama journal */
.pkp_site_name .is_img::after {
  content: "Soeharso Orthopaedic Journal";

  font-family: 'Merriweather', Georgia, 'Times New Roman', serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 1.3;
  letter-spacing: 0.4px;

  color: #ffffff;       /* putih sesuai header */
  white-space: nowrap;
  text-decoration: none;
}

/* Desktop — lebih besar & tegas */
@media (min-width: 992px) {
  .pkp_site_name .is_img::after {
    font-size: 26px;
  }
}

/* ==========================================
   MOBILE — HIDE ISSN & JOURNAL NAME
   ========================================== */
@media (max-width: 991px) {

  /* hide ISSN */
  .pkp_site_name::after {
    display: none !important;
    content: none !important;
  }

  /* hide journal name */
  .pkp_site_name .is_img::after {
    display: none !important;
    content: none !important;
  }
}


/* =========================================================
   MAKE A SUBMISSION — Premium Animated CTA (OJS)
   ========================================================= */

/* Base button */
.pkp_structure_main .block_make_submission_link,
.pkp_structure_sidebar .block_make_submission_link,
.block_make_submission_link {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  padding: 14px 22px !important;
  border-radius: 16px !important;

  font-family: 'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.6px !important;
  text-transform: uppercase !important;

  color: #ffffff !important;
  text-decoration: none !important;

  border: 1px solid rgba(255,255,255,0.18) !important;

  /* Animated gradient */
  background: linear-gradient(135deg, #129e97 0%, #257a84 45%, #129e97 100%) !important;
  background-size: 220% 220% !important;
  animation: sojCtaGradient 8s ease infinite !important;

  box-shadow:
    0 16px 40px rgba(18, 158, 151, 0.40),
    0 6px 16px rgba(7, 39, 61, 0.20),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;

  cursor: pointer !important;
  user-select: none !important;

  transform: translateZ(0) !important;
  will-change: transform, box-shadow, filter !important;

  transition:
    transform .18s ease,
    box-shadow .18s ease,
    filter .18s ease !important;

  overflow: hidden !important; /* for shine + ripple */
}

/* Icon (simple, clean) */
.pkp_structure_main .block_make_submission_link::before,
.pkp_structure_sidebar .block_make_submission_link::before,
.block_make_submission_link::before {
  content: "➜" !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  opacity: .95 !important;
  transform: translateY(-1px) !important;
}

/* Shine sweep overlay */
.pkp_structure_main .block_make_submission_link::after,
.pkp_structure_sidebar .block_make_submission_link::after,
.block_make_submission_link::after {
  content: "" !important;
  position: absolute !important;
  inset: -40% -60% !important;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.22) 45%,
    rgba(255,255,255,0) 70%
  ) !important;
  transform: rotate(18deg) translateX(-120%) !important;
  animation: sojCtaShine 3.2s ease-in-out infinite !important;
  pointer-events: none !important;
  mix-blend-mode: screen !important;
}

/* Hover = lift + glow + slight saturation */
.pkp_structure_main .block_make_submission_link:hover,
.pkp_structure_sidebar .block_make_submission_link:hover,
.block_make_submission_link:hover {
  transform: translateY(-3px) scale(1.01) !important;
  filter: saturate(1.12) brightness(1.02) !important;
  box-shadow:
    0 22px 54px rgba(18, 158, 151, 0.55),
    0 10px 22px rgba(7, 39, 61, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.28) !important;
}

/* Active = press + ripple flash */
.pkp_structure_main .block_make_submission_link:active,
.pkp_structure_sidebar .block_make_submission_link:active,
.block_make_submission_link:active {
  transform: translateY(-1px) scale(0.995) !important;
  box-shadow:
    0 12px 28px rgba(18, 158, 151, 0.45),
    inset 0 6px 14px rgba(0,0,0,0.22) !important;
}

/* Focus-visible accessibility ring */
.pkp_structure_main .block_make_submission_link:focus-visible,
.pkp_structure_sidebar .block_make_submission_link:focus-visible,
.block_make_submission_link:focus-visible {
  outline: none !important;
  box-shadow:
    0 0 0 4px rgba(133, 193, 233, 0.55),
    0 16px 40px rgba(18, 158, 151, 0.40),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* Ripple effect (CSS only via background circle) */
.pkp_structure_main .block_make_submission_link span,
.pkp_structure_sidebar .block_make_submission_link span,
.block_make_submission_link span {
  position: relative !important;
  z-index: 2 !important;
}

/* Optional: if link text not wrapped in <span>, still safe */
.pkp_structure_main .block_make_submission_link,
.pkp_structure_sidebar .block_make_submission_link,
.block_make_submission_link {
  z-index: 1 !important;
}

/* =========================================================
   Animations
   ========================================================= */
@keyframes sojCtaGradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes sojCtaShine {
  0%   { transform: rotate(18deg) translateX(-120%); opacity: .0; }
  15%  { opacity: .9; }
  35%  { opacity: .35; }
  60%  { opacity: .0; transform: rotate(18deg) translateX(120%); }
  100% { opacity: .0; transform: rotate(18deg) translateX(120%); }
}

/* Subtle floating attention (only when not hovered) */
.pkp_structure_main .block_make_submission_link,
.pkp_structure_sidebar .block_make_submission_link,
.block_make_submission_link {
  animation:
    sojCtaGradient 8s ease infinite,
    sojCtaFloat 4.6s ease-in-out infinite !important;
}

@keyframes sojCtaFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-1.5px); }
}

/* Reduce motion respect */
@media (prefers-reduced-motion: reduce) {
  .pkp_structure_main .block_make_submission_link,
  .pkp_structure_sidebar .block_make_submission_link,
  .block_make_submission_link {
    animation: none !important;
    transition: none !important;
  }
  .pkp_structure_main .block_make_submission_link::after,
  .pkp_structure_sidebar .block_make_submission_link::after,
  .block_make_submission_link::after {
    animation: none !important;
  }
}

/* Mobile: full width + centered */
@media (max-width: 640px) {
  .pkp_structure_main .block_make_submission_link,
  .pkp_structure_sidebar .block_make_submission_link,
  .block_make_submission_link {
    width: 100% !important;
    padding: 14px 18px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }
}


/* ========================================================= SIDEBAR — UNIFIED STYLE (Menul + Information + Browse) - No big card wrapper - Same title style + underline accent - Same pill links + arrow + hover - Add block padding - Rename "Menul" -> "Menu Sidebar" ========================================================= */
/* ---------- 1) BLOCK WRAPPER: flat + padding ---------- */
.pkp_structure_sidebar .pkp_block#customblock-menul,
.pkp_structure_sidebar .pkp_block.block_information,
.pkp_structure_sidebar .pkp_block.block_browse {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  margin: 0 0 22px 0 !important;
}

/* ---------- 2) TITLES: unify ---------- */
.pkp_structure_sidebar .pkp_block#customblock-menul>.title,
.pkp_structure_sidebar .pkp_block.block_information>.title,
.pkp_structure_sidebar .pkp_block.block_browse>.title {
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  letter-spacing: 0.3px !important;
  color: #257a84 !important;
}

/* If Menul title is screen-reader only, make it visible */
.pkp_structure_sidebar .pkp_block#customblock-menul>.title.pkp_screen_reader {
  position: static !important;
  width: auto !important;
  height: auto !important;
  clip: auto !important;
  overflow: visible !important;
  white-space: normal !important;
}

/* ✅ Rename Menul -> Menu Sidebar (CSS-only) */
.pkp_structure_sidebar .pkp_block#customblock-menul>.title {
  color: transparent !important;
  /* sembunyikan teks asli */
  position: relative !important;
}

.pkp_structure_sidebar .pkp_block#customblock-menul>.title::before {
  content: "Menu Sidebar" !important;
  display: block !important;
  color: #257a84 !important;
  font-family: 'Merriweather', Georgia, serif !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  letter-spacing: 0.3px !important;
}

/* Underline accent */
.pkp_structure_sidebar .pkp_block#customblock-menul>.title::after,
.pkp_structure_sidebar .pkp_block.block_information>.title::after,
.pkp_structure_sidebar .pkp_block.block_browse>.title::after {
  content: "" !important;
  display: block !important;
  width: 42px !important;
  height: 2px !important;
  margin-top: 6px !important;
  background: linear-gradient(90deg, #129e97, #257a84) !important;
}

/* ---------- 3) CONTENT spacing ---------- */
.pkp_structure_sidebar .pkp_block#customblock-menul .content,
.pkp_structure_sidebar .pkp_block.block_information .content,
.pkp_structure_sidebar .pkp_block.block_browse .content {
  padding: 0 !important;
}

/* Remove extra <br> inside custom block */
.pkp_structure_sidebar #customblock-menul .sidebar-box>br {
  display: none !important;
}

/* Custom aside wrapper should be flat too */
.pkp_structure_sidebar #customblock-menul .sidebar-box {
  width: auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
}

/* ---------- 4) LIST reset (all blocks) ---------- */
.pkp_structure_sidebar #customblock-menul .sidebar-menu,
.pkp_structure_sidebar .pkp_block.block_information ul,
.pkp_structure_sidebar .pkp_block.block_browse ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ---------- 5) LINK STYLE: unify pill links ---------- */
.pkp_structure_sidebar #customblock-menul .sidebar-menu li a,
.pkp_structure_sidebar .pkp_block.block_information li a,
.pkp_structure_sidebar .pkp_block.block_browse li a {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  margin: 6px 0 !important;
  border-radius: 12px !important;
  border: 1px solid #d6eaf8 !important;
  /* soft outline */
  background: #f0f7fc !important;
  /* very light */
  font-family: 'Geist', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #0b3c5d !important;
  text-decoration: none !important;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease !important;
}

/* Arrow indicator (same everywhere) */
.pkp_structure_sidebar #customblock-menul .sidebar-menu li a::after,
.pkp_structure_sidebar .pkp_block.block_information li a::after,
.pkp_structure_sidebar .pkp_block.block_browse li a::after {
  content: "→" !important;
  font-weight: 900 !important;
  opacity: 0.6 !important;
  transition: transform .15s ease, opacity .15s ease !important;
}

/* Hover effect */
.pkp_structure_sidebar #customblock-menul .sidebar-menu li a:hover,
.pkp_structure_sidebar .pkp_block.block_information li a:hover,
.pkp_structure_sidebar .pkp_block.block_browse li a:hover {
  background: #d6eaf8 !important;
  border-color: #85c1e9 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 16px rgba(7, 39, 61, .08) !important;
}

.pkp_structure_sidebar #customblock-menul .sidebar-menu li a:hover::after,
.pkp_structure_sidebar .pkp_block.block_information li a:hover::after,
.pkp_structure_sidebar .pkp_block.block_browse li a:hover::after {
  transform: translateX(3px) !important;
  opacity: 1 !important;
}

/* Focus ring */
.pkp_structure_sidebar #customblock-menul .sidebar-menu li a:focus-visible,
.pkp_structure_sidebar .pkp_block.block_information li a:focus-visible,
.pkp_structure_sidebar .pkp_block.block_browse li a:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(133, 193, 233, .45), 0 6px 16px rgba(7, 39, 61, .08) !important;
}

/* ---------- 6) BROWSE: "Categories" label row (match typography) ---------- */
.pkp_structure_sidebar .pkp_block.block_browse li.has_submenu {
  margin-top: 10px !important;
  font-family: 'Geist', system-ui, sans-serif !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .4px !important;
  color: #5d6d7e !important;
}

/* Submenu list spacing */
.pkp_structure_sidebar .pkp_block.block_browse li.has_submenu>ul {
  margin-top: 6px !important;
}

/* Indent category pills slightly */
.pkp_structure_sidebar .pkp_block.block_browse li.has_submenu>ul>li a {
  margin-left: 10px !important;
}

/* Dot for category items (adds before arrow) */
.pkp_structure_sidebar .pkp_block.block_browse li.has_submenu>ul>li a::before {
  content: "•" !important;
  margin-right: 8px !important;
  color: #129e97 !important;
  font-weight: 900 !important;
}

/* ---------- 7) OPTIONAL: active link style (if you add .active manually) ---------- */
.pkp_structure_sidebar #customblock-menul .sidebar-menu li.active a,
.pkp_structure_sidebar .pkp_block li.active a {
  background: #aed6f1 !important;
  border-color: #85c1e9 !important;
  color: #07273d !important;
}

/* Mobile tuning */
@media (max-width: 640px) {

  .pkp_structure_sidebar #customblock-menul .sidebar-menu li a,
  .pkp_structure_sidebar .pkp_block.block_information li a,
  .pkp_structure_sidebar .pkp_block.block_browse li a {
    padding: 9px 10px !important;
    font-size: 13.5px !important;
  }
}

/* =========================================================
   FIXED NAV — Elegant + Animated (SOJ)
   ========================================================= */

/* Base state (normal) */
.pkp_navigation_primary_row {
  position: relative;
  z-index: 20;

  transition:
    transform .35s ease,
    box-shadow .35s ease,
    background .35s ease,
    opacity .25s ease;
}

/* ✅ Layout rapih (normal & fixed) */
.pkp_navigation_primary_wrapper {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

/* Pastikan ul & search sejajar */
.pkp_navigation_primary {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}

.pkp_navigation_search_wrapper {
  display: flex !important;
  align-items: center !important;
}

/* Fixed state */
.pkp_navigation_primary_row.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;

  z-index: 999;

  background: linear-gradient(
    135deg,
    rgba(18, 158, 151, 0.94),
    rgba(37, 122, 132, 0.94)
  ) !important;

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  box-shadow: 0 12px 32px rgba(7,39,61,.22);

  animation: sojNavIn .45s cubic-bezier(.22,1,.36,1);
}

/* Entrance animation (slide + fade + subtle scale) */
@keyframes sojNavIn {
  from { transform: translateY(-110%) scale(0.98); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}

/* =========================================================
   NAV LINKS — refine on fixed
   ========================================================= */
.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li > a {
  color: #ffffff !important;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;

  /* ✅ rapih: tinggi bar konsisten */
  display: inline-flex !important;
  align-items: center !important;
  line-height: 1.1 !important;
  padding: 14px 10px !important;

  transition: color .2s ease, transform .2s ease;
}

/* Hover underline animated */
.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li > a::after {
  content: "";
  display: block;
  height: 2px;
  width: 0;
  margin-top: 6px;
  background: linear-gradient(90deg, #eaf6fb, #ffffff);
  transition: width .25s ease;
}

.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li > a:hover::after {
  width: 100%;
}

/* Hover state */
.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li > a:hover {
  color: #eaf6fb !important;
  transform: translateY(-1px);
}

/* Active link */
.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li.current > a,
.pkp_navigation_primary_row.is-fixed .pkp_navigation_primary > li.active > a {
  color: #ffffff !important;
}

/* =========================================================
   ✅ DROPDOWN ARROW — jangan turun + lebih rapih saat fixed
   ========================================================= */

/* Matikan caret bawaan theme/bootstrap (kalau ada) */
.pkp_navigation_primary a[data-toggle="dropdown"]::after {
  display: none !important;
}

/* Buat anchor dropdown tetap inline-flex biar arrow nempel */
.pkp_navigation_primary a[data-toggle="dropdown"] {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding-right: 18px !important; /* ruang arrow */
  line-height: 1.1 !important;
  position: relative !important;
}

/* Arrow custom */
.pkp_navigation_primary a[data-toggle="dropdown"]::before {
  content: "▾" !important;
  display: inline-block !important;

  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;

  margin-left: 4px !important;

  /* ✅ kunci supaya tidak turun */
  transform: translateY(0) !important;

  opacity: .9 !important;
  transition: transform .2s ease, opacity .2s ease !important;
}

/* Hover: rotate */
.pkp_navigation_primary a[data-toggle="dropdown"]:hover::before {
  transform: rotate(180deg) !important;
  opacity: 1 !important;
}

/* Saat dropdown terbuka (OJS bisa pakai .show atau .open) */
.pkp_navigation_primary li.show > a[data-toggle="dropdown"]::before,
.pkp_navigation_primary li.open > a[data-toggle="dropdown"]::before {
  transform: rotate(180deg) !important;
  opacity: 1 !important;
}

/* =========================================================
   DROPDOWN MENU — fixed state
   ========================================================= */
.pkp_navigation_primary_row.is-fixed .dropdown-menu {
  background: #ffffff !important;
  border-radius: 14px;
  border: 1px solid #d6eaf8;
  box-shadow: 0 16px 36px rgba(7,39,61,.22);
}

.pkp_navigation_primary_row.is-fixed .dropdown-menu li a {
  color: #0b3c5d !important;
  font-weight: 600;
}

.pkp_navigation_primary_row.is-fixed .dropdown-menu li a:hover {
  background: #f0f7fc !important;
  color: #257a84 !important;
}

/* =========================================================
   SEARCH LINK — fixed state (rapih sejajar)
   ========================================================= */
.pkp_navigation_primary_row.is-fixed .pkp_navigation_search_wrapper a {
  color: #ffffff !important;
  font-weight: 700;

  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 14px 10px !important;
  line-height: 1.1 !important;
}

.pkp_navigation_primary_row.is-fixed .pkp_navigation_search_wrapper a:hover {
  color: #eaf6fb !important;
}

/* =========================================================
   MOBILE TUNING
   ========================================================= */
@media (max-width: 992px) {
  .pkp_navigation_primary_row.is-fixed {
    background: linear-gradient(
      135deg,
      rgba(18, 158, 151, 0.98),
      rgba(37, 122, 132, 0.98)
    ) !important;
  }
}

/* =========================================================
   ACCESSIBILITY — reduce motion
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  .pkp_navigation_primary_row,
  .pkp_navigation_primary_row.is-fixed {
    animation: none !important;
    transition: none !important;
  }
}


/* =========================================================
   MOBILE PRIMARY NAV — Vertical & Clean
   Target: #navigationPrimary (UL biasa)
   ========================================================= */
@media (max-width: 992px) {

  /* UL utama */
  #navigationPrimary {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;

    width: 100% !important;
    margin: 0 !important;
    padding: 16px !important;

    list-style: none !important;
    gap: 8px !important;
  }

  /* LI utama */
  #navigationPrimary > li {
    width: 100% !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Link utama */
  #navigationPrimary > li > a {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;

    width: 100% !important;
    padding: 12px 14px !important;

    border-radius: 12px !important;
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.14) !important;

    color: #ffffff !important;
    font-weight: 800 !important;
    font-size: 15px !important;
    letter-spacing: .2px !important;
    text-decoration: none !important;
  }

  /* Hover / tap */
  #navigationPrimary > li > a:hover {
    background: rgba(255,255,255,0.14) !important;
  }

  /* ============================
     SUBMENU (About → children)
     ============================ */

  /* UL submenu */
  #navigationPrimary > li > ul {
    display: block !important;
    margin: 6px 0 0 0 !important;
    padding: 6px !important;

    list-style: none !important;
    border-radius: 12px !important;

    background: rgba(0,0,0,0.08) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
  }

  /* LI submenu */
  #navigationPrimary > li > ul > li {
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Link submenu */
  #navigationPrimary > li > ul > li > a {
    display: block !important;

    padding: 10px 12px !important;
    border-radius: 10px !important;

    color: #ffffff !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-decoration: none !important;
  }

  #navigationPrimary > li > ul > li > a:hover {
    background: rgba(255,255,255,0.12) !important;
  }

}
