:root {
    --pern-blocks-navy: #04082e;
    --pern-blocks-blue: #0a1473;
    --pern-blocks-green: #2eb135;
    --pern-blocks-white: #ffffff;
    --pern-blocks-muted: #f4f5f8;
    --pern-blocks-font-heading: "futura-pt", sans-serif;
    --pern-blocks-font-body: "Calibri", sans-serif;
}

.pern-block {
    box-sizing: border-box;
    font-family: var(--pern-blocks-font-body);
    color: var(--pern-blocks-blue);
}

.pern-block *, .pern-block *::before, .pern-block *::after { box-sizing: border-box; }

.pern-blocks-container {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 576px) { .pern-blocks-container { max-width: 540px; } }
@media (min-width: 768px) { .pern-blocks-container { max-width: 720px; } }
@media (min-width: 992px) { .pern-blocks-container { max-width: 960px; } }

.pern-block h1, .pern-block h2, .pern-block h3 {
    margin: 0 0 24px;
    font-family: var(--pern-blocks-font-heading);
    color: inherit;
    line-height: 1.08;
}

.pern-block h1 { font-size: clamp(32px, 4vw, 56px); }
.pern-block h2 { font-size: clamp(25px, 2.6vw, 38px); }
.pern-block p { margin: 0 0 16px; line-height: 1.52; }
.pern-block img { display: block; max-width: 100%; height: auto; }

.pern-blocks-eyebrow {
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.pern-blocks-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 16px 34px;
    border: 0;
    background: var(--pern-blocks-blue);
    color: var(--pern-blocks-white);
    font-weight: 700;
    letter-spacing: .08em;
    text-decoration: none;
    text-transform: uppercase;
    cursor: pointer;
}

.pern-blocks-button:hover, .pern-blocks-button:focus { background: var(--pern-blocks-green); color: var(--pern-blocks-white); }
.pern-blocks-button--secondary { background: var(--pern-blocks-white); color: var(--pern-blocks-blue); }
.pern-blocks-actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 28px; }

.pern-hero-landing {
    --pern-blocks-site-header-offset: clamp(86px, 8vw, 116px);
    padding: calc(clamp(56px, 7vw, 92px) + var(--pern-blocks-site-header-offset)) 0 clamp(56px, 7vw, 92px);
    background-color: var(--pern-blocks-navy);
    background-position: center;
    background-size: cover;
    color: var(--pern-blocks-white);
}
.pern-hero-landing__inner {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: 30px;
    align-items: center;
    min-height: 470px;
}
.pern-hero-landing__content { min-width: 0; grid-column: 1; }
.pern-hero-landing__spacer { min-height: 1px; grid-column: 2; }
.pern-hero-landing__lead { max-width: 680px; font-size: clamp(17px, 1.8vw, 22px); }
.pern-hero-landing__copy { max-width: 720px; }

