/* Fortified — single portfolio (cpt_portfolio) layout.
   trx_addons renders the markup (.portfolio_page article + "You May Also Like"
   .related_wrap); Tint supplied the CSS, which our lightweight theme now
   provides. Without it the article is full-bleed, the columns stack, and the
   gallery images render at ~1300px each (a 28,000px-tall page).

   Two content patterns exist:
   1. Simple galleries  -> two-column: sticky details (left) + image gallery.
   2. Custom case studies (.fcs, with their own embedded <style>) -> full width,
      no details sidebar (matches live, which sets the sidebar to display:none). */

/* Live hides the in-content post title + views/likes/share meta bar on single
   portfolio pages (the title already appears in the sidebar for galleries and
   in the case-study hero). trx_addons renders them here, so hide to match. */
.single-cpt_portfolio .portfolio_page_content_wrap > .portfolio_page_title,
.single-cpt_portfolio .portfolio_page_content_wrap > .portfolio_page_meta {
  display: none;
}

/* Box simple-gallery pages + the related band to the site content width.
   Case-study (.fcs) pages are excluded — they are designed full-width (see the
   .fcs block below). */
.single-cpt_portfolio .fortified-site-wrap > .portfolio_page:not(:has(.fcs)),
.single-cpt_portfolio .fortified-site-wrap > .related_wrap {
  max-width: var(--ft-elementor-content-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ft-container-pad);
  padding-right: var(--ft-container-pad);
  box-sizing: border-box;
}
.single-cpt_portfolio .portfolio_page { padding-top: 80px; padding-bottom: 80px; }

/* ── Pattern 1: simple gallery — two columns ──────────────────────────────── */
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) {
  display: flex;
  gap: 50px;
  align-items: flex-start;
}
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_details_wrap {
  flex: 0 0 34%;
  max-width: 34%;
  position: sticky;
  top: 40px;
}
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_content_wrap {
  flex: 1 1 auto;
  min-width: 0; /* let the flex child shrink so images don't overflow */
}
/* Gallery images — stacked, full content-column width. */
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_content_wrap img {
  display: block;
  width: 100%;
  height: auto;
}
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_featured { margin-bottom: 24px; }
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_content p { margin: 0 0 24px; }
.single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_content p:last-child { margin-bottom: 0; }

/* ── Pattern 2: custom case study (.fcs) — full width, no sidebar ─────────── */
/* These pages span the full viewport (their hero is full-bleed and the content
   bands are meant to be wide); only a small side padding keeps text off the
   edges. The .fcs CSS caps its own text at 780px. */
.single-cpt_portfolio .portfolio_page:has(.fcs) {
  display: block;
  max-width: none;
  padding-left: var(--ft-container-pad);
  padding-right: var(--ft-container-pad);
  box-sizing: border-box;
}
.single-cpt_portfolio .portfolio_page:has(.fcs) .portfolio_page_details_wrap { display: none; }
.single-cpt_portfolio .portfolio_page:has(.fcs) .portfolio_page_content_wrap { width: 100%; }

/* Details column ----------------------------------------------------------- */
.single-cpt_portfolio .portfolio_page_subtitle {
  margin: 0 0 24px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ft-color-ink);
}
.single-cpt_portfolio .portfolio_page_details_item {
  display: block;
  padding: 12px 0;
  border-top: 1px solid var(--ft-color-line);
  font-size: 15px;
  line-height: 1.5;
}
.single-cpt_portfolio .portfolio_page_details_item_title {
  margin-right: 10px;
  color: var(--ft-color-ink-soft);
}
.single-cpt_portfolio .portfolio_page_details_item_value {
  color: var(--ft-color-ink);
  font-weight: 500;
}
.single-cpt_portfolio .socials_share { margin-top: 26px; }
.single-cpt_portfolio .socials_share .social_items { display: flex; gap: 10px; }
.single-cpt_portfolio .socials_share .social_item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--ft-color-line);
  border-radius: 50%;
  color: var(--ft-color-ink-soft);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.single-cpt_portfolio .socials_share .social_item:hover {
  background: var(--ft-color-red);
  border-color: var(--ft-color-red);
  color: #fff;
}

