.page-header {
    background: var(--nook-c-white);
    border-bottom: var(--nook-border-50);
    padding: 36px 0 28px;
    position: relative;
    overflow: hidden;
}
.page-header::after {
    content: '';
    position: absolute; inset: 0;
    background-image: radial-gradient(circle, rgba(0,51,141,0.055) 1px, transparent 1px);
    background-size: 24px 24px;
    mask-image: linear-gradient(to left, black 0%, black 30%, transparent 68%);
    -webkit-mask-image: linear-gradient(to left, black 0%, black 30%, transparent 68%);
    pointer-events: none;
}

.page-header-inner { position: relative; z-index: 1; }

.header-breadcrumb {
    display:flex; align-items:center; gap:6px;
    font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.13em;
    color:var(--nook-c-meta); margin-bottom:18px;
}
.header-breadcrumb a { color:var(--nook-c-meta); }
.header-breadcrumb a:hover { color:var(--nook-c-primary); }
.header-breadcrumb .sep { display:inline-block; width:12px; height:1px; background:#d4d4d4; flex-shrink:0; }
.header-breadcrumb .current { color:var(--nook-c-blue); font-weight:800; }

.header-eyebrow {
    display:inline-flex; align-items:center; gap:8px;
    font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:0.22em;
    color:var(--nook-c-primary); margin-bottom:8px;
}
.header-eyebrow::before { content:''; width:20px; height:2px; background:var(--nook-c-primary); flex-shrink:0; }

.header-title {
    font-family: var(--f-display);
    font-size: clamp(40px, 5vw, 68px);
    line-height:1; letter-spacing:0.02em;
    color:var(--nook-c-blue); margin-bottom:10px;
}
.header-desc { font-size:13px; line-height:20px; color:var(--nook-c-text); max-width:520px; }

.header-bottom {
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:12px; margin-top:20px; padding-top:16px;
    border-top: var(--nook-border-50);
}
.header-count { display:flex; align-items:baseline; gap:6px; }
.header-count-num { font-family:var(--f-display); font-size:26px; line-height:1; color:var(--nook-c-blue); }
.header-count-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.13em; color:var(--nook-c-meta); }

/* ================================================
    CITY GRID
================================================ */
.nook-section { margin-top: var(--nook-section-pad); margin-bottom: var(--nook-section-pad); }

.cities-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--nook-col-gap);
}

/* pierwsza karta — "featured", zajmuje 2 kolumny */
.city-card--featured {
    grid-column: span 2;
}

/* ---- CITY CARD — bazuje na .nook-offer-card ---- */
.city-card {
    display: flex;
    width: 100%;
    backface-visibility: hidden;
}
.city-card:hover a {
    color: var(--nook-c-text);
}

.city-card-link {
    display: flex; flex-direction: column; width: 100%;
    background: var(--nook-c-white);
    border: var(--nook-border-50);
    border-radius: var(--nook-radius) var(--nook-radius) var(--nook-radius-lg) var(--nook-radius);
    text-decoration: none; color: var(--nook-c-text);
    overflow: hidden; transition: var(--nook-transition);
    position: relative;
}
.city-card-link:hover {
    box-shadow: 0 8px 28px rgba(0,0,0,0.09);
}
 
 

/* media — ratio 4:3 jak offer-media */
.city-img {
    position: relative; overflow: hidden;
    padding-top: 75%; /* 4:3 */
}
.city-card--featured .city-img {
    padding-top: 52%; /* featured — szersza, nieco niższa */
}
.city-img img {
    position: absolute; inset: 0;
    width: 100%; height: 100%; object-fit: cover;
    display: block; transition: transform 0.4s ease;
}

/* pink→blue pasek na dole zdjęcia — identyczny jak offer-media::after */
.city-img::after {
    content: "";
    position: absolute; bottom: 0; left: 0;
    width: 100%; height: 4px;
    background: linear-gradient(90deg, var(--pink), var(--blue));
    opacity: 0.8;
    z-index: 2;
}

/* badge popularności */
.city-badge {
    position: absolute; top: 10px; left: 10px; z-index: 3;
    font-size: 9px; font-weight: 800; text-transform: uppercase;
    letter-spacing: 0.14em; padding: 3px 8px;
    border-radius: var(--nook-radius-xs);
    background: var(--nook-c-primary); color: #fff;
}

/* content */
.city-content {
    display: flex; flex-direction: column; flex: 1;
    padding: var(--sp-4);
}
.city-meta-top {
    display: flex; justify-content: space-between; align-items: center;
    gap: var(--sp-2); margin-bottom: var(--sp-2);
    font-size: var(--nook-fs-xsmall); line-height: var(--nook-lh-xsmall);
    color: var(--nook-c-text); opacity: .7;
}
.city-name {
    font-size: var(--nook-fs-h4); line-height: var(--nook-lh-h4);
    font-weight: 600; margin-bottom: var(--sp-2);
    color: var(--nook-c-title);
}
.city-desc {
 
    margin-bottom: var(--sp-3);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* types pills */
.city-types {
    display: flex; flex-wrap: wrap; gap: 4px;
    margin-bottom: var(--sp-3);
}
.city-type-pill {
    font-size: 9px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.08em; padding: 2px 7px;
    border-radius: var(--nook-radius-xs);
    background: var(--nook-bg-page);
    border: 1px solid var(--nook-c-border);
    color: var(--nook-c-meta);
    white-space: nowrap;
}

/* footer — jak offer-footer */
.city-footer {
    margin-top: auto;
    display: flex; justify-content: space-between; align-items: center;
    gap: var(--sp-2);
}
.city-count-wrap { display: flex; flex-direction: column; gap: 1px; }
.city-count-num {
    font-family: var(--f-display);
    font-size: 20px; line-height: 1; color: var(--nook-c-blue);
}
.city-count-label {
    font-size: 9px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .13em; color: var(--nook-c-meta);
}
.city-arrow {
    display: flex; align-items: center; justify-content: center;
    width: 30px; height: 30px;
    background: #eee; border-radius: 50%;
    font-size: var(--nook-fs-small); font-weight: 600;
    transition: var(--nook-transition);
    flex-shrink: 0;
}

@media (max-width: 1024px) {
    .cities-grid { grid-template-columns: repeat(3,1fr); }
    .city-card--featured { grid-column: span 2; }
}
@media (max-width: 680px) {
    .cities-grid { grid-template-columns: repeat(2,1fr); }
    .city-card--featured { grid-column: span 2; }
}
