/* =============================================================================
   p-d-s-style.css  —  project-display-plus-socials
   Single project page: Fancybox gallery + meta column + bottom nav.
   Imports shared tokens from prjct-style.css.
   Version: 1.0.0
   ============================================================================= */

/* ── Outer wrapper ───────────────────────────────────────────────────────── */
.prjct-detail-outer {
    max-width:  var(--prjct-max-width);
    margin:     0 auto;
    padding:    0 var(--prjct-padding-x);
    box-sizing: border-box;
}

/* ── Two-column layout ───────────────────────────────────────────────────── */
.prjct-detail-wrap {
    display:               grid;
    grid-template-columns: 2fr 1fr;
    gap:                   32px;
    padding-bottom:        48px;
    padding-top:           8px;
    box-sizing:            border-box;
    align-items:           start;
}

/* ── Gallery column ──────────────────────────────────────────────────────── */
.prjct-gallery { min-width: 0; }

.pprjct-gallery-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   6px;
}

.pprjct-gallery-grid[data-count="1"] .prjct-gallery-img,
.prjct-gallery-grid[data-count="1"]  .prjct-gallery-img { grid-column: 1 / -1; }
.prjct-gallery-img.prjct-landscape  { grid-column: 1 / -1; }

.prjct-gallery-img {
    display:       block;
    overflow:      hidden;
    background:    var(--prjct-surface-alt);
    cursor:        zoom-in;
    border-radius: 6px;
    /* aspect-ratio set inline from PHP ($w/$h) — reserves correct cell
       height before images load, preventing the background-colour gap. */
}

.prjct-gallery-img img {
    width:         100%;
    height:        100%;   /* fill the aspect-ratio-driven wrapper height */
    display:       block;
    object-fit:    cover;
    transition:    var(--prjct-transition-img);
    border-radius: 6px;
}

/* Height caps on the wrapper (not the img) so they coexist with aspect-ratio */
.prjct-gallery-img.prjct-portrait  { max-height: 680px; }
.prjct-gallery-img.prjct-landscape { max-height: 380px; }
.prjct-gallery-img:hover img { transform: scale(1.03); }

/* Remove focus outlines (Fancybox adds its own) */
.prjct-gallery-img:focus,
.prjct-gallery-img:focus-visible,
.prjct-gallery-img:active {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}
img:focus-visible { outline: none !important; }

/* ── Meta column ─────────────────────────────────────────────────────────── */
.prjct-meta {
    min-width: 0;
    position:  sticky;
    top:       100px;
}

/* ── Heading block (title + payoff) ──────────────────────────────────────── */
.prjct-detail-heading {
    margin-bottom:  24px;
    padding-bottom: 20px;
    border-bottom:  1px solid rgba(0,0,0,0.08);
}

/* H1 inherits from theme.json h1 styles;
   fall back to explicit values for non-FSE contexts */
.prjct-detail-title {
    font-size:      var(--wp--preset--font-size--x-large,
                        clamp(1.5rem, 2.5vw, 2.2rem));
    font-family:    var(--wp--preset--font-family--heading, Georgia, serif);
    font-weight:    400;
    line-height:    1.1;
    letter-spacing: -0.02em;
    margin:         0 0 8px;
}

.prjct-detail-payoff {
    font-size:   var(--wp--preset--font-size--medium, 1rem);
    font-style:  italic;
    font-family: var(--wp--preset--font-family--heading, Georgia, serif);
    color:       var(--prjct-ink-muted);
    margin:      0;
    line-height: 1.4;
}

/* Desktop: show heading inside meta column; mobile: move above gallery */
/* Note: actual classes are prjct-heading-top / prjct-heading-meta */
.prjct-detail-heading-top,
.prjct-heading-top  { display: none; }

.prjct-detail-heading-meta,
.prjct-heading-meta { display: block; }

@media (max-width: 900px) {
    .prjct-detail-heading-top,
    .prjct-heading-top  { display: block; }

    .prjct-detail-heading-meta,
    .prjct-heading-meta { display: none; }
}

/* ── Description ─────────────────────────────────────────────────────────── */
.prjct-detail-description {
    font-size:     var(--wp--preset--font-size--small, 0.92rem);
    line-height:   1.75;
    color:         var(--prjct-ink-muted);
    margin-bottom: 20px;
}

/* ── Meta data grid ──────────────────────────────────────────────────────── */
.prjct-meta-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   0;
}