/* "You May Also Like" related grid ----------------------------------------- */
.single-cpt_portfolio .related_wrap { padding-bottom: 90px; }
.single-cpt_portfolio .related_wrap_title {
  margin: 0 0 36px;
  font-size: 30px;
  font-weight: 700;
  color: var(--ft-color-ink);
}
.single-cpt_portfolio .related_columns.trx_addons_columns_wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
.single-cpt_portfolio .related_columns .trx_addons_column-1_2 {
  width: auto;
  padding: 0;
}
.single-cpt_portfolio .related_wrap .sc_portfolio_item {
  position: relative;
  overflow: hidden;
}
.single-cpt_portfolio .related_wrap .sc_portfolio_item img {
  display: block;
  width: 100%;
  height: auto;
}

/* ── Portfolio archive (archive-cpt_portfolio.php) ────────────────────────── */
.fortified-portfolio-archive .fp-archive { padding-top: 72px; padding-bottom: 90px; }
.fortified-portfolio-archive .fp-archive-head { margin-bottom: 40px; }
.fortified-portfolio-archive .fp-archive-title {
  margin: 0;
  font-size: 44px;
  font-weight: 700;
  color: var(--ft-color-ink);
}
/* Category filter bar (All / Commercial / Residential / …) */
.fortified-portfolio-archive .fp-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 36px;
}
.fortified-portfolio-archive .fp-filter {
  padding: 10px 22px;
  border: 1px solid var(--ft-color-line);
  background: transparent;
  color: var(--ft-color-ink);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.fortified-portfolio-archive .fp-filter:hover { border-color: var(--ft-color-red); color: var(--ft-color-red); }
.fortified-portfolio-archive .fp-filter.is-active {
  background: var(--ft-color-red);
  border-color: var(--ft-color-red);
  color: #fff;
}
.fortified-portfolio-archive .fp-card.is-hidden { display: none; }

.fortified-portfolio-archive .fp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
/* Clickable card with uniform image + hover overlay (category + title). */
.fortified-portfolio-archive .fp-card {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--ft-color-ink);
}
.fortified-portfolio-archive .fp-card-media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.fortified-portfolio-archive .fp-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease, opacity 0.3s ease;
}
.fortified-portfolio-archive .fp-card:hover .fp-card-media img {
  transform: scale(1.06);
  opacity: 0.55;
}
/* Overlay hidden until hover, then slides up — the name/category reveal. */
.fortified-portfolio-archive .fp-card-overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 22px 24px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.78), rgba(0, 0, 0, 0));
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}
.fortified-portfolio-archive .fp-card:hover .fp-card-overlay {
  opacity: 1;
  transform: translateY(0);
}
.fortified-portfolio-archive .fp-card-cat {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: #fff;
  opacity: 0.85;
}
.fortified-portfolio-archive .fp-card-title {
  display: block;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
}

/* Pagination */
.fortified-portfolio-archive .navigation.pagination { margin-top: 48px; }
.fortified-portfolio-archive .nav-links {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
}
.fortified-portfolio-archive .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 12px;
  border: 1px solid var(--ft-color-line);
  color: var(--ft-color-ink);
  font-size: 15px;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.fortified-portfolio-archive .page-numbers.current,
.fortified-portfolio-archive .page-numbers:hover {
  background: var(--ft-color-red);
  border-color: var(--ft-color-red);
  color: #fff;
}

@media (max-width: 1024px) {
  .fortified-portfolio-archive .fp-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .fortified-portfolio-archive .fp-archive { padding-top: 48px; }
  .fortified-portfolio-archive .fp-archive-title { font-size: 32px; }
  .fortified-portfolio-archive .fp-grid { grid-template-columns: 1fr; }
}

/* Responsive: single column, non-sticky details. */
@media (max-width: 900px) {
  .single-cpt_portfolio .portfolio_page { padding-top: 48px; padding-bottom: 56px; }
  .single-cpt_portfolio .portfolio_page:not(:has(.fcs)) {
    flex-direction: column;
    gap: 36px;
  }
  .single-cpt_portfolio .portfolio_page:not(:has(.fcs)) .portfolio_page_details_wrap {
    position: static;
    flex-basis: auto;
    max-width: none;
    width: 100%;
  }
  .single-cpt_portfolio .related_columns.trx_addons_columns_wrap {
    grid-template-columns: 1fr;
  }
}
