/* ============================================
   LOCARDE V2 — EU AI Act Page Styles
   ============================================ */

/* ---------- Title Hero (2-col: H1 left | subheading + button right) ---------- */
.title-hero {
  padding: var(--section-padding) var(--grid-gutter);
  padding-bottom: var(--section-padding-2x);
}

.title-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--grid-gap);
  align-items: end;
}

.title-hero__heading {
  font-size: var(--type-h1);
  font-variation-settings: "wght" 400;
  line-height: 1em;
  margin-bottom: 0;
}

.title-hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--gap-2);
  align-items: flex-start;
}

.title-hero__subheading {
  font-size: var(--type-h5);
  font-variation-settings: "wght" 400;
  line-height: 1.3em;
  color: var(--color-white-muted);
}

/* ---------- Metrics Section (3-col bordered cards) ---------- */
.metrics-section {
  padding: 0 var(--grid-gutter);
  padding-bottom: var(--section-padding-half);
}

.metrics-section__heading {
  margin-bottom: var(--section-padding);
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap);
}

.bordered-metric {
  position: relative;
  padding-top: var(--gap-1);
  display: flex;
  flex-direction: column;
  gap: var(--gap-2);
}

.bordered-metric .line.top {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-white-border);
  overflow: hidden;
}

.bordered-metric__label {
  font-family: var(--font-badges);
  font-size: var(--type-small);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-white-muted);
}

.bordered-metric__value {
  font-size: var(--type-h2);
  font-variation-settings: "wght" 350;
  line-height: 1em;
}

/* ---------- CTA Section (Gradient BG + Grid Pattern + Frosted Box) ---------- */
.cta-section {
  padding: var(--section-padding) var(--grid-gutter);
  position: relative;
  background-image: linear-gradient(90deg, #555, #868685);
  overflow: hidden;
}

.cta-section__grid-pattern {
  position: absolute;
  inset: 0;
  opacity: 0.25;
  mix-blend-mode: overlay;
  background-image: url('../../images/grid-pattern.svg');
  background-position: 0 -12px;
  background-repeat: repeat;
  background-size: auto;
  pointer-events: none;
}

.cta-section__box {
  position: relative;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(var(--blur-box));
  -webkit-backdrop-filter: blur(var(--blur-box));
  border: none;
  border-radius: 0;
  padding: var(--gap-15);
  width: var(--grid-col-10);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--gap-2);
  align-items: flex-start;
}

.cta-section__heading {
  margin-bottom: 0;
}

.cta-section__desc {
  font-size: var(--type-body-size);
  color: var(--color-white-muted);
  max-width: 600px;
  line-height: var(--lh-body);
}

/* ---------- Scroll Reveal Animations ---------- */
[data-animate] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

[data-animate].is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-animate="fade"] {
  transform: none;
}

[data-animate="fade"].is-visible {
  opacity: 1;
}

[data-animate="scale"] {
  transform: scale(0.95);
}

[data-animate="scale"].is-visible {
  opacity: 1;
  transform: scale(1);
}

[data-animate-stagger] > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-animate-stagger].is-visible > *:nth-child(1) { transition-delay: 0s; }
[data-animate-stagger].is-visible > *:nth-child(2) { transition-delay: 0.15s; }
[data-animate-stagger].is-visible > *:nth-child(3) { transition-delay: 0.3s; }

[data-animate-stagger].is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

/* Light path animation */
@keyframes lightPathH {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.line.is-animated .gradient-line-h {
  animation: lightPathH 1.5s ease-in-out forwards;
}

/* ---------- Responsive ---------- */
@media (max-width: 991px) {
  .title-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--gap-2);
  }

  .metric-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap-2);
  }

  .cta-section__box {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .title-hero {
    padding-bottom: var(--section-padding);
  }

  .bordered-metric.hide-on-mobile {
    display: none;
  }

  .metric-grid {
    grid-template-columns: 1fr;
    gap: var(--gap-3);
  }
}

@media (max-width: 479px) {
  .title-hero__heading {
    font-size: var(--type-h2);
  }
}
