/* Partnerships — page-specific styles (base layout in company.css). */

:root {
  --psn-stroke: rgba(0, 64, 255, 0.12);
  --psn-stroke-light: rgba(0, 12, 138, 0.08);
  --psn-surface: rgba(0, 64, 255, 0.03);
  --psn-glow: rgba(0, 204, 253, 0.22);
}

.company-partnerships-page .co-hero__inner {
  grid-template-columns: 1.15fr 0.85fr;
  align-items: center;
}

/* Shell hero grid/beams are for template pages; co-hero supplies its own background. */
.company-partnerships-page .co-hero.hero::before,
.company-partnerships-page .co-hero.hero::after {
  content: none;
}

.company-partnerships-page .co-section[id] {
  scroll-margin-top: 88px;
}

/* Hero visual stack */
.psn-hero-visual {
  min-height: 340px;
}

.psn-hero-stack {
  position: relative;
  width: min(360px, 92%);
  min-height: 280px;
}

.psn-hero-card {
  position: absolute;
  left: 50%;
  width: min(300px, 88%);
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--psn-stroke);
  background: rgba(0, 1, 31, 0.55);
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
  transform: translateX(-50%);
}

[data-theme="light"] .psn-hero-card {
  background: rgba(255, 255, 255, 0.88);
  border-color: var(--psn-stroke-light);
  box-shadow: 0 18px 48px rgba(0, 12, 138, 0.1);
}

.psn-hero-card--back {
  top: 0;
  opacity: 0.55;
  transform: translateX(-58%) rotate(-6deg);
}

.psn-hero-card--mid {
  top: 52px;
  opacity: 0.78;
  transform: translateX(-42%) rotate(4deg);
}

.psn-hero-card--front {
  top: 108px;
  transform: translateX(-50%);
  z-index: 2;
}

.psn-hero-card__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.psn-hero-card__dot {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(0, 204, 253, 0.65);
  margin-bottom: 12px;
}

.psn-hero-card__line {
  display: block;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.1), rgba(0, 204, 253, 0.24));
  margin-bottom: 10px;
}

.psn-hero-card__line--short {
  width: 68%;
}

.psn-hero-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.psn-hero-card__badges span {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-glow);
  background: rgba(0, 64, 255, 0.08);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-lightest-blue);
}

[data-theme="light"] .psn-hero-card__badges span {
  color: var(--color-accent-cyan);
}

/* Clients grid — bento layout */
.psn-clients-grid {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
}

.psn-client {
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  border: 1px solid var(--psn-stroke);
  background: var(--psn-surface);
  overflow: hidden;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

[data-theme="light"] .psn-client {
  background: rgba(0, 12, 138, 0.03);
  border-color: var(--psn-stroke-light);
}

.psn-client:hover {
  transform: translateY(-3px);
  border-color: rgba(0, 204, 253, 0.35);
  box-shadow: 0 18px 42px rgba(0, 64, 255, 0.12);
}

.psn-clients-grid[data-reveal].is-inview .psn-client:hover {
  transform: translateY(-3px);
}

.psn-client--showcase {
  grid-column: span 6;
}

.psn-client--text {
  grid-column: span 6;
  padding: 22px;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-content: start;
}

.psn-client__frame {
  position: relative;
  border-bottom: 1px solid var(--psn-stroke);
}

.psn-client__chrome {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(0, 0, 0, 0.22);
  border-bottom: 1px solid rgba(0, 64, 255, 0.1);
}

[data-theme="light"] .psn-client__chrome {
  background: rgba(0, 12, 138, 0.05);
}

.psn-client__chrome span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(0, 64, 255, 0.12);
}

.psn-client__url {
  grid-column: 1 / -1;
  margin-left: 2px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0, 64, 255, 0.12);
  background: rgba(0, 64, 255, 0.06);
  font-size: 0.78rem;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.psn-client__shot-link {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}

.psn-client__shot {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 420ms ease;
}

.psn-client__shot-link:hover .psn-client__shot,
.psn-client__shot-link:focus-visible .psn-client__shot {
  transform: scale(1.04);
}

.psn-client__body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.psn-client--text .psn-client__body {
  padding: 0;
}

.psn-client__icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  border: 1px solid var(--border-glow);
  background: rgba(0, 64, 255, 0.08);
  color: var(--color-accent-cyan);
  font-size: 1.35rem;
}

.psn-client__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px 14px;
  margin-bottom: 10px;
}

.psn-client__title {
  margin: 0;
  font-size: 1.12rem;
  letter-spacing: -0.02em;
}

.psn-client__domain {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--color-lightest-blue);
  text-decoration: none;
}

