/* =========================================================
   STARPOL SHARED PATCHES
   Wspólne poprawki dla:
   - template-metal-hub.php
   - template-metal-service.php
   - template-project-hub.php
   - template-project-service.php
========================================================= */

/* ===== TEMPLATE SCOPE ===== */
body.page-template-template-metal-hub,
body.page-template-template-metal-service,
body.page-template-template-project-hub,
body.page-template-template-project-service {
  --sp-shared-card-radius: 28px;
  --sp-shared-figure-radius: 24px;
  --sp-shared-card-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
  --sp-shared-card-shadow-hover: 0 24px 55px rgba(15, 23, 42, 0.10);
}

/* ===== HERO TYPO SAFETY ===== */
body.page-template-template-metal-hub .sp-metal-hero h1,
body.page-template-template-metal-service .sp-metal-hero h1,
body.page-template-template-project-hub .sp-metal-hero h1,
body.page-template-template-project-service .sp-metal-hero h1 {
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  -webkit-hyphens: none !important;
  -ms-hyphens: none !important;
  text-wrap: balance;
}

/* projektowe H1 trochę mniejsze, żeby nie wróciły myślniki */
body.page-template-template-project-hub .sp-metal-hero h1,
body.page-template-template-project-service .sp-metal-hero h1 {
  font-size: clamp(36px, 4.2vw, 60px) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.03em !important;
  max-width: 13ch !important;
}

@media (max-width: 768px) {
  body.page-template-template-project-hub .sp-metal-hero h1,
  body.page-template-template-project-service .sp-metal-hero h1 {
    font-size: clamp(32px, 7.2vw, 46px) !important;
    max-width: none !important;
  }
}

/* ===== SECTION HEADINGS TYPO SAFETY ===== */
body.page-template-template-metal-hub .sp-metal-section h2,
body.page-template-template-metal-hub .sp-metal-section-alt h2,
body.page-template-template-metal-hub .sp-metal-dark h2,
body.page-template-template-metal-hub .sp-metal-cta h2,
body.page-template-template-metal-service .sp-metal-section h2,
body.page-template-template-metal-service .sp-metal-section-alt h2,
body.page-template-template-metal-service .sp-metal-dark h2,
body.page-template-template-metal-service .sp-metal-cta h2,
body.page-template-template-project-hub .sp-metal-section h2,
body.page-template-template-project-hub .sp-metal-section-alt h2,
body.page-template-template-project-hub .sp-metal-dark h2,
body.page-template-template-project-hub .sp-metal-cta h2,
body.page-template-template-project-service .sp-metal-section h2,
body.page-template-template-project-service .sp-metal-section-alt h2,
body.page-template-template-project-service .sp-metal-dark h2,
body.page-template-template-project-service .sp-metal-cta h2 {
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  -webkit-hyphens: none !important;
  -ms-hyphens: none !important;
  text-wrap: balance;
}

/* ===== UNIFIED CARD FIGURES ===== */
body.page-template-template-metal-hub .sp-metal-card figure,
body.page-template-template-metal-service .sp-metal-card figure,
body.page-template-template-project-hub .sp-metal-card figure,
body.page-template-template-project-service .sp-metal-card figure {
  margin: 0 0 18px !important;
  overflow: hidden !important;
  border-radius: var(--sp-shared-figure-radius) !important;
}

body.page-template-template-metal-hub .sp-metal-card figure img,
body.page-template-template-metal-service .sp-metal-card figure img,
body.page-template-template-project-hub .sp-metal-card figure img,
body.page-template-template-project-service .sp-metal-card figure img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
}

/* gdy karta ma mieć równy obraz w siatce 2 kolumn */
body.page-template-template-metal-hub .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure,
body.page-template-template-metal-service .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure,
body.page-template-template-project-hub .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure,
body.page-template-template-project-service .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure {
  aspect-ratio: 16 / 9;
}

body.page-template-template-metal-hub .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure img,
body.page-template-template-metal-service .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure img,
body.page-template-template-project-hub .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure img,
body.page-template-template-project-service .sp-metal-grid.sp-metal-grid-2 .sp-metal-card figure img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* ===== UNIFIED CARD LAYOUT ===== */
body.page-template-template-metal-hub .sp-metal-grid,
body.page-template-template-metal-service .sp-metal-grid,
body.page-template-template-project-hub .sp-metal-grid,
body.page-template-template-project-service .sp-metal-grid {
  align-items: stretch;
}

body.page-template-template-metal-hub .sp-metal-grid .sp-metal-card,
body.page-template-template-metal-service .sp-metal-grid .sp-metal-card,
body.page-template-template-project-hub .sp-metal-grid .sp-metal-card,
body.page-template-template-project-service .sp-metal-grid .sp-metal-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  border-radius: var(--sp-shared-card-radius) !important;
}

