/* weBump — Safety explainer */

.onboarding-screen.safety-shell {
  padding:
    calc(var(--viewport-bleed) + max(34px, env(safe-area-inset-top)))
    max(18px, env(safe-area-inset-right))
    calc(var(--viewport-bleed) + max(34px, env(safe-area-inset-bottom)))
    max(18px, env(safe-area-inset-left)) !important;
}

.safety-card {
  --safety-purple: #8d6cf2;
  --safety-yellow: #e7ad28;
  --safety-red: #e84f60;
  position: relative;
  z-index: 10;
  width: min(100%, 980px);
  margin: 0 auto;
  overflow: hidden;
  color: var(--section-text);
  background:
    radial-gradient(circle at 90% 2%, color-mix(in srgb, var(--accent-blue) 14%, transparent), transparent 25%),
    radial-gradient(circle at 2% 34%, color-mix(in srgb, var(--accent-pink) 9%, transparent), transparent 24%),
    linear-gradient(145deg, color-mix(in srgb, var(--section-glass-strong) 94%, #ffffff 6%), var(--section-glass)),
    var(--section-glass-strong);
  border: 1px solid var(--section-border);
  border-radius: clamp(28px, 4vw, 40px);
  box-shadow: 0 30px 90px var(--section-shadow);
  backdrop-filter: blur(32px) saturate(140%);
  -webkit-backdrop-filter: blur(32px) saturate(140%);
  opacity: 0;
  transform: translateY(18px) scale(0.99);
  animation: safety-card-in 0.72s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes safety-card-in {
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.safety-hero {
  padding: clamp(30px, 7vw, 72px) clamp(24px, 8vw, 84px) clamp(42px, 7vw, 72px);
  text-align: center;
}

.safety-home-link {
  display: inline-block;
  margin-bottom: clamp(20px, 4vw, 30px);
  border-radius: 26%;
  transition: transform 0.22s ease;
}

.safety-home-link:hover {
  transform: translateY(-2px) rotate(-1deg);
}

.safety-app-icon-wrap {
  display: block;
}

.safety-app-icon {
  display: block;
  width: clamp(70px, 12vw, 94px);
  height: auto;
  border-radius: 26%;
  box-shadow:
    0 18px 44px rgba(15, 23, 42, 0.2),
    0 0 0 1px rgba(255, 255, 255, 0.32) inset;
}

.safety-kicker,
.safety-eyebrow {
  color: var(--accent-blue);
  font-size: clamp(0.72rem, 1.5vw, 0.84rem);
  font-weight: 950;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.safety-kicker {
  margin-bottom: 12px;
}

.safety-hero h1 {
  max-width: 800px;
  margin: 0 auto;
  font-size: clamp(2.45rem, 7vw, 5rem);
  font-weight: 950;
  line-height: 0.98;
  letter-spacing: -0.035em;
}

.safety-lede {
  max-width: 680px;
  margin: clamp(20px, 4vw, 30px) auto 0;
  color: var(--section-muted);
  font-size: clamp(1.04rem, 2.4vw, 1.28rem);
  font-weight: 680;
  line-height: 1.55;
}

.safety-problem {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(250px, 0.85fr);
  gap: clamp(26px, 5vw, 54px);
  padding: clamp(36px, 6vw, 62px) clamp(24px, 7vw, 72px);
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--safety-red) 10%, transparent), transparent 62%),
    color-mix(in srgb, var(--section-glass-strong) 72%, transparent);
  border-block: 1px solid var(--section-border);
}

.safety-eyebrow {
  margin-bottom: 10px;
}

.safety-eyebrow--danger {
  color: var(--safety-red);
}

.safety-eyebrow--green {
  color: var(--accent-green);
}

.safety-eyebrow--orange {
  color: var(--accent-orange);
}

.safety-problem h2,
.safety-answer > h2,
.safety-location h2,
.safety-honesty h2,
.safety-summary > h2 {
  font-size: clamp(1.8rem, 4.4vw, 3rem);
  font-weight: 950;
  line-height: 1.06;
  letter-spacing: -0.025em;
}

.safety-problem-copy > p:not(.safety-eyebrow),
.safety-location p:not(.safety-eyebrow),
.safety-honesty p:not(.safety-eyebrow) {
  margin-top: 18px;
  color: var(--section-muted);
  font-size: clamp(0.98rem, 2vw, 1.1rem);
  font-weight: 650;
  line-height: 1.58;
}

.safety-card code {
  padding: 0.14em 0.42em;
  color: var(--section-text);
  background: color-mix(in srgb, var(--section-text) 7%, transparent);
  border-radius: 7px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.9em;
}

.beacon-demo {
  padding: 24px;
  background: color-mix(in srgb, var(--section-glass-strong) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--safety-red) 28%, var(--section-border));
  border-radius: 24px;
  box-shadow: 0 20px 50px color-mix(in srgb, var(--safety-red) 10%, transparent);
}

.beacon-receiver {
  display: flex;
  width: 74px;
  height: 54px;
  margin: 0 auto 20px;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: color-mix(in srgb, var(--section-text) 84%, transparent);
  border-radius: 16px;
  box-shadow: 0 12px 25px rgba(0, 0, 0, 0.18);
}

.receiver-light {
  width: 8px;
  height: 8px;
  background: var(--safety-red);
  border-radius: 50%;
  box-shadow: 0 0 12px var(--safety-red);
  animation: receiver-pulse 1.8s ease-in-out infinite;
}

.receiver-light:nth-child(2) {
  animation-delay: 0.2s;
}

.receiver-light:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes receiver-pulse {
  50% {
    opacity: 0.32;
    transform: scale(0.72);
  }
}

.beacon-log {
  display: grid;
  gap: 8px;
}

.beacon-log span {
  display: flex;
  min-height: 42px;
  padding: 8px 10px;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--section-muted);
  background: color-mix(in srgb, var(--section-text) 4%, transparent);
  border-radius: 11px;
}

