/* =============================================================================
   NowartBIP — główny arkusz stylów (WCAG 2.1 AA)
   - Bez zewnętrznych zależności (działa bez JS i CDN)
   - Zmienne motywu wstrzykiwane z _Layout.cshtml: --bip-akcent, --bip-font
   ============================================================================= */

:root {
    --bip-akcent: #003366;
    --bip-akcent-jasny: #1a4d80;
    --bip-akcent-tlo: #e8eef7;
    --bip-czerwony: #c8102e;
    --bip-tekst: #1a1a1a;
    --bip-tekst-szary: #555;
    --bip-tlo: #ffffff;
    --bip-tlo-alt: #f4f6fa;
    --bip-ramka: #d0d6df;
    --bip-fokus: #ffaa00;
    --bip-font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --bip-font-mono: ui-monospace, "Cascadia Code", Consolas, monospace;
    --bip-rozmiar-bazowy: 16px;
    --bip-szerokosc-max: 1200px;
}

html[data-font="L"]  { --bip-rozmiar-bazowy: 18px; }
html[data-font="XL"] { --bip-rozmiar-bazowy: 20px; }

* { box-sizing: border-box; }

html { font-size: var(--bip-rozmiar-bazowy); }

body {
    margin: 0;
    font-family: var(--bip-font);
    color: var(--bip-tekst);
    background: var(--bip-tlo);
    line-height: 1.55;
}

/* --- Linki i fokus --- */
a {
    color: var(--bip-akcent);
    text-decoration: underline;
    text-underline-offset: 2px;
}
a:hover { color: var(--bip-akcent-jasny); }
a:focus, button:focus, input:focus, select:focus, textarea:focus {
    outline: 3px solid var(--bip-fokus);
    outline-offset: 2px;
}

/* --- Skip link --- */
.skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--bip-akcent);
    color: #fff !important;
    padding: 0.5em 1em;
    text-decoration: none;
    z-index: 10000;
}
.skip-link:focus { top: 0; }

.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

