/* ============================================================
   PORTFOLIO PAGE — css/portfolio.css
   ============================================================ */

.portfolio-hero {
  padding: 72px 0;
  background: var(--white);
  border-bottom: 1px solid var(--border);
}
.portfolio-hero h1 { margin-bottom: 16px; }

/* Full Case Study Card */
.cs-full {
  background: var(--white); border-radius: 24px; overflow: hidden;
  border: 1px solid var(--border); box-shadow: 0 4px 24px rgba(0,0,0,.07);
}
.cs-header {
  background: linear-gradient(135deg, var(--teal) 0%, #0f5f5f 100%);
  padding: 48px 56px;
}
.cs-header h2 { color: var(--white); margin-bottom: 8px; }
.cs-header p { color: rgba(255,255,255,.8); }
.cs-location-pill {
  display: inline-block; background: rgba(255,255,255,.2);
  color: var(--white); font-size: .75rem; font-weight: 700;
  padding: 5px 14px; border-radius: 50px; margin-bottom: 16px;
}
.cs-body { padding: 56px; }

.cs-stat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px;
}
.cs-stat {
  background: var(--bg); border-radius: var(--r); padding: 28px;
  text-align: center; border: 1px solid var(--border);
}
.cs-stat-val { font-size: 1.5rem; font-weight: 800; color: var(--teal); margin-bottom: 4px; }
.cs-stat-label { font-size: .8rem; color: var(--ink-light); }

.cs-section-label {
  font-size: .85rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-light); margin-bottom: 14px;
}

.live-site-box {
  background: var(--teal-light); border-radius: var(--r); padding: 24px;
  border: 1px solid rgba(26,122,122,.2);
}
.live-site-label { font-size: .9rem; font-weight: 600; color: var(--teal); margin-bottom: 4px; }
.live-site-url { font-size: 1rem; font-weight: 700; color: var(--teal); margin-bottom: 4px; }
.live-site-sub { font-size: .85rem; color: var(--ink-light); }

.cs-footer-cta {
  border-top: 1px solid var(--border); padding-top: 36px; margin-top: 36px;
  text-align: center;
}
.cs-footer-cta .p-body { margin-bottom: 20px; }

/* Coming Soon */
.coming-soon-card {
  background: var(--white); border-radius: var(--r); padding: 40px;
  border: 2px dashed var(--border); text-align: center;
  transition: border-color .2s, transform .2s;
}
.coming-soon-card:hover { border-color: var(--teal); transform: translateY(-3px); }
.coming-soon-icon { font-size: 2.5rem; margin-bottom: 14px; }
.coming-soon-card h3 { margin-bottom: 8px; }

/* Responsive */
@media (max-width: 960px) {
  .cs-header { padding: 36px 32px; }
  .cs-body { padding: 32px; }
  .cs-stat-grid { grid-template-columns: 1fr; }
}
