/*
Pollution & Diseases Repository — Final Clean OJS CSS
Version: 6.0
Upload in: Settings → Website → Appearance → Journal style sheet

This is a clean version without stacked/duplicated fixes.
Main goals:
- matte deep-green academic design
- stable desktop menu alignment
- good mobile layout
- flower/tree logo in header and footer
*/

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:wght@400;700&family=Source+Sans+3:wght@400;600;700&display=swap');

:root {
    --repo-green-950: #052f26;
    --repo-green-900: #073b30;
    --repo-green-850: #084434;
    --repo-green-800: #0b4a39;
    --repo-green-700: #0f5b45;
    --repo-green-600: #176f54;

    --repo-bg: #f7faf8;
    --repo-bg-soft: #eef5f1;
    --repo-card: #ffffff;
    --repo-border: #d9e5df;
    --repo-border-dark: #bfd4ca;

    --repo-text: #1d2723;
    --repo-muted: #5f6d66;
    --repo-light-text: #f7fbf9;

    --repo-radius: 14px;
    --repo-shadow: 0 16px 38px rgba(5, 47, 38, 0.10);
    --repo-shadow-soft: 0 8px 22px rgba(5, 47, 38, 0.07);

    --repo-title-font: "Libre Baskerville", Georgia, "Times New Roman", serif;
    --repo-ui-font: "Source Sans 3", Arial, Helvetica, sans-serif;

    --repo-logo-svg: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 220'%3E%3Ccircle cx='110' cy='110' r='94' fill='none' stroke='white' stroke-width='5' opacity='0.9'/%3E%3Cpath d='M110 160 C110 135 110 108 110 78' stroke='white' stroke-width='6' stroke-linecap='round' fill='none'/%3E%3Cpath d='M110 83 C95 66 92 47 106 31 C114 44 118 60 110 83Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M110 83 C125 66 128 47 114 31 C106 44 102 60 110 83Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M108 96 C82 92 64 75 65 51 C87 58 102 72 108 96Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M112 96 C138 92 156 75 155 51 C133 58 118 72 112 96Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M109 116 C78 113 55 98 48 73 C75 75 98 90 109 116Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M111 116 C142 113 165 98 172 73 C145 75 122 90 111 116Z' fill='none' stroke='white' stroke-width='5' stroke-linejoin='round'/%3E%3Cpath d='M110 158 C96 171 82 181 61 188' stroke='white' stroke-width='4' stroke-linecap='round' fill='none'/%3E%3Cpath d='M110 158 C124 171 138 181 159 188' stroke='white' stroke-width='4' stroke-linecap='round' fill='none'/%3E%3Cpath d='M110 158 C110 174 110 184 110 194' stroke='white' stroke-width='4' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
}

/* =========================
   BASE
========================= */

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background: var(--repo-bg);
    color: var(--repo-text);
    font-family: var(--repo-title-font);
    font-size: 16px;
    line-height: 1.68;
}

a {
    color: var(--repo-green-800);
    text-decoration: none;
    transition: 0.18s ease;
}

a:hover,
a:focus {
    color: var(--repo-green-600);
    text-decoration: none;
}

h1, h2, h3, h4, h5 {
    font-family: var(--repo-title-font);
    color: var(--repo-green-900);
    font-weight: 700;
    line-height: 1.22;
}

h1 {
    font-size: clamp(2.05rem, 3.5vw, 3rem);
    letter-spacing: -0.035em;
    margin: 0 0 1.45rem;
}

p {
    margin-top: 0;
}

/* =========================
   PAGE
========================= */

