/* ============================================
   SERVICES PAGE STYLES
   ============================================ */

/* Page Hero */
.page-hero {
  background: var(--color-navy);
  padding-top: calc(80px + clamp(var(--space-16), 10vw, var(--space-24)));
  padding-bottom: clamp(var(--space-16), 8vw, var(--space-24));
  border-bottom: 1px solid var(--color-navy-border);
}

.page-hero-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.page-hero h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--color-navy-text);
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.page-hero p {
  font-size: var(--text-lg);
  color: var(--color-navy-muted);
  max-width: 52ch;
  line-height: 1.6;
}

/* Active nav link */
.nav-link--active {
  color: var(--color-primary) !important;
}

/* Service Blocks */
.service-block {
  background: var(--color-bg);
  border-top: 1px solid var(--color-divider);
}

.service-block--alt {
  background: var(--color-surface-offset);
}

.service-inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(var(--space-12), 6vw, var(--space-20));
  align-items: start;
}

.service-inner--flip {
  grid-template-columns: 1.4fr 1fr;
}

.service-inner--flip .service-visual { order: -1; }

.service-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: sticky;
  top: 100px;
}

.service-number {
  color: var(--color-text-faint);
  font-size: var(--text-xs);
}

.service-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  border-radius: 0;
  color: var(--color-primary);
}

.service-header h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.service-lead {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.75;
  max-width: 46ch;
}

.service-detail {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.service-items {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.service-item {
  padding: var(--space-6);
  border-radius: 0;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  transition: all var(--transition-interactive);
}

.service-item:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

.service-item h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.service-item p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.65;
}

/* Browser mockup */
.browser-mockup {
  border-radius: 0;
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
}

.browser-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
}

.browser-dots {
  display: flex;
  gap: var(--space-2);
}

.browser-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-divider);
}

.browser-url {
  flex: 1;
  display: flex;
  justify-content: center;
}

.browser-url .label {
  padding: var(--space-1) var(--space-4);
  background: var(--color-surface-offset);
  border-radius: 0;
}

.browser-content {
  aspect-ratio: 16/10;
  padding: clamp(var(--space-8), 5%, var(--space-16));
  display: flex;
  align-items: center;
}

.mock-hero-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  width: 70%;
}

.mock-line {
  background: rgba(255,255,255,0.15);
  border-radius: var(--radius-sm);
  height: 8px;
}
.mock-line--lg { height: 28px; width: 90%; background: rgba(255,255,255,0.25); }
.mock-line--md { height: 16px; width: 70%; }
.mock-line--sm { height: 12px; width: 55%; }
.mock-btns { display: flex; gap: var(--space-3); margin-top: var(--space-3); }
.mock-btn { height: 34px; border-radius: 0; }
.mock-btn--primary { width: 100px; background: var(--color-primary); opacity: 0.9; }
.mock-btn--outline { width: 90px; border: 1.5px solid rgba(255,255,255,0.3); }

/* Stats card */
.stats-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0;
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

.stats-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}

.stat-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.stat-big {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1;
  letter-spacing: -0.03em;
}

.stats-divider {
  height: 1px;
  background: var(--color-divider);
  margin-bottom: var(--space-6);
}

.stats-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.stats-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* AI flow visual */
.ai-flow-visual {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0;
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
  position: relative;
}

.flow-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-6);
  border-radius: 0;
  border: 1px solid var(--color-border);
  min-width: 90px;
  text-align: center;
}

.flow-node--input { background: var(--color-surface-offset); }
.flow-node--ai {
  background: color-mix(in srgb, var(--color-primary) 12%, transparent);
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.flow-node--output {
  background: color-mix(in srgb, #4ade80 8%, transparent);
  border-color: color-mix(in srgb, #4ade80 40%, transparent);
}

.flow-arrow {
  font-size: 1.25rem;
  color: var(--color-text-muted);
}

.flow-time {
  position: absolute;
  bottom: var(--space-4);
  right: var(--space-6);
}

@media (max-width: 860px) {
  .service-inner,
  .service-inner--flip {
    grid-template-columns: 1fr;
  }
  .service-header { position: static; }
  .service-inner--flip .service-visual { order: unset; }
}