.beacon-log b {
  font-size: 0.72rem;
  letter-spacing: 0.05em;
}

.beacon-demo > p {
  margin-top: 16px;
  color: var(--safety-red);
  font-size: 0.79rem;
  font-weight: 900;
  line-height: 1.4;
  text-align: center;
}

.safety-answer {
  padding: clamp(48px, 8vw, 82px) clamp(22px, 7vw, 72px);
}

.safety-answer > .safety-eyebrow,
.safety-answer > h2 {
  text-align: center;
}

.safety-answer > h2 {
  margin: 0 auto clamp(38px, 7vw, 64px);
}

.safety-timeline {
  max-width: 800px;
  margin: 0 auto;
  list-style: none;
}

.timeline-step {
  --step-color: var(--accent-blue);
  position: relative;
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: clamp(14px, 3vw, 24px);
  padding-bottom: clamp(24px, 5vw, 42px);
}

.timeline-step:not(:last-child)::before {
  content: "";
  position: absolute;
  top: 54px;
  bottom: -2px;
  left: 27px;
  width: 2px;
  background: linear-gradient(var(--step-color), color-mix(in srgb, var(--step-color) 20%, var(--section-border)));
  opacity: 0.42;
}

.timeline-step--pink {
  --step-color: var(--accent-pink);
}

.timeline-step--orange {
  --step-color: var(--accent-orange);
}

.timeline-step--green {
  --step-color: var(--accent-green);
}

.timeline-step--purple {
  --step-color: var(--safety-purple);
}

.timeline-step--yellow {
  --step-color: var(--safety-yellow);
}

.timeline-step--red {
  --step-color: var(--safety-red);
}

.timeline-marker {
  position: relative;
  z-index: 1;
  display: grid;
  width: 56px;
  height: 56px;
  place-items: center;
  color: #fff;
  background: var(--step-color);
  border: 6px solid color-mix(in srgb, var(--section-glass-strong) 92%, transparent);
  border-radius: 50%;
  box-shadow: 0 10px 25px color-mix(in srgb, var(--step-color) 28%, transparent);
}

.timeline-marker span {
  font-size: 1rem;
  font-weight: 950;
}

.timeline-card {
  padding: clamp(22px, 4vw, 34px);
  background:
    radial-gradient(circle at 100% 0, color-mix(in srgb, var(--step-color) 10%, transparent), transparent 38%),
    color-mix(in srgb, var(--section-glass-strong) 80%, transparent);
  border: 1px solid var(--section-border);
  border-radius: 24px;
  box-shadow: 0 16px 38px color-mix(in srgb, var(--section-shadow) 65%, transparent);
}

.timeline-cause {
  margin-bottom: 8px !important;
  color: var(--step-color) !important;
  font-size: 0.78rem !important;
  font-weight: 950 !important;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.timeline-card h3 {
  font-size: clamp(1.25rem, 3vw, 1.65rem);
  font-weight: 950;
  line-height: 1.15;
  letter-spacing: -0.015em;
}

.timeline-card p {
  margin-top: 14px;
  color: var(--section-muted);
  font-size: clamp(0.94rem, 1.9vw, 1.05rem);
  font-weight: 640;
  line-height: 1.56;
}

.timeline-effect {
  padding: 13px 15px;
  color: var(--section-text) !important;
  background: color-mix(in srgb, var(--step-color) 9%, transparent);
  border-radius: 13px;
}

.timeline-effect strong {
  color: var(--step-color);
  font-weight: 950;
}

.rolling-strip {
  display: flex;
  margin-top: 18px;
  padding: 15px;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: color-mix(in srgb, var(--accent-pink) 7%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-pink) 20%, var(--section-border));
  border-radius: 15px;
}

.rolling-strip span {
  display: grid;
  gap: 4px;
  justify-items: center;
}

.rolling-strip small {
  color: var(--section-muted);
  font-size: 0.68rem;
  font-weight: 850;
}

.rolling-strip i {
  color: var(--accent-pink);
  font-style: normal;
  font-weight: 950;
}

.safety-location {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.65fr);
  gap: clamp(30px, 6vw, 64px);
  padding: clamp(42px, 7vw, 72px) clamp(24px, 7vw, 72px);
  align-items: center;
  background:
    radial-gradient(circle at 84% 50%, color-mix(in srgb, var(--accent-green) 14%, transparent), transparent 26%),
    color-mix(in srgb, var(--section-glass-strong) 70%, transparent);
  border-block: 1px solid var(--section-border);
}

