/* ==========================================================================
   PB Projects Grid Block
   .pb-section-pb-f-projects-grid
   Responsive 2 / 3 / 4 column grid of project tiles pulled from the
   pb_projects CPT. Header (intro left, optional link button right), optional
   front-end category + country filters, then a grid of translucent tiles:
   featured image (16:9) + title + blurb, the whole tile linking to the project.

   COLOUR DERIVATION: like pb_f_cards / pb_f_team_grid, the section background
   (`.pb-section.bg-*`) determines the tile colours. The section's own
   text/heading/link is derived globally in pb-section-bgcolors.css (§4.0 G2);
   the tile surface + tile text are derived HERE, scoped per section ground,
   because G2 does not cover nested tiles. Figma ground is teal (#09414e), with
   tiles at rgba(0,44,53,0.5) (teal-dark @ 50%).
   ========================================================================== */

/* ---- Section base -------------------------------------------------------- */

.pb-section-pb-f-projects-grid {
    position: relative;
}

/* ---- Margin wrapper ------------------------------------------------------ */

.pb-section-pb-f-projects-grid .pb-section-margin-wrap {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
    padding-left: 24px;
    padding-right: 24px;
}

@media (min-width: 768px) {
    .pb-section-pb-f-projects-grid .pb-section-margin-wrap {
        padding-left: 24px;
        padding-right: 24px;
    }
}

@media (min-width: 1300px) {
    .pb-section-pb-f-projects-grid .pb-section-margin-wrap {
        padding-left: 0px;
        padding-right: 0px;
    }
}

/* ==========================================================================
   Header — intro block (left) + optional link button (right)
   ========================================================================== */

.pb-section-pb-f-projects-grid .pb-projects-grid-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

@media (min-width: 768px) {
    .pb-section-pb-f-projects-grid .pb-projects-grid-header {
        margin-bottom: 48px;
    }
}

.pb-section-pb-f-projects-grid .pb-projects-grid-intro {
    max-width: 640px;
        min-width: 0;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 24px;
}

@media (min-width: 768px) {
.pb-section-pb-f-projects-grid .pb-projects-grid-intro {

    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;

}
}

.pb-section-pb-f-projects-grid .pb-projects-grid-heading {
    margin: 0;
    font-family: var(--font-mono, 'Source Code Pro', monospace);
    font-weight: 500;
    font-size: 40px;
    line-height: 1.15;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}