.prjct-meta-section {
    padding:       12px 0;
    border-bottom: 1px solid rgba(0,0,0,0.07);
}
.prjct-meta-section-full { grid-column: 1 / -1; }

/* H4 label — inherits from theme.json h4 styles */
.prjct-meta-label {
    font-size:      var(--wp--preset--font-size--x-small, 0.65rem);
    font-weight:    600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color:          var(--prjct-ink-muted);
    margin:         0 0 4px;
}

.prjct-meta-value {
    font-size:   var(--wp--preset--font-size--small, 0.88rem);
    color:       var(--prjct-ink);
    margin:      0;
    line-height: 1.5;
}
.prjct-meta-value p          { margin: 0 0 0.4em; }
.prjct-meta-value p:last-child { margin: 0; }

/* ── Tags ────────────────────────────────────────────────────────────────── */
.prjct-tags {
    display:   flex;
    flex-wrap: wrap;
    gap:       5px;
    margin:    0;
}

.prjct-tag {
    display:         inline-block;
    padding:         3px 10px;
    border:          1px solid rgba(0,0,0,0.15);
    border-radius:   20px;
    font-size:       0.74rem;
    color:           var(--prjct-ink-muted);
    text-decoration: none;
    transition:      background 180ms, color 180ms;
    line-height:     1.6;
}
a.prjct-tag:hover { background: var(--prjct-accent); color: #fff; border-color: var(--prjct-accent); }

/* ── External link ───────────────────────────────────────────────────────── */
.prjct-detail-link {
    font-size:       var(--wp--preset--font-size--small, 0.88rem);
    color:           var(--prjct-ink);
    text-decoration: none;
    border-bottom:   1px solid rgba(0,0,0,0.2);
    transition:      border-color 180ms;
}
.prjct-detail-link:hover { border-color: var(--prjct-ink); }

/* ── Video embed ─────────────────────────────────────────────────────────── */
.prjct-video-wrap {
    position:     relative;
    width:        100%;
    aspect-ratio: 16/9;
    overflow:     hidden;
    background:   #000;
    margin-top:   8px;
}
.prjct-video-wrap iframe,
.prjct-video-wrap embed,
.prjct-video-wrap object {
    position: absolute;
    inset:    0;
    width:    100%;
    height:   100%;
}

/* ── Social sharing ──────────────────────────────────────────────────────── */
.prjct-social-wrapper {
    margin-top:  60px;
    padding-top: 20px;
}

.prjct-social {
    border-top:  1px solid rgba(0,0,0,0.06);
    padding-top: 24px;
}

.prjct-share-buttons {
    display:    flex;
    flex-wrap:  wrap;
    gap:        4px;
    align-items: center;
}

.prjct-share-btn {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           32px;
    height:          32px;
    padding:         0;
    border-radius:   50%;
    text-decoration: none;
    transition:      all 0.2s ease;
    cursor:          pointer;
    background:      transparent;
    color:           rgba(0,0,0,0.35);
    border:          none;
    opacity:         0.6;
}
.prjct-share-btn svg     { width: 14px; height: 14px; flex-shrink: 0; }
.prjct-share-btn:hover   { opacity: 1; transform: translateY(-1px); background: rgba(0,0,0,0.05); color: rgba(0,0,0,0.8); }

.prjct-share-copy.prjct-copied {
    background:     rgba(16,185,129,0.1);
    color:          #10b981;
    opacity:        1;
    pointer-events: none;
}
@keyframes prjct-check-pop {
    0%   { transform: scale(1);   }
    50%  { transform: scale(1.2); }
    100% { transform: scale(1);   }
}
.prjct-share-copy.prjct-copied svg { animation: prjct-check-pop 0.3s ease; }

/* ── Bottom project navigation bar ──────────────────────────────────────── */
.prjct-nav {
    position:                fixed;
    bottom:                  0;
    left:      max(0px, calc(50vw - (var(--wp--style--global--wide-size, 1200px) / 2)));
    width:     var(--wp--style--global--wide-size, 1200px);
    max-width: 100vw;
    z-index:                 9999;
    display:                 grid;
    grid-template-columns:   1fr auto 1fr;
    gap:                     12px;
    padding-top:             16px;
    padding-bottom:          16px;
    padding-left:            max(24px, env(safe-area-inset-left));
    padding-right:           max(24px, env(safe-area-inset-right));
    box-sizing:              border-box;
    border-top:              1px solid rgba(0,0,0,0.1);
    background:              var(--wp--custom--project-grid--nav-bg,
                                 rgba(255,255,255,0.97));
    backdrop-filter:         blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow:              0 -2px 20px rgba(0,0,0,0.06);
    transform:               translateY(100%);
    opacity:                 0;
    pointer-events:          none;
    transition:              transform 0.4s cubic-bezier(0.175,0.885,0.32,1.275),
                             opacity   0.3s ease,
                             bottom    0.2s ease;
}


/* ── Nav items (prev / next) ─────────────────────────────────────────────── */
.prjct-nav-item {
    display:         flex;
    align-items:     center;
    gap:             14px;
    text-decoration: none;
    color:           inherit;
    padding:         14px;
    border:          1px solid rgba(0,0,0,0.08);
    border-radius:   6px;
    background:      rgba(0,0,0,0.01);
    transition:      background 200ms, box-shadow 200ms;
    min-height:      72px;
    width:           100%;
    box-sizing:      border-box;
}

.prjct-nav-item:hover:not(.prjct-nav-disabled) {
    background:  rgba(0,0,0,0.04);
    box-shadow:  0 3px 12px rgba(0,0,0,0.08);
}

.prjct-nav-disabled { opacity: 0.35; pointer-events: none; }

/* Prev — thumb left, text right of thumb */
.prjct-nav-prev {
    flex-direction:  row;
    justify-content: flex-start;
    text-align:      left;
}

.prjct-nav-prev .prjct-nav-thumb   { order: 1; }
.prjct-nav-prev .prjct-nav-content { order: 2; align-items: flex-start; }

/* Next — text fills space, thumb pinned to right edge */
.prjct-nav-next {
    flex-direction:  row;
    justify-content: flex-start;
    text-align:      right;
}

.prjct-nav-next .prjct-nav-content {
    order:       1;
    align-items: flex-end;
    flex:        1;
}

.prjct-nav-next .prjct-nav-thumb {
    order:       2;
    margin-left: auto;
    flex-shrink: 0;
}

/* ── Thumbnails ──────────────────────────────────────────────────────────── */
.prjct-nav-thumb {
    width:         56px;
    height:        56px;
    border-radius: 4px;
    overflow:      hidden;
    flex-shrink:   0;
}

.prjct-nav-thumb img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    display:    block;
}

