/* =============================================================
   HZL Microsite — Base / reset
   ============================================================= */

*,
*::before,
*::after { box-sizing: border-box; }

* { margin: 0; padding: 0; }

html {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  scroll-behavior: auto; /* Lenis handles smoothing */
}

body {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.6;
  color: var(--on-dark);
  background: var(--navy-900);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Lock scroll while drawer / search overlay is open */
body.is-locked { overflow: hidden; }

img,
svg,
video { display: block; max-width: 100%; }

a { color: inherit; text-decoration: none; }

button {
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  cursor: pointer;
}

ul { list-style: none; }

:focus-visible {
  outline: 2px solid var(--teal-400);
  outline-offset: 3px;
  border-radius: 2px;
}

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* =============================================================
   SHARED SHIMMER-PILL CTA  — applied to every section CTA
   ============================================================= */
@keyframes hzlCtaShimmer {
  0%   { background-position: 0 0, 0%   50%; }
  50%  { background-position: 0 0, 100% 50%; }
  100% { background-position: 0 0, 0%   50%; }
}

.about__cta,
.aw__cta,
.bed-flow__cta,
.bod__cta,
.bs__cta,
.ceo-qna__cta,
.cfo-statement__cta,
.esg__cta,
.inv-case__card-cta,
.kpi3d__cta,
.kpi__slide-cta,
.social-photo-overlay__cta,
.sp__card-cta,
.cs__view-all,
.sustain__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.68em 1.6em;
  border-radius: 999px;
  border: 1.5px solid transparent;
  background:
    linear-gradient(rgba(4, 13, 24, 0.88), rgba(4, 13, 24, 0.88)) padding-box,
    linear-gradient(
      135deg,
      #0060a3  0%, #4fe0cf 22%, #ffffff 44%,
      #7fb942 66%, #4fe0cf 82%, #0060a3 100%
    ) border-box;
  background-size: 100%, 300% 300%;
  animation: hzlCtaShimmer 2.8s ease-in-out infinite;
  font-family: var(--font-display);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(238, 242, 246, 0.88);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  transition: color 0.22s;
  cursor: pointer;
}

.about__cta:hover,
.aw__cta:hover,
.bed-flow__cta:hover,
.bod__cta:hover,
.bs__cta:hover,
.ceo-qna__cta:hover,
.cfo-statement__cta:hover,
.esg__cta:hover,
.inv-case__card-cta:hover,
.kpi3d__cta:hover,
.kpi__slide-cta:hover,
.social-photo-overlay__cta:hover,
.sp__card-cta:hover,
.cs__view-all:hover,
.sustain__cta:hover {
  color: #ffffff;
}

/* Arrow spans inside shimmer CTAs */
.about__cta-arrow,
.aw__cta-arrow,
.bod__cta-arrow,
.bs__cta-arrow,
.ceo-qna__cta-arrow,
.cfo-statement__cta-arrow,
.esg__cta-arrow,
.kpi3d__cta-arrow,
.mine__card-cta-arrow,
.sustain__cta-arrow {
  display: inline-block;
  transition: transform 0.22s;
}

.about__cta:hover .about__cta-arrow,
.aw__cta:hover .aw__cta-arrow,
.bod__cta:hover .bod__cta-arrow,
.bs__cta:hover .bs__cta-arrow,
.ceo-qna__cta:hover .ceo-qna__cta-arrow,
.cfo-statement__cta:hover .cfo-statement__cta-arrow,
.esg__cta:hover .esg__cta-arrow,
.kpi3d__cta:hover .kpi3d__cta-arrow,
.mine__card-cta:hover .mine__card-cta-arrow,
.sustain__cta:hover .sustain__cta-arrow {
  transform: translateX(5px);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
