/* ──────────────────────────────────────────────────────────────────
   Strona /wypozyczalnia-2/ — wszystkie wartości 1:1 z JSON Elementor
   (post 5827). Prefix: .wyp-
─────────────────────────────────────────────────────────────────── */

.page-wypozyczalnia h1,
.page-wypozyczalnia h2 { text-transform: uppercase; }

/* 01 — HERO (z JSON: min-height 628/317/250, overlay gradient 61% white) */
.wyp-hero {
    width: 100%;
    height: 628px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: #f3e9da;
    position: relative;
    margin-bottom: clamp(-160px, -10vw, -100px);
    mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 100%);
    -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 100%);
    z-index: 0;
}

/* 02 — INTRO (padding 100/50, title 45px, body 16px, width 63%/69%) */
.wyp-intro {
    position: relative;
    z-index: 1;
    padding: clamp(120px, 14vw, 200px) 0 100px;
    background: transparent;
}
.wyp-intro__inner { text-align: center; }
.wyp-intro__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: 45px;
    line-height: 50px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: #000;
    margin: 0 auto 28px;
    max-width: 63%;
}
.wyp-intro__title strong { font-weight: 500; }
.wyp-intro__body {
    font-family: "Source Sans Pro", "Source Sans 3", sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    color: #000;
    margin: 0 auto;
    max-width: 69%;
}
.wyp-intro__body p { margin: 0 0 14px; }
.wyp-intro__body p:last-child { margin-bottom: 0; }
.wyp-intro__body strong, .wyp-intro__body b { font-weight: 700; }
.wyp-intro__body.is-clamped {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.wyp-intro__body.is-expanded { display: block; -webkit-line-clamp: unset; overflow: visible; }
.wyp-intro__toggle {
    margin: -15px auto 0;
    padding: 8px 0;
    background: transparent;
    border: 0;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #B58A2D;
    cursor: pointer;
    text-decoration: none;
    display: block;
}
.wyp-intro__toggle:hover { color: #000; }

/* 03 — PÓŁWYPOŻYCZENIE (bg #F5EEE8 primary, padding 50/0)
   ROZSZERZONA: 3 kolumny szersze, większe obrazki, mniej środkowej kolumny. */
.wyp-pol { padding: 50px 0; background: #F5EEE8; }
.wyp-pol__row {
    max-width: 1600px;                              /* szersza niż domyślny container 1320px */
    margin: 0 auto;
    padding: 0 30px;
    display: grid;
    grid-template-columns: 30% 40% 30%;             /* boki 30/30 zamiast 25/25 → większe zdjęcia */
    gap: 40px;
    align-items: center;
}
.wyp-pol__col--side { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.wyp-pol__cap {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    text-align: center;
    color: #000;
    margin: 0 0 10px;
}
.wyp-pol__cap .customtext1 { color: #B58A2D; font-weight: 600; }
.wyp-pol__img { width: 100%; height: auto; display: block; }

.wyp-pol__col--center { display: flex; flex-direction: column; align-items: center; gap: 18px; padding: 0 10px; }
.wyp-pol__divider {
    display: flex;
    align-items: center;
    gap: 16px;
    width: 100%;
    max-width: 480px;
}
.wyp-pol__divider--line { width: 53%; }
.wyp-pol__divider--icon { width: 60%; justify-content: center; gap: 14px; }
.wyp-pol__divider-line {
    flex: 1 1 auto;
    height: 1px;
    background: #B58A2D;
    display: block;
}
.wyp-pol__divider--line .wyp-pol__divider-text,
.wyp-pol__divider--icon .wyp-pol__divider-text {
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: 35px;
    text-transform: uppercase;
    color: #000;
    white-space: nowrap;
}
.wyp-pol__divider--icon .wyp-pol__divider-text { font-weight: 500; }
.wyp-pol__divider-icon { flex: 0 0 auto; width: 42px; height: 42px; }
.wyp-pol__body {
    font-family: "Source Sans Pro", sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.55;
    color: #000;
    text-align: center;
    max-width: 73%;
    margin: 0 auto;
}
.wyp-pol__body p { margin: 0 0 12px; }
.wyp-pol__body p:last-child { margin-bottom: 0; }
.wyp-pol__body strong, .wyp-pol__body b { font-weight: 700; }

/* 04 — CENNIK BOXES (padding 50/0, max-width 1360px, 3 kolumny 33/33/33) */
.wyp-cennik { padding: 50px 0; background: #fff; }
.wyp-cennik__inner { max-width: 1360px; margin: 0 auto; padding: 0 20px; }
.wyp-cennik__zasady { text-align: right; margin-bottom: 30px; }
.wyp-cennik__zasady-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #000;
    text-decoration: none;
    transition: color var(--ideo-dur-fast) var(--ideo-ease);
}
.wyp-cennik__zasady-link svg { transition: transform var(--ideo-dur-base) var(--ideo-ease); }
.wyp-cennik__zasady-link:hover { color: #B58A2D; }
.wyp-cennik__zasady-link:hover svg { transform: translateX(6px); }

.wyp-cennik__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
    align-items: stretch;
}

.wyp-cennik__text { padding: 0 20px; }
.wyp-cennik__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: 30px;
    line-height: 36px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: #000;
    margin: 0 0 22px;
}
.wyp-cennik__title strong { font-weight: 500; }
.wyp-cennik__body {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: #000;
    margin: 0 0 8px;
}
.wyp-cennik__body p { margin: 0 0 12px; }
.wyp-cennik__body p:last-child { margin-bottom: 0; }
.wyp-cennik__body strong { font-weight: 700; }
.wyp-cennik__body.is-clamped {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.wyp-cennik__body.is-expanded { display: block; -webkit-line-clamp: unset; overflow: visible; }
.wyp-cennik__toggle {
    margin-top: -10px;
    padding: 8px 0;
    background: transparent;
    border: 0;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #B58A2D;
    cursor: pointer;
}
.wyp-cennik__toggle:hover { color: #000; }

/* Karty cennika */
.wyp-cennik__card {
    padding: 30px 30px;
    min-height: 500px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
}
.wyp-cennik__card--klasyczne {
    background: #fff;
    border: 1px solid #F5EEE8;
    color: #000;
}
.wyp-cennik__card--gold {
    background: linear-gradient(282deg, #927535 0%, #CAAB69 100%);
    border: 1px solid #F5EEE8;
    color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
}
.wyp-cennik__card-divider {
    display: flex; align-items: center; gap: 14px;
    width: 82%;
    margin-bottom: 6px;
}
.wyp-cennik__card-divider-line {
    flex: 1 1 auto;
    height: 1px;
    background: currentColor;
    opacity: 0.7;
}
.wyp-cennik__card-divider-text {
    flex: 0 0 auto;
    font-family: "Playfair Display", "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: 20px;
    text-transform: uppercase;
    color: inherit;
    white-space: nowrap;
}
.wyp-cennik__card--klasyczne .wyp-cennik__card-divider-text { color: #B58A2D; }
.wyp-cennik__card--gold      .wyp-cennik__card-divider-text { color: #fff; }
.wyp-cennik__card-lead {
    font-family: "Source Sans Pro", sans-serif;
    font-style: italic;
    font-size: 16px;
    color: inherit;
    line-height: 1.5;
    max-width: 85%;
    margin: 0 0 10px;
}
.wyp-cennik__card--klasyczne .wyp-cennik__card-lead { color: #686868; }
.wyp-cennik__list {
    list-style: none;
    padding: 20px 0;
    margin: 0;
    width: 90%;
    border-top: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.wyp-cennik__card--klasyczne .wyp-cennik__list { border-color: #000; }
.wyp-cennik__card--gold      .wyp-cennik__list { border-color: #fff; }
.wyp-cennik__list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 16px;
    line-height: 23px;
    text-align: left;
    color: inherit;
}
.wyp-cennik__check { flex: 0 0 14px; margin-top: 5px; }
.wyp-cennik__card--klasyczne .wyp-cennik__check { color: #B58A2D; }
.wyp-cennik__card--gold      .wyp-cennik__check { color: #fff; }
.wyp-cennik__list li strong { font-weight: 700; }

.wyp-cennik__prices {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 10px 0;
    width: 90%;
    align-items: center;
}
.wyp-cennik__price { text-align: center; padding: 0 6px; }
.wyp-cennik__price strong {
    display: block;
    font-family: "Lato", "Source Sans Pro", sans-serif;
    font-weight: 600;
    font-size: 22px;
    color: #B58A2D;
    line-height: 1.2;
}
.wyp-cennik__card--gold .wyp-cennik__price strong { color: #fff; }
.wyp-cennik__price span {
    display: block;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 14px;
    color: inherit;
    margin-top: 4px;
}
.wyp-cennik__price--big { padding: 14px 0; }
.wyp-cennik__price--big strong {
    font-family: "Source Sans Pro", sans-serif;
    font-weight: 600;
    font-size: 26px;
    color: #fff;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.06);
}

/* 07 — CENNIK (2 zdjęcia + tekst) — padding 50, 2 obrazki 40% each */
.wyp-cennik2 { padding: 50px 0; background: #fff; }
.wyp-cennik2__row {
    display: grid;
    grid-template-columns: 55% 45%;
    gap: 40px;
    align-items: center;
}
.wyp-cennik2__media { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wyp-cennik2__photo {
    aspect-ratio: 4/5;
    min-height: 400px;
    background-size: cover;
    background-position: center;
    background-color: #f3e9da;
}
.wyp-cennik2__text { padding: 0 20px; }
.wyp-cennik2__title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: 30px;
    line-height: 36px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: #000;
    margin: 0 0 22px;
    max-width: 70%;
}
.wyp-cennik2__body {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: #000;
    text-align: justify;
    margin: 0 0 8px;
    max-width: 73%;
}
.wyp-cennik2__body p { margin: 0 0 12px; }
.wyp-cennik2__body p:last-child { margin-bottom: 0; }
.wyp-cennik2__body strong { font-weight: 700; }
.wyp-cennik2__body.is-clamped {
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.wyp-cennik2__body.is-expanded { display: block; -webkit-line-clamp: unset; overflow: visible; }
.wyp-cennik2__toggle {
    margin-top: -10px;
    padding: 8px 0;
    background: transparent;
    border: 0;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #B58A2D;
    cursor: pointer;
}
.wyp-cennik2__toggle:hover { color: #000; }

/* ── Mobile/Tablet ── */
@media (max-width: 1024px) {
    .wyp-hero { height: 317px; }
    .wyp-pol__row { grid-template-columns: 1fr; }
    .wyp-pol__col--side { display: none; }              /* obrazki side ukryte na tablet — z JSON-a */
    .wyp-cennik__grid { grid-template-columns: 1fr; gap: 40px; }
    .wyp-cennik__card { min-height: auto; max-width: 70%; margin: 0 auto; }
    .wyp-cennik2__row { grid-template-columns: 1fr; gap: 30px; }
}
@media (max-width: 600px) {
    .wyp-hero { height: 250px; }
    .wyp-intro { padding: 100px 10px 50px; }
    .wyp-intro__title { font-size: 25px; line-height: 1; max-width: 100%; }
    .wyp-intro__body { font-size: 16px; max-width: 100%; }
    .wyp-cennik__card { max-width: 90%; }
    .wyp-cennik2__title,
    .wyp-cennik2__body { max-width: 100%; }
    .wyp-cennik2__title { font-size: 25px; line-height: 1; }
    .wyp-cennik2__media { grid-template-columns: 1fr; }
    .wyp-cennik2__photo { min-height: 280px; }
    .wyp-pol__divider-text,
    .wyp-pol__divider--icon .wyp-pol__divider-text { font-size: 25px; white-space: normal; }
}
