@import url("https://cdn.jsdelivr.net/npm/@xz/fonts@1/serve/plus-jakarta-display.min.css");

/* ==========================================================
   GLOBAL: Header, Nav, Footer — applies to ALL pages
   ========================================================== */

/* --- Header: White background --- */
header.pkp_structure_head,
.pkp_structure_head,
.pkp_structure_page .pkp_structure_head {
    background: #ffffff !important;
    background-color: #ffffff !important;
    border-bottom: none !important;
}

.pkp_head_wrapper,
.has_site_logo .pkp_head_wrapper {
    background: #ffffff !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
}

.pkp_site_name_wrapper {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    flex-direction: row !important;
    width: 100% !important;
    max-width: 100% !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    padding: 15px 30px !important;
}

/* --- Logo: left side, small --- */
.pkp_site_name {
    display: flex !important;
    align-items: center !important;
    flex-direction: row !important;
    order: -1 !important;
    flex-shrink: 0 !important;
    margin-right: 20px !important;
    gap: 20px;
    width: auto !important;
}

.pkp_site_name a.is_img {
    display: flex !important;
    align-items: center !important;
    flex-direction: row !important;
    gap: 20px;
    text-decoration: none !important;
}

.pkp_site_name a.is_img img {
    max-height: 80px !important;
    width: auto !important;
    height: auto !important;
    flex-shrink: 0;
}

/* --- Title: visible next to logo on ALL pages --- */
.pkp_site_title_text,
.pkp_site_name_wrapper > .pkp_site_title_text {
    position: static !important;
    clip: auto !important;
    clip-path: none !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 1.5em !important;
    font-weight: 700 !important;
    color: #333 !important;
    font-family: 'Plus Jakarta Display', 'Noto Sans', sans-serif !important;
    white-space: normal !important;
    line-height: 1.3 !important;
    order: 0 !important;
    flex: 1 !important;
}

/* --- Subtitle below title --- */
.pkp_site_title_text::after {
    content: "Indonesian Orthopaedic Association for Upper Limb and Reconstructive Microsurgery";
    display: block !important;
    font-size: 0.55em !important;
    font-weight: 400 !important;
    color: #555 !important;
    margin-top: 4px !important;
    line-height: 1.4 !important;
}

/* --- Hamburger toggle --- */
.pkp_site_nav_toggle {
    order: -2;
}

/* --- Login button --- */
.pkp_navigation_user {
    position: absolute;
    top: 15px;
    right: 30px;
}

.pkp_navigation_user a {
    color: #333 !important;
    border: 1px solid #ccc;
    padding: 5px 15px;
    border-radius: 3px;
}

/* --- Navigation: Purple bar, full width --- */
.pkp_navigation_primary_row,
.pkp_structure_head .pkp_navigation_primary_row {
    background-color: #7C4196 !important;
    background: #7C4196 !important;
    padding: 0 !important;
}

.pkp_navigation_primary_wrapper {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    background: transparent !important;
}

.pkp_navigation_primary_wrapper > ul,
#navigationPrimary {
    padding-left: 30px !important;
    padding-right: 30px !important;
}

.pkp_navigation_primary a,
.pkp_navigation_primary > li > a {
    color: #ffffff !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    font-size: 0.85em !important;
    letter-spacing: 0.5px;
}

.pkp_navigation_primary a:hover,
.pkp_navigation_primary a:focus {
    color: #f0d0ff !important;
}

.pkp_navigation_primary ul ul {
    background: #7C4196 !important;
}

.pkp_navigation_primary ul ul a {
    color: #ffffff !important;
}

.pkp_navigation_user_wrapper {
    left: unset !important;
    right: 30px !important;
}


/* Mobile nav */
.pkp_site_nav_menu {
    background: #7C4196 !important;
}

/* Search in nav */
.pkp_search_desktop,
.pkp_navigation_primary_row .pkp_search_desktop {
    color: #ffffff !important;
}

.pkp_search_desktop a,
.pkp_search_desktop button {
    color: #ffffff !important;
}

