/* Shared hero + track chrome for index.html and services.html.
   Keep page-specific illustration / card styles in each page. */

.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(1200px 600px at 100% 0%, rgba(59,123,196,0.08), transparent 60%),
    linear-gradient(180deg, #FAFBFD 0%, #FFFFFF 100%);
  padding: 80px 0 96px;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--color-primary-subtle);
  color: var(--color-primary);
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 24px;
}
.hero-eyebrow .dot {
  width: 6px;
  height: 6px;
  background: var(--color-secondary);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(216,31,38,0.15);
}
.hero h1 {
  font-size: 60px;
  line-height: 1.1;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
  margin: 0 0 24px;
}
.hero h1 .accent { color: var(--color-primary); }
.hero h1 .underline {
  background-image: linear-gradient(transparent 65%, rgba(216,31,38,0.20) 65%);
  background-repeat: no-repeat;
  padding: 0 4px;
}
.hero-sub {
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-text-secondary);
  margin: 0 0 36px;
  max-width: 540px;
}
.hero-cta { display: flex; gap: 16px; align-items: center; }
.hero-meta {
  display: flex;
  gap: 32px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--color-border-subtle);
}
.hero-meta .item .num {
  font-size: 28px;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
}
.hero-meta .item .lbl {
  font-size: 13px;
  color: var(--color-text-tertiary);
  margin-top: 2px;
}

.track-bar {
  margin-top: -56px;
  position: relative;
  z-index: 2;
  padding: 0 0 var(--space-section-md);
}
.track-card {
  background: #fff;
  border-radius: 16px;
  border: 1px solid var(--color-border-subtle);
  box-shadow: 0 16px 40px -12px rgba(15,23,42,0.10);
  padding: 24px 28px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 20px;
  align-items: center;
}
.track-card .lbl {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.track-card .lbl .h {
  font-weight: 600;
  font-size: 16px;
  color: var(--color-text-primary);
}
.track-card .lbl .s {
  font-size: 13px;
  color: var(--color-text-tertiary);
}
.track-input {
  height: 52px;
  width: 100%;
  border: 1px solid var(--color-border-default);
  border-radius: var(--input-radius);
  padding: 0 16px 0 44px;
  font-size: 15px;
  color: var(--color-text-primary);
  background: var(--color-bg-surface)
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='16' rx='2'/><path d='M7 4v16M11 4v16M15 4v16M19 4v16'/></svg>") no-repeat 14px center;
  background-size: 18px 18px;
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
}
.track-input:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-focus-ring);
}
.track-card .btn { height: 52px; }
.track-help {
  color: var(--color-text-tertiary);
  font-size: 13px;
  padding-left: 8px;
  border-left: 1px solid var(--color-border-subtle);
}
.track-help a {
  color: var(--color-primary);
  font-weight: 500;
}

/* Shared dark hero treatment for index.html / services.html */
.hero {
  background: linear-gradient(165deg, #0F2A4F 0%, #061327 100%) !important;
  color: #fff;
  overflow: hidden;
}
.hero::before {
  background:
    radial-gradient(800px 500px at 100% 0%, rgba(216,31,38,0.18), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(59,123,196,0.20), transparent 60%) !important;
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.hero-grid { position: relative; z-index: 1; }
.hero-eyebrow {
  background: rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(255,255,255,0.15);
}
.hero h1 { color: #fff !important; }
.hero h1 .accent { color: #FF9498 !important; }
.hero h1 .underline {
  background-image: linear-gradient(transparent 65%, rgba(255,148,152,0.30) 65%) !important;
}
.hero-sub { color: rgba(255,255,255,0.82) !important; }
.hero-cta .btn-secondary {
  color: #fff !important;
  border-color: rgba(255,255,255,0.30) !important;
  background: rgba(255,255,255,0.06) !important;
}
.hero-cta .btn-secondary:hover { background: rgba(255,255,255,0.14) !important; }
.hero-meta { border-top-color: rgba(255,255,255,0.14) !important; }
.hero-meta .item .num { color: #fff !important; }
.hero-meta .item .lbl { color: rgba(255,255,255,0.62) !important; }
.track-bar { margin-top: -56px; position: relative; z-index: 2; }
