:root {
  --um-blue: #2D3192;
  --um-blue-dark: #1A1D6E;
  --um-red: #C8102E;
  --um-yellow: #FFD200;
  --um-ink: #141821;
  --um-gray: #f4f6fa;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.lp-um { margin: 0; font-family: 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  color: var(--um-ink); background: #ffffff; line-height: 1.5; }
img { max-width: 100%; display: block; }
h1, h2, h3 { line-height: 1.15; margin: 0 0 .6rem; }

/* buttons */
.um-btn { display: inline-block; padding: 1rem 2.2rem; border: 0; border-radius: 8px;
  font-weight: 800; font-size: 1.05rem; text-decoration: none; cursor: pointer;
  letter-spacing: .01em; text-align: center; }
.um-btn--blue { background: var(--um-blue); color: #fff;
  box-shadow: 0 10px 24px rgba(11,77,162,.28); }
.um-btn--red { background: var(--um-red); color: #fff;
  box-shadow: 0 10px 24px rgba(200,16,46,.28); }
.um-btn:hover { filter: brightness(1.08); }

/* header */
.um-top { display: flex; align-items: center; justify-content: space-between;
  padding: 14px 5vw; border-bottom: 1px solid #e7eaf0; }
.um-logo { height: 44px; width: auto; }
.um-top__tel { color: var(--um-blue-dark); font-weight: 800; font-size: 1.1rem;
  text-decoration: none; white-space: nowrap; }

/* hero — LARGE full-bleed background with the lead form ON THE RIGHT */
.um-hero--bg { position: relative; padding: 0;
  background: url('assets/hero_main.jpg') center 38%/cover no-repeat; }
.um-hero--bg::before { content: ''; position: absolute; inset: 0;
  background: linear-gradient(100deg, rgba(8,18,42,.78) 0%, rgba(8,18,42,.42) 48%, rgba(8,18,42,.18) 100%); }
.um-hero__grid { position: relative; z-index: 2; display: grid;
  grid-template-columns: 1.15fr 460px; gap: 3.2rem; align-items: center;
  max-width: 1280px; margin: 0 auto; padding: 5.5rem 5vw 8.5rem; }
.um-hero__copy { text-align: left; }
.um-hero--bg h1 { font-size: clamp(1.9rem, 4.4vw, 3.3rem); color: #ffffff;
  font-weight: 900; text-shadow: 0 2px 18px rgba(0,0,0,.5); }
.um-hero__sub { font-size: 1.18rem; color: #e8edf6;
  margin: .9rem 0 1.4rem; text-shadow: 0 1px 10px rgba(0,0,0,.45); }
.um-hero__sub strong { color: var(--um-yellow); }
.um-hero__tel { color: #cfd9ea; font-size: 1.02rem; }
.um-hero__tel a { color: var(--um-yellow); font-weight: 800; text-decoration: none; }
.um-hero .um-form-card { margin: 0; padding: 1.6rem 1.5rem; max-width: none; }
.um-hero .um-form-card h2 { font-size: 1.45rem; }
.um-hero .um-cd { margin: .6rem 0 1rem; }
.um-hero .um-cd b { font-size: 1.25rem; min-width: 52px; }

/* benefits strip — overlaps the hero photo's bottom edge.
   EXACTLY one row of 5 on desktop; never a 4+1 orphan row (operator rule). */
.um-feats-strip { display: flex; gap: 14px; max-width: 1280px;
  margin: -72px auto 0; padding: 0 5vw; position: relative; z-index: 6; }
.um-feats-strip .um-feat { flex: 1 1 0; min-width: 0; background: #fff;
  box-shadow: 0 16px 34px rgba(8,18,42,.18); }

/* form card */
.um-form-section { background: var(--um-blue-dark); padding: 3rem 5vw; }
.um-form-card { background: #fff; max-width: 660px; margin: 0 auto; border-radius: 16px;
  padding: 2rem 1.8rem; box-shadow: 0 18px 44px rgba(0,0,0,.3); text-align: center; }
.um-form-card__tag { display: inline-block; background: var(--um-yellow);
  color: var(--um-ink); font-weight: 900; font-size: .82rem; letter-spacing: .12em;
  padding: .35rem .9rem; border-radius: 999px; }
.um-form-card h2 { color: var(--um-blue-dark); font-size: 1.7rem; margin-top: .6rem; }
.um-cd { display: flex; justify-content: center; gap: 18px; margin: .8rem 0 1.2rem; }
.um-cd span { display: flex; flex-direction: column; align-items: center; }
.um-cd b { background: var(--um-red); color: #fff; font-size: 1.5rem; min-width: 58px;
  padding: .45rem .5rem; border-radius: 8px; font-variant-numeric: tabular-nums; }
.um-cd i { font-style: normal; font-size: .72rem; color: #5b6270; margin-top: .3rem;
  text-transform: uppercase; letter-spacing: .08em; }
.um-form { text-align: left; }
.um-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin-bottom: 12px; }
.um-form label > span { display: block; font-size: .85rem; font-weight: 700;
  color: #2c3342; margin-bottom: .25rem; }
.um-form input[type=text], .um-form input[type=tel], .um-form input[type=email],
.um-form select { width: 100%; padding: .8rem .9rem; border: 1px solid #c9cfdb;
  border-radius: 8px; font-size: 1rem; background: #fff; color: var(--um-ink); }
.um-form__consent { display: flex; gap: 10px; align-items: flex-start;
  font-size: .76rem; color: #5b6270; margin: 10px 0 4px; }
.um-form__consent input { margin-top: 3px; }
.um-form .um-btn--red { width: 100%; font-size: 1.15rem; }
.um-form-thanks h3 { color: var(--um-blue-dark); }

/* feature chips */
.um-feat { background: var(--um-gray); border-radius: 14px; padding: 1.6rem 1.2rem;
  border-top: 4px solid var(--um-blue); text-align: center;
  transition: transform .22s ease, box-shadow .22s ease; }
.um-feat:hover { transform: translateY(-7px);
  box-shadow: 0 16px 30px rgba(11,77,162,.18); }
.um-feat__ic { font-size: 2.2rem; margin-bottom: .5rem; }
.um-feat h3 { font-size: 1.05rem; color: var(--um-blue-dark); margin: 0; }

/* badge seals */
.um-seals { display: flex; flex-wrap: wrap; justify-content: center; gap: 22px;
  padding: 1.6rem 5vw; background: #fff; border-bottom: 1px solid #e7eaf0; }
.um-seal { width: 132px; height: 132px; border-radius: 50%; border: 3px double var(--um-blue);
  background: radial-gradient(circle at 50% 36%, #f6f9ff 0%, #e8effc 100%);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 10px; box-shadow: 0 6px 16px rgba(11,77,162,.14); }
.um-seal b { font-size: .98rem; font-weight: 900; color: var(--um-blue-dark);
  letter-spacing: .02em; }
.um-seal i { font-style: normal; font-size: .58rem; font-weight: 800; color: #4a5468;
  letter-spacing: .1em; margin-top: .25rem; }

/* offers */
.um-offers { padding: 1rem 5vw 2.5rem; text-align: center; max-width: 1080px; margin: 0 auto; }
.um-offers h2 { font-size: 2rem; color: var(--um-blue-dark); }
.um-offers__row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 1.4rem; }
.um-offer { background: #fff; border: 1px solid #e7eaf0; border-radius: 16px;
  overflow: hidden; box-shadow: 0 10px 30px rgba(20,24,33,.08); padding-bottom: 1.4rem; }
.um-offer img { width: 100%; height: 250px; object-fit: cover; }
.um-offer h3 { font-size: 1.25rem; color: var(--um-blue-dark); padding: 1rem 1.2rem .2rem; }
.um-offer p { color: #3a4150; font-size: .95rem; padding: 0 1.2rem; margin: .4rem 0 1rem; }
.um-fine { font-size: .74rem; color: #8a8f9c; max-width: 760px; margin: 1.2rem auto 0; }

/* calculator */
.um-calc { max-width: 660px; margin: 1rem auto 3rem; padding: 2rem 1.6rem;
  background: #fff; border-radius: 16px; border-top: 5px solid var(--um-blue);
  box-shadow: 0 12px 32px rgba(11,77,162,.14); }
.um-calc h2 { color: var(--um-blue-dark); font-size: 1.45rem; text-align: center; }
.um-calc h2 small { display: block; margin-top: .3rem; font-size: .76rem;
  font-weight: 400; color: #8a8f9c; }
.um-calc__row { display: block; max-width: 480px; margin: 1.2rem auto; }
.um-calc__row > span { display: block; font-size: .92rem; font-weight: 700;
  margin-bottom: .4rem; }
.um-calc__row input[type=range] { width: 100%; display: block; margin: 0 0 .35rem;
  accent-color: var(--um-blue); }
.um-calc__row output { display: block; text-align: center; font-weight: 800;
  color: var(--um-blue-dark); font-variant-numeric: tabular-nums; }
.um-calc__result { max-width: 480px; margin: 0 auto; padding: 1.1rem 1rem;
  background: #eef4fc; border: 1px solid #c7dbf5; border-radius: 10px;
  text-align: center; font-size: 1.05rem; }
.um-calc__result strong { color: var(--um-blue); font-size: 1.7rem;
  font-variant-numeric: tabular-nums; }
.um-calc__result small { display: block; margin-top: .4rem; font-size: .8rem;
  color: #5b6270; }
.um-calc__whole { text-align: center; margin-top: .9rem; font-size: .95rem; }
.um-calc__whole strong { color: var(--um-red); }

/* urgency */
.um-urg { background: var(--um-red); color: #fff; text-align: center; padding: 3rem 5vw; }
.um-urg h2 { font-size: clamp(1.5rem, 3.4vw, 2.2rem); color: #fff; }
.um-urg p { font-size: 1.1rem; margin: 0 0 1.4rem; }
.um-urg .um-btn--red { background: #fff; color: var(--um-red); box-shadow: none; }

/* testimonials */
.um-tests { padding: 3rem 5vw; max-width: 1120px; margin: 0 auto; text-align: center; }
.um-tests h2 { font-size: 1.9rem; color: var(--um-blue-dark); margin-bottom: 1.4rem; }
.um-tests__row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.um-test { background: var(--um-gray); border-radius: 14px; padding: 1.6rem 1.3rem;
  text-align: left; }
.um-test__photo { width: 76px; height: 76px; border-radius: 50%; object-fit: cover;
  border: 3px solid var(--um-blue); margin-bottom: .8rem;
  box-shadow: 0 6px 14px rgba(11,77,162,.2); }
.um-test blockquote { margin: 0 0 .7rem; font-size: .95rem; color: #2c3342; }
.um-test cite { font-style: normal; font-weight: 700; font-size: .84rem; color: #5b6270; }

/* final CTA */
.um-final { text-align: center; padding: 3rem 5vw; background: var(--um-gray); }
.um-final h2 { font-size: clamp(1.5rem, 3.4vw, 2.1rem); color: var(--um-blue-dark); }
.um-final p { color: #3a4150; max-width: 640px; margin: .4rem auto; }
.um-final__urg { font-weight: 800; color: var(--um-red); }
.um-final .um-btn { margin-top: 1rem; }

/* social proof */
.um-proof { text-align: center; padding: 3rem 5vw 4rem; max-width: 1080px; margin: 0 auto; }
.um-proof h2 { font-size: 1.8rem; color: var(--um-blue-dark); }
.um-proof blockquote { font-size: 1.05rem; color: #3a4150; max-width: 640px;
  margin: .6rem auto 1.6rem; }
.um-proof cite { font-style: normal; font-weight: 700; }
.um-proof__imgs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  margin-bottom: 1.8rem; }
.um-proof__imgs img { width: 100%; height: 200px; object-fit: cover; border-radius: 12px; }

/* sticky CTA */
.um-sticky { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  background: var(--um-blue); color: #fff; text-align: center; font-weight: 800;
  padding: .95rem 1rem; text-decoration: none; font-size: 1rem;
  box-shadow: 0 -8px 22px rgba(0,0,0,.18); }
body.lp-um { padding-bottom: 64px; }

/* footer */
.paradise-footer { background: var(--um-ink); color: #aab0bd; padding: 2.2rem 5vw 3rem; }
.paradise-footer__inner { max-width: 880px; margin: 0 auto; text-align: center;
  font-size: .82rem; }
.paradise-footer a { color: #cfd5e2; }
.paradise-footer__tag { color: #e6e9f0; font-weight: 700; }
.paradise-footer__sms, .paradise-footer__fb-disclaimer { font-size: .72rem; color: #7d8494; }

/* mobile */
@media (max-width: 980px) {
  .um-hero__grid { grid-template-columns: 1fr; gap: 2rem;
    padding: 3.5rem 5vw 6.5rem; }
  .um-hero__copy { text-align: center; }
  .um-feats-strip { flex-wrap: wrap; margin-top: -56px; }
  .um-feats-strip .um-feat { flex: 1 1 44%; }
}
@media (max-width: 760px) {
  .um-form__row { grid-template-columns: 1fr; }
  .um-offers__row { grid-template-columns: 1fr; }
  .um-tests__row { grid-template-columns: 1fr; }
  .um-proof__imgs { grid-template-columns: 1fr; }
  .um-cd b { font-size: 1.25rem; min-width: 50px; }
  /* stack benefits cleanly 1-per-row — a clean stack, not an orphan row */
  .um-feats-strip { flex-direction: column; }
}