/* --- Body / Fonts --- */
body, .pkp_structure_page {
    font-family: 'Plus Jakarta Display', 'Noto Sans', sans-serif !important;
}

/* --- Page structure: full width --- */
.pkp_structure_page {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.pkp_structure_content {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.pkp_structure_main {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 30px !important;
}

/* --- Footer: full width, consistent on all pages --- */
.pkp_structure_footer_wrapper {
    background-color: #ffffff !important;
    border-bottom: 0 !important;
    border-top: none !important;
    padding: 0 !important;
}

/* --- PERAMOI Custom Footer: Logo + Contact --- */
.peramoi_footer_main {
    background: #ffffff;
    border-top: 1px solid #ddd;
    padding: 20px 30px;
}

.peramoi_footer_inner {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-width: 1400px;
    margin: 0 auto;
    gap: 40px;
}

.peramoi_footer_contact {
    flex: 0.5;
    text-align: left;
}
.peramoi_footer_logo { flex: 0.5; }
.peramoi_footer_logo img {
    max-height: 110px;
    width: auto;
}

.peramoi_footer_contact h3 {
    font-size: 1.05em;
    font-weight: 700;
    margin: 0 0 8px 0;
    color: #222;
}

.peramoi_footer_contact p {
    margin: 4px 0;
    color: #444;
    font-size: 0.9em;
    line-height: 1.5;
}

.peramoi_footer_contact a {
    color: #444;
    text-decoration: none;
}

/* --- PERAMOI Footer Copyright Bar --- */
.peramoi_footer_copyright {
    background: #7C4196;
    text-align: center;
    padding: 10px 30px;
}

.peramoi_footer_copyright p {
    margin: 0;
    font-size: 0.85em;
    color: #ffffff;
}

/* Mobile footer */
@media (max-width: 640px) {
    .peramoi_footer_inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }
}

/* --- Links & Accent --- */
a {
    color: #7C4196;
}

a:hover {
    color: #5a2d6e;
}

.obj_article_details .entry_details .sub_item:not(:first-child) .label {
    border-bottom-color: #F7BC4A !important;
}


/* ==========================================================
   LOGIN PAGE: Custom two-column layout
   ========================================================== */

/* Hide standard header/nav/footer on login page */
.pkp_page_login .pkp_structure_head,
.pkp_page_login .peramoi_footer_main,
.pkp_page_login .peramoi_footer_copyright {
    display: none !important;
}

.pkp_page_login .pkp_structure_footer_wrapper {
    display: none !important;
}

.pkp_page_login .pkp_structure_content,
.pkp_page_login .pkp_structure_main {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Two-column wrapper */
.peramoi_login_page {
    display: flex;
    min-height: 100vh;
    align-items: stretch;
}

/* Left: side image */
.peramoi_login_side {
    flex-shrink: 0;
    width: 500px;
    overflow: hidden;
}

.peramoi_login_side img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Right: banner + form */
.peramoi_login_main {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-left: 50px;
}

.peramoi_login_banner {
    width: 100%;
}

.peramoi_login_banner img {
    display: block;
    width: 100%;
    max-width: 300px;
    height: auto;
}

.peramoi_login_form {
    padding: 30px 40px;
    width: 100%;
    max-width: 560px;
}

.peramoi_login_form h1 {
    font-size: 1.5em;
    font-weight: 700;
    margin-bottom: 8px;
    color: #222;
}

.peramoi_login_form hr {
    border: none;
    border-top: 1px solid #ddd;
    margin-bottom: 20px;
}

/* --- Form fields --- */
.peramoi_login_form .fields {
    border: none;
    padding: 0;
    margin: 0;
}

.pkp_page_login .cmp_form .fields > div {
    padding-bottom: 0 !important;
}

.peramoi_login_subtitle {
    font-size: 0.88em;
    color: #888;
    margin: 2px 0 10px 0;
}

.peramoi_login_form .username,
.peramoi_login_form .password {
    margin-bottom: 14px;
}

.peramoi_login_form label {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.peramoi_login_form .label {
    font-size: 0.9em;
    font-weight: 700;
    color: #222;
}

.peramoi_login_form .required {
    color: #c0392b;
    margin-left: 2px;
}

.peramoi_login_form input[type="text"],
.peramoi_login_form input[type="password"] {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: 0.95em;
    color: #333;
    background: #fff;
    box-sizing: border-box;
    transition: border-color 0.2s, box-shadow 0.2s;
    outline: none;
}

.peramoi_login_form input[type="text"]::placeholder,
.peramoi_login_form input[type="password"]::placeholder {
    color: #bbb;
    font-size: 0.95em;
}

.peramoi_login_form input[type="text"]:focus,
.peramoi_login_form input[type="password"]:focus {
    border-color: #7C4196;
    box-shadow: 0 0 0 3px rgba(124, 65, 150, 0.12);
}

/* Remember + Forgot password — same row */
.peramoi_remember_row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 4px 0 16px 0;
}

.remember_label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 8px;
    font-size: 0.9em;
    font-weight: 600;
    color: #222;
    cursor: pointer;
}

.remember_label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: #7C4196;
    cursor: pointer;
    flex-shrink: 0;
}

