/* ============================================================
   JANSSEN LLC — pages.css
   Styles for interior pages (About, Services, Contact, etc.)
   ============================================================ */

/* ── Page Hero ─────────────────────────────────────────────── */
.page-hero {
  background: var(--color-bg-dark);
  color: white;
  padding: var(--space-20) 0 var(--space-16);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(30,111,207,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30,111,207,0.07) 1px, transparent 1px);
  background-size: 60px 60px;
}
.page-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 760px;
}
.page-hero__title {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 700;
  line-height: 1.15;
  color: white;
  margin-bottom: var(--space-5);
}
.page-hero__sub {
  font-size: var(--text-xl);
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
}

/* ── About Founder ─────────────────────────────────────────── */
.about-founder {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-12);
  align-items: start;
}
@media (max-width: 768px) {
  .about-founder { grid-template-columns: 1fr; }
}
.about-founder__photo-wrap {
  position: sticky;
  top: 100px;
}
.about-founder__photo-placeholder {
  width: 100%;
  aspect-ratio: 1;
  background: var(--color-gradient);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 5rem;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  font-family: var(--font-mono);
}
.about-founder__bio h2 {
  font-size: var(--text-3xl);
  font-weight: 700;
  margin: var(--space-3) 0 var(--space-5);
}
.about-founder__bio p {
  color: var(--color-text-muted);
  line-height: 1.8;
  margin-bottom: var(--space-4);
}
.about-founder__links {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-top: var(--space-6);
}

/* ── Values Grid ───────────────────────────────────────────── */
.values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
@media (max-width: 640px) {
  .values-grid { grid-template-columns: 1fr; }
}
.value-card {
  padding: var(--space-8);
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: all var(--transition);
}
.value-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  border-color: rgba(30,111,207,0.2);
}
.value-card__icon { font-size: 2rem; margin-bottom: var(--space-4); }
.value-card h3 { font-size: var(--text-xl); font-weight: 600; margin-bottom: var(--space-3); }
.value-card p { color: var(--color-text-muted); line-height: 1.7; }

/* ── Services Page ─────────────────────────────────────────── */
.services-detail-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}
.service-detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  padding: var(--space-10);
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}
.service-detail:nth-child(even) { direction: rtl; }
.service-detail:nth-child(even) > * { direction: ltr; }
@media (max-width: 768px) {
  .service-detail,
  .service-detail:nth-child(even) { grid-template-columns: 1fr; direction: ltr; }
}
.service-detail__icon {
  font-size: 4rem;
  width: 96px; height: 96px;
  background: linear-gradient(135deg, rgba(30,111,207,0.08) 0%, rgba(124,58,237,0.08) 100%);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-5);
}
.service-detail h2 { font-size: var(--text-2xl); font-weight: 700; margin-bottom: var(--space-4); }
.service-detail p { color: var(--color-text-muted); line-height: 1.8; margin-bottom: var(--space-4); }
.service-detail ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}
.service-detail li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}
.service-detail li::before {
  content: '→';
  color: var(--color-primary);
  font-weight: 700;
  flex-shrink: 0;
}
.service-detail__visual {
  padding: var(--space-8);
  background: linear-gradient(135deg, rgba(30,111,207,0.04) 0%, rgba(124,58,237,0.04) 100%);
  border: 1px solid rgba(30,111,207,0.1);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 260px;
}

/* ── Portfolio Page ────────────────────────────────────────── */
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 900px)  { .portfolio-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .portfolio-grid { grid-template-columns: 1fr; } }
.portfolio-card {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition);
}
.portfolio-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}
.portfolio-card__img {
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, #1e6fcf22, #7c3aed22);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}
.portfolio-card__body { padding: var(--space-5); }
.portfolio-card__tag {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  font-family: var(--font-mono);
  margin-bottom: var(--space-2);
}
.portfolio-card h3 { font-size: var(--text-lg); font-weight: 600; margin-bottom: var(--space-2); }
.portfolio-card p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; }

/* ── Contact Page ──────────────────────────────────────────── */
.contact-page-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: start;
}
@media (max-width: 768px) { .contact-page-grid { grid-template-columns: 1fr; } }
.contact-info-card {
  padding: var(--space-8);
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}
.contact-info-card h2 { font-size: var(--text-2xl); font-weight: 700; margin-bottom: var(--space-4); }
.contact-info-card p { color: var(--color-text-muted); line-height: 1.7; margin-bottom: var(--space-6); }
.contact-info-items { display: flex; flex-direction: column; gap: var(--space-5); }
.contact-info-item { display: flex; align-items: flex-start; gap: var(--space-4); }
.contact-info-item__icon {
  font-size: 1.5rem;
  width: 48px; height: 48px;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contact-info-item__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  font-family: var(--font-mono);
  margin-bottom: var(--space-1);
}
.contact-info-item__value {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-text);
}
.contact-info-item__value a { color: var(--color-primary); }