.location-grid {
  display: grid;
  width: min(100%, 300px);
  aspect-ratio: 1;
  margin: 0 auto;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 10px;
  background: color-mix(in srgb, var(--section-text) 4%, transparent);
  border: 1px solid var(--section-border);
  border-radius: 26px;
  transform: rotate(3deg);
}

.location-grid > span {
  position: relative;
  background: color-mix(in srgb, var(--section-muted) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--section-muted) 12%, transparent);
  border-radius: 13px;
}

.location-grid .location-grid-active {
  background: color-mix(in srgb, var(--accent-green) 24%, transparent);
  border-color: color-mix(in srgb, var(--accent-green) 54%, transparent);
  box-shadow: 0 0 28px color-mix(in srgb, var(--accent-green) 30%, transparent);
}

.location-grid-active i {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 15px;
  height: 15px;
  background: var(--accent-green);
  border: 4px solid color-mix(in srgb, var(--section-glass-strong) 92%, transparent);
  border-radius: 50%;
  box-shadow: 0 0 0 8px color-mix(in srgb, var(--accent-green) 14%, transparent);
  transform: translate(-50%, -50%);
}

.safety-honesty {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(48px, 8vw, 82px) clamp(24px, 7vw, 72px);
  text-align: center;
}

.safety-summary {
  padding: clamp(40px, 7vw, 68px) clamp(24px, 7vw, 72px);
  background: color-mix(in srgb, var(--section-text) 3%, transparent);
  border-top: 1px solid var(--section-border);
}

.safety-summary > h2 {
  margin-bottom: clamp(24px, 4vw, 34px);
  text-align: center;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.summary-grid article {
  padding: 22px;
  background: color-mix(in srgb, var(--section-glass-strong) 78%, transparent);
  border: 1px solid var(--section-border);
  border-radius: 20px;
}

.summary-icon {
  display: block;
  width: 13px;
  height: 13px;
  margin-bottom: 14px;
  background: var(--accent-blue);
  border-radius: 50%;
  box-shadow: 0 0 16px var(--accent-blue);
}

.summary-icon--pink {
  background: var(--accent-pink);
  box-shadow: 0 0 16px var(--accent-pink);
}

.summary-icon--green {
  background: var(--accent-green);
  box-shadow: 0 0 16px var(--accent-green);
}

.summary-icon--orange {
  background: var(--accent-orange);
  box-shadow: 0 0 16px var(--accent-orange);
}

.summary-grid h3 {
  font-size: 1.04rem;
  font-weight: 900;
  line-height: 1.25;
}

.summary-grid p {
  margin-top: 7px;
  color: var(--section-muted);
  font-size: 0.91rem;
  font-weight: 640;
  line-height: 1.45;
}

.safety-footer {
  padding: clamp(28px, 5vw, 44px) 24px;
  color: var(--section-muted);
  font-size: 0.88rem;
  font-weight: 720;
  line-height: 1.5;
  text-align: center;
}

.safety-footer nav {
  display: flex;
  margin-top: 14px;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.safety-footer a {
  color: var(--accent-blue);
  font-weight: 850;
  text-decoration: none;
}

.safety-footer a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (prefers-color-scheme: dark) {
  .safety-card {
    background:
      radial-gradient(circle at 90% 2%, color-mix(in srgb, var(--accent-blue) 11%, transparent), transparent 25%),
      radial-gradient(circle at 2% 34%, color-mix(in srgb, var(--accent-pink) 8%, transparent), transparent 24%),
      linear-gradient(145deg, color-mix(in srgb, var(--section-glass-strong) 94%, #000000 6%), var(--section-glass)),
      var(--section-glass-strong);
  }

  .safety-card code {
    background: rgba(255, 255, 255, 0.08);
  }
}

@media (max-width: 720px) {
  .safety-problem,
  .safety-location {
    grid-template-columns: 1fr;
  }

  .beacon-demo,
  .location-grid {
    width: min(100%, 340px);
    margin-inline: auto;
  }

  .timeline-step {
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 12px;
  }

  .timeline-marker {
    width: 44px;
    height: 44px;
    border-width: 5px;
  }

  .timeline-step:not(:last-child)::before {
    top: 42px;
    left: 21px;
  }
}

@media (max-width: 520px) {
  .safety-hero {
    padding-inline: 22px;
  }

  .safety-hero h1 {
    font-size: clamp(2.25rem, 12vw, 3.35rem);
  }

  .safety-answer {
    padding-inline: 14px;
  }

  .timeline-card {
    padding: 20px 17px;
    border-radius: 20px;
  }

  .rolling-strip {
    gap: 5px;
    padding: 12px 8px;
  }

  .rolling-strip code {
    padding-inline: 0.28em;
    font-size: 0.78rem;
  }

  .summary-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .safety-card {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .receiver-light {
    animation: none;
  }

  .safety-home-link {
    transition: none;
  }
}
