/* ===================================================================
   PORTFOLIO PAGE - Sleek, modern showcase
   Design system aligned, positioning and UX focused
   =================================================================== */

.page-portfolio .portfolio-hero {
  padding: var(--hero-padding-top) 0 var(--hero-padding-bottom);
  background: #121218;
}

.page-portfolio .portfolio-hero .hero-title {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
}

.page-portfolio .portfolio-hero-subtitle {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.15rem;
  color: var(--muted);
  margin-top: var(--space-md);
}

.portfolio-intro {
  padding: var(--space-3xl) 0;
  background: #0d0d10;
  border-top: 1px solid var(--line);
}

.portfolio-intro-text {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 1.2rem;
  line-height: 1.6;
  color: var(--muted);
  text-align: center;
  margin: 0;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.portfolio-grid-section {
  padding: var(--section-padding) 0;
  background: #121218;
}

.page-portfolio .portfolio-section-title {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2xl);
  text-align: center;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-xl);
  max-width: 1200px;
  margin: 0 auto;
}

.portfolio-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 220ms ease, transform 220ms ease;
}

.portfolio-card:hover {
  border-color: rgba(255, 118, 80, 0.25);
  transform: translateY(-2px);
}

.portfolio-card-image {
  aspect-ratio: 16 / 10;
  background: var(--bg-elev);
  overflow: hidden;
}

.portfolio-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.portfolio-card-content {
  padding: var(--space-lg);
}

.portfolio-card-title {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: #FDFFFC;
  margin: 0 0 var(--space-xs);
  line-height: 1.2;
}

.portfolio-card-client {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 0.9rem;
  color: var(--muted);
  margin: 0 0 var(--space-sm);
}

.portfolio-card-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.portfolio-card-pills .pill {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 0.75rem;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
}

.portfolio-card-pills .pill-orange {
  background: rgba(255, 118, 80, 0.15);
  color: var(--orange);
}

.portfolio-card-pills .pill-green {
  background: rgba(211, 255, 135, 0.12);
  color: var(--green);
}

.portfolio-card-outcome {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--muted);
  margin: 0;
}

.portfolio-card-status {
  font-family: 'Bricolage Grotesque', system-ui, sans-serif;
  font-size: 0.8rem;
  color: var(--green);
  margin: var(--space-sm) 0 0;
  font-weight: 500;
}

.portfolio-cta {
  text-align: center;
  margin-top: var(--space-3xl);
}

.portfolio-cta .cta {
  display: inline-flex;
}

@media (max-width: 1024px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-lg);
  }
}

@media (max-width: 768px) {
  .page-portfolio .portfolio-hero {
    padding: var(--hero-padding-top-mobile) 0 var(--hero-padding-bottom-mobile);
  }

  .portfolio-intro {
    padding: var(--space-2xl) 0;
  }

  .portfolio-intro-text {
    font-size: 1.05rem;
  }

  .portfolio-grid-section {
    padding: var(--section-padding-mobile) 0;
  }

  .portfolio-grid {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .portfolio-card-content {
    padding: var(--space-md);
  }

  .portfolio-cta {
    margin-top: var(--space-2xl);
  }
}