/* ── Text content ────────────────────────────────────────────────────────── */
.prjct-nav-content {
    display:        flex;
    flex-direction: column;
    gap:            4px;
    min-width:      0;
    flex:           1;
}

.prjct-nav-label {
    font-size:      var(--wp--preset--font-size--x-small, 0.68rem);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color:          var(--prjct-ink-muted);
    font-weight:    600;
    white-space:    nowrap;
}

.prjct-nav-title {
    font-size:     0.9rem;
    font-weight:   600;
    color:         var(--prjct-ink);
    white-space:   nowrap;
    overflow:      hidden;
    text-overflow: ellipsis;
    max-width:     100%;
}

.prjct-nav-none { font-style: italic; color: var(--prjct-border); }

/* ── Centre home button ──────────────────────────────────────────────────── */
.prjct-nav-home {
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             6px;
    text-decoration: none;
    color:           var(--prjct-ink-muted);
    padding:         12px;
    border:          1px solid rgba(0,0,0,0.08);
    border-radius:   6px;
    background:      rgba(0,0,0,0.01);
    font-size:       0.72rem;
    font-weight:     600;
    text-transform:  uppercase;
    letter-spacing:  0.06em;
    transition:      background 200ms;
    min-width:       80px;
    white-space:     nowrap;
}

.prjct-nav-home:hover { background: rgba(0,0,0,0.05); color: var(--prjct-ink); }

/* ── Hide nav when Fancybox is open ─────────────────────────────────────── */
html.with-fancybox .prjct-nav {
    transform:      translateY(100%) !important;
    opacity:        0 !important;
    pointer-events: none !important;
    transition:     none !important;
}

/* ── Animations ──────────────────────────────────────────────────────────── */
@keyframes prjct-nav-shake {
    0%,100% { transform: translateX(0);    }
    20%,60% { transform: translateX(-6px); }
    40%,80% { transform: translateX(6px);  }
}
.prjct-nav-shake { animation: prjct-nav-shake 0.4s ease; }