.pern-info-highlight { padding: clamp(52px, 6vw, 76px) 0 0; background: var(--pern-blocks-white); color: var(--pern-blocks-blue); }
.pern-info-highlight__header { max-width: 920px; margin: 0 auto clamp(34px, 4vw, 48px); text-align: center; }
.pern-info-highlight__header h2 { margin-bottom: 0; font-size: clamp(30px, 3.2vw, 42px); }
.pern-info-highlight__grid { display: grid; grid-template-columns: minmax(0, 5fr) minmax(0, 6fr); gap: clamp(44px, 6vw, 78px); align-items: center; }
.pern-info-highlight--plain { padding: clamp(56px, 7vw, 92px) 0; }
.pern-info-highlight--plain .pern-info-highlight__grid { grid-template-columns: minmax(0, 1fr); }
.pern-info-highlight--plain .pern-info-highlight__content { max-width: 820px; padding: clamp(28px, 4vw, 44px); background: #f6f7fb; }
.pern-info-highlight__content { min-width: 0; }
.pern-info-highlight__items { margin: 0 0 0; padding-left: 20px; }
.pern-info-highlight__items li { margin-bottom: 4px; line-height: 1.35; }
.pern-info-highlight__media img { width: 100%; aspect-ratio: 1.45 / 1; object-fit: cover; }
.pern-info-highlight .pern-blocks-actions { margin-top: clamp(28px, 4vw, 56px); }

/* Presety „Wariant bloku” w CMS — klasy z pern_blocks_variant_class() */
.pern-info-highlight.pern-blocks-variant-dark { background: var(--pern-blocks-navy); color: #fff; }
.pern-info-highlight.pern-blocks-variant-dark.pern-info-highlight--plain .pern-info-highlight__content { background: rgba(255, 255, 255, .1); color: #fff; }
.pern-info-highlight.pern-blocks-variant-dark a { color: #b8d9ff; }

.pern-info-highlight.pern-blocks-variant-accent.pern-info-highlight--plain .pern-info-highlight__content { border-left: 4px solid var(--pern-blocks-green); }
.pern-info-highlight.pern-blocks-variant-green.pern-info-highlight--plain .pern-info-highlight__content { box-shadow: inset 0 0 0 2px rgba(46, 177, 53, .45); }

.pern-info-highlight.pern-blocks-variant-light.pern-info-highlight--plain .pern-info-highlight__content { background: #fff; }

.pern-split-content.pern-blocks-variant-dark { background: var(--pern-blocks-navy); }
.pern-split-content.pern-blocks-variant-accent { background: linear-gradient(145deg, #0a1473 0%, #061238 100%); }
.pern-split-content.pern-blocks-variant-green .pern-blocks-button { background: var(--pern-blocks-green); color: #fff; }
.pern-split-content.pern-blocks-variant-green .pern-blocks-button:hover,
.pern-split-content.pern-blocks-variant-green .pern-blocks-button:focus { filter: brightness(1.08); }

.pern-hero-landing.pern-blocks-variant-dark { background-color: var(--pern-blocks-navy); }
.pern-hero-landing.pern-blocks-variant-accent { background-color: var(--pern-blocks-blue); }
.pern-hero-landing.pern-blocks-variant-green .pern-blocks-button:not(.pern-blocks-button--secondary) { background: var(--pern-blocks-green); }

.pern-contact-form.pern-blocks-variant-dark { background: var(--pern-blocks-navy); color: #fff; }
.pern-contact-form.pern-blocks-variant-dark .pern-contact-form__placeholder { border-color: rgba(255, 255, 255, .35); color: rgba(255, 255, 255, .85); }
.pern-contact-form.pern-blocks-variant-accent { background: var(--pern-blocks-muted); }
.pern-contact-form.pern-blocks-variant-green .pern-contact-form__submit.pern-blocks-button { background: var(--pern-blocks-green); }

.pern-accordion-popup.pern-blocks-variant-dark { background: var(--pern-blocks-navy); color: #fff; }
.pern-editable-map.pern-blocks-variant-accent .pern-editable-map__header h2 { color: var(--pern-blocks-green); }

.pern-service-split-card.pern-blocks-variant-green .pern-blocks-button { background: var(--pern-blocks-green); color: #fff; }

.pern-service-split-card { padding: clamp(58px, 7vw, 92px) 0; }
.pern-service-split-card--dark { padding: 0 0 clamp(50px, 6vw, 68px); background: var(--pern-blocks-blue); color: var(--pern-blocks-white); }
.pern-service-split-card--light { background: var(--pern-blocks-white); color: var(--pern-blocks-blue); }
.pern-service-split-card__section-title { margin: 0; padding: 0; background: var(--pern-blocks-blue); color: var(--pern-blocks-white); text-align: center; }
.pern-service-split-card__section-title .pern-blocks-container { display: flex; min-height: 92px; align-items: center; justify-content: center; }
.pern-service-split-card__section-title h2 { margin: 0; font-size: clamp(32px, 3.3vw, 44px); letter-spacing: .02em; }
.pern-service-split-card__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 72px); align-items: center; }
.pern-service-split-card--dark .pern-service-split-card__grid { width: 100%; max-width: none; padding-right: 0; padding-left: 0; grid-template-columns: minmax(0, 50vw) minmax(0, 470px); gap: clamp(38px, 5vw, 70px); justify-content: start; }
.pern-service-split-card--dark.pern-service-split-card--media-right .pern-service-split-card__grid { grid-template-columns: minmax(0, 470px) minmax(0, 50vw); justify-content: end; }
.pern-service-split-card--media-right .pern-service-split-card__media { order: 2; }
.pern-service-split-card__media img { width: 100%; aspect-ratio: 1.35 / 1; object-fit: cover; }
.pern-service-split-card--dark .pern-service-split-card__media img { height: clamp(340px, 36vw, 430px); aspect-ratio: auto; }
.pern-service-split-card--dark .pern-service-split-card__content { max-width: 470px; padding: clamp(34px, 5vw, 58px) 15px clamp(30px, 4vw, 48px) 0; }
.pern-service-split-card--dark.pern-service-split-card--media-right .pern-service-split-card__content { padding-right: 0; padding-left: 15px; justify-self: end; }
.pern-service-split-card--light .pern-service-split-card__content { max-width: 450px; }
.pern-service-split-card--light .pern-service-split-card__grid { min-height: 420px; }
.pern-service-split-card__content h2 { font-size: clamp(28px, 3vw, 40px); }
.pern-service-split-card--dark .pern-blocks-button { background: #fff; color: var(--pern-blocks-blue); }
.pern-split-content { padding: clamp(56px, 7vw, 86px) 0; background: var(--pern-blocks-blue); color: var(--pern-blocks-white); }
.pern-split-content__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 72px); align-items: center; }
.pern-split-content--media-right .pern-split-content__media { order: 2; }
.pern-split-content__media img { width: 100%; aspect-ratio: 1.28 / 1; object-fit: cover; }
.pern-split-content .pern-blocks-button { background: var(--pern-blocks-white); color: var(--pern-blocks-blue); }

.pern-accordion-popup {
    padding: clamp(64px, 8vw, 104px) 0;
    background: linear-gradient(180deg, #ffffff 0%, #f6f7fb 100%);
}
.pern-accordion-popup__grid {
    display: grid;
    grid-template-columns: minmax(0, 4fr) minmax(0, 6fr);
    gap: clamp(36px, 6vw, 76px);
    align-items: start;
}
.pern-accordion-popup__intro { position: sticky; top: 110px; }
.pern-accordion-popup__modal[hidden] { display: none; }
.pern-accordion-popup__modal { position: fixed; inset: 0; z-index: 99999; display: grid; place-items: center; padding: 24px; }
.pern-accordion-popup__overlay { position: absolute; inset: 0; background: rgba(4, 8, 46, .72); }
.pern-accordion-popup__dialog { position: relative; width: min(960px, 100%); max-height: min(760px, 90vh); overflow: auto; padding: clamp(28px, 5vw, 64px); background: #fff; color: var(--pern-blocks-blue); outline: 0; box-shadow: 0 28px 80px rgba(4, 8, 46, .3); }
.pern-accordion-popup__close { position: absolute; top: 18px; right: 18px; width: 42px; height: 42px; border: 0; background: var(--pern-blocks-blue); color: #fff; font-size: 28px; cursor: pointer; }
.pern-accordion-popup__inline { display: grid; gap: 14px; }
.pern-accordion-popup__item { border: 1px solid rgba(10, 20, 115, .14); background: #fff; box-shadow: 0 14px 34px rgba(4, 8, 46, .06); }
.pern-accordion-popup__trigger { width: 100%; padding: 22px 26px; border: 0; background: transparent; color: var(--pern-blocks-blue); font: inherit; font-weight: 700; text-align: left; cursor: pointer; }
.pern-accordion-popup__trigger::after { content: "+"; float: right; font-size: 24px; line-height: 1; }
.pern-accordion-popup__trigger[aria-expanded="true"]::after { content: "–"; }
.pern-accordion-popup__panel { padding: 0 26px 24px; color: #26306f; }
.pern-blocks-modal-open { overflow: hidden; }

.pern-editable-map {
    padding: clamp(64px, 8vw, 112px) 0;
    background: #ffffff;
}
.pern-editable-map__header { max-width: 760px; margin-bottom: 38px; }
.pern-editable-map__layout {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(280px, 3fr);
    gap: clamp(28px, 5vw, 60px);
    align-items: stretch;
}
.pern-editable-map__stage {
    position: relative;
    min-height: 560px;
    padding: clamp(18px, 3vw, 34px);
    border: 1px solid rgba(10, 20, 115, .1);
    background: #fff;
    box-shadow: 0 24px 70px rgba(4, 8, 46, .11);
}
.pern-editable-map__image { width: 100%; height: 100%; object-fit: contain; }

.pern-editable-map__svg-base {
    width: 100%;
    height: 100%;
}
.pern-editable-map__svg-base svg {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 520px;
}
.pern-editable-map__svg-base #paliwa,
.pern-editable-map__svg-base #baza_paliw,
.pern-editable-map__svg-base #ropa,
.pern-editable-map__svg-base #magazyny_ropy_naftowej,
.pern-editable-map__svg-base #biura,
.pern-editable-map__svg-base #siedziba,
.pern-editable-map__svg-base #laboratoria {
    display: none;
}

.pern-editable-map__point {
    position: absolute;
    transform: translate(-50%, -50%);
    width: 36px;
    height: 36px;
    border: 3px solid #fff;
    border-radius: 999px;
    background: var(--pern-blocks-green);
    color: #fff;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(46, 177, 53, .35);
}
.pern-editable-map__point::before {
    content: "";
    position: absolute;
    inset: -9px;
    border: 1px solid rgba(46, 177, 53, .35);
    border-radius: inherit;
}
.pern-editable-map__tooltip {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 16px);
    display: none;
    min-width: 270px;
    transform: translateX(-50%);
    padding: 20px;
    background: var(--pern-blocks-navy);
    color: #fff;
    text-align: left;
    box-shadow: 0 18px 46px rgba(4, 8, 46, .28);
    z-index: 5;
}
.pern-editable-map__tooltip strong { display: block; font-size: 18px; line-height: 1.25; }
.pern-editable-map__tooltip em { display: block; margin-top: 8px; font-style: normal; line-height: 1.45; }
.pern-editable-map__tooltip a { display: inline-block; margin-top: 8px; color: #fff; font-weight: 700; }
.pern-editable-map__point:hover .pern-editable-map__tooltip,
.pern-editable-map__point:focus .pern-editable-map__tooltip,
.pern-editable-map__point[aria-expanded="true"] .pern-editable-map__tooltip { display: block; }
.pern-editable-map__pin-label { display: inline-flex; align-items: center; justify-content: center; width: 100%; height: 100%; font-size: 13px; }
.pern-editable-map__directory {
    padding: 28px;
    background: var(--pern-blocks-navy);
    color: #fff;
    box-shadow: 0 24px 70px rgba(4, 8, 46, .16);
}
.pern-editable-map__directory h3 { margin: 0 0 22px; color: #fff; }
.pern-editable-map__list { display: grid; gap: 14px; margin: 0; }
.pern-editable-map__list article { padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,.16); }
.pern-editable-map__list article:last-child { border-bottom: 0; }
.pern-editable-map__list strong { display: block; color: #fff; }
.pern-editable-map__list span { display: block; margin-top: 4px; color: rgba(255,255,255,.72); font-size: 13px; line-height: 1.35; }
.pern-editable-map__legend { margin-top: 22px; font-size: 13px; color: rgba(10, 20, 115, .75); }

.pern-contact-form { padding: clamp(70px, 8vw, 120px) 0; background: var(--pern-blocks-white); color: var(--pern-blocks-blue); text-align: center; }
.pern-contact-form__map { max-width: 780px; margin: 0 auto 44px; }
.pern-contact-form__form { max-width: 980px; margin: 0 auto; text-align: left; }
.pern-contact-form__placeholder { padding: 20px; border: 1px dashed rgba(10, 20, 115, .35); text-align: center; }
.pern-contact-form__legal { max-width: 980px; margin: 48px auto 0; font-size: 13px; text-align: left; }

@media (max-width: 900px) {
    .pern-hero-landing {
        --pern-blocks-site-header-offset: 72px;
    }

    .pern-info-highlight__grid,
    .pern-service-split-card__grid,
    .pern-split-content__grid,
    .pern-accordion-popup__grid,
    .pern-editable-map__layout { grid-template-columns: 1fr; }
    .pern-service-split-card--media-right .pern-service-split-card__media,
    .pern-split-content--media-right .pern-split-content__media { order: initial; }
    .pern-hero-landing__inner { grid-template-columns: 1fr; min-height: 420px; }
    .pern-accordion-popup__intro { position: static; }
    .pern-editable-map__stage { min-height: 420px; }
    .pern-hero-landing__spacer { display: none; }
}

.pern-contact-form__map-image { width: 100%; }

.pern-editable-map__list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 28px;
}
.pern-editable-map__list span {
    display: inline-flex;
    padding: 8px 12px;
    border: 1px solid rgba(10, 20, 115, .18);
    border-radius: 999px;
    background: #fff;
    color: var(--pern-blocks-blue);
    font-size: 13px;
}
.pern-editable-map__tooltip a {
    display: inline-block;
    margin-top: 8px;
    color: #fff;
    font-weight: 700;
}
.pern-editable-map__pin-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 12px;
}
.pern-info-highlight a { color: var(--pern-blocks-blue); font-weight: 700; }

.pern-contact-form__mock {
    display: grid;
    gap: 14px;
}
.pern-contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.pern-contact-form__mock input[type="text"],
.pern-contact-form__mock input[type="email"],
.pern-contact-form__mock input[type="tel"],
.pern-contact-form__mock textarea {
    width: 100%;
    border: 1px solid rgba(10, 20, 115, .28);
    padding: 13px 14px;
    color: var(--pern-blocks-blue);
    font: inherit;
}
.pern-contact-form__consent {
    display: grid;
    grid-template-columns: 18px 1fr;
    gap: 10px;
    align-items: start;
    font-size: 13px;
    line-height: 1.35;
}
.pern-contact-form__submit {
    justify-self: end;
    background: var(--pern-blocks-green);
}
@media (max-width: 700px) {
    .pern-contact-form__row { grid-template-columns: 1fr; }
    .pern-contact-form__submit { justify-self: stretch; }
}
