/* ============================================================
   SILLIMAN JOURNAL (OJS 3.3) — FULL CUSTOM CSS
   Theme: Silliman Red & White
============================================================ */

/* ---------------------------
   COLOR SYSTEM
---------------------------- */

:root{
  --sj-red: #8B0000;
  --sj-red-2: #B22222;
  --sj-red-light: #B22222;
  --sj-white: #ffffff;
  --sj-offwhite: #fdfdfd;
  --sj-gray-1: #f5f5f5;
  --sj-gray-2: #e6e6e6;
  --sj-text: #1f1f1f;
  --sj-muted: #555;
  --sj-shadow: 0 6px 18px rgba(0,0,0,.08);
  --sj-radius: 12px;
}

/* ---------------------------
   GLOBAL
---------------------------- */

html, body{
  background: var(--sj-offwhite);
  color: var(--sj-text);
  scroll-padding-top: 110px;
}

body{
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.65;
}

a{
  color: var(--sj-red);
}

a:hover{
  color: var(--sj-red-2);
}

:focus-visible{
  outline: 3px solid rgba(139,0,0,.35);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ---------------------------
   HEADER
---------------------------- */

.pkp_structure_head{
  background: var(--sj-red);
  color: var(--sj-white);
}

.pkp_site_name,
.pkp_site_name a{
  color: var(--sj-white) !important;
  text-decoration: none !important;
}

/* ---------------------------
   STICKY NAVIGATION
---------------------------- */

.pkp_navigation_primary_wrapper{
  background: var(--sj-white);
  border-bottom: 4px solid var(--sj-red);
  box-shadow: var(--sj-shadow);

  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

.pkp_navigation_primary > li > a{
  color: var(--sj-red) !important;
  font-weight: 700;
  padding: 12px 14px;
  border-radius: 10px;
  transition: all .2s ease;
}

.pkp_navigation_primary > li > a:hover{
  background: var(--sj-red);
  color: var(--sj-white) !important;
}

/* ---------------------------
   SEARCH BUTTON FIX
---------------------------- */

.pkp_navigation_search_wrapper a,
.pkp_navigation_search_wrapper button,
.pkp_navigation_search_wrapper .pkp_search_search{
  background: var(--sj-red) !important;
  color: var(--sj-white) !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.pkp_navigation_search_wrapper a:hover,
.pkp_navigation_search_wrapper button:hover{
  background: var(--sj-red-2) !important;
}

.pkp_navigation_search_wrapper svg{
  fill: var(--sj-white) !important;
}

/* ---------------------------
   CONTENT CARDS
---------------------------- */

.pkp_page_index .cmp_announcements,
.pkp_page_index .cmp_issue_toc,
.pkp_page_index .current_issue,
.pkp_page_article .main_entry,
.pkp_page_issue .issue{
  background: var(--sj-white);
  border: 1px solid var(--sj-gray-2);
  border-radius: var(--sj-radius);
  box-shadow: var(--sj-shadow);
  padding: 18px;
}

h1,h2,h3,h4,h5{
  color: var(--sj-red);
}

.pkp_page_title::after{
  content:"";
  display:block;
  height:3px;
  width:84px;
  background:var(--sj-red);
  margin-top:10px;
  border-radius:999px;
}

/* ---------------------------
   ARTICLE CARDS
---------------------------- */

.obj_article_summary{
  border:1px solid var(--sj-gray-2);
  border-left:6px solid var(--sj-red);
  border-radius:var(--sj-radius);
  background:var(--sj-white);
  box-shadow:var(--sj-shadow);
  padding:14px 16px;
  margin-bottom:14px;
}

.obj_article_summary .title a{
  color:var(--sj-red) !important;
}

.obj_article_summary .meta{
  color:var(--sj-muted);
}

/* ---------------------------
   BUTTONS
---------------------------- */

.cmp_button,
.cmp_form button,
input[type="submit"],
input[type="button"]{
  background:var(--sj-red) !important;
  color:var(--sj-white) !important;

  border:none !important;
  border-radius:999px !important;
  padding:10px 18px !important;

  font-weight:700 !important;
  letter-spacing:.2px;

  box-shadow:0 10px 20px rgba(0,0,0,.12);
  transition:all .2s ease !important;
}

.cmp_button:hover,
.cmp_form button:hover{
  background:var(--sj-red-light) !important;
  transform:translateY(-1px);
}

.cmp_button_wire{
  background:transparent !important;
  color:var(--sj-red) !important;

  border:2px solid var(--sj-red) !important;
  border-radius:999px !important;
}

.cmp_button_wire:hover{
  background:rgba(139,0,0,.1);
}

/* ---------------------------
   PDF BUTTONS
---------------------------- */

.cmp_galley_link{
  display:inline-flex;
  align-items:center;
  gap:8px;

  padding:8px 14px !important;
  border-radius:999px !important;

  border:2px solid var(--sj-red) !important;
  color:var(--sj-red) !important;
  background:rgba(139,0,0,.08) !important;

  font-weight:800 !important;
}

.cmp_galley_link:hover{
  background:var(--sj-red) !important;
  color:var(--sj-white) !important;
}

/* ---------------------------
   SIDEBAR
---------------------------- */

.pkp_block{
  background:var(--sj-gray-1);
  border:1px solid var(--sj-gray-2);
  border-left:6px solid var(--sj-red);
  border-radius:var(--sj-radius);
  box-shadow:var(--sj-shadow);
  padding:14px;
}

.pkp_block .title{
  color:var(--sj-red);
  font-weight:800;
}

/* ---------------------------
   TABLES
---------------------------- */

table{
  width:100%;
  border-collapse:collapse;
  background:var(--sj-white);
}

th{
  background:var(--sj-red);
  color:var(--sj-white);
  padding:10px;
}

td{
  padding:10px;
  border:1px solid var(--sj-gray-2);
}

/* ---------------------------
   FOOTER
---------------------------- */

.pkp_structure_footer{
  background:var(--sj-red) !important;
  color:var(--sj-white) !important;

  position:relative;
  left:50%;
  margin-left:-50vw;
  width:100vw;

  padding:30px 0;
}

.pkp_structure_footer .pkp_footer_content{
  max-width:1140px;
  margin:0 auto;
  padding:0 20px;

  display:flex;
  align-items:center;
  gap:18px;
}

.pkp_structure_footer img{
  max-height:70px;
}

.pkp_structure_footer a{
  color:var(--sj-white) !important;
}

.pkp_structure_footer .pkp_brand_footer{
  display:none !important;
}

/* ---------------------------
   HOMEPAGE IMAGE FIX
---------------------------- */

.pkp_page_index .homepage_image,
.pkp_page_index .cmp_homepage_image{
  overflow:hidden;
  border-radius:12px;
}

.pkp_page_index img{
  max-width:100%;
  display:block;
}

/* ---------------------------
   SCROLL ANIMATION
---------------------------- */

.sj-reveal-init{
  opacity:0;
  transform:translateY(18px);
}

.sj-reveal{
  opacity:1;
  transform:translateY(0);
  transition:opacity .7s ease, transform .7s ease;
}

@media (prefers-reduced-motion: reduce){
  .sj-reveal-init,
  .sj-reveal{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}

/* ---------------------------
   RESPONSIVE
---------------------------- */

@media (max-width:768px){

  .pkp_navigation_primary > li > a{
    display:block;
    margin:6px 0;
  }

  .pkp_structure_footer .pkp_footer_content{
    flex-direction:column;
    align-items:flex-start;
  }

}
/* ==========================================================
   FORCE CURRENT ISSUE TO ALIGN WITH ANNOUNCEMENTS
========================================================== */

/* Make both homepage blocks start at exactly the same position */
.pkp_page_index .cmp_announcements,
.pkp_page_index .current_issue {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Remove extra indent from Current Issue wrappers */
.pkp_page_index .current_issue,
.pkp_page_index .current_issue .current_issue_title,
.pkp_page_index .current_issue .issue_toc,
.pkp_page_index .current_issue .obj_issue_summary,
.pkp_page_index .current_issue .sections,
.pkp_page_index .current_issue .section,
.pkp_page_index .current_issue .description {
  margin-left: 0 !important;
  left: 0 !important;
}

/* Normalize homepage main column */
.pkp_page_index .pkp_structure_main {
  padding-left: 0 !important;
  padding-right: 0 !important;
}



/* PDF / galley buttons */
a.cmp_galley_link,
.cmp_galley_link {
  background: rgba(139,0,0,.08) !important;
  color: #8B0000 !important;
  border: 2px solid #8B0000 !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  display: inline-block !important;
}

a.cmp_galley_link:hover,
.cmp_galley_link:hover {
  background: #8B0000 !important;
  color: #ffffff !important;
}
/* Make a Submission button specifically */
.pkp_block.block_make_submission a {
  background: #8B0000 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 10px 18px !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  display: inline-block !important;
}

/* ==========================================================
   FIX: HOMEPAGE BANNER NOT CUT / OVERLAPPING SIDEBAR (OJS 3.3)
========================================================== */

/* 1) Make the MAIN column clip anything that overflows */
.pkp_page_index .pkp_structure_main {
  overflow: hidden !important;
}

/* 2) Clip the common homepage-image wrappers (covers most OJS 3.3 themes) */
.pkp_page_index .homepage_image,
.pkp_page_index .cmp_homepage_image,
.pkp_page_index .pkp_structure_main .homepage_image,
.pkp_page_index .pkp_structure_main .cmp_homepage_image,
.pkp_page_index .pkp_structure_main .pkp_page_content {
  overflow: hidden !important;
  border-radius: 12px !important;
}

/* 3) Force the banner image to stay within its container */
.pkp_page_index .homepage_image img,
.pkp_page_index .cmp_homepage_image img,
.pkp_page_index .pkp_structure_main .pkp_page_content img {
  display: block !important;
  max-width: 100% !important;
  width: 100% !important;
  height: auto !important;

  /* Prevent any theme offsets that push the image into the sidebar */
  margin: 0 !important;
}
/* Hard stop for theme offsets on the homepage banner */
.pkp_page_index .pkp_structure_main .pkp_page_content img {
  position: relative !important;
  left: 0 !important;
  right: 0 !important;
}
/* ==========================================================
   FORCE STYLE PDF BUTTON (OJS 3.3)
========================================================== */

.obj_galley_link,
.obj_galley_link.pdf,
a.obj_galley_link,
a.obj_galley_link.pdf,
a.file,
a.file.pdf {

  background: #8B0000 !important;
  color: #ffffff !important;

  border: none !important;
  border-radius: 999px !important;

  padding: 6px 14px !important;
  font-size: 13px !important;
  font-weight: 700 !important;

  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;

  box-shadow: 0 6px 14px rgba(0,0,0,.15) !important;
  transition: all .2s ease !important;
}

/* Hover effect */
.obj_galley_link:hover,
a.file:hover {
  background: #B22222 !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}