.pkp_structure_page {
    background:
        radial-gradient(circle at 15% 10%, rgba(7, 59, 48, 0.06), transparent 22rem),
        linear-gradient(180deg, #ffffff 0%, var(--repo-bg) 48%, #f2f7f4 100%);
}

.pkp_structure_content {
    max-width: 1380px;
    margin-left: auto;
    margin-right: auto;
    padding: 2rem 2rem 2.4rem;
    box-sizing: border-box;
}

.pkp_structure_main {
    background: var(--repo-card);
    border: 1px solid var(--repo-border);
    border-radius: var(--repo-radius);
    box-shadow: var(--repo-shadow-soft);
    padding: clamp(1.5rem, 3vw, 2.2rem);
    min-height: 420px;
}

.pkp_structure_sidebar {
    font-family: var(--repo-ui-font);
}

/* =========================
   HEADER
========================= */

.pkp_structure_head,
.pkp_head_wrapper,
.pkp_site_name_wrapper,
.pkp_site_name,
.pkp_navigation_primary_row,
.pkp_navigation_user_wrapper {
    background: var(--repo-green-900) !important;
    background-image: none !important;
}

.pkp_site_name_wrapper {
    border: 0 !important;
}

.pkp_site_name {
    position: relative !important;
    max-width: 1380px;
    margin: 0 auto !important;
    padding: 1.55rem 2rem 1.35rem 128px !important;
    min-height: 118px !important;
    display: flex !important;
    align-items: center !important;
    box-sizing: border-box !important;
}

.pkp_site_name::before {
    content: "";
    position: absolute;
    left: 34px;
    top: 50%;
    transform: translateY(-50%);
    width: 72px;
    height: 72px;
    opacity: 0.96;
    background-image: var(--repo-logo-svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

.pkp_site_name a,
.pkp_site_name .is_text,
.pkp_site_name_wrapper a {
    display: inline-block;
    color: var(--repo-light-text) !important;
    font-family: var(--repo-title-font) !important;
    font-weight: 700 !important;
    font-size: clamp(1.55rem, 2.55vw, 2.22rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.015em;
    text-shadow: 0 2px 7px rgba(0, 0, 0, 0.22);
}

.pkp_site_name a:hover {
    color: #ffffff !important;
    text-decoration: none !important;
}

/* =========================
   TOP USER BAR
========================= */

.pkp_navigation_user_wrapper {
    border: 0 !important;
    font-family: var(--repo-ui-font);
}

.pkp_navigation_user {
    max-width: 1380px;
    margin: 0 auto !important;
    padding: 0 2rem !important;
    min-height: 34px;
    line-height: 34px;
}

.pkp_navigation_user a,
.pkp_navigation_user > li > a {
    color: rgba(255,255,255,0.94) !important;
    font-weight: 600;
}

/* =========================
   DESKTOP NAVIGATION — CLEAN FIX
========================= */

.pkp_navigation_primary_row {
    display: block !important;
    width: 100% !important;
    min-height: 58px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-top: 1px solid rgba(255,255,255,0.12);
    border-bottom: 1px solid rgba(255,255,255,0.16);
    overflow: visible !important;
    clear: both !important;
}

.pkp_navigation_primary_wrapper {
    max-width: 1380px !important;
    margin: 0 auto !important;
    padding: 0 2rem !important;
    min-height: 58px !important;
    box-sizing: border-box !important;

    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1.5rem !important;

    position: relative !important;
    top: auto !important;
    transform: none !important;
    overflow: visible !important;
}

.pkp_navigation_primary {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0.15rem !important;

    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;

    float: none !important;
    clear: none !important;
    width: auto !important;
    max-width: calc(100% - 170px) !important;

    position: static !important;
    top: auto !important;
    transform: none !important;
}

.pkp_navigation_primary > li {
    display: block !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
}

.pkp_navigation_primary > li > a,
.pkp_navigation_primary > li > span {
    display: flex !important;
    align-items: center !important;
    min-height: 58px !important;
    padding: 0 1.05rem !important;
    margin: 0 !important;

    color: #ffffff !important;
    font-family: var(--repo-title-font) !important;
    font-size: 1.02rem !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
    border-radius: 8px;
    text-shadow: 0 1px 4px rgba(0,0,0,0.18);
}

.pkp_navigation_primary > li > a:hover,
.pkp_navigation_primary > li > a:focus,
.pkp_navigation_primary > li:hover > a {
    background: rgba(255,255,255,0.10) !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

/* Dropdowns */
.pkp_navigation_primary ul {
    background: #ffffff !important;
    border: 1px solid var(--repo-border);
    border-radius: 12px;
    padding: 0.45rem;
    box-shadow: var(--repo-shadow);
    z-index: 9999 !important;
}

.pkp_navigation_primary ul a {
    color: var(--repo-green-900) !important;
    font-family: var(--repo-ui-font) !important;
    font-weight: 700;
    border-radius: 8px;
    padding: 0.65rem 0.85rem !important;
}

.pkp_navigation_primary ul a:hover {
    background: var(--repo-bg-soft) !important;
}

/* Search link stays on the same line */
.pkp_navigation_search_wrapper {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    top: auto !important;
    right: auto !important;
    transform: none !important;
    min-height: 58px !important;
}

.pkp_navigation_search_wrapper a {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    min-height: 58px !important;
    color: #ffffff !important;
    font-family: var(--repo-title-font) !important;
    font-weight: 700 !important;
    font-size: 1.02rem !important;
    line-height: 1 !important;
    padding: 0 !important;
    white-space: nowrap !important;
}

.pkp_navigation_search_wrapper a:hover {
    color: #ffffff !important;
}

/* =========================
   BREADCRUMBS
========================= */

.cmp_breadcrumbs,
.breadcrumbs {
    font-family: var(--repo-ui-font);
    font-size: 0.98rem;
    color: var(--repo-muted);
    margin: 0 0 2.4rem;
}

.cmp_breadcrumbs a,
.breadcrumbs a {
    color: var(--repo-green-700);
    font-weight: 600;
}

/* =========================
   CATEGORY / ISSUE PAGES
========================= */

.page_catalog_category h1,
.page_catalog h1,
.page_issue h1,
.obj_issue_toc h1 {
    color: var(--repo-green-900);
    position: relative;
    padding-right: 210px;
}

.page_catalog_category h1::after,
.page_catalog h1::after,
.page_issue h1::after,
.obj_issue_toc h1::after {
    content: "";
    display: block;
    width: 70px;
    height: 3px;
    background: var(--repo-green-700);
    margin-top: 1rem;
}

.page_catalog_category .category_description,
.page_catalog_category .description,
.obj_issue_toc .description,
.obj_issue_toc .issue_description {
    display: block;
    max-width: 78%;
    margin: 0 0 1.8rem !important;
    padding-right: 0 !important;
    color: #4e5652;
    font-family: var(--repo-title-font);
    font-size: 1.07rem;
    font-style: italic;
    line-height: 1.75;
}

.page_catalog_category .category_description::after,
.page_catalog_category .description::after,
.obj_issue_toc .description::after,
.obj_issue_toc .issue_description::after {
    content: "";
    display: block;
    height: 1px;
    background: var(--repo-border);
    margin-top: 1.8rem;
}

/* Item count badge */
.page_catalog_category .count,
.page_catalog_category .num_items,
.page_catalog_category .items {
    float: right;
    clear: right;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-width: 120px;
    min-height: 52px;
    margin: -1.5rem 0 1rem 2rem !important;
    padding: 0.7rem 1.2rem !important;
    background: #f0f6f3;
    border: 1px solid var(--repo-border-dark);
    border-radius: 12px;
    color: var(--repo-green-900) !important;
    font-family: var(--repo-ui-font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    text-align: center;
    box-shadow: 0 4px 12px rgba(5, 47, 38, 0.05);
}

.page_catalog_category .category_description + span,
.page_catalog_category .description + span {
    color: var(--repo-green-900);
    font-family: var(--repo-ui-font);
    font-weight: 700;
}

/* Empty / no results message */
.page_catalog_category .empty,
.page_catalog_category .no_results,
.page_catalog_category .category_description ~ p:last-child,
.page_catalog_category .description ~ p:last-child,
.obj_issue_toc .empty,
.page_search .cmp_notification,
.page_search .no_results {
    clear: both;
    background: linear-gradient(90deg, #f4faf7, #ffffff);
    border: 1px solid var(--repo-border);
    border-left: 5px solid var(--repo-green-700);
    border-radius: 10px;
    color: #303b36;
    font-family: var(--repo-title-font);
    font-size: 1rem;
    padding: 1rem 1.15rem;
    margin-top: 1.5rem;
}

/* =========================
   ARTICLE / ITEM CARDS
========================= */

.obj_article_summary,
.obj_issue_summary,
.obj_monograph_summary,
.page_search .obj_article_summary,
.obj_issue_toc .articles > li {
    background: #ffffff;
    border: 1px solid var(--repo-border);
    border-left: 5px solid var(--repo-green-700);
    border-radius: 12px;
    box-shadow: 0 7px 20px rgba(5, 47, 38, 0.06);
    padding: 1.1rem 1.25rem;
    margin-bottom: 1rem;
    transition: 0.18s ease;
}

.obj_article_summary:hover,
.obj_issue_summary:hover,
.obj_monograph_summary:hover,
.obj_issue_toc .articles > li:hover {
    transform: translateY(-1px);
    box-shadow: 0 13px 28px rgba(5, 47, 38, 0.10);
}

.obj_article_summary .title,
.obj_article_summary h3,
.obj_issue_summary .title,
.obj_monograph_summary .title {
    font-family: var(--repo-title-font);
    color: var(--repo-green-900);
    font-size: 1.16rem;
    font-weight: 700;
}

.obj_article_summary .title a,
.obj_issue_summary .title a,
.obj_monograph_summary .title a {
    color: var(--repo-green-900);
}

.obj_article_summary .authors,
.obj_article_summary .meta,
.obj_article_summary .pages,
.obj_issue_summary .series,
.obj_monograph_summary .author {
    font-family: var(--repo-ui-font);
    color: var(--repo-muted);
}

/* Buttons */
.obj_galley_link,
.galley-link,
.cmp_button,
.cmp_form .buttons button,
button.submit,
a.download,
a.pdf {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--repo-green-800) !important;
    border: 1px solid var(--repo-green-800) !important;
    color: #ffffff !important;
    border-radius: 999px !important;
    padding: 0.5rem 0.95rem !important;
    font-family: var(--repo-ui-font) !important;
    font-weight: 700 !important;
    box-shadow: 0 4px 12px rgba(5, 47, 38, 0.18);
}

.obj_galley_link:hover,
.galley-link:hover,
.cmp_button:hover,
.cmp_form .buttons button:hover,
button.submit:hover,
a.download:hover,
a.pdf:hover {
    background: var(--repo-green-950) !important;
    border-color: var(--repo-green-950) !important;
    color: #ffffff !important;
}

/* =========================
   SIDEBAR / BROWSE
========================= */

.pkp_block,
.block_custom,
.block_browse,
.block_make_submission {
    background: var(--repo-card);
    border: 1px solid var(--repo-border);
    border-radius: 16px;
    box-shadow: var(--repo-shadow-soft);
    padding: 1.25rem 1.35rem;
    margin-bottom: 1.2rem;
}

.pkp_block .title,
.pkp_block h2,
.pkp_block h3,
.block_browse .title,
.block_custom .title {
    color: var(--repo-green-900);
    font-family: var(--repo-title-font) !important;
    font-size: 1.35rem;
    font-weight: 700;
    border-bottom: 2px solid rgba(15, 91, 69, 0.45);
    padding-bottom: 0.45rem;
    margin-bottom: 1rem;
}

.pkp_block ul,
.block_browse ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pkp_block li,
.block_browse li {
    border-bottom: 1px solid var(--repo-border);
    padding: 0.75rem 0;
}

.pkp_block li:last-child,
.block_browse li:last-child {
    border-bottom: 0;
}

.pkp_block a,
.block_browse a,
.block_browse .content a,
.pkp_structure_sidebar a {
    color: var(--repo-green-850);
    font-family: var(--repo-ui-font);
    font-size: 1.12rem !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
}

.pkp_block a:hover,
.block_browse a:hover {
    color: var(--repo-green-600);
}

.pkp_block a[aria-current="page"],
.block_browse a[aria-current="page"],
.pkp_block li.current a,
.block_browse li.current a,
.pkp_block li.active a,
.block_browse li.active a {
    display: block;
    background: #eaf2ee;
    border-left: 4px solid var(--repo-green-700);
    color: var(--repo-green-950) !important;
    padding: 0.55rem 0.7rem;
    margin-left: -0.7rem;
    border-radius: 0 6px 6px 0;
}

/* =========================
   SEARCH / FORMS
========================= */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
    border: 1px solid var(--repo-border-dark) !important;
    border-radius: 9px !important;
    padding: 0.65rem 0.75rem !important;
    background: #ffffff !important;
    color: var(--repo-text) !important;
    font-family: var(--repo-ui-font);
}

input:focus,
textarea:focus,
select:focus {
    outline: 3px solid rgba(15, 91, 69, 0.18) !important;
    border-color: var(--repo-green-700) !important;
}

.page_search .cmp_form,
.cmp_form {
    background: #f4faf7;
    border: 1px solid var(--repo-border);
    border-radius: var(--repo-radius);
    padding: 1.1rem;
}

.page_search .submit,
.page_search button,
.page_search .cmp_form button,
.page_search .search button,
.page_search .buttons button {
    min-width: 120px !important;
    width: auto !important;
    padding: 0.75rem 1.4rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.6rem !important;
    font-size: 1rem !important;
}

.page_search .submit::before,
.page_search button::before {
    margin-right: 6px;
}

/* =========================
   FOOTER
========================= */

.pkp_structure_footer_wrapper,
.pkp_footer_content {
    background: var(--repo-green-900) !important;
    color: rgba(255,255,255,0.92) !important;
}

.pkp_structure_footer {
    position: relative !important;
    max-width: 1380px;
    min-height: 170px !important;
    margin: 0 auto;
    padding: 2rem 2rem 2rem 190px !important;
    border-top: 1px solid rgba(255,255,255,0.16);
    box-sizing: border-box;

    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.pkp_structure_footer::before {
    content: "";
    position: absolute;
    left: 58px;
    top: 50%;
    transform: translateY(-50%);
    width: 92px;
    height: 92px;
    opacity: 0.98;
    background-image: var(--repo-logo-svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

.pkp_structure_footer a,
.pkp_footer_content a {
    color: #e4f4ee !important;
    font-weight: 700;
}

.pkp_structure_footer a:hover,
.pkp_footer_content a:hover {
    color: #ffffff !important;
}

/* =========================
   TABLES
========================= */

table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid var(--repo-border);
    border-radius: 12px;
    overflow: hidden;
    background: #ffffff;
}

th, td {
    padding: 0.8rem;
    border-bottom: 1px solid var(--repo-border);
}

th {
    background: var(--repo-green-900);
    color: #ffffff;
    font-family: var(--repo-ui-font);
}

tr:nth-child(even) td {
    background: #f7faf8;
}

/* =========================
   ACCESSIBILITY
========================= */

:focus-visible {
    outline: 3px solid rgba(15, 91, 69, 0.42);
    outline-offset: 3px;
}

::selection {
    background: var(--repo-green-800);
    color: #ffffff;
}

/* =========================
   MOBILE
========================= */

@media (max-width: 760px) {
    body {
        font-size: 15px;
    }

    .pkp_site_name {
        padding: 1.3rem 1.2rem 1.2rem 92px !important;
        min-height: 92px !important;
    }

    .pkp_site_name::before {
        left: 20px;
        width: 54px;
        height: 54px;
    }

    .pkp_site_name a,
    .pkp_site_name .is_text,
    .pkp_site_name_wrapper a {
        font-size: 1.45rem !important;
    }

    .pkp_navigation_primary_wrapper {
        display: block !important;
        min-height: 58px !important;
        padding: 0 1.2rem !important;
    }

    .pkp_navigation_primary {
        display: block !important;
        max-width: none !important;
        white-space: normal !important;
    }

    .pkp_navigation_primary > li {
        display: block !important;
    }

    .pkp_navigation_primary > li > a,
    .pkp_navigation_primary > li > span {
        min-height: 0 !important;
        padding: 0.8rem 0 !important;
        line-height: 1.25 !important;
    }

    .pkp_navigation_search_wrapper {
        display: block !important;
        min-height: 0 !important;
        padding: 0.8rem 0 !important;
    }

    .pkp_navigation_search_wrapper a {
        min-height: 0 !important;
        line-height: 1.25 !important;
    }

    .pkp_structure_content {
        padding: 1.2rem;
    }

    .pkp_structure_main {
        border-radius: 0;
        padding: 1.15rem;
    }

    .page_catalog_category h1,
    .page_catalog h1,
    .page_issue h1,
    .obj_issue_toc h1 {
        padding-right: 0 !important;
    }

    .page_catalog_category .category_description,
    .page_catalog_category .description,
    .obj_issue_toc .description,
    .obj_issue_toc .issue_description {
        max-width: 100% !important;
    }

    .page_catalog_category .count,
    .page_catalog_category .num_items,
    .page_catalog_category .items {
        float: none;
        clear: both;
        margin: 1rem 0 !important;
        width: fit-content !important;
    }

    .obj_galley_link,
    .galley-link,
    .cmp_button {
        width: 100%;
        box-sizing: border-box;
        margin-top: 0.4rem;
    }

    .pkp_structure_footer {
        padding-left: 1.2rem !important;
        padding-top: 115px !important;
        min-height: 230px !important;
        text-align: center !important;
    }

    .pkp_structure_footer::before {
        left: 50%;
        top: 30px;
        transform: translateX(-50%);
        width: 76px;
        height: 76px;
    }
}

/* =========================
   SMALL DESKTOP ADJUSTMENT
========================= */

@media (min-width: 761px) and (max-width: 1150px) {
    .pkp_navigation_primary > li > a,
    .pkp_navigation_primary > li > span {
        font-size: 0.95rem !important;
        padding-left: 0.7rem !important;
        padding-right: 0.7rem !important;
    }

    .pkp_navigation_primary {
        max-width: calc(100% - 135px) !important;
    }
}


/* =========================================================
   DESKTOP MENU POSITION FIX v9
   Forced visual alignment for desktop only.
   Mobile remains unchanged.
========================================================= */

@media (min-width: 761px) {

    /*
      Main idea:
      OJS may keep its own internal menu width.
      So we force the whole visible navigation content to start
      at the same visual position as the main content card.
    */

    .pkp_navigation_primary_row {
        background: var(--repo-green-900) !important;
        width: 100% !important;
        min-height: 58px !important;
        height: 58px !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: visible !important;
        border-top: 1px solid rgba(255,255,255,0.12) !important;
        border-bottom: 1px solid rgba(255,255,255,0.16) !important;
    }

    .pkp_navigation_primary_wrapper {
        width: 100% !important;
        max-width: none !important;
        height: 58px !important;
        min-height: 58px !important;
        margin: 0 !important;
        padding: 0 !important;
        position: relative !important;
        display: block !important;
        box-sizing: border-box !important;
        overflow: visible !important;
    }

    .pkp_navigation_primary {
        position: absolute !important;
        left: 50% !important;
        top: 0 !important;
        transform: translateX(-50%) !important;

        width: 990px !important;
        max-width: 990px !important;
        height: 58px !important;
        min-height: 58px !important;

        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        flex-wrap: nowrap !important;

        margin: 0 !important;
        padding: 0 150px 0 0 !important;
        list-style: none !important;
        box-sizing: border-box !important;
        float: none !important;
        clear: none !important;
        overflow: visible !important;
    }

    .pkp_navigation_primary > li {
        display: flex !important;
        align-items: center !important;
        height: 58px !important;
        min-height: 58px !important;
        margin: 0 !important;
        padding: 0 !important;
        float: none !important;
    }

    .pkp_navigation_primary > li > a,
    .pkp_navigation_primary > li > span {
        display: flex !important;
        align-items: center !important;
        height: 58px !important;
        min-height: 58px !important;
        margin: 0 !important;
        padding: 0 1rem !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        box-sizing: border-box !important;
    }

    .pkp_navigation_search_wrapper {
        position: absolute !important;
        right: calc((100vw - 990px) / 2) !important;
        top: 0 !important;

        height: 58px !important;
        min-height: 58px !important;

        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;

        margin: 0 !important;
        padding: 0 !important;
        transform: none !important;
        z-index: 20 !important;
    }

    .pkp_navigation_search_wrapper a {
        display: flex !important;
        align-items: center !important;
        height: 58px !important;
        min-height: 58px !important;
        margin: 0 !important;
        padding: 0 !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }
}

/* For smaller desktop screens */
@media (min-width: 761px) and (max-width: 1050px) {
    .pkp_navigation_primary {
        left: 24px !important;
        right: 150px !important;
        transform: none !important;
        width: auto !important;
        max-width: none !important;
        padding-right: 0 !important;
    }

    .pkp_navigation_search_wrapper {
        right: 24px !important;
    }

    .pkp_navigation_primary > li > a,
    .pkp_navigation_primary > li > span {
        padding-left: 0.65rem !important;
        padding-right: 0.65rem !important;
        font-size: 0.95rem !important;
    }
}


/* =========================================================
   FINAL FIXES v10 — DROPDOWN + SIDEBAR POSITION
   Place at the end. Desktop-focused, mobile preserved.
========================================================= */

/* 1. DROPDOWN MUST OPEN ABOVE CONTENT */
.pkp_structure_head,
.pkp_head_wrapper,
.pkp_site_nav_menu,
.pkp_navigation_primary_row,
.pkp_navigation_primary_wrapper,
.pkp_navigation_primary,
.pkp_navigation_primary > li {
    overflow: visible !important;
}

.pkp_structure_head {
    position: relative !important;
    z-index: 9999 !important;
}

.pkp_head_wrapper {
    position: relative !important;
    z-index: 9999 !important;
}

.pkp_navigation_primary_row {
    position: relative !important;
    z-index: 9999 !important;
}

.pkp_navigation_primary_wrapper {
    position: relative !important;
    z-index: 10000 !important;
}

.pkp_navigation_primary > li {
    position: relative !important;
    z-index: 10001 !important;
}

.pkp_navigation_primary ul,
.pkp_navigation_primary li ul,
.pkp_navigation_primary .dropdown-menu {
    position: absolute !important;
    top: 58px !important;
    left: 0 !important;
    z-index: 20000 !important;

    display: none;
    min-width: 220px !important;

    background: #ffffff !important;
    border: 1px solid var(--repo-border) !important;
    border-radius: 12px !important;
    padding: 0.45rem !important;
    box-shadow: 0 18px 42px rgba(5, 47, 38, 0.20) !important;
}

.pkp_navigation_primary li:hover > ul,
.pkp_navigation_primary li:focus-within > ul {
    display: block !important;
}

.pkp_structure_content,
.pkp_structure_main,
.pkp_structure_sidebar {
    position: relative !important;
    z-index: 1 !important;
}

/* 2. DESKTOP SIDEBAR/BROWSE ALIGNMENT */
@media (min-width: 761px) {

    .pkp_structure_content {
        display: grid !important;
        grid-template-columns: minmax(0, 770px) 300px !important;
        column-gap: 2rem !important;
        align-items: start !important;

        max-width: 1060px !important;
        margin-left: auto !important;
        margin-right: auto !important;

        padding-top: 2rem !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
    }

    .pkp_structure_main {
        grid-column: 1 !important;
        width: 100% !important;
        max-width: 770px !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }

    .pkp_structure_sidebar {
        grid-column: 2 !important;
        width: 300px !important;
        max-width: 300px !important;
        margin: 0 !important;
        padding: 0 !important;
        align-self: start !important;
        transform: none !important;
    }

    .pkp_structure_sidebar .pkp_block,
    .pkp_structure_sidebar .block_browse,
    .pkp_structure_sidebar .block_custom {
        margin-top: 0 !important;
    }

    /* If theme uses floats instead of grid, neutralize them */
    .pkp_structure_main,
    .pkp_structure_sidebar {
        float: none !important;
        clear: none !important;
    }
}

/* 3. WIDER DESKTOP */
@media (min-width: 1200px) {
    .pkp_structure_content {
        grid-template-columns: minmax(0, 790px) 300px !important;
        max-width: 1090px !important;
    }

    .pkp_structure_main {
        max-width: 790px !important;
    }
}

/* 4. SMALLER DESKTOP */
@media (min-width: 761px) and (max-width: 1100px) {
    .pkp_structure_content {
        grid-template-columns: minmax(0, 1fr) 280px !important;
        column-gap: 1.4rem !important;
        max-width: calc(100% - 48px) !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .pkp_structure_sidebar {
        width: 280px !important;
        max-width: 280px !important;
    }
}

/* 5. MOBILE: keep original flow */
@media (max-width: 760px) {
    .pkp_structure_content {
        display: block !important;
    }

    .pkp_structure_main,
    .pkp_structure_sidebar {
        width: auto !important;
        max-width: none !important;
        margin: 0 !important;
    }

    .pkp_structure_sidebar {
        margin-top: 1.2rem !important;
    }
}
