@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,wght@0,400;0,600;0,700;0,800;1,400&display=swap');

/* =========================================
   1. BASE & RESET
========================================= */
html {
  scroll-behavior: smooth;
}

* {
  transition: color 0.3s ease, border-color 0.3s ease, background 0.3s ease, transform 0.3s ease;
}

body {
  overflow-x: hidden !important;
  text-align: justify;
  font-family: 'Nunito Sans', sans-serif;
  color: #2d2d2d;
}

body::before {
  content: '';
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-image: url('https://journal.eternaedu.com/public/site/bg-image.png');
  background-repeat: repeat;
  background-size: 30%;
  z-index: -1; 
}

a {
  text-decoration: none;
}

.container {
  padding: 0 !important;
}

/* =========================================
   2. HEADER & NAVIGATION
========================================= */
/* Header Custom */
.pull-md-right .navbar-form.navbar-left .form-group .form-control {
  border-radius: 20px 4px;
}

.navbar {
  margin: 0 auto;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.navbar:hover {
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

.nav.nav-pills {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
  margin-top: 4px !important;
}

/* Header Navigation Interactive Styles */
.navbar-nav > li > a {
  position: relative;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  font-weight: 500;
}

.navbar-nav > li > a::before {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 50%;
  width: 0;
  height: 3px;
  background: linear-gradient(90deg, #c08511 0%, #840b0f 50%);
  transform: translateX(-50%);
  transition: width 0.3s ease-in-out;
  border-radius: 2px;
}

.navbar-nav > li > a:hover::before,
.navbar-nav > li.active > a::before {
  width: 80%;
}

.navbar-nav > li > a:hover {
  color: #840b0f !important;
  transform: translateY(-2px);
}

/* Badge Animations */
.site-name a {
  animation: slideInDown 0.6s ease-out;
}

@keyframes slideInDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Badge Icons Interactive */
.navbar-right .btn,
.navbar-right a {
  transition: all 0.3s ease !important;
  transform: translateZ(0);
}

.navbar-right .btn:hover,
.navbar-right a:hover {
  transform: scale(1.05) translateY(-3px);
  box-shadow: 0 6px 15px rgba(200, 133, 17, 0.3);
}

/* Search Button Enhancement */
.navbar-form.navbar-left .btn.btn-default {
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  position: relative;
  overflow: hidden;
}

.navbar-form.navbar-left .btn.btn-default::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.2);
  transition: left 0.3s ease;
}

.navbar-form.navbar-left .btn.btn-default:hover::before {
  left: 100%;
}

.navbar-form.navbar-left .btn.btn-default:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(132, 11, 15, 0.4);
}

/* Form Control Interactive */
.navbar-form.navbar-left .form-group .form-control {
  transition: all 0.3s ease !important;
  border: 2px solid transparent !important;
}

.navbar-form.navbar-left .form-group .form-control:focus {
  border-color: #c08511 !important;
  box-shadow: 0 0 15px rgba(192, 133, 17, 0.3) !important;
  transform: scale(1.02);
}

.site-name {
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}

.site-name a {
  margin-left: 0 !important;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0px;
  transition: all 0.3s ease;
  position: relative;
}

.site-name a:hover {
  transform: scale(1.02);
  filter: brightness(1.1);
}

.site-name a img {
  width: 100% !important;
  border-left: solid 3px #eeeaea;
  border-right: solid 3px #eeeaea;
  transition: all 0.3s ease !important;
}

.site-name a:hover img {
  filter: drop-shadow(0 0 10px rgba(192, 133, 17, 0.4));
}

img {}

img {}

.page_index_journal {
  display: flex;
  flex-direction: column;
}

/* Search Form Enhancement */
.navbar-form.navbar-left .btn.btn-default {
  position: relative;
  overflow: hidden;
}

.navbar-form.navbar-left .btn.btn-default::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.2);
  transition: left 0.3s ease;
}

.navbar-form.navbar-left .btn.btn-default:hover::before {
  left: 100%;
}

.navbar-form.navbar-left .btn.btn-default:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(132, 11, 15, 0.4);
}

.navbar-form.navbar-left .form-group .form-control {
  border: 2px solid transparent !important;
  border-radius: 20px 4px;
}

.navbar-form.navbar-left .form-group .form-control:focus {
  border-color: #c08511 !important;
  box-shadow: 0 0 15px rgba(192, 133, 17, 0.3) !important;
  transform: scale(1.02);
}

/* =========================================
   3. FORMS & BUTTONS (LOGIN/REGISTER)
========================================= */
.form-group {
  margin-bottom: 15px;
}