.forgot_link {
    font-size: 0.88em;
    color: #7C4196 !important;
    text-decoration: none;
}

.forgot_link:hover {
    text-decoration: underline;
}

/* Login button — full width */
.peramoi_login_form .buttons {
    margin-top: 4px;
}

.peramoi_login_form button.submit {
    display: block;
    width: 100%;
    padding: 13px;
    background-color: #7C4196;
    color: #ffffff;
    border: none;
    border-radius: 6px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s;
    text-align: center;
}

.peramoi_login_form button.submit:hover {
    background-color: #5a2d6e;
}

.peramoi_login_form a.register {
    display: block;
    margin-top: 12px;
    font-size: 0.88em;
    color: #7C4196;
    text-decoration: none;
    text-align: center;
}

.peramoi_login_form a.register:hover {
    text-decoration: underline;
}

/* Error message */
.peramoi_login_form .pkp_form_error {
    background: #fdecea;
    border: 1px solid #f5c6c2;
    color: #c0392b;
    padding: 10px 14px;
    border-radius: 6px;
    font-size: 0.88em;
    margin-bottom: 16px;
}

/* Mobile */
@media (max-width: 768px) {
    .peramoi_login_side {
        display: none;
    }
    .peramoi_login_form {
        padding: 20px;
    }
}

/* ==========================================================
   HOMEPAGE ONLY: Hide default sections, show additionalHomeContent
   ========================================================== */

/* Hide About the Journal on homepage */
.pkp_page_index .page_index_journal > #homepageAbout,
.pkp_page_index #homepageAbout,
.pkp_page_index #homepageAbout + .description,
.pkp_page_index .page_index_journal > h2:first-of-type,
.pkp_page_index .page_index_journal > .description {
    display: none !important;
}

/* Hide Announcements on homepage */
.pkp_page_index .cmp_announcements,
.pkp_page_index #homepageAnnouncements {
    display: none !important;
}

/* Hide Current Issue on homepage */
.pkp_page_index .current_issue,
.pkp_page_index section.current_issue {
    display: none !important;
}

/* Hide article listings on homepage */
.pkp_page_index .obj_article_summary,
.pkp_page_index .cmp_article_list,
.pkp_page_index .obj_issue_toc {
    display: none !important;
}

/* Additional home content */
.additional_content {
    padding: 0 !important;
    width: 100% !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
}

.page_index_journal {
    width: 100% !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 20px 30px !important;
}
.page_login .login {
    max-width: none !important;
}
.username > label > input { 
    width: 100% !important; 
    max-width: none !important;
    padding: 20px 14px !important;
    font-size: 1.3em !important;
}
.password > label > input { width: 100% !important; max-width: none !important; padding: 20px 14px !important; font-size: 1.3em !important;}
