/* css/hero.css */
.hero {
  min-height: 100dvh;
  display: grid;
  grid-template-columns: 60fr 40fr;
  align-items: center;
  padding-top: var(--nav-height);
  padding-inline: var(--gutter);
  position: relative;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  background-image: url('../assets/images/400_PATTERN.png');
  background-size: cover;
  opacity: 0.04;
  pointer-events: none;
}
.hero__left { padding-right: var(--space-8); }
.hero__headline {
  font-family: var(--font-display);
  font-size: var(--text-hero);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--color-text);
}
.hero__right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-8);
  padding-left: var(--space-8);
  border-left: 1px solid var(--color-border);
}
.hero__sub {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 36ch;
  line-height: 1.5;
}
.hero__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-bg);
  background-color: var(--color-accent);
  padding: var(--space-4) var(--space-8);
  width: fit-content;
  transition: background-color var(--transition-fast), transform 150ms var(--ease-out);
}
@media (hover: hover) { .hero__cta:hover { background-color: var(--color-accent-hover); } }
.hero__cta:active { transform: scale(0.97); }
@media (max-width: 768px) {
  .hero { grid-template-columns: 1fr; grid-template-rows: auto auto; gap: var(--space-12); align-content: center; }
  .hero__right { border-left: none; border-top: 1px solid var(--color-border); padding-left: 0; padding-top: var(--space-8); }
}
