/* Shared OTO funnel pages — matches Afripay Launch dark theme */
.oto-body{
  margin:0;
  min-height:100vh;
  min-height:100dvh;
  font-family:Inter,Arial,sans-serif;
  color:var(--text);
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(96,165,250,.18), transparent),
    radial-gradient(700px 450px at 90% 25%, rgba(141,245,93,.1), transparent),
    var(--bg);
}
.oto-noise{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.06;
  background-image:radial-gradient(#fff 0.6px, transparent 0.6px);
  background-size:3px 3px;
}
.oto-page{
  position:relative;
  z-index:1;
  max-width:1100px;
  margin:0 auto;
  padding:0 clamp(12px,4vw,28px) max(48px,calc(24px + env(safe-area-inset-bottom)));
}
.oto-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:0;
  border-bottom:1px solid rgba(43,57,80,.75);
}
.oto-topbar-nav{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}
.al-brand--compact .al-brand-logo{height:56px;max-width:min(300px,58vw)}
.oto-thank{
  margin:0 0 clamp(24px,4vw,40px);
  padding:18px 22px;
  border-radius:14px;
  border:1px solid rgba(141,245,93,.28);
  background:linear-gradient(135deg,rgba(141,245,93,.1),rgba(15,23,42,.5));
  box-shadow:0 12px 32px -16px rgba(0,0,0,.35);
  text-align:center;
}
.oto-thank-line{
  margin:0;
  font-size:clamp(15px,1.9vw,17px);
  line-height:1.55;
  color:#e2e8f0;
}
.oto-thank-line strong{
  color:var(--text);
  font-weight:700;
}
.oto-thank-line strong:last-of-type{
  color:var(--primary);
}
.oto-hero{
  text-align:center;
  padding:clamp(8px,2vw,20px) 0 clamp(40px,7vw,64px);
  max-width:820px;
  margin:0 auto;
}
.oto-hero h1{
  margin:0 0 16px;
  font-size:clamp(26px,4.2vw,40px);
  line-height:1.1;
  font-weight:800;
  letter-spacing:-.6px;
}
.oto-hero .oto-lead{
  margin:0 auto;
  max-width:36em;
  font-size:clamp(16px,2vw,18px);
  line-height:1.55;
  color:var(--muted);
}
.oto-hero-trio{
  margin:22px auto 0;
  max-width:32em;
  display:flex;
  flex-direction:column;
  gap:10px;
  font-size:15px;
  font-weight:700;
  line-height:1.4;
  color:#94a3b8;
  text-align:center;
}
.oto-hero-trio span{
  display:block;
  padding:8px 14px;
  border-radius:10px;
  border:1px solid rgba(148,163,184,.15);
  background:rgba(15,23,42,.35);
  color:#cbd5e1;
}
.oto-hero-callout{
  margin:20px auto 0;
  max-width:40em;
  padding:16px 18px;
  border-radius:12px;
  border:1px solid rgba(250,204,21,.28);
  background:rgba(250,204,21,.07);
  font-size:14px;
  line-height:1.6;
  color:#fde68a;
  text-align:center;
}
.oto-hero-callout strong{
  color:#fef9c3;
  font-weight:800;
}
.oto-hero-callout--bundle{
  border-color:rgba(141,245,93,.25);
  background:rgba(141,245,93,.08);
  color:#d9f99d;
}
.oto-hero-callout--bundle strong{color:var(--primary)}
.oto-preview-box{
  max-width:900px;
  margin:0 auto;
  min-height:200px;
  border-radius:14px;
  border:1px dashed rgba(148,163,184,.35);
  background:rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px 20px;
}
.oto-preview-box p{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:#7c8ca5;
  text-align:center;
  max-width:28em;
}
.oto-marketing-mockup{
  width:100%;
  max-width:min(1100px,100%);
  margin:0 auto;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(124,58,237,.35);
  box-shadow:0 24px 60px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.04) inset;
  background:rgba(15,23,42,.4);
}
.oto-marketing-mockup img{
  display:block;
  width:100%;
  height:auto;
  vertical-align:middle;
}
.oto-section--mockup{
  padding-top:clamp(28px,4vw,48px);
}
.oto-section{
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:clamp(40px,6vw,72px) 0;
  border-top:1px solid rgba(148,163,184,.12);
  text-align:center;
}
.oto-section > .oto-section-head,
.oto-section > .oto-grid,
.oto-section > .oto-preview-box,
.oto-section > .oto-marketing-mockup,
.oto-section > .oto-rescue-price-block,
.oto-section > .oto-live-list,
.oto-section > .oto-social-proof,
.oto-section > .oto-proof-metrics,
.oto-section > .oto-live-activity,
.oto-section > .oto-save-line,
.oto-section > .oto-bundle-anchor{
  width:100%;
}
.oto-section-head{
  text-align:center;
  margin:0 auto 36px;
  max-width:640px;
}
.oto-section-head h2{
  margin:0 0 10px;
  font-size:clamp(22px,3.2vw,30px);
  font-weight:800;
  letter-spacing:-.4px;
  line-height:1.15;
}
.oto-section-head p{
  margin:0;
  font-size:15px;
  line-height:1.55;
  color:var(--muted);
}
.oto-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  width:100%;
  max-width:1040px;
  margin-left:auto;
  margin-right:auto;
  justify-items:stretch;
}
.oto-grid--2{
  grid-template-columns:repeat(2,minmax(0,1fr));
  max-width:880px;
  margin-left:auto;
  margin-right:auto;
}
.oto-grid--3,
.oto-grid.oto-grid--3{
  max-width:1040px;
  margin-left:auto;
  margin-right:auto;
}
.oto-grid--auto{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  max-width:960px;
  margin-left:auto;
  margin-right:auto;
}
.oto-card{
  padding:22px 20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  text-align:center;
  transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;
}
.oto-card:hover{
  transform:translateY(-4px);
  border-color:rgba(141,245,93,.4);
  box-shadow:0 20px 44px -18px rgba(0,0,0,.4);
}
.oto-card h3{
  margin:0 0 10px;
  font-size:17px;
  font-weight:700;
  letter-spacing:-.2px;
  color:#f1f5f9;
}
.oto-card h3:last-child{margin-bottom:0}
.oto-card p{
  margin:0 0 8px;
  font-size:14px;
  line-height:1.55;
  color:#cbd5e1;
}
.oto-card p:last-child{margin-bottom:0}
.oto-card--neg{
  border-color:rgba(248,113,113,.28);
  background:rgba(248,113,113,.07);
}
.oto-card--neg h3{color:#fecaca}
.oto-card--neg p{color:#fecaca;opacity:.92}
.oto-card--pos{
  border-color:rgba(141,245,93,.35);
  background:rgba(141,245,93,.08);
}
.oto-card--pos h3{color:#d9ffc4}
.oto-card--pos p{color:#bbf7d0;opacity:.95}
.oto-card--simple{
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:96px;
  padding:20px 16px;
}
.oto-card--simple h3{
  margin:0;
  font-size:15px;
  line-height:1.35;
  font-weight:700;
  color:#e2e8f0;
}
.oto-card--include{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  text-align:center;
}
.oto-card--include strong{
  font-size:16px;
  font-weight:700;
  color:#f1f5f9;
  letter-spacing:-.02em;
}
.oto-include-mark{
  flex-shrink:0;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  font-size:15px;
  font-weight:800;
  color:#0f172a;
  background:var(--primary);
  box-shadow:0 0 0 2px rgba(141,245,93,.2);
}
.oto-bundle-anchor{
  max-width:460px;
  margin:0 auto 28px;
  padding:22px 24px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.22);
  background:rgba(0,0,0,.22);
}
.oto-bundle-anchor-title{
  margin:0 0 14px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#94a3b8;
}
.oto-bundle-line{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:20px;
  padding:11px 0;
  font-size:15px;
  color:#e2e8f0;
  border-bottom:1px solid rgba(148,163,184,.12);
}
.oto-bundle-line:last-child{border-bottom:none}
.oto-bundle-line span:last-child{
  font-weight:700;
  color:#f8fafc;
  font-variant-numeric:tabular-nums;
}
.oto-bundle-line--total{
  margin-top:6px;
  padding-top:16px;
  border-top:1px solid rgba(148,163,184,.2);
  border-bottom:none;
  font-size:17px;
  font-weight:800;
}
.oto-bundle-line--total span:last-child{color:var(--primary)}
.oto-grid--bundle-compare{margin-top:8px}
.oto-card--pricebox{
  text-align:center;
  display:block;
  padding:26px 20px;
}
.oto-card--pricebox:hover{transform:translateY(-3px)}
.oto-pricebox-label{
  margin:0 0 10px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.9;
}
.oto-card--neg .oto-pricebox-label{color:#fecaca}
.oto-card--pos .oto-pricebox-label{color:#bbf7d0}
.oto-pricebox-amount{
  margin:0;
  font-size:clamp(26px,4vw,34px);
  font-weight:800;
  letter-spacing:-.5px;
  font-variant-numeric:tabular-nums;
}
.oto-card--neg .oto-pricebox-amount{color:#fecaca}
.oto-card--pos .oto-pricebox-amount{color:var(--primary)}
.oto-save-line{
  margin:22px 0 0;
  text-align:center;
  font-size:clamp(17px,2.4vw,22px);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--primary);
}
.oto-save-line--amber{
  margin:14px 0 0;
  font-size:clamp(16px,2.2vw,20px);
  line-height:1.45;
  color:#facc15;
}
.oto-body.oto-body--rescue{
  background:
    radial-gradient(720px 380px at 50% 0%, rgba(250,204,21,.08), transparent),
    radial-gradient(900px 500px at 10% 0%, rgba(96,165,250,.16), transparent),
    radial-gradient(700px 450px at 90% 28%, rgba(141,245,93,.1), transparent),
    var(--bg);
}
.oto-rescue-kicker{
  margin:0 0 20px;
  text-align:center;
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#7c8ca5;
}
.oto-hero--rescue{
  padding-top:clamp(4px,1.5vw,16px);
  border-bottom:1px solid rgba(148,163,184,.1);
  margin-bottom:clamp(8px,2vw,16px);
  padding-bottom:clamp(28px,5vw,44px);
}
.oto-section-head .oto-sub-lead{
  margin:0;
  font-size:16px;
  line-height:1.6;
  color:var(--muted);
}
.oto-section-head .oto-sub-lead strong{color:#e2e8f9}
.oto-alt-signup{margin:14px 0 0;text-align:center;font-size:13px;color:#94a3b8}
.oto-alt-signup a{color:#7dd3fc;text-decoration:underline}
/* Global click affordance: pointer on interactive elements */
a[href],
button,
[role="button"],
input[type="button"],
input[type="submit"],
input[type="reset"],
summary,
label[for],
[onclick],
[data-href],
[data-clickable="true"] {
    cursor: pointer !important;
}
a[href]:active,
button:active,
[role="button"]:active,
input[type="button"]:active,
input[type="submit"]:active,
input[type="reset"]:active,
summary:active,
label[for]:active,
[onclick]:active,
[data-href]:active,
[data-clickable="true"]:active {
    cursor: pointer !important;
}

/* OTO-wide fallback: force hand cursor on clickable controls/links. */
a,
button,
.btn,
input[type="submit"],
input[type="button"],
[role="button"]{
  cursor:pointer !important;
}
a *,
button *,
.btn *,
[role="button"] *{
  cursor:pointer !important;
}
button:disabled,
input:disabled,
.btn[aria-disabled="true"]{
  cursor:not-allowed !important;
}


.oto-flw-banner{margin:0 0 16px;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;text-align:center}
.oto-flw-banner--ok{background:rgba(34,197,94,.18);border:1px solid rgba(34,197,94,.45);color:#bbf7d0}
.oto-flw-banner--fail{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.4);color:#fecaca}

.oto-rescue-price-block{
  margin:12px auto 0;
  max-width:420px;
  text-align:center;
}
.oto-old-price{
  margin:0 0 8px;
  font-size:clamp(18px,2.4vw,22px);
  font-weight:600;
  color:#94a3b8;
  text-decoration:line-through;
  font-variant-numeric:tabular-nums;
}
.oto-rescue-today{
  margin:0 0 6px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fde68a;
}
.oto-rescue-price-block .oto-price{
  margin:0 0 10px;
}
.oto-section--rescue-price .oto-section-head{margin-bottom:28px}
.oto-cta-block{
  text-align:center;
  padding:clamp(44px,7vw,80px) 0 24px;
  border-top:1px solid rgba(148,163,184,.12);
}
.oto-cta-block h2{
  margin:0 0 12px;
  font-size:clamp(22px,3.2vw,30px);
  font-weight:800;
  letter-spacing:-.35px;
}
.oto-cta-block .oto-cta-lead{
  margin:0 auto 22px;
  max-width:32em;
  font-size:15px;
  color:var(--muted);
  line-height:1.55;
}
.oto-price{
  margin:0 0 20px;
  font-size:clamp(32px,5vw,44px);
  font-weight:800;
  letter-spacing:-1px;
  color:var(--primary);
}
.oto-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
  align-items:center;
  margin-bottom:18px;
}
.oto-downsell{
  margin:0;
  font-size:14px;
  color:#7c8ca5;
}
.oto-downsell a{
  display:inline-block;
  color:#94a3b8;
  text-decoration:underline;
  text-underline-offset:3px;
  padding:10px 4px;
  min-height:44px;
  line-height:1.4;
}
.oto-downsell a:hover{color:var(--primary)}
.oto-kicker{
  margin:0 0 10px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#93c5fd;
  text-align:center;
}
.oto-list{
  margin:12px auto 0;
  padding-left:1.15em;
  max-width:22em;
  text-align:left;
  display:inline-block;
}
.oto-card--neg .oto-list,
.oto-card--pos .oto-list,
.oto-card--neg h3,
.oto-card--pos h3{
  text-align:center;
}
.oto-preview-checklist{
  margin:0;
  padding:0;
  list-style:none;
  width:100%;
  text-align:center;
}
.oto-preview-checklist li{
  margin:0;
  padding:6px 8px;
  font-size:14px;
  line-height:1.45;
  color:#cbd5e1;
}
.oto-preview-checklist--cols{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px 14px;
  justify-items:center;
  text-align:center;
}
.oto-preview-box--live{
  border-style:solid;
  border-color:rgba(141,245,93,.28);
  background:linear-gradient(145deg,rgba(141,245,93,.08),rgba(15,23,42,.5));
}
.oto-live-list{
  margin:0 auto;
  padding:0;
  list-style:none;
  width:min(680px,100%);
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  justify-items:center;
}
.oto-live-list li{
  width:100%;
  box-sizing:border-box;
  font-size:14px;
  color:#dcfce7;
  text-align:center;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid rgba(141,245,93,.22);
  background:rgba(2,6,23,.4);
}
.oto-social-proof{
  margin:22px auto 0;
  max-width:820px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.oto-social-proof p{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:#e2e8f0;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.2);
  background:rgba(15,23,42,.45);
}
.oto-proof-metrics{
  margin:14px auto 0;
  max-width:820px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:10px;
}
.oto-proof-metrics span{
  display:block;
  text-align:center;
  padding:9px 10px;
  border-radius:10px;
  border:1px solid rgba(56,189,248,.25);
  background:rgba(2,6,23,.46);
  color:#dbeafe;
  font-size:12px;
  font-weight:700;
}
.oto-prereg-form{
  max-width:860px;
  margin:0 auto;
  padding:18px;
  border:1px solid rgba(148,163,184,.22);
  border-radius:14px;
  background:rgba(15,23,42,.52);
}
.oto-prereg-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-bottom:12px;
}
.oto-prereg-form label{
  display:block;
}
.oto-prereg-form label span{
  display:block;
  margin:0 0 6px;
  font-size:12px;
  font-weight:700;
  color:#cbd5e1;
}
.oto-prereg-form input,
.oto-prereg-form textarea{
  width:100%;
  box-sizing:border-box;
  border:1px solid rgba(148,163,184,.34);
  border-radius:10px;
  background:#0f172a;
  color:#e2e8f0;
  padding:10px 12px;
}
.oto-prereg-form textarea{
  resize:vertical;
  min-height:84px;
  margin-bottom:12px;
}
.oto-prereg-form .btn{
  width:100%;
  justify-content:center;
}
.oto-live-activity{
  margin:16px auto 0;
  max-width:820px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.oto-live-activity p{
  margin:0;
  font-size:13px;
  font-weight:700;
  color:#bbf7d0;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(34,197,94,.25);
  background:rgba(2,6,23,.48);
}
.oto-cta-note{
  margin:0 0 12px;
  font-size:13px;
  color:#94a3b8;
}
.oto-mobile-sticky-cta{
  position:sticky;
  bottom:0;
  z-index:35;
  display:none;
  padding:10px 0 calc(10px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(2,6,23,0),rgba(2,6,23,.88) 40%,rgba(2,6,23,.96));
}
.oto-mobile-sticky-cta .btn{
  width:100%;
  justify-content:center;
}
.oto-body .btn{
  min-height:48px;
  touch-action:manipulation;
}
.oto-cta-row .btn-primary{
  width:100%;
  max-width:min(420px,100%);
  justify-content:center;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, border-color .18s ease;
}
.oto-cta-row .btn-primary:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
  border-color:rgba(74,222,128,.85);
  box-shadow:0 0 0 2px rgba(34,197,94,.18),0 16px 36px rgba(2,6,23,.45),0 0 32px rgba(34,197,94,.35);
}
.oto-cta-row .btn-primary:active{
  transform:translateY(0);
  filter:brightness(1);
}
.oto-footer-mini{
  text-align:center;
  padding:24px 0 0;
  border-top:1px solid rgba(43,57,80,.55);
  font-size:13px;
  color:#64748b;
}
.oto-footer-mini a{color:var(--muted)}
.oto-footer-mini a:hover{color:var(--primary)}

/* Thank-you / onboarding dashboard */
.ty-progress{
  max-width:520px;
  margin:0 auto;
  padding:0 0 8px;
}
.ty-progress-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:12px;
  margin-bottom:10px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#94a3b8;
}
.ty-progress-pct{
  font-variant-numeric:tabular-nums;
  color:var(--primary);
  letter-spacing:0;
}
.ty-progress-track{
  height:10px;
  border-radius:999px;
  background:rgba(148,163,184,.18);
  overflow:hidden;
}
.ty-progress-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary-dark),var(--primary));
  transition:width .4s ease;
}
.ty-progress-hint{
  margin:12px 0 0;
  font-size:14px;
  line-height:1.5;
  color:var(--muted);
  text-align:center;
}
.ty-checklist{
  display:flex;
  flex-direction:column;
  gap:14px;
  max-width:720px;
  margin:0 auto;
}
.ty-checklist-item{
  display:flex;
  gap:16px;
  align-items:flex-start;
  padding:18px 18px 18px 16px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.14);
  background:rgba(15,23,42,.45);
  text-align:left;
}
.ty-checklist-num{
  flex:0 0 36px;
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  border-radius:50%;
  font-size:15px;
  font-weight:800;
  color:#11270a;
  background:var(--primary);
}
.ty-checklist-item h3{
  margin:0 0 6px;
  font-size:17px;
  font-weight:700;
  letter-spacing:-.2px;
  color:#f1f5f9;
}
.ty-checklist-item p{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:#94a3b8;
}
.ty-cta-center{
  text-align:center;
  padding:8px 0 12px;
}
.ty-cta-center .btn-primary{
  padding:14px 28px;
  font-size:17px;
}
.ty-cta-sub{
  margin:14px 0 0;
  font-size:14px;
  color:var(--muted);
  line-height:1.5;
}
.ty-cta-sub a{
  color:var(--primary);
  text-decoration:underline;
  text-underline-offset:3px;
}
.ty-cta-sub a:hover{color:var(--primary-dark)}
.ty-stats-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:10px 20px;
  margin:0 auto 22px;
  max-width:480px;
  padding:14px 20px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.12);
  background:rgba(255,255,255,.03);
  font-size:15px;
  font-weight:700;
  font-variant-numeric:tabular-nums;
  color:#cbd5e1;
}
.ty-stats-row span{color:#64748b;font-weight:600}
.ty-quicklinks{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
  max-width:720px;
  margin:0 auto;
}
.ty-quicklinks a{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 16px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  font-size:14px;
  font-weight:700;
  color:#e2e8f0;
  transition:border-color .2s,background .2s,color .2s;
}
.ty-quicklinks a:hover{
  border-color:rgba(141,245,93,.45);
  color:var(--primary);
  background:rgba(141,245,93,.06);
}
.ty-video-card{
  max-width:640px;
  margin:0 auto;
  padding:22px 22px 20px;
  border-radius:16px;
  border:1px solid rgba(96,165,250,.28);
  background:linear-gradient(145deg,rgba(96,165,250,.1),rgba(15,23,42,.55));
  text-align:center;
}
.ty-video-card h3{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  letter-spacing:-.3px;
  color:#f1f5f9;
}
.ty-video-card p{
  margin:0 0 16px;
  font-size:14px;
  line-height:1.55;
  color:#94a3b8;
}
.ty-account-card{
  max-width:440px;
  margin:0 auto;
  padding:22px 22px 20px;
  border-radius:16px;
  border:1px solid rgba(148,163,184,.16);
  background:rgba(255,255,255,.04);
  text-align:left;
}
.ty-account-card p{
  margin:0 0 10px;
  font-size:15px;
  line-height:1.5;
  color:#cbd5e1;
}
.ty-account-card p:last-of-type{margin-bottom:16px}
.ty-account-card strong{color:#f1f5f9}
.ty-account-card .btn{
  width:100%;
  margin-top:4px;
}
.btn-ty-outline{
  border:1px solid rgba(141,245,93,.5)!important;
  background:transparent!important;
  color:var(--primary)!important;
}
.btn-ty-outline:hover{
  border-color:var(--primary)!important;
  background:rgba(141,245,93,.08)!important;
  color:#dcfce7!important;
}
.ty-upgrade-reminder{
  max-width:640px;
  margin:0 auto;
  padding:22px 22px 20px;
  border-radius:16px;
  border:1px solid rgba(141,245,93,.28);
  background:linear-gradient(135deg,rgba(141,245,93,.1),rgba(15,23,42,.5));
  text-align:center;
}
.ty-upgrade-reminder h3{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  color:#ecfccb;
}
.ty-upgrade-reminder p{
  margin:0 0 16px;
  font-size:14px;
  line-height:1.55;
  color:#bbf7d0;
  opacity:.95;
}
.ty-support{
  margin:0 auto;
  max-width:36em;
  text-align:center;
  font-size:15px;
  line-height:1.6;
  color:#94a3b8;
}
.ty-support a{
  color:var(--primary);
  text-decoration:underline;
  text-underline-offset:3px;
}
.ty-support a:hover{color:var(--primary-dark)}
@media (max-width:900px){
  .oto-grid{grid-template-columns:1fr}
  .oto-grid--2{grid-template-columns:1fr}
  .oto-grid--auto{grid-template-columns:1fr}
  .oto-topbar{
    flex-wrap:wrap;
    align-items:flex-start;
    gap:12px;
    padding:0;
  }
  .oto-topbar-nav{
    width:100%;
    justify-content:flex-start;
    flex-wrap:wrap;
    gap:8px;
  }
  .oto-hero{padding-left:0;padding-right:0}
  .oto-section{padding:clamp(32px,8vw,56px) 0}
  .oto-cta-row{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }
  .oto-cta-row .btn-primary{max-width:none}
  .oto-footer-mini{
    font-size:12px;
    line-height:1.55;
    padding:20px 0 0;
    word-break:break-word;
  }
  .oto-live-list,
  .oto-live-activity{grid-template-columns:1fr}
  .oto-prereg-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .oto-hero h1{font-size:clamp(22px,6.5vw,32px);letter-spacing:-.45px}
  .oto-hero{padding:12px 0 28px}
  .oto-hero-trio{font-size:14px;gap:8px}
  .oto-hero-trio span{padding:7px 12px}
  .oto-thank{padding:14px 12px;margin-bottom:18px}
  .oto-thank-line{font-size:14px;line-height:1.5}
  .oto-section{padding:28px 0}
  .oto-section-head{margin-bottom:18px}
  .oto-section-head h2{font-size:clamp(20px,5.5vw,26px)}
  .oto-section-head p{font-size:14px}
  .oto-card{padding:16px 14px}
  .oto-card h3{font-size:16px}
  .oto-card p{font-size:14px;line-height:1.5}
  .oto-price{font-size:clamp(26px,8vw,38px)}
  .oto-downsell{font-size:13px;line-height:1.5;word-break:break-word}
  .oto-downsell a{display:inline-block;padding:4px 0;min-height:44px;line-height:1.4}
  .oto-topbar-nav{width:100%}
  .oto-topbar-nav .btn{min-height:44px;font-size:14px}
  .ty-checklist-item{padding:14px 12px 14px 12px;gap:12px}
  .ty-checklist-num{flex-basis:34px;width:34px;height:34px;font-size:14px}
  .ty-quicklinks{grid-template-columns:1fr}
  .ty-video-card,.ty-upgrade-reminder,.ty-account-card{padding:18px 16px}
  .ty-cta-center .btn-primary{width:100%;max-width:none;font-size:16px;min-height:48px}
  .oto-mobile-sticky-cta{display:block}
  .oto-page{
    padding-left:max(12px,env(safe-area-inset-left));
    padding-right:max(12px,env(safe-area-inset-right));
    padding-bottom:max(120px,calc(80px + env(safe-area-inset-bottom)));
  }
  .oto-footer-mini{
    margin-bottom:8px;
    padding-top:16px;
  }
  .oto-marketing-mockup{border-radius:12px}
  .oto-preview-box{padding:14px 12px}
  .oto-cta-row .btn,.oto-cta-row .btn-primary,.oto-cta-row .btn-ghost{
    width:100%;
    max-width:none;
    min-height:48px;
    box-sizing:border-box;
  }
}

/* Final ecosystem polish layer: consistent premium UX across OTO stack. */
.oto-page{
  max-width:1120px;
}
.oto-section{
  padding:clamp(44px,6.2vw,76px) 0;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.oto-hero{
  max-width:860px;
  padding-bottom:clamp(44px,7vw,72px);
}
.oto-hero h1{
  font-size:clamp(30px,4.8vw,48px);
  font-weight:900;
  line-height:1.06;
  margin-bottom:18px;
}
.oto-hero .oto-lead{
  max-width:38em;
  font-size:clamp(17px,2.1vw,19px);
}
.oto-hero-callout{
  margin-top:24px;
}
.oto-kicker{
  color:#a5f3fc;
}
.oto-card{
  border-radius:18px;
  background:linear-gradient(165deg,rgba(15,23,42,.68),rgba(30,41,59,.5));
  border-color:rgba(148,163,184,.2);
  box-shadow:0 10px 26px rgba(2,6,23,.24);
}
.oto-card:hover{
  box-shadow:0 22px 46px -18px rgba(0,0,0,.48),0 0 30px rgba(56,189,248,.12);
}
.oto-cta-row .btn-primary{
  min-height:52px;
  font-size:16px;
  font-weight:800;
  box-shadow:0 14px 34px rgba(34,197,94,.24);
}
.oto-preview-box--live{
  position:relative;
  overflow:hidden;
}
.oto-preview-box--live::before{
  content:"";
  position:absolute;
  inset:-25% -20% auto;
  height:68%;
  background:radial-gradient(circle, rgba(56,189,248,.2), transparent 72%);
  pointer-events:none;
  animation:otoGlowSweep 10s ease-in-out infinite alternate;
}
.oto-live-list li,
.oto-live-activity p{
  position:relative;
  overflow:hidden;
}
.oto-live-list li::before,
.oto-live-activity p::before{
  content:"";
  position:absolute;
  top:50%;
  left:10px;
  width:7px;
  height:7px;
  border-radius:999px;
  transform:translateY(-50%);
  background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.42);
  animation:otoPulse 2.2s ease-in-out infinite;
}
.oto-live-list li,
.oto-live-activity p{
  padding-left:24px;
  text-align:center;
}
.oto-live-activity{
  justify-items:center;
}
.oto-social-proof{
  align-items:center;
}
.oto-card.oto-social-proof{
  text-align:center;
}
.oto-trust-bar{
  margin:0 0 18px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(56,189,248,.26);
  background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(2,6,23,.46));
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
}
.oto-trust-bar span{
  font-size:12px;
  font-weight:700;
  color:#cffafe;
  border:1px solid rgba(125,211,252,.22);
  border-radius:999px;
  padding:6px 10px;
  background:rgba(15,23,42,.52);
}
.oto-mobile-sticky-cta{
  position:fixed;
  left:max(10px,env(safe-area-inset-left));
  right:max(10px,env(safe-area-inset-right));
  bottom:calc(10px + env(safe-area-inset-bottom));
  z-index:55;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.24);
  background:rgba(2,6,23,.72);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
  box-shadow:0 14px 34px rgba(2,6,23,.45);
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.oto-mobile-sticky-cta .btn,
a.oto-mobile-sticky-cta{
  width:100%;
  min-height:48px;
  border-radius:12px;
  text-align:center;
}
.oto-mobile-sticky-cta.is-hidden{
  transform:translateY(120%);
  opacity:.01;
}
.oto-live-toast{
  position:fixed;
  right:max(12px,env(safe-area-inset-right));
  bottom:calc(84px + env(safe-area-inset-bottom));
  z-index:60;
  max-width:min(340px,calc(100vw - 24px));
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(34,197,94,.35);
  background:rgba(2,6,23,.84);
  color:#dcfce7;
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
  transform:translateY(12px);
  opacity:0;
  transition:transform .3s ease, opacity .3s ease;
}
.oto-live-toast.is-show{
  transform:translateY(0);
  opacity:1;
}
@keyframes otoGlowSweep{
  from{opacity:.32;transform:translateX(-5%) scale(1);}
  to{opacity:.72;transform:translateX(6%) scale(1.06);}
}
@keyframes otoPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.36);}
  55%{box-shadow:0 0 0 10px rgba(34,197,94,0);}
}
@media (prefers-reduced-motion:reduce){
  .oto-preview-box--live::before,
  .oto-live-list li::before,
  .oto-live-activity p::before{
    animation:none;
  }
}