[data-theme="light"] .psn-client__domain {
  color: var(--color-accent-cyan);
}

.psn-client__domain:hover,
.psn-client__domain:focus-visible {
  color: var(--color-accent-cyan);
}

.psn-client__desc {
  margin: 0 0 14px;
  color: var(--text-muted);
  line-height: 1.58;
  font-size: 0.94rem;
}

.psn-client__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: auto 0 0;
  padding: 0;
  list-style: none;
}

.psn-client__tags li {
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0, 64, 255, 0.14);
  background: rgba(0, 64, 255, 0.06);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text);
}

.psn-client__note {
  margin: 14px 0 0;
  font-size: 0.84rem;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Staggered reveal for client cards */
.psn-clients-grid[data-reveal].is-inview .psn-client {
  opacity: 1;
  transform: translateY(0);
}

.psn-clients-grid[data-reveal]:not(.is-inview) .psn-client {
  opacity: 0;
  transform: translateY(18px);
}

.psn-clients-grid[data-reveal] .psn-client {
  transition:
    opacity 520ms ease,
    transform 520ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(1) { transition-delay: 60ms; }
.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(2) { transition-delay: 130ms; }
.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(3) { transition-delay: 200ms; }
.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(4) { transition-delay: 270ms; }
.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(5) { transition-delay: 340ms; }
.psn-clients-grid[data-reveal].is-inview .psn-client:nth-child(6) { transition-delay: 410ms; }

/* Partners grid */
.psn-partners-grid {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.psn-partner {
  padding: 22px 20px;
  border-radius: 16px;
  border: 1px solid var(--psn-stroke);
  background: var(--psn-surface);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

[data-theme="light"] .psn-partner {
  background: rgba(255, 255, 255, 0.72);
  border-color: var(--psn-stroke-light);
}

.psn-partner:hover {
  transform: translateY(-2px);
  border-color: rgba(0, 204, 253, 0.32);
  background: rgba(0, 64, 255, 0.06);
}

.psn-partners-grid[data-reveal].is-inview .psn-partner:hover {
  transform: translateY(-2px);
}

.psn-partner__logo-wrap {
  min-height: 44px;
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}

.psn-partner__logo {
  max-width: 150px;
  max-height: 36px;
  width: auto;
  color: var(--text);
}

.psn-partner__badge {
  display: inline-block;
  margin-bottom: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0, 204, 253, 0.28);
  background: rgba(0, 204, 253, 0.08);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-accent-cyan);
}

.psn-partner__name {
  margin: 0 0 8px;
  font-size: 1.05rem;
  letter-spacing: -0.02em;
}

.psn-partner__desc {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.psn-partners-grid[data-reveal].is-inview .psn-partner {
  opacity: 1;
  transform: translateY(0);
}

.psn-partners-grid[data-reveal]:not(.is-inview) .psn-partner {
  opacity: 0;
  transform: translateY(14px);
}

.psn-partners-grid[data-reveal] .psn-partner {
  transition: opacity 480ms ease, transform 480ms ease, border-color 180ms ease, background 180ms ease;
}

.psn-partners-grid[data-reveal].is-inview .psn-partner:nth-child(1) { transition-delay: 70ms; }
.psn-partners-grid[data-reveal].is-inview .psn-partner:nth-child(2) { transition-delay: 140ms; }
.psn-partners-grid[data-reveal].is-inview .psn-partner:nth-child(3) { transition-delay: 210ms; }
.psn-partners-grid[data-reveal].is-inview .psn-partner:nth-child(4) { transition-delay: 280ms; }

.co-section__subtitle code {
  padding: 2px 6px;
  border-radius: 6px;
  background: rgba(0, 64, 255, 0.08);
  font-size: 0.88em;
}

@media (max-width: 1100px) {
  .psn-partners-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .psn-client--showcase,
  .psn-client--text {
    grid-column: span 12;
  }

  .psn-client--text {
    grid-template-columns: 1fr;
  }

  .psn-client__icon {
    width: 48px;
    height: 48px;
    font-size: 1.15rem;
  }
}

@media (max-width: 720px) {
  .company-partnerships-page .co-hero__highlights {
    grid-template-columns: 1fr;
  }

  .psn-partners-grid {
    grid-template-columns: 1fr;
  }

  .psn-hero-stack {
    min-height: 240px;
  }

  .psn-hero-card--front {
    top: 88px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .psn-clients-grid[data-reveal] .psn-client,
  .psn-partners-grid[data-reveal] .psn-partner,
  .psn-client__shot {
    transition: none;
  }
}