@keyframes prjct-slide-left  { to { transform: translateX(-60px); opacity: 0; } }
@keyframes prjct-slide-right { to { transform: translateX( 60px); opacity: 0; } }
.prjct-nav-navigate-prev .prjct-nav-prev { animation: prjct-slide-right 0.35s ease forwards; }
.prjct-nav-navigate-next .prjct-nav-next { animation: prjct-slide-left  0.35s ease forwards; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .prjct-nav {
        padding-top:    10px;
        padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
        padding-left:   12px;
        padding-right:  12px;
        gap:            6px;
    }
    .prjct-nav-thumb { width: 44px; height: 44px; }
    .prjct-nav-item  { min-height: 48px; padding: 8px 10px; gap: 10px; }
}

@media (max-width: 600px) {
    .prjct-nav-thumb { display: none !important; }
    .prjct-nav-label { display: none !important; }
    .prjct-nav-item,
    .prjct-nav-home  { padding: 8px 10px; }
    .prjct-nav-content::before {
        display:       block;
        font-size:     2.4rem;
        line-height:   1;
        color:         #333;
        margin-bottom: 2px;
    }
    .prjct-nav-prev .prjct-nav-content::before { content: "←"; }
    .prjct-nav-next .prjct-nav-content::before { content: "→"; }
    .prjct-nav-title     { font-size: 0.52rem !important; font-weight: 400 !important; color: #888 !important; }
    .prjct-nav-home svg  { width: 16px; height: 16px; }
    .prjct-nav-home span { font-size: 0.6rem; letter-spacing: 0.04em; text-transform: uppercase; margin-top: 4px; }
}

@media (max-width: 380px) {
    .prjct-nav-item,
    .prjct-nav-home        { padding: 6px; }
    .prjct-nav-content::before { font-size: 2rem; }
    .prjct-nav-title       { font-size: 0.46rem !important; }
}
/* ── Fix: remove focus/border on video thumb after Fancybox closes ───────── */
.prjct-video-thumb:focus,
.prjct-video-thumb:focus-visible {
    outline:    none !important;
    box-shadow: none !important;
    border:     none !important;
}
.prjct-video-thumb.fancybox__trigger:focus {
    outline: none !important;
}

/* =============================================================================
   FANCYBOX — close button, sizing, backdrop

   Fancybox 5 puts .f-button.is-close-btn into .fancybox__content at
   top:-38px; right:0 when closeButton:true and Toolbar is disabled.

   ROOT CAUSE of button appearing at browser corner:
   Fancybox's own CSS sets overflow:hidden on ALL media slides:
     .fancybox__slide.has-image        { overflow: hidden }
     .fancybox__slide.has-html5video   { overflow: hidden }
     .fancybox__slide.has-iframe       { overflow: hidden }
     .fancybox__slide.has-video        { overflow: hidden }
   This clips the close button (top:-38px) before it can be seen.
   The button then falls back to fixed positioning at the browser corner.
   FIX: override those slides to overflow:visible.
   ============================================================================= */

/* Dark backdrop */
.fancybox__backdrop {
    background: rgba(0, 0, 0, 0.92) !important;
}

/* ── 'over Henkst' text popup: allow close btn to escape above the box ────── */
/* The hh-fb-popup content box has overflow:hidden by default which clips     */
/* the native close button (top:-38px). Override to overflow:visible.         */
.fancybox__container.hh-fb-popup .fancybox__content {
    overflow: visible !important;
}

/* ── THE KEY FIX: allow close button to escape above the slide ───────────── */
.fancybox__slide.has-image,
.fancybox__slide.has-html5video,
.fancybox__slide.has-iframe,
.fancybox__slide.has-video {
    overflow: visible !important;
}

/* Video content: overflow hidden keeps video clipped; close btn escapes via slide:overflow:visible */
.fancybox__slide.has-html5video .fancybox__content,
.fancybox__slide.has-iframe     .fancybox__content,
.fancybox__slide.has-video      .fancybox__content {
    overflow: hidden !important;
}

/* Match slide background to video so no gap is visible */
.fancybox__slide.has-html5video {
    background: #000 !important;
}

/* Image/gif slide: content stays transparent (Fancybox default), image clips to it */
.fancybox__slide.has-image .fancybox__content {
    overflow: visible !important;   /* needed for close btn child */
}

/* ── Close button: style only, native position (top:-38px right:0) kept ──── */
.fancybox__content > .f-button.is-close-btn {
    --f-button-color:            #fff !important;
    --f-button-hover-color:      #fff !important;
    --f-button-bg:               transparent !important;
    --f-button-hover-bg:         transparent !important;
    --f-button-active-bg:        transparent !important;
    --f-button-svg-width:        24px !important;
    --f-button-svg-height:       24px !important;
    --f-button-svg-stroke-width: 2.5 !important;
    --f-button-svg-filter:       drop-shadow(0 1px 4px rgba(0,0,0,0.9)) !important;
    opacity: 1 !important;
    top:    -40px !important;
    right:   0 !important;
}

.fancybox__content > .f-button.is-close-btn:hover {
    opacity: 0.7 !important;
}

/* ── Suppress any toolbar-level close button (Toolbar disabled in show()) ─── */
/* Belt-and-suspenders: hide any stray close button not inside .fancybox__content */
.fancybox__container > .f-button.is-close-btn {
    display: none !important;
}

/* ── YouTube / Vimeo: override Fancybox 960×540 default → responsive ──────── */
.has-youtube .fancybox__content,
.has-vimeo   .fancybox__content {
    width:        min(80vw, 1100px) !important;
    height:       auto !important;
    aspect-ratio: 16 / 9 !important;
    max-width:    min(80vw, 1100px) !important;
    max-height:   82vh !important;
    padding:      0 !important;
    background:   #000 !important;
}

.has-youtube .fancybox__iframe,
.has-vimeo   .fancybox__iframe {
    width:  100% !important;
    height: 100% !important;
}

/* ── mp4 / html5video ─────────────────────────────────────────────────────── */
/* Slide: no padding, black bg — matches video so no border gap visible */
.fancybox__slide.has-html5video {
    padding:    0 !important;
    background: #000 !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Content box: exact 16:9 size, no padding, pure black */
.has-html5video .fancybox__content {
    width:        min(90vw, 1100px) !important;
    max-width:    min(90vw, 1100px) !important;
    height:       calc(min(90vw, 1100px) * 9 / 16) !important;
    max-height:   82vh !important;
    padding:      0 !important;
    background:   #000 !important;
    border:       none !important;
    box-shadow:   none !important;
    flex-shrink:  0 !important;
}

/* Video fills content box exactly */
.has-html5video .fancybox__html5video {
    width:   100% !important;
    height:  100% !important;
    display: block !important;
}

/* ── Gallery images: cap width + rounded corners ──────────────────────────── */
.fancybox__container:not([data-hh-popup]) .fancybox__slide.has-image .fancybox__content {
    max-width:     min(90vw, 1100px) !important;
    border-radius: 10px !important;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .has-youtube .fancybox__content,
    .has-vimeo   .fancybox__content {
        width: min(88vw, 1100px) !important; max-width: min(88vw, 1100px) !important;
    }
    .fancybox__container:not([data-hh-popup]) .fancybox__slide.has-image .fancybox__content {
        max-width: 92vw !important;
    }
}

@media (max-width: 600px) {
    .has-youtube .fancybox__content,
    .has-vimeo   .fancybox__content,
    .has-html5video .fancybox__content {
        width: 96vw !important; max-width: 96vw !important;
    }
    .fancybox__container:not([data-hh-popup]) .fancybox__slide.has-image .fancybox__content {
        max-width: 96vw !important; border-radius: 6px !important;
    }
}


/* ── Loading spinner — shown while video/iframe popup content loads ──────── */
.hpd-spinner {
    position:        absolute;
    inset:           0;
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             14px;
    background:      rgba(0, 0, 0, 0.85);
    z-index:         50;
    pointer-events:  none;
    border-radius:   inherit;
}

.hpd-spinner__ring {
    width:        44px;
    height:       44px;
    border:       3px solid rgba(255, 255, 255, 0.15);
    border-top:   3px solid #fff;
    border-radius: 50%;
    animation:    hpd-spin 0.8s linear infinite;
    flex-shrink:  0;
}

@keyframes hpd-spin {
    to { transform: rotate(360deg); }
}

.hpd-spinner__text {
    margin:      0;
    font-family: var(--prjct-font, system-ui, sans-serif);
    font-size:   0.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color:       rgba(255, 255, 255, 0.7);
    text-transform: uppercase;
}

/* ── Gallery grid (note: class has a historic double-p typo — both targeted) ── */
.pprjct-gallery-grid,
.prjct-gallery-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   6px;
}
