/* parts.css — hero, reveal, reusable section bits */

.section { padding-block: clamp(56px, 8vw, 104px); }
.section-tight { padding-block: clamp(40px, 6vw, 72px); }

.section-head { max-width: 720px; margin-bottom: 44px; }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head p { color: var(--color-ink-soft); font-size: 1.06rem; }

/* hero */
.front {
  position: relative;
  background: var(--color-deep);
  color: #fff;
  overflow: hidden;
}
.front-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
}
.front-text {
  padding: clamp(56px, 9vw, 110px) 22px clamp(48px, 7vw, 84px);
  max-width: 640px;
}
.front .eyebrow { color: var(--color-accent); }
.front .eyebrow::before { background: var(--color-accent); }
.hero-title { color: #fff; max-width: 14ch; }
.front-text p { color: rgba(231,239,233,.84); font-size: 1.12rem; max-width: 52ch; }
.front-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.front-media { position: relative; min-height: 320px; }
.front-media img { width: 100%; height: 100%; object-fit: cover; }
.front-figures {
  display: flex;
  flex-wrap: wrap;
  gap: 28px 44px;
  margin-top: 42px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.16);
}
.front-figures div { min-width: 110px; }
.front-figures b {
  display: block;
  font-family: var(--ff-display);
  font-size: 1.9rem;
  color: var(--color-accent);
  line-height: 1;
}
.front-figures span { font-size: .9rem; color: rgba(231,239,233,.72); }

/* reveal (IO inline in sheet.js) */
.rise { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.rise.on { opacity: 1; transform: none; }

/* trust strip */
.trust {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 40px;
  align-items: center;
  color: var(--color-ink-soft);
  font-size: .94rem;
}
.trust span { display: inline-flex; align-items: center; gap: 9px; }
.trust svg { width: 20px; height: 20px; flex: none; color: var(--color-primary); }

.breadcrumbs { font-size: .88rem; color: var(--color-ink-soft); padding-block: 18px 0; }
.breadcrumbs a { color: var(--color-primary); }
.breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 0; }
.breadcrumbs li::after { content: "/"; margin-left: 8px; color: var(--color-line); }
.breadcrumbs li:last-child::after { content: ""; }

@media (min-width: 920px) {
  .front-grid { grid-template-columns: 1.05fr .95fr; }
  .front-text { padding-block: clamp(86px, 9vw, 132px); }
  .front-media { min-height: 100%; }
}