/* Top-right link button column — never shrinks. */
.pb-section-pb-f-projects-grid .pb-projects-grid-cta {
    flex: 0 0 auto;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-cta .pb-projects-grid-cta-wrap {
    margin: 0;
}

/* ==========================================================================
   Front-end filters (optional)
   ========================================================================== */

.pb-section-pb-f-projects-grid .pb-projects-grid-filters {
    display: flex;
    justify-content: flex-start;
    align-items: flex-end;
    gap: 40px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-filter {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-filter-select {
    font-family: var(--font-body, 'Outfit', sans-serif);
    font-size: 16px;
    line-height: 1.2;
    padding: 6px 14px;
    background-color: transparent;
    color: inherit;
    border: 1px solid currentColor;
    border-radius: 0;
    cursor: pointer;
    min-width: 180px;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-filter-select:focus-visible {
    outline: 2px solid var(--colour-primary-orange);
    outline-offset: 2px;
}

/* The <select> popup list is drawn by the OS using these colours; force a
   readable contrast regardless of the (possibly translucent) section text. */
.pb-section-pb-f-projects-grid .pb-projects-grid-filter-select option {
    color: var(--colour-teal-dark);
    background-color: var(--colour-white);
}


/* ==========================================================================
   Tiles grid — auto layout based on result count
   .layout-solo  (1 project) — text column + media column (whole row linked)
   .layout-duo   (2 projects) — two bigger tiles, side by side from tablet up
   .layout-grid  (3+)         — 1 / 2 / 3 cols responsive
   Mobile collapses every layout to a single column.
   ========================================================================== */

.pb-section-pb-f-projects-grid .pb-projects-grid-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 64px 32px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-item {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    min-width: 0;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-row.cards-have-bg {
    gap: 16px 16px;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-row.cards-have-bg .pb-projects-grid-item {
    padding: 24px;
}

.pb-section-pb-f-projects-grid .pb-projects-grid-row.cards-have-bg .bg-teal-dark h3 {
    color: var(--colour-white);
}

/* ---- 3+ projects (grid) -------------------------------------------------- */

@media (min-width: 768px) and (max-width: 1023px) {
    .pb-section-pb-f-projects-grid .pb-projects-grid-row.layout-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .pb-section-pb-f-projects-grid .pb-projects-grid-row.layout-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ---- 2 projects (duo) ---------------------------------------------------- */
/* Two columns from tablet up, slightly larger gap. Tile typography scales up
   so the duo doesn't read like a half-empty 3-col grid. */

@media (min-width: 768px) {
    .pb-section-pb-f-projects-grid .pb-projects-grid-row.layout-duo {
        grid-template-columns: repeat(2, 1fr);
        gap: 64px 32px;
    }
}

.pb-section-pb-f-projects-grid .layout-duo .pb-projects-card {
    gap: 24px;
}

@media (min-width: 768px) {
    .pb-section-pb-f-projects-grid .layout-duo .pb-projects-card-title {
        font-size: 32px;
    }
    .pb-section-pb-f-projects-grid .layout-duo .pb-projects-card-blurb {
        font-size: 20px;
    }
}

/* ---- 1 project (solo) ---------------------------------------------------- */
/* Single full-width tile that becomes a 2-up layout at ≥768px: text left,
   media right (image lifted out of the stacked column flow). The whole tile
   is still one <a>; we just reshape the inside. */

.pb-section-pb-f-projects-grid .pb-projects-grid-row.layout-solo .pb-projects-grid-item {
    width: 100%;
}

.pb-projects-card-location {
    color: #b2bcc1;
}

.layout-solo .pb-projects-card-location {
    text-transform: uppercase;
    margin: 10px 0;
}

@media (min-width: 768px) {
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card {
        display: grid;
        grid-template-columns: 30% auto;
        gap: 48px;
        padding: 0;
    }

    /* Text first in the source order — CSS grid columns put it left, media right. */
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card-text {
        order: 1;
    }
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card-media {
        order: 2;
    }

    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card-title {
        font-size: 28px;
    }
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card-blurb {
        font-size: 20px;
    }
}

@media (min-width: 1280px) {
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card {
        gap: 80px;
        padding: 0;
    }
    .pb-section-pb-f-projects-grid .layout-solo .pb-projects-card-title {
        font-size: 28px;
    }
}

/* ==========================================================================
   Project tile (whole-tile link)
   ========================================================================== */

.pb-section-pb-f-projects-grid .pb-projects-card {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 0;
    height: 100%;
    width: 100%;
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s linear, background-color 0.2s linear;
}


a.pb-projects-card:focus-visible {
    outline: 2px solid var(--colour-primary-orange);
    outline-offset: 4px;
}

.pb-section-pb-f-projects-grid .pb-projects-card.is-no-link {
    cursor: default;
}

/* The whole tile is a link, so it must NOT carry the global body-link underline
   (`.pb-section.bg-* ul > li > a`, specificity 0-2-3, out-specifies the base
   .pb-projects-card rule and propagates an underline onto the title/blurb).
   Kill it at the source with a higher-specificity selector — the tile's
   affordance is the hover lift + focus ring, not an underline (matches Figma). */
.pb-section-pb-f-projects-grid .pb-projects-grid-row > .pb-projects-grid-item > a.pb-projects-card,
.pb-section-pb-f-projects-grid .pb-projects-grid-row > .pb-projects-grid-item > a.pb-projects-card:hover,
.pb-section-pb-f-projects-grid .pb-projects-grid-row > .pb-projects-grid-item > a.pb-projects-card:focus {
    text-decoration: none;
}

/* ---- Tile media (16:9 cover) -------------------------------------------- */

.pb-section-pb-f-projects-grid .pb-projects-card-media {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.pb-section-pb-f-projects-grid .pb-projects-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.pb-section-pb-f-projects-grid .pb-projects-card-media-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: var(--font-body, 'Outfit', sans-serif);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.25;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.9);
    transition: opacity 0.3s ease;

}

.pb-projects-card:hover .pb-projects-card-media-overlay {
    opacity: 1;
}


.pb-section-pb-f-projects-grid .pb-projects-card-img-placeholder {
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.12));
}

/* ---- Tile text ----------------------------------------------------------- */

.pb-section-pb-f-projects-grid .pb-projects-card-text {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.pb-section-pb-f-projects-grid .pb-projects-card-title {
    margin: 0;
    font-family: var(--font-mono, 'Source Code Pro', monospace);
    font-weight: 500;
    font-size: 24px;
    line-height: 1.1;
    letter-spacing: 0.32px;
    text-transform: uppercase;
}

.pb-section-pb-f-projects-grid .pb-projects-card-blurb {
    font-family: var(--font-body, 'Outfit', sans-serif);
    font-size: 18px;
    line-height: 1.4;
    color: var(--colour-light-grey);
}

.pb-section-pb-f-projects-grid .pb-projects-card-blurb p {
    margin: 0 0 0.75em;
}

.pb-section-pb-f-projects-grid .pb-projects-card-blurb p:last-child {
    margin-bottom: 0;
}

.pb-section-pb-f-projects-grid .pb-projects-card-blurb a {
    color: inherit;
    text-decoration: underline;
}

/* JS filter visibility toggle */
.pb-section-pb-f-projects-grid .pb-projects-grid-item.is-hidden {
    display: none !important;
}




/* ---- LIGHT grounds (white / light-grey / teal-light) --------------------
   Tile = a subtle dark veil; title teal-dark; blurb muted teal-dark; the
   header text uses the on-light treatment. The title + blurb MUST be set
   explicitly here (the base colours are light/white and would vanish). */

.pb-section-pb-f-projects-grid.bg-white .pb-projects-card,
.pb-section-pb-f-projects-grid.bg-light-grey .pb-projects-card,
.pb-section-pb-f-projects-grid.bg-teal-light .pb-projects-card {
    background-color: rgba(0, 44, 53, 0.06);
}

.pb-section-pb-f-projects-grid.bg-white .pb-projects-card-title,
.pb-section-pb-f-projects-grid.bg-light-grey .pb-projects-card-title,
.pb-section-pb-f-projects-grid.bg-teal-light .pb-projects-card-title {
    color: var(--colour-teal-dark);
}

.pb-section-pb-f-projects-grid.bg-white .pb-projects-card-blurb,
.pb-section-pb-f-projects-grid.bg-light-grey .pb-projects-card-blurb,
.pb-section-pb-f-projects-grid.bg-teal-light .pb-projects-card-blurb {
    color: rgba(0, 44, 53, 0.7);
    color: color-mix(in srgb, var(--colour-teal-dark) 70%, transparent);
}



/* On light grounds the placeholder gradient (built for dark grounds) is nearly
   invisible — swap to a dark-tint gradient so empty tiles still read. */
.pb-section-pb-f-projects-grid.bg-white .pb-projects-card-img-placeholder,
.pb-section-pb-f-projects-grid.bg-light-grey .pb-projects-card-img-placeholder,
.pb-section-pb-f-projects-grid.bg-teal-light .pb-projects-card-img-placeholder {
    background: linear-gradient(135deg, rgba(0, 44, 53, 0.06), rgba(0, 44, 53, 0.14));
}

/* ==========================================================================
   Mobile-down adjustments
   ========================================================================== */

@media (max-width: 767px) {
    .pb-section-pb-f-projects-grid .pb-projects-grid-row {
        grid-template-columns: 1fr;
    }

    .pb-section-pb-f-projects-grid .pb-projects-grid-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .pb-section-pb-f-projects-grid .pb-projects-grid-filters {
        justify-content: flex-start;
    }

    .pb-section-pb-f-projects-grid .pb-projects-grid-filter-select {
        min-width: 0;
        width: 100%;
    }

    .pb-section-pb-f-projects-grid .pb-projects-grid-heading {
        font-size: 30px;
    }

    .pb-section-pb-f-projects-grid .pb-projects-card-title {
        font-size: 26px;
    }
}

/* ---- Editor preview placeholder ----------------------------------------- */

.pb-section-pb-f-projects-grid .pb-projects-grid-item.is-placeholder {
    opacity: 0.85;
    outline: 1px dashed rgba(255, 255, 255, 0.25);
}