/* --- Pasek dostępności --- */
.bip-a11y {
    background: #1a1a1a;
    color: #fff;
    padding: 0.4em 1em;
    font-size: 0.875rem;
}
.bip-a11y-form {
    max-width: var(--bip-szerokosc-max);
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4em;
    align-items: center;
}
.bip-a11y-label { font-weight: bold; margin-right: 0.5em; }
.bip-a11y-btn {
    background: transparent;
    color: #fff;
    border: 1px solid #fff;
    padding: 0.2em 0.7em;
    cursor: pointer;
    font: inherit;
}
.bip-a11y-btn:hover { background: #fff; color: #000; }
.bip-a11y-btn[aria-pressed="true"] {
    background: #fff;
    color: #000;
    font-weight: bold;
}
.bip-a11y-sep { color: #888; }
.bip-a11y-link {
    color: #fff !important;
    margin-left: auto;
}
.bip-font-A { font-size: 0.9em; }
.bip-font-AA { font-size: 1em; }
.bip-font-AAA { font-size: 1.1em; }

/* --- Header --- */
.bip-header {
    background: var(--bip-tlo);
    border-bottom: 3px solid var(--bip-akcent);
    padding: 0 1em;
}
.bip-header-bar {
    max-width: var(--bip-szerokosc-max);
    margin: 0 auto;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1.5em;
    padding: 0.8em 0;
    border-bottom: 1px solid var(--bip-ramka);
}
.bip-logo-link img { display: block; height: 48px; width: auto; }
.bip-header-meta {
    display: flex;
    flex-direction: column;
    flex: 1;
}
.bip-podmiot-eyebrow {
    font-size: 0.85em;
    color: var(--bip-tekst-szary);
    text-transform: uppercase;
    letter-spacing: 1px;
}
.bip-link-serwis { font-weight: bold; }
.bip-podmiot {
    max-width: var(--bip-szerokosc-max);
    margin: 0 auto;
    padding: 1em 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 1em;
}
.bip-podmiot-title {
    margin: 0;
    font-size: 1.7em;
    color: var(--bip-akcent);
}
.bip-podmiot-title a {
    color: inherit;
    text-decoration: none;
}
.bip-podmiot-adres {
    margin: 0.3em 0 0;
    color: var(--bip-tekst-szary);
    font-size: 0.95em;
}
.bip-search {
    display: flex;
    gap: 0.3em;
    align-items: center;
}
.bip-search input {
    font: inherit;
    padding: 0.4em 0.6em;
    border: 1px solid var(--bip-ramka);
    min-width: 14em;
}
.bip-search button {
    font: inherit;
    background: var(--bip-akcent);
    color: #fff;
    border: none;
    padding: 0.45em 1em;
    cursor: pointer;
}
.bip-search button:hover { background: var(--bip-akcent-jasny); }

/* --- Menu --- */
.bip-menu {
    background: var(--bip-akcent);
    color: #fff;
}
.bip-menu-list {
    max-width: var(--bip-szerokosc-max);
    margin: 0 auto;
    list-style: none;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
}
.bip-menu-link {
    display: block;
    color: #fff;
    text-decoration: none;
    padding: 0.7em 1em;
    border-right: 1px solid rgba(255,255,255,0.2);
}
.bip-menu-link:hover, .bip-menu-link[aria-current="page"] {
    background: var(--bip-akcent-jasny);
    color: #fff;
}

/* --- Główny układ: main + aside --- */
.bip-container {
    max-width: var(--bip-szerokosc-max);
    margin: 1.5em auto;
    padding: 0 1em;
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 2em;
}
@media (max-width: 900px) {
    .bip-container { grid-template-columns: 1fr; }
}
main { min-width: 0; }

.bip-aside { font-size: 0.95em; }
.bip-aside-block {
    background: var(--bip-tlo-alt);
    border-left: 4px solid var(--bip-akcent);
    padding: 0.8em 1em;
    margin-bottom: 1.2em;
}
.bip-aside-h {
    margin: 0 0 0.5em;
    font-size: 1em;
    color: var(--bip-akcent);
}
.bip-aside ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.bip-aside ul li { margin: 0.25em 0; }
.bip-cta {
    display: inline-block;
    background: var(--bip-akcent);
    color: #fff !important;
    padding: 0.4em 0.9em;
    text-decoration: none;
    margin-top: 0.4em;
}
.bip-cta:hover { background: var(--bip-akcent-jasny); }

/* --- Nagłówki, lista artykułów --- */
.bip-h1 {
    color: var(--bip-akcent);
    font-size: 1.8em;
    margin: 0 0 0.6em;
    line-height: 1.2;
}
.bip-h2 {
    color: var(--bip-akcent);
    font-size: 1.3em;
    margin: 1.5em 0 0.5em;
    border-bottom: 1px solid var(--bip-ramka);
    padding-bottom: 0.2em;
}
.bip-lead {
    font-size: 1.05em;
    color: var(--bip-tekst-szary);
    margin: 0 0 1.2em;
}
.bip-breadcrumbs {
    font-size: 0.9em;
    margin-bottom: 1em;
    color: var(--bip-tekst-szary);
}
.bip-breadcrumbs a { color: var(--bip-akcent); }

.bip-articles-list {
    list-style: none;
    padding: 0;
}
.bip-article-item {
    padding: 0.8em 0;
    border-bottom: 1px solid var(--bip-ramka);
}
.bip-article-h {
    margin: 0 0 0.2em;
    font-size: 1.15em;
}
.bip-article-h a { text-decoration: none; }
.bip-article-h a:hover { text-decoration: underline; }
.bip-article-meta {
    margin: 0;
    color: var(--bip-tekst-szary);
    font-size: 0.9em;
}
.bip-article-lid {
    margin: 0.4em 0 0;
    color: var(--bip-tekst);
}
.bip-pinned {
    color: var(--bip-czerwony);
    margin-left: 0.4em;
}

/* --- Pojedynczy artykuł --- */
.bip-article {
    background: var(--bip-tlo);
    padding: 0.5em 0;
}
.bip-article-body { line-height: 1.65; font-size: 1.02em; }
.bip-article-body h2 { color: var(--bip-akcent); margin-top: 1.4em; }
.bip-article-body img { max-width: 100%; height: auto; }
.bip-article-body table {
    border-collapse: collapse;
    width: 100%;
    margin: 1em 0;
}
.bip-article-body th, .bip-article-body td {
    border: 1px solid var(--bip-ramka);
    padding: 0.4em 0.6em;
    text-align: left;
}
.bip-article-body th { background: var(--bip-akcent-tlo); }

.bip-attachments {
    margin-top: 2em;
    background: var(--bip-tlo-alt);
    border-left: 4px solid var(--bip-akcent);
    padding: 0.8em 1em;
}
.bip-attachments ul { list-style: none; padding: 0; margin: 0.5em 0 0; }
.bip-attachments li { padding: 0.4em 0; }
.bip-att-meta {
    color: var(--bip-tekst-szary);
    font-size: 0.9em;
}
.bip-att-alt {
    margin: 0.2em 0 0;
    font-size: 0.9em;
    color: var(--bip-tekst-szary);
    font-style: italic;
}

.bip-article-footer {
    margin-top: 2em;
    border-top: 2px solid var(--bip-akcent);
    padding-top: 1em;
}
.bip-meta {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.3em 1em;
    font-size: 0.95em;
}
.bip-meta dt { font-weight: bold; color: var(--bip-tekst-szary); }
.bip-meta dd { margin: 0; }
.bip-article-actions {
    margin-top: 1em;
    display: flex;
    gap: 0.6em;
    flex-wrap: wrap;
}
.bip-action {
    background: var(--bip-tlo-alt);
    border: 1px solid var(--bip-ramka);
    color: var(--bip-akcent) !important;
    padding: 0.4em 0.8em;
    text-decoration: none;
}
.bip-action:hover { background: var(--bip-akcent-tlo); }

/* --- Tabele --- */
.bip-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1em 0;
    font-size: 0.95em;
}
.bip-table th, .bip-table td {
    border: 1px solid var(--bip-ramka);
    padding: 0.5em 0.7em;
    text-align: left;
    vertical-align: top;
}
.bip-table th {
    background: var(--bip-akcent);
    color: #fff;
}
.bip-table tbody tr:nth-child(even) { background: var(--bip-tlo-alt); }

/* --- Paginacja --- */
.bip-pagination {
    margin-top: 1.5em;
    display: flex;
    gap: 1em;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}

/* --- Formularz wniosku --- */
.bip-form fieldset {
    border: 1px solid var(--bip-ramka);
    padding: 1em;
    margin: 0 0 1em;
}
.bip-form legend {
    font-weight: bold;
    color: var(--bip-akcent);
    padding: 0 0.4em;
}
.bip-form-row {
    margin: 0.7em 0;
    display: flex;
    flex-direction: column;
    gap: 0.3em;
}
.bip-form-row label { font-weight: bold; }
.bip-form-row input,
.bip-form-row textarea {
    font: inherit;
    padding: 0.5em;
    border: 1px solid var(--bip-ramka);
    width: 100%;
    max-width: 35em;
}
.bip-form-row textarea { min-height: 8em; }
.bip-form-hint { font-size: 0.85em; color: var(--bip-tekst-szary); margin: 0; }
.bip-form-radio {
    display: flex;
    gap: 1em;
    flex-wrap: wrap;
}
.bip-form-radio label { font-weight: normal; }
.bip-form-info {
    color: var(--bip-tekst-szary);
    font-size: 0.9em;
}
.bip-submit {
    background: var(--bip-akcent);
    color: #fff;
    border: none;
    padding: 0.7em 1.5em;
    font: inherit;
    font-weight: bold;
    cursor: pointer;
}
.bip-submit:hover { background: var(--bip-akcent-jasny); }

.bip-alert {
    padding: 1em;
    margin: 1em 0;
    border-left: 4px solid;
}
.bip-alert-success {
    background: #e8f6e8;
    border-color: #2d8f2d;
    color: #1a4d1a;
}
.bip-alert-error {
    background: #fbe7e7;
    border-color: #c8102e;
    color: #6a0a17;
}

/* --- Redakcja, ludzie --- */
.bip-people {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1em;
}
.bip-person {
    background: var(--bip-tlo-alt);
    padding: 1em;
    border-left: 4px solid var(--bip-akcent);
}
.bip-person-name {
    margin: 0 0 0.2em;
    color: var(--bip-akcent);
    font-size: 1.1em;
}
.bip-person-role {
    color: var(--bip-tekst-szary);
    margin: 0 0 0.5em;
}
.bip-person-contact {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.2em 0.7em;
    margin: 0;
    font-size: 0.95em;
}
.bip-person-contact dt { font-weight: bold; color: var(--bip-tekst-szary); }
.bip-person-contact dd { margin: 0; }

/* --- Wyszukiwarka --- */
.bip-search-form {
    display: flex;
    gap: 0.5em;
    margin: 1em 0;
    align-items: center;
    flex-wrap: wrap;
}
.bip-search-form input[type="search"] {
    flex: 1;
    min-width: 20em;
    font: inherit;
    padding: 0.5em;
    border: 1px solid var(--bip-ramka);
}
.bip-search-form button {
    font: inherit;
    background: var(--bip-akcent);
    color: #fff;
    border: none;
    padding: 0.55em 1.2em;
    cursor: pointer;
}
.bip-search-summary { font-style: italic; color: var(--bip-tekst-szary); }
.bip-search-results { padding: 0; list-style: decimal inside; }
.bip-search-results li { padding: 0.8em 0; border-bottom: 1px solid var(--bip-ramka); }
.bip-search-h {
    font-size: 1.1em;
    margin: 0 0 0.3em;
    display: inline;
}
.bip-search-fragment mark {
    background: #fff4a3;
    padding: 0 0.2em;
}

/* --- Mapa serwisu --- */
.bip-sitemap-tree { padding-left: 1.5em; }
.bip-sitemap-tree li { margin: 0.3em 0; }

/* --- Statystyki --- */
.bip-stats-list { list-style: none; padding: 0; font-size: 1.05em; }
.bip-stats-list li { padding: 0.3em 0; }
.bip-stats-top { padding-left: 1.5em; }
.bip-stats-top li { padding: 0.25em 0; }

/* --- Footer --- */
.bip-footer {
    margin-top: 3em;
    background: var(--bip-akcent);
    color: #fff;
    padding: 2em 1em 1em;
}
.bip-footer a { color: #ffe8a8; }
.bip-footer-cols {
    max-width: var(--bip-szerokosc-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 2em;
}
.bip-footer-h {
    color: #fff;
    font-size: 1.1em;
    margin: 0 0 0.5em;
    border-bottom: 1px solid rgba(255,255,255,0.3);
    padding-bottom: 0.3em;
}
.bip-footer-col ul {
    list-style: none;
    padding: 0;
}
.bip-footer-col li { padding: 0.2em 0; }
.bip-footer-adres { font-style: normal; line-height: 1.7; }
.bip-footer-bottom {
    max-width: var(--bip-szerokosc-max);
    margin: 1.5em auto 0;
    padding-top: 1em;
    border-top: 1px solid rgba(255,255,255,0.3);
    text-align: center;
    font-size: 0.9em;
    opacity: 0.85;
}

/* --- Błąd / utility --- */
.bip-error { text-align: center; padding: 2em 0; }
.bip-error-trace { font-family: var(--bip-font-mono); color: var(--bip-tekst-szary); }

code, kbd {
    font-family: var(--bip-font-mono);
    background: var(--bip-tlo-alt);
    padding: 0.1em 0.3em;
    border-radius: 2px;
}

/* --- Logo tenanta w header --- */
.bip-podmiot-logo img {
    max-height: 60px;
    max-width: 150px;
    width: auto;
    height: auto;
    margin-right: 1em;
    vertical-align: middle;
}

/* --- Status badges (przetargi, konkursy, zapytania) --- */
.bip-status {
    display: inline-block;
    font-size: 0.8em;
    padding: 0.15em 0.6em;
    border-radius: 4px;
    margin-left: 0.5em;
    vertical-align: middle;
    background: var(--bip-tlo-alt);
    color: var(--bip-tekst-szary);
    font-weight: normal;
}
.bip-status-opublikowany, .bip-status-opublikowane, .bip-status-aktualna {
    background: #d4edda; color: #155724;
}
.bip-status-trwa {
    background: #fff3cd; color: #856404;
}
.bip-status-rozstrzygniety, .bip-status-rozstrzygniete, .bip-status-zakonczona, .bip-status-zakonczone {
    background: #cce5ff; color: #004085;
}
.bip-status-uniewazniony, .bip-status-rozwiazana, .bip-status-anulowane, .bip-status-anulowany {
    background: #f8d7da; color: #721c24;
}
.bip-status-archiwalny, .bip-status-archiwalne {
    background: #e2e3e5; color: #383d41;
}

/* --- Kategorie przetargów --- */
.bip-przetargi-kat ul {
    list-style: none;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
    margin: 0.5em 0 1em;
}
.bip-przetargi-kat li a {
    display: inline-block;
    padding: 0.3em 0.8em;
    background: var(--bip-tlo-alt);
    border: 1px solid var(--bip-ramka);
    text-decoration: none;
    color: var(--bip-akcent);
}
.bip-przetargi-kat li a.active {
    background: var(--bip-akcent);
    color: #fff;
    border-color: var(--bip-akcent);
}

/* --- Liczby (kwoty) wyrównane do prawej --- */
td.bip-num, th.bip-num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* --- Wykres SVG statystyk --- */
.bip-stats-chart {
    margin: 1em 0;
}
.bip-stats-chart figcaption {
    font-size: 0.85em;
    color: var(--bip-tekst-szary);
    margin-top: 0.4em;
}
.bip-stats-chart svg rect {
    transition: opacity 0.15s;
}
.bip-stats-chart svg rect:hover {
    opacity: 1;
}

details {
    margin: 1em 0;
}
details summary {
    cursor: pointer;
    color: var(--bip-akcent);
    font-weight: bold;
    padding: 0.3em 0;
}