body.page-template-template-metal-hub .sp-metal-grid .sp-metal-card p:last-of-type,
body.page-template-template-metal-service .sp-metal-grid .sp-metal-card p:last-of-type,
body.page-template-template-project-hub .sp-metal-grid .sp-metal-card p:last-of-type,
body.page-template-template-project-service .sp-metal-grid .sp-metal-card p:last-of-type {
  margin-top: auto;
}

/* ===== FULL CLICK CARDS ===== */
body.page-template-template-metal-hub a.sp-project-card-link,
body.page-template-template-metal-service a.sp-project-card-link,
body.page-template-template-project-hub a.sp-project-card-link,
body.page-template-template-project-service a.sp-project-card-link,
body.page-template-template-metal-hub .sp-metal-link-card,
body.page-template-template-metal-service .sp-metal-link-card,
body.page-template-template-project-hub .sp-metal-link-card,
body.page-template-template-project-service .sp-metal-link-card {
  text-decoration: none !important;
  color: inherit !important;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

body.page-template-template-metal-hub a.sp-project-card-link:hover,
body.page-template-template-metal-service a.sp-project-card-link:hover,
body.page-template-template-project-hub a.sp-project-card-link:hover,
body.page-template-template-project-service a.sp-project-card-link:hover,
body.page-template-template-metal-hub .sp-metal-link-card:hover,
body.page-template-template-metal-service .sp-metal-link-card:hover,
body.page-template-template-project-hub .sp-metal-link-card:hover,
body.page-template-template-project-service .sp-metal-link-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--sp-shared-card-shadow-hover) !important;
}

body.page-template-template-metal-hub a.sp-project-card-link h3,
body.page-template-template-metal-hub a.sp-project-card-link p,
body.page-template-template-metal-service a.sp-project-card-link h3,
body.page-template-template-metal-service a.sp-project-card-link p,
body.page-template-template-project-hub a.sp-project-card-link h3,
body.page-template-template-project-hub a.sp-project-card-link p,
body.page-template-template-project-service a.sp-project-card-link h3,
body.page-template-template-project-service a.sp-project-card-link p {
  color: inherit !important;
}

body.page-template-template-metal-hub .sp-project-card-link__cta,
body.page-template-template-metal-service .sp-project-card-link__cta,
body.page-template-template-project-hub .sp-project-card-link__cta,
body.page-template-template-project-service .sp-project-card-link__cta {
  margin-top: auto !important;
  color: #dc2626 !important;
  font-weight: 700 !important;
}

/* ===== LINK GRID BODY ===== */
body.page-template-template-metal-hub .sp-metal-link-grid,
body.page-template-template-metal-service .sp-metal-link-grid,
body.page-template-template-project-hub .sp-metal-link-grid,
body.page-template-template-project-service .sp-metal-link-grid {
  align-items: stretch;
}

body.page-template-template-metal-hub .sp-metal-link-card,
body.page-template-template-metal-service .sp-metal-link-card,
body.page-template-template-project-hub .sp-metal-link-card,
body.page-template-template-project-service .sp-metal-link-card {
  display: flex !important;
  height: 100% !important;
  min-height: 220px !important;
}

body.page-template-template-metal-hub .sp-metal-link-body,
body.page-template-template-metal-service .sp-metal-link-body,
body.page-template-template-project-hub .sp-metal-link-body,
body.page-template-template-project-service .sp-metal-link-body {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: 100% !important;
}

body.page-template-template-metal-hub .sp-metal-link-text,
body.page-template-template-metal-service .sp-metal-link-text,
body.page-template-template-project-hub .sp-metal-link-text,
body.page-template-template-project-service .sp-metal-link-text {
  flex: 1 1 auto !important;
}

body.page-template-template-metal-hub .sp-metal-link-cta,
body.page-template-template-metal-service .sp-metal-link-cta,
body.page-template-template-project-hub .sp-metal-link-cta,
body.page-template-template-project-service .sp-metal-link-cta {
  margin-top: auto !important;
}

/* ===== LIGHTBOX IMAGE SAFETY ===== */
body.page-template-template-metal-service .sp-metal-photo img,
body.page-template-template-metal-service .sp-metal-page figure img,
body.page-template-template-project-service .sp-metal-photo img,
body.page-template-template-project-service .sp-metal-page figure img {
  position: relative;
  z-index: 3;
  pointer-events: auto;
  cursor: zoom-in;
}