.pkp_form .form-group input,
.pkp_form .form-group select {
  border-radius: 12px !important;
}

.pkp_form .buttons {
  display: flex !important;
  justify-content: flex-end;
  gap: 15px;
}

.pkp_form .buttons button,
.pkp_form .buttons a {
  background: linear-gradient(90deg, #c08511 0%, #840b0f 100%);
  color: #fff !important;
  border: none !important;
  border-radius: 20px 0px;
  padding: 10px 20px;
  font-weight: 600;
  cursor: pointer;
}

.pkp_form .buttons a:hover,
.pkp_form .buttons button:hover {
  background: linear-gradient(90deg, #840b0f 0%, #c08511 100%);
  transform: translateY(-2px);
  box-shadow: 0 6px 15px rgba(200, 133, 17, 0.3);
}

/* =========================================
   4. SIDEBAR & CUSTOM BLOCKS
========================================= */
.pkp_block.block_custom,
.pkp_block.block_web_feed {
  border-radius: 8px !important;
  border: none;
  box-shadow: 0px 0px 6px 0px #eaeaea;
  overflow: hidden;
}

.pkp_block.block_custom:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

.pkp_block .title,
.panel-default > .panel-heading {
  color: #243140;
  background-color: #eaeaea;
  border-bottom: 4px solid #f7f223;
  text-align: center;
  font-size: 24px;
  font-weight: 600;
  padding: 14px 0px;
}

.pkp_block.block_custom .content .sidebar__title {
  border-left: 2px solid #accf5f;
  padding-left: 10px;
  font-size: 20px;
  font-weight: 600;
  position: relative;
}

.pkp_block.block_custom .content .sidebar__title::before {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #accf5f 0%, #c08511 100%);
}

.pkp_block.block_custom:hover .content .sidebar__title::before {
  width: 100%;
}

.sidebar__container {
  padding: 15px;
  border: 1px solid #eaeaea;
  border-radius: 8px;
  transition: all 0.3s ease;
}

.sidebar__container:hover {
  border-color: #accf5f;
  box-shadow: 0px 0px 12px rgba(172, 207, 95, 0.2);
}

.submissions__btn,
.issue__journal-expand {
  background-color: #accf5f;
  color: #222 !important;
  border-radius: 8px;
  padding: 10px;
  font-weight: 600;
  text-align: center;
  display: block;
  position: relative;
  overflow: hidden;
}

.submissions__btn:hover,
.issue__journal-expand:hover {
  background-color: #b8dd75;
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(172, 207, 95, 0.35);
}

/* Sidebar Gradient Menu Link */
.menu__link {
  display: block;
  padding: 10px 14px;
  border-radius: 20px 4px;
  color: #fff !important;
  background: linear-gradient(90deg, #c08511 0%, #840b0f 50%);
  text-align: center;
  font-weight: bold;
  position: relative;
  overflow: hidden;
}

.menu__link:hover {
  background: linear-gradient(90deg, #840b0f 0%, #c08511 50%);
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 8px 20px rgba(132, 11, 15, 0.35);
}

/* =========================================
   5. MAIN CONTENT & ARTICLE LISTS
========================================= */
.pkp_structure_content.container {
  padding: 20px !important;
  background-color: #fff !important;
  box-shadow: 0px 0px 4px 0px #ddd;
  border-right: 2px solid #ececec;
  border-left: 2px solid #ececec;
}

.current_issue .page-header h2 {
  font-size: 24px !important;
  font-weight: 600;
  color: #222;
  position: relative;
  padding-bottom: 10px;
}

.current_issue .page-header h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: linear-gradient(90deg, #c08511 0%, #840b0f 50%);
}

.current_issue .page-header h2:hover::after {
  width: 100%;
}

/* PDF Galley Button */
.galley-link.btn.btn-primary.pdf,
.galley-link.btn.btn-primary.file {
  background-color: #d31517 !important;
  border-radius: 4px;
  color: #fff !important;
  border: none !important;
  position: relative;
  overflow: hidden;
}

.galley-link.btn.btn-primary.pdf:hover,
.galley-link.btn.btn-primary.file:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(211, 21, 23, 0.3);
}

/* Read More Button */
.btn.btn-primary.read-more {
  background-color: #032a64 !important;
  border-radius: 12px;
  float: right;
  font-weight: 600;
  color: white !important;
}

.btn.btn-primary.read-more:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 10px 25px rgba(3, 42, 100, 0.4);
}

/* Article Links */
.media-list a {
  font-weight: 600 !important;
  color: #000;
  position: relative;
  display: inline-block;
}

.media-list a::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #1b75ee 0%, #032a64 100%);
}

.media-list a:hover::after {
  width: 100%;
}

/* =========================================
   6. ARTICLE TEMPLATE & TOOLS SECTION
========================================= */
.article-template-box,
.template-download-box {
  border: 2px dashed #c08511;
  border-radius: 12px;
  padding: 20px;
  background: linear-gradient(135deg, #fafafa 0%, #ffffff 100%);
  position: relative;
}

.article-template-box:hover {
  border-color: #840b0f;
  transform: scale(1.02);
  box-shadow: 0 0 20px rgba(192, 133, 17, 0.3);
}

.template-download-btn {
  padding: 12px 32px !important;
  font-weight: 600 !important;
  border-radius: 25px !important;
  background: linear-gradient(90deg, #840b0f 0%, #c08511 100%) !important;
  color: #fff !important;
  text-transform: uppercase;
}

.template-download-btn:hover {
  transform: translateY(-4px) scale(1.05) !important;
  box-shadow: 0 12px 28px rgba(132, 11, 15, 0.35) !important;
}

/* =========================================
   7. FOOTER
========================================= */
footer[role='contentinfo'] {
  background: #e6e6e6;
  padding: 40px 0 0 0;
  margin-top: 4em;
}

.footer__content {
  display: grid;
  gap: 20px;
}

.footer-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 30px;
  width: 100%;
}

.footer-copy a {
  color: #fff;
  position: relative;
}

.footer-copy a::before {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #accf5f 0%, #c08511 100%);
}

.footer-copy a:hover::before {
  width: 100%;
}

/* =========================================
   8. RESPONSIVE MEDIA QUERIES
========================================= */
/* Mobile Devices */
@media (max-width: 767px) {
  .container-fluid {
    background-color: #3b0002 !important;
  }
  .navbar-default .nav > li > a {
    color: #fff !important;
  }
  .page-header {
    font-size: 28px;
  }
  .breadcrumb {
    display: none;
  }
  .footer__content {
    grid-template-columns: 1fr;
  }
}

/* Tablet Devices */
@media (min-width: 768px) {
  .container, footer, .navbar {
    width: 100% !important;
  }
  .footer__content {
    grid-template-columns: repeat(2, 1fr);
  }
  .pkp_block.block_custom {
    width: 100%;
  }
}

/* Desktop Devices */
@media (min-width: 1024px) {
  .container, footer, .navbar {
    width: 85% !important;
  }
  .col-md-8 { width: 69% !important; padding: 0px 30px; }
  .col-md-4 { width: 31% !important; }
  
  .navbar-form.navbar-left .btn.btn-default {
    position: absolute !important;
    right: 35px;
    border-radius: 0px 0px 20px 0px !important;
    color: #fff !important;
    background: linear-gradient(90deg, #c08511 0%, #840b0f 50%);
    height: 43px !important;
  }
  .navbar-form.navbar-left .form-group .form-control {
    width: 300px !important;
  }
}

@media (min-width: 1640px) {
  .container, footer, .navbar { width: 70% !important; }
}
/* =========================================
   EFEK SLIDE KE SAMPING (MARQUEE) KOLABORASI
========================================= */
.collab-wrapper {
  overflow: hidden;
  width: 100%;
  position: relative;
  background: #ffffff; 
  padding: 20px 0;
  border-radius: 8px;
}

.collab-track {
  display: flex;
  align-items: center;
  gap: 30px; /* Jarak antar logo */
  width: max-content;
  /* Durasi 12 detik, ubah angkanya jika ingin lebih cepat/lambat */
  animation: slideCollab 12s linear infinite; 
}

/* Efek opsional: Slide akan berhenti saat kursor diarahkan ke logo */
.collab-track:hover {
  animation-play-state: paused;
}

.collab-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 130px; /* Lebar area per logo */
}

.collab-item img {
  width: 90px;
  height: auto;
  margin-bottom: 12px;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.05));
}

/* Efek membesar sedikit saat logo disorot */
.collab-item:hover img {
  transform: scale(1.1) translateY(-3px);
  filter: drop-shadow(0 6px 12px rgba(0,0,0,0.15));
}

.collab-item span {
  font-family: 'Nunito Sans', sans-serif;
  font-size: 13px;
  text-align: center;
  font-weight: 600;
  color: #243140; /* Mengikuti warna teks judul di CSS lamamu */
}

/* Animasi Pergerakan */
@keyframes slideCollab {
  0% { 
    transform: translateX(0); 
  }
  100% { 
    /* Bergeser sejauh -50% dari total lebar track agar looping mulus */
    transform: translateX(-50%); 
  } 
}