/* ===== MOBILE ===== */
@media (max-width: 820px) {
  body.page-template-template-metal-hub .sp-metal-grid-2,
  body.page-template-template-metal-hub .sp-metal-grid-3,
  body.page-template-template-metal-service .sp-metal-grid-2,
  body.page-template-template-metal-service .sp-metal-grid-3,
  body.page-template-template-project-hub .sp-metal-grid-2,
  body.page-template-template-project-hub .sp-metal-grid-3,
  body.page-template-template-project-service .sp-metal-grid-2,
  body.page-template-template-project-service .sp-metal-grid-3 {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   STARPOL SHARED PATCHES — UX POLISH
========================================================= */

/* subtelniejszy premium hover na kartach */
body.page-template-template-metal-hub .sp-metal-card,
body.page-template-template-metal-service .sp-metal-card,
body.page-template-template-project-hub .sp-metal-card,
body.page-template-template-project-service .sp-metal-card,
body.page-template-template-metal-hub .sp-metal-link-card,
body.page-template-template-metal-service .sp-metal-link-card,
body.page-template-template-project-hub .sp-metal-link-card,
body.page-template-template-project-service .sp-metal-link-card {
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    border-color .24s ease,
    background-color .24s ease !important;
}

body.page-template-template-metal-hub .sp-metal-card:hover,
body.page-template-template-metal-service .sp-metal-card:hover,
body.page-template-template-project-hub .sp-metal-card:hover,
body.page-template-template-project-service .sp-metal-card:hover,
body.page-template-template-metal-hub .sp-metal-link-card:hover,
body.page-template-template-metal-service .sp-metal-link-card:hover,
body.page-template-template-project-hub .sp-metal-link-card:hover,
body.page-template-template-project-service .sp-metal-link-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.11) !important;
}

/* delikatny zoom na zdjęciu w kartach */
body.page-template-template-metal-hub .sp-metal-card figure img,
body.page-template-template-metal-service .sp-metal-card figure img,
body.page-template-template-project-hub .sp-metal-card figure img,
body.page-template-template-project-service .sp-metal-card figure img {
  transition: transform .35s ease !important;
}

body.page-template-template-metal-hub .sp-metal-card:hover figure img,
body.page-template-template-metal-service .sp-metal-card:hover figure img,
body.page-template-template-project-hub .sp-metal-card:hover figure img,
body.page-template-template-project-service .sp-metal-card:hover figure img,
body.page-template-template-metal-hub .sp-metal-link-card:hover figure img,
body.page-template-template-metal-service .sp-metal-link-card:hover figure img,
body.page-template-template-project-hub .sp-metal-link-card:hover figure img,
body.page-template-template-project-service .sp-metal-link-card:hover figure img {
  transform: scale(1.025) !important;
}

/* CTA link bardziej jak mini-button */
body.page-template-template-metal-hub .sp-project-card-link__cta,
body.page-template-template-metal-service .sp-project-card-link__cta,
body.page-template-template-project-hub .sp-project-card-link__cta,
body.page-template-template-project-service .sp-project-card-link__cta,
body.page-template-template-metal-hub .sp-metal-card p:last-child a,
body.page-template-template-metal-service .sp-metal-card p:last-child a,
body.page-template-template-project-hub .sp-metal-card p:last-child a,
body.page-template-template-project-service .sp-metal-card p:last-child a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(220, 38, 38, 0.08) !important;
  color: #b91c1c !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: background-color .22s ease, color .22s ease, transform .22s ease !important;
}

body.page-template-template-metal-hub .sp-project-card-link__cta::after,
body.page-template-template-metal-service .sp-project-card-link__cta::after,
body.page-template-template-project-hub .sp-project-card-link__cta::after,
body.page-template-template-project-service .sp-project-card-link__cta::after,
body.page-template-template-metal-hub .sp-metal-card p:last-child a::after,
body.page-template-template-metal-service .sp-metal-card p:last-child a::after,
body.page-template-template-project-hub .sp-metal-card p:last-child a::after,
body.page-template-template-project-service .sp-metal-card p:last-child a::after {
  content: "→";
}

body.page-template-template-metal-hub .sp-project-card-link__cta:hover,
body.page-template-template-metal-service .sp-project-card-link__cta:hover,
body.page-template-template-project-hub .sp-project-card-link__cta:hover,
body.page-template-template-project-service .sp-project-card-link__cta:hover,
body.page-template-template-metal-hub .sp-metal-card p:last-child a:hover,
body.page-template-template-metal-service .sp-metal-card p:last-child a:hover,
body.page-template-template-project-hub .sp-metal-card p:last-child a:hover,
body.page-template-template-project-service .sp-metal-card p:last-child a:hover {
  background: rgba(220, 38, 38, 0.13) !important;
  color: #991b1b !important;
  transform: translateY(-1px) !important;
}

/* równe odstępy w kartach */
body.page-template-template-metal-hub .sp-metal-card h3,
body.page-template-template-metal-service .sp-metal-card h3,
body.page-template-template-project-hub .sp-metal-card h3,
body.page-template-template-project-service .sp-metal-card h3 {
  margin-bottom: 14px !important;
}

body.page-template-template-metal-hub .sp-metal-card p,
body.page-template-template-metal-service .sp-metal-card p,
body.page-template-template-project-hub .sp-metal-card p,
body.page-template-template-project-service .sp-metal-card p {
  margin-top: 0 !important;
}

/* mobile: CTA nie może wyglądać za ciężko */
@media (max-width: 767px) {
  body.page-template-template-metal-hub .sp-project-card-link__cta,
  body.page-template-template-metal-service .sp-project-card-link__cta,
  body.page-template-template-project-hub .sp-project-card-link__cta,
  body.page-template-template-project-service .sp-project-card-link__cta,
  body.page-template-template-metal-hub .sp-metal-card p:last-child a,
  body.page-template-template-metal-service .sp-metal-card p:last-child a,
  body.page-template-template-project-hub .sp-metal-card p:last-child a,
  body.page-template-template-project-service .sp-metal-card p:last-child a {
    padding: 9px 12px !important;
    font-size: 14px !important;
  }
}

/* =========================================================
   /STARPOL SHARED PATCHES — UX POLISH
========================================================= */

/* =========================================================
   STARPOL SHARED PATCHES / FULL-WIDTH TEMPLATE LAYOUT
   usuwa boczne marginesy i padding ASTRY dla hubów i lead pages
========================================================= */

body.page-template-template-project-hub .site,
body.page-template-template-project-service .site {
  overflow-x: clip;
}

body.page-template-template-project-hub .site-content,
body.page-template-template-project-service .site-content,
body.page-template-template-project-hub .ast-container,
body.page-template-template-project-service .ast-container,
body.page-template-template-project-hub #primary,
body.page-template-template-project-service #primary {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.page-template-template-project-hub article,
body.page-template-template-project-service article,
body.page-template-template-project-hub .ast-article-post,
body.page-template-template-project-service .ast-article-post,
body.page-template-template-project-hub .ast-article-single,
body.page-template-template-project-service .ast-article-single {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

body.page-template-template-project-hub .entry-content,
body.page-template-template-project-service .entry-content {
  margin: 0 !important;
  padding: 0 !important;
}

body.page-template-template-project-hub .entry-content > *:not(.sp-metal-page),
body.page-template-template-project-service .entry-content > *:not(.sp-metal-page) {
  display: none !important;
}

body.page-template-template-project-hub .sp-metal-page,
body.page-template-template-project-service .sp-metal-page {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* sekcje mają dochodzić do krawędzi content area */
body.page-template-template-project-hub .sp-metal-section,
body.page-template-template-project-hub .sp-metal-section-alt,
body.page-template-template-project-hub .sp-metal-dark,
body.page-template-template-project-hub .sp-metal-cta,
body.page-template-template-project-service .sp-metal-section,
body.page-template-template-project-service .sp-metal-section-alt,
body.page-template-template-project-service .sp-metal-dark,
body.page-template-template-project-service .sp-metal-cta {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* hero też bez dodatkowych gutterów */
body.page-template-template-project-hub .sp-metal-hero,
body.page-template-template-project-service .sp-metal-hero {
  margin-left: 0 !important;
  margin-right: 0 !important;
  border-radius: 0 !important;
}


/* =========================================================
   STARPOL SHARED PATCHES / BREADCRUMBS BELOW HERO
========================================================= */

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap {
  background: #eef2f7 !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs {
  color: #64748b !important;
}

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs a,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs a {
  color: #64748b !important;
  text-decoration: none !important;
}

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs a:hover,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumbs a:hover {
  color: #0f172a !important;
}

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumb-sep,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumb-sep {
  color: #94a3b8 !important;
}

body.page-template-template-project-hub .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumb-current,
body.page-template-template-project-service .sp-metal-breadcrumbs-wrap .sp-metal-breadcrumb-current {
  color: #0f172a !important;
  font-weight: 700 !important;
}


/* =========================================================
   PROJECT HUB / REMOVE STRIP ABOVE HERO
========================================================= */

body.page-template-template-project-hub .sp-metal-page.sp-metal-breadcrumbs-wrap:first-of-type {
  display: none !important;
}

body.page-template-template-project-hub .site-main {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

body.page-template-template-project-hub .sp-metal-page > .sp-metal-hero:first-child,
body.page-template-template-project-hub .sp-metal-hero:first-child {
  margin-top: 0 !important;
}

body.page-template-template-project-hub .site-content,
body.page-template-template-project-hub .ast-container,
body.page-template-template-project-hub #primary {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

