/* ============================================================
   Онбординг мини-аппа — отдельный «серый» режим (по прототипу
   design-preview/miniapp-redesign/onboarding.html). Полноэкранный
   оверлей поверх трекера; показывается, пока клиент не активирован.
   Все правила scoped под .obx, переменные — локальные, чтобы не
   конфликтовать с розовой темой трекера (app.css).
   ============================================================ */
.obx {
  position: absolute; inset: 0; z-index: 45; display: none; background: #f5f5f6;
  --pink: #ffc5dc; --pink-deep: #ff9ec4; --ink: #0c0e12;
  --sub: rgba(12,14,18,.6); --mut: rgba(12,14,18,.4); --bd: rgba(12,14,18,.12);
}
.obx.on { display: block; }
.obx .ob { display: flex; flex-direction: column; height: 100%; font-family: var(--font); color: var(--ink); }

/* ---- shell: шапка / прогресс / скролл / футер ---- */
.obx .ob__top { flex: 0 0 auto; padding: max(8px, env(safe-area-inset-top)) 16px 0; }
.obx .ob__bar { position: relative; display: flex; align-items: center; min-height: 44px; }
.obx .ob__back { width: 44px; height: 44px; border-radius: 50%; border: 0; cursor: pointer; background: #fff; box-shadow: 0 2px 10px rgba(20,4,12,.08), inset 0 0 0 1px rgba(12,14,18,.04); display: grid; place-items: center; color: #404040; transition: transform .12s ease; }
.obx .ob__back:active { transform: scale(.92); }
.obx .ob__back svg { width: 22px; height: 22px; }
.obx .ob__title { position: absolute; left: 50%; transform: translateX(-50%); font-size: 17px; font-weight: 600; letter-spacing: -.43px; color: var(--ink); }
.obx .ob__menu { position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; border: 0; cursor: pointer; background: rgba(12,14,18,.05); display: grid; place-items: center; color: var(--ink); }
.obx .ob__menu svg { width: 22px; height: 22px; }
.obx .ob__prog { display: flex; gap: 6px; padding: 16px 4px 2px; }
.obx .ob__prog i { flex: 1 1 0; height: 6px; border-radius: 9999px; background: rgba(12,14,18,.10); transition: background .3s ease; }
.obx .ob__prog i.on { background: var(--pink-deep); }
.obx .ob__scroll { flex: 1 1 auto; overflow-y: auto; overflow-x: hidden; padding: 18px 20px 10px; scrollbar-width: none; }
.obx .ob__scroll::-webkit-scrollbar { display: none; }
.obx .ob__foot { flex: 0 0 auto; padding: 10px 20px calc(16px + env(safe-area-inset-bottom)); }

/* ---- общие примитивы ---- */
.obx .ob__h { font-size: 28px; font-weight: 600; letter-spacing: -.56px; line-height: 1.12; color: var(--ink); }
.obx .ob__sub { font-size: 14px; color: var(--sub); letter-spacing: -.28px; line-height: 1.55; margin-top: 10px; }
.obx .ob-btn { width: 100%; height: 56px; border: 0; cursor: pointer; border-radius: 9999px; background: #1d020c; color: #fff; font-family: var(--font); font-size: 16px; font-weight: 600; letter-spacing: -.2px; transition: opacity .18s ease, transform .12s ease; }
.obx .ob-btn:active { transform: scale(.99); }
.obx .ob-btn.off { opacity: .45; pointer-events: none; }
.obx .ob-skip { width: 100%; border: 0; background: transparent; cursor: pointer; font-family: var(--font); font-size: 15px; font-weight: 500; color: var(--mut); padding: 12px; margin-top: 2px; }
.obx .ob-note { display: flex; gap: 8px; align-items: flex-start; font-size: 13px; color: var(--sub); line-height: 1.45; margin-top: 14px; }
.obx .ob-note svg { width: 16px; height: 16px; flex: 0 0 auto; margin-top: 1px; color: var(--pink-deep); }
.obx .ob-info { background: #fff; border-radius: 16px; box-shadow: inset 0 0 0 1px rgba(12,14,18,.04); padding: 14px 16px; margin-top: 20px; display: flex; align-items: center; gap: 12px; text-align: left; }
.obx .ob-info__ic { width: 40px; height: 40px; border-radius: 11px; flex: 0 0 auto; display: grid; place-items: center; background: #fbe6f0; color: #c8377f; }
.obx .ob-info__ic svg { width: 20px; height: 20px; }
.obx .ob-info__t { font-size: 14px; font-weight: 600; color: var(--ink); }
.obx .ob-info__m { font-size: 12.5px; color: var(--mut); margin-top: 1px; }

/* ---- анкета: опции / поля ---- */
.obx .ob-qidx { font-size: 12px; font-weight: 700; color: var(--pink-deep); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 8px; }
.obx .ob__opts { display: flex; flex-direction: column; gap: 9px; margin-top: 22px; }
.obx .ob-opt { display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%; text-align: left; border: 0; cursor: pointer; font-family: var(--font); background: #fff; border-radius: 12px; padding: 11px 13px; min-height: 54px; box-shadow: 0 4px 12px rgba(20,4,12,.045), inset 0 0 0 1px rgba(12,14,18,.03); transition: background .15s ease, box-shadow .15s ease, transform .12s ease; }
.obx .ob-opt:active { transform: scale(.99); }
.obx .ob-opt.sel { background: #f6eef3; box-shadow: inset 0 0 0 1px rgba(160,80,120,.14); }
.obx .ob-opt__l { display: flex; align-items: center; gap: 11px; min-width: 0; }
.obx .ob-opt__ic { width: 36px; height: 36px; flex: 0 0 auto; border-radius: 50%; background: #eef0f1; color: #4d473f; display: grid; place-items: center; transition: background .15s ease; }
.obx .ob-opt.sel .ob-opt__ic { background: #fff; }
.obx .ob-opt__ic svg { width: 19px; height: 19px; display: block; }
.obx .ob-opt__b { min-width: 0; }
.obx .ob-opt__t { display: block; font-size: 15px; font-weight: 500; letter-spacing: -.2px; color: var(--ink); line-height: 1.2; }
.obx .ob-opt__d { display: block; font-size: 12.5px; font-weight: 400; color: rgba(12,14,18,.5); line-height: 1.3; margin-top: 0; }
.obx .ob-opt__ck { width: 22px; height: 22px; flex: 0 0 auto; border-radius: 50%; box-shadow: inset 0 0 0 1px var(--bd); display: grid; place-items: center; color: #fff; transition: background .15s ease, box-shadow .15s ease; }
.obx .ob-opt.sel .ob-opt__ck { background: #1d020c; box-shadow: none; }
.obx .ob-opt__ck svg { width: 12px; height: 12px; opacity: 0; transition: opacity .15s ease; }
.obx .ob-opt.sel .ob-opt__ck svg { opacity: 1; }
.obx .ob-field { margin-top: 22px; position: relative; }
.obx .ob-input { width: 100%; border: 0; background: #fff; border-radius: 20px; padding: 18px 16px; font-family: var(--font); font-size: 18px; font-weight: 500; color: var(--ink); box-shadow: inset 0 0 0 1px rgba(12,14,18,.06); outline: none; }
.obx .ob-input::placeholder { color: rgba(12,14,18,.32); font-weight: 400; }
.obx .ob-input:focus { box-shadow: inset 0 0 0 1.5px var(--pink); }
.obx .ob-input[type=number] { -moz-appearance: textfield; }
.obx .ob-input::-webkit-outer-spin-button, .obx .ob-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.obx textarea.ob-input { min-height: 96px; resize: none; line-height: 1.45; }
.obx .ob-suffix { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); font-size: 16px; color: var(--mut); pointer-events: none; }

/* ---- анкета завершена ---- */
.obx .ob-done { text-align: center; padding: 22px 6px 0; }
.obx .ob-done__ic { width: 80px; height: 80px; border-radius: 50%; margin: 0 auto; display: grid; place-items: center; background: var(--pink); color: #0a0d12; }
.obx .ob-done__ic svg { width: 40px; height: 40px; }
.obx .ob-done__t { font-size: 26px; font-weight: 600; letter-spacing: -.52px; margin-top: 18px; }
.obx .ob-done__s { font-size: 14px; color: var(--sub); line-height: 1.55; margin-top: 10px; }
.obx .ob-next { background: #fff; border-radius: 20px; box-shadow: 0 6px 18px rgba(20,4,12,.05), inset 0 0 0 1px rgba(12,14,18,.03); margin-top: 22px; padding: 4px 16px; text-align: left; }
.obx .ob-next__row { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-top: 1px solid rgba(12,14,18,.06); }
.obx .ob-next__row:first-child { border-top: 0; }
.obx .ob-next__n { width: 28px; height: 28px; flex: 0 0 auto; border-radius: 50%; background: #f3eef7; color: #7a4d96; display: grid; place-items: center; font-size: 13px; font-weight: 600; }
.obx .ob-next__t { font-size: 15px; font-weight: 500; color: var(--ink); }
.obx .ob-next__m { font-size: 12.5px; color: var(--mut); margin-top: 1px; }

/* ---- хаб подготовки (чек-лист старта) ---- */
.obx .hub-step { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-top: 1px solid rgba(12,14,18,.05); }
.obx .hub-step:first-child { border-top: 0; }
.obx .hub-step__c { width: 26px; height: 26px; border-radius: 50%; flex: 0 0 auto; display: grid; place-items: center; }
.obx .hub-step__c.done { background: #e8f5dc; color: #5b8a1f; }
.obx .hub-step__c.done svg { width: 15px; height: 15px; }
.obx .hub-step__c.now { background: var(--pink); color: #0a0d12; font-size: 13px; font-weight: 700; }
.obx .hub-step__c.wait { background: #eef0f3; }
.obx .hub-step__b { flex: 1 1 auto; min-width: 0; }
.obx .hub-step__t { font-size: 15px; font-weight: 500; color: var(--ink); }
.obx .hub-step__m { font-size: 12.5px; color: var(--mut); margin-top: 1px; }
.obx .hub-step__st { font-size: 11.5px; font-weight: 600; border-radius: 9999px; padding: 3px 9px; flex: 0 0 auto; }
.obx .st-ok { color: #5b8a1f; background: #e8f5dc; }
.obx .st-now { color: #c8377f; background: #fbe6f0; }
.obx .st-wait { color: var(--mut); background: #eef0f3; }
.obx .ob-label { font-size: 13px; font-weight: 600; color: var(--sub); margin-top: 22px; }

/* ---- замеры (3 фото) ---- */
.obx .ob-photos { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-top: 22px; }
.obx .ob-photo { position: relative; overflow: hidden; aspect-ratio: 3/4; border-radius: 18px; border: 1.5px dashed var(--bd); background: #fff; background-size: cover; background-position: center; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; cursor: pointer; color: var(--mut); font-family: var(--font); -webkit-tap-highlight-color: transparent; }
.obx .ob-photo svg { width: 24px; height: 24px; }
.obx .ob-photo small { font-size: 12px; font-weight: 500; }
.obx .ob-photo.filled { border-style: solid; border-color: transparent; color: #fff; background-color: #efd2de; }
/* загруженное фото-превью: чек-бейдж + подпись «заменить» */
.obx .ob-photo__chk { position: absolute; top: 8px; right: 8px; width: 24px; height: 24px; border-radius: 50%; background: #16a34a; color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 6px rgba(0,0,0,.28); }
.obx .ob-photo__chk svg { width: 15px; height: 15px; }
.obx .ob-photo__cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 20px 8px 9px; display: flex; flex-direction: column; align-items: center; gap: 1px; background: linear-gradient(to top, rgba(0,0,0,.62), rgba(0,0,0,0)); color: #fff; pointer-events: none; }
.obx .ob-photo__cap small { font-size: 12px; font-weight: 600; color: #fff; }
.obx .ob-photo__cap em { font-size: 10px; font-style: normal; opacity: .9; }

/* ---- анализы (upload) ---- */
.obx .ob-upload { margin-top: 22px; border-radius: 20px; border: 1.5px dashed var(--bd); background: #fff; padding: 26px 18px; text-align: center; cursor: pointer; }
.obx .ob-upload.filled { border: 1.5px solid transparent; box-shadow: inset 0 0 0 1.5px var(--pink); }
.obx .ob-upload__ic { width: 48px; height: 48px; border-radius: 14px; margin: 0 auto 12px; display: grid; place-items: center; background: #fbe6f0; color: #c8377f; }
.obx .ob-upload__ic svg { width: 24px; height: 24px; }
.obx .ob-upload__t { font-size: 15px; font-weight: 500; color: var(--ink); }
.obx .ob-upload__m { font-size: 13px; color: var(--mut); margin-top: 3px; }
.obx .ob-hintlist { margin-top: 16px; background: #fff; border-radius: 16px; padding: 2px 16px; box-shadow: inset 0 0 0 1px rgba(12,14,18,.04); }
.obx .ob-hintlist__row { display: flex; gap: 10px; align-items: center; padding: 11px 0; border-top: 1px solid rgba(12,14,18,.05); font-size: 14px; color: var(--ink); }
.obx .ob-hintlist__row:first-child { border-top: 0; }
.obx .ob-hintlist__row svg { width: 18px; height: 18px; color: var(--pink-deep); flex: 0 0 auto; }
/* инлайн-ошибка числового поля */
.obx .ob-fielderr { min-height: 16px; margin-top: 8px; font-size: 12.5px; color: #d2475f; line-height: 1.3; }
/* прикреплённые файлы анализов */
.obx .ob-files { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.obx .ob-file { display: flex; align-items: center; gap: 12px; background: #fff; border-radius: 14px; padding: 12px 12px 12px 14px; box-shadow: inset 0 0 0 1px rgba(12,14,18,.04); }
.obx .ob-file__ic { width: 36px; height: 36px; flex: 0 0 auto; border-radius: 50%; background: #fbe6f0; color: #c8377f; display: grid; place-items: center; }
.obx .ob-file__ic svg { width: 18px; height: 18px; }
.obx .ob-file__b { flex: 1 1 auto; min-width: 0; }
.obx .ob-file__t { font-size: 14px; font-weight: 500; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.obx .ob-file__m { font-size: 12px; color: var(--mut); margin-top: 1px; }
.obx .ob-file__x { flex: 0 0 auto; width: 30px; height: 30px; border: 0; border-radius: 50%; background: #f1eff0; color: #8a8088; font-size: 14px; cursor: pointer; }
.obx .ob-file__x:active { transform: scale(.94); }

/* ---- ожидание / коуч / встреча (PR-4) ---- */
.obx .ob-lock { text-align: center; padding: 30px 10px 0; }
.obx .ob-lock__ic { width: 80px; height: 80px; border-radius: 50%; margin: 0 auto; display: grid; place-items: center; background: #fff; color: #c8377f; box-shadow: 0 10px 24px rgba(20,4,12,.08); }
.obx .ob-lock__ic svg { width: 36px; height: 36px; }
.obx .ob-lock__t { font-size: 24px; font-weight: 600; letter-spacing: -.5px; margin-top: 18px; }
.obx .ob-lock__s { font-size: 14px; color: var(--sub); line-height: 1.55; margin-top: 10px; }
.obx .ob-wait { width: 80px; height: 80px; border-radius: 24px; margin: 0 auto; display: grid; place-items: center; background: linear-gradient(160deg,#efe6fb,#d8c6f3); color: #3a1d5a; box-shadow: 0 14px 30px rgba(120,77,150,.22); }
.obx .ob-wait svg { width: 38px; height: 38px; }
.obx .ob-dots { display: flex; gap: 7px; justify-content: center; margin-top: 16px; }
.obx .ob-dots i { width: 8px; height: 8px; border-radius: 50%; background: #cbb4da; animation: obpulse 1.2s infinite ease-in-out; }
.obx .ob-dots i:nth-child(2) { animation-delay: .2s; }
.obx .ob-dots i:nth-child(3) { animation-delay: .4s; }
@keyframes obpulse { 0%, 100% { opacity: .3; transform: scale(.85); } 50% { opacity: 1; transform: scale(1); } }
.obx .ob-coach { text-align: center; padding: 26px 8px 0; }
.obx .ob-coach__av { width: 104px; height: 104px; border-radius: 50%; object-fit: cover; margin: 0 auto; display: block; box-shadow: 0 14px 30px rgba(20,4,12,.14); }
.obx .ob-coach__role { font-size: 12px; font-weight: 600; color: #e84d8f; letter-spacing: .05em; text-transform: uppercase; margin-top: 16px; }
.obx .ob-coach__name { font-size: 24px; font-weight: 600; letter-spacing: -.5px; margin-top: 6px; color: var(--ink); }
.obx .ob-coach__bio { font-size: 14px; color: var(--sub); line-height: 1.55; margin-top: 10px; }
.obx .ob-meet { border-radius: 20px; background: #fff; box-shadow: inset 0 0 0 1px rgba(12,14,18,.04), 0 8px 22px rgba(20,4,12,.06); padding: 18px; text-align: center; margin-top: 18px; }
.obx .ob-meet__when { font-size: 20px; font-weight: 600; letter-spacing: -.4px; color: var(--ink); }
.obx .ob-meet__sub { font-size: 13px; color: var(--mut); margin-top: 4px; }
.obx .ob-meet__count { display: inline-block; margin-top: 12px; font-size: 12px; font-weight: 600; color: #7a4d96; background: #efe6fa; border-radius: 9999px; padding: 5px 12px; }
.obx .ob-actions { display: flex; gap: 10px; margin-top: 16px; }
.obx .ob-actions button { flex: 1 1 0; border: 0; cursor: pointer; font-family: var(--font); font-size: 14px; font-weight: 600; border-radius: 14px; padding: 13px 0; }
.obx .ob-actions .resch { color: var(--ink); background: #fff; box-shadow: inset 0 0 0 1px rgba(12,14,18,.10); }
.obx .ob-actions .canc { color: #c2185b; background: #ffe1ee; }

/* ---- меню профиля (PR-6) ---- */
.obx .menu-profile { display: flex; align-items: center; gap: 14px; background: #fff; border-radius: 18px; padding: 16px; box-shadow: inset 0 0 0 1px rgba(12,14,18,.03); margin-top: 8px; }
.obx .menu-profile img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; }
.obx .menu-profile__n { font-size: 17px; font-weight: 600; color: var(--ink); }
.obx .menu-profile__s { font-size: 13px; color: var(--mut); margin-top: 2px; }
.obx .menu-list { background: #fff; border-radius: 16px; box-shadow: inset 0 0 0 1px rgba(12,14,18,.03); margin-top: 10px; padding: 2px 16px; }
.obx .menu-row { display: flex; align-items: center; gap: 13px; padding: 14px 0; border-top: 1px solid rgba(12,14,18,.05); cursor: pointer; width: 100%; border-left: 0; border-right: 0; border-bottom: 0; background: transparent; font-family: var(--font); text-align: left; }
.obx .menu-row:first-child { border-top: 0; }
.obx .menu-row__ic { width: 36px; height: 36px; border-radius: 10px; flex: 0 0 auto; display: grid; place-items: center; background: #f3eef7; color: #7a4d96; }
.obx .menu-row__ic svg { width: 19px; height: 19px; }
.obx .menu-row__t { flex: 1 1 auto; font-size: 15px; font-weight: 500; color: var(--ink); }
.obx .menu-row__val { font-size: 13px; color: var(--mut); margin-right: 6px; flex: 0 0 auto; }
.obx .menu-row__chev { color: rgba(12,14,18,.28); flex: 0 0 auto; }
.obx .menu-row__chev svg { width: 20px; height: 20px; }
.obx .menu-signout { width: 100%; border: 0; background: #fff; border-radius: 16px; padding: 15px; margin-top: 12px; font-family: var(--font); font-size: 15px; font-weight: 600; color: #e0395f; cursor: pointer; box-shadow: inset 0 0 0 1px rgba(12,14,18,.03); }

/* ============================================================
   Экраны входа/регистрации/сброса — серый стиль прототипа
   (#v-auth = живой контейнер из шаблона; id перекрывает старый
   розовый фон .v-auth из inline-стилей).
   ============================================================ */
#v-auth {
  background: #f5f5f6;
  --pink: #ffc5dc; --pink-deep: #ff9ec4; --ink: #0c0e12;
  --sub: rgba(12,14,18,.6); --mut: rgba(12,14,18,.4); --bd: rgba(12,14,18,.12);
}
#v-auth .v-auth__in { justify-content: flex-start; padding-top: max(34px, env(safe-area-inset-top)); }
#v-auth .v-auth__brand { font-weight: 800; font-size: 19px; letter-spacing: -.3px; color: var(--ink); margin: 4px 0 8px; }
#v-auth .v-auth__brand i { font-style: normal; color: var(--pink-deep); }
#v-auth .ob-input { width: 100%; border: 0; background: #fff; border-radius: 20px; padding: 16px; font-family: var(--font); font-size: 16px; font-weight: 500; color: var(--ink); box-shadow: inset 0 0 0 1px rgba(12,14,18,.06); outline: none; }
#v-auth .ob-input::placeholder { color: rgba(12,14,18,.32); font-weight: 400; }
#v-auth .ob-input:focus { box-shadow: inset 0 0 0 1.5px var(--pink); }
#v-auth .ob-btn { width: 100%; height: 54px; border: 0; cursor: pointer; border-radius: 9999px; background: var(--pink); color: #0a0d12; font-family: var(--font); font-size: 16px; font-weight: 500; letter-spacing: -.32px; transition: transform .12s ease; }
#v-auth .ob-btn:active { transform: scale(.99); }
#v-auth .auth { padding: 6px 2px 24px; }
#v-auth .auth__t { font-size: 27px; font-weight: 600; letter-spacing: -.5px; line-height: 1.16; text-align: center; margin-top: 8px; color: var(--ink); }
#v-auth .auth__t2 { font-size: 26px; font-weight: 600; letter-spacing: -.5px; color: var(--ink); margin-top: 6px; }
#v-auth .auth__s { font-size: 14px; color: var(--sub); line-height: 1.5; text-align: center; margin: 10px auto 0; max-width: 320px; }
#v-auth .auth__s--left { text-align: left; margin-left: 2px; max-width: none; }
#v-auth .auth-div { display: flex; align-items: center; gap: 12px; margin: 18px 0; color: var(--mut); font-size: 12px; }
#v-auth .auth-div::before, #v-auth .auth-div::after { content: ""; flex: 1; height: 1px; background: rgba(12,14,18,.1); }
#v-auth .auth-alt { text-align: center; font-size: 14px; color: var(--sub); margin-top: 22px; }
#v-auth .auth-alt b { color: var(--ink); cursor: pointer; }
#v-auth .auth-back { width: 40px; height: 40px; border-radius: 50%; border: 0; cursor: pointer; background: #fff; box-shadow: 0 2px 10px rgba(20,4,12,.08), inset 0 0 0 1px rgba(12,14,18,.04); display: grid; place-items: center; color: #404040; margin-bottom: 6px; }
#v-auth .auth-back svg { width: 22px; height: 22px; }
#v-auth .af { margin-top: 16px; }
#v-auth .af__l { display: block; font-size: 12.5px; font-weight: 500; color: var(--sub); margin: 0 0 7px 2px; }
#v-auth .af__pw { position: relative; }
#v-auth .af__pw .ob-input { padding-right: 48px; }
#v-auth .af__eye { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; cursor: pointer; color: var(--mut); padding: 6px; }
#v-auth .af__eye svg { width: 20px; height: 20px; }
#v-auth .auth-forgot { text-align: right; margin-top: 10px; }
#v-auth .auth-forgot b { font-size: 13px; color: #209cdf; cursor: pointer; font-weight: 600; }
#v-auth .auth-soc-row { display: flex; gap: 10px; }
#v-auth .auth-soc { display: flex; align-items: center; justify-content: center; gap: 10px; border: 0; cursor: pointer; font-family: var(--font); font-size: 15px; font-weight: 600; border-radius: 16px; padding: 14px; background: #fff; color: var(--ink); box-shadow: inset 0 0 0 1px rgba(12,14,18,.09); transition: transform .12s ease; }
#v-auth .auth-soc:active { transform: scale(.99); }
#v-auth .auth-soc svg { width: 20px; height: 20px; flex: 0 0 auto; }
#v-auth .auth-soc.sq { flex: 1 1 0; }
#v-auth .auth-soc.apple { background: #0c0e12; color: #fff; box-shadow: none; }
#v-auth .auth-sent__ic { width: 72px; height: 72px; border-radius: 50%; margin: 8px auto 0; display: grid; place-items: center; background: linear-gradient(135deg,#ffe0ec,#ffc5dc); color: #b23a6b; }
#v-auth .auth-sent__ic svg { width: 34px; height: 34px; }
#v-auth .v-auth__msg { font-size: 13px; min-height: 16px; margin-top: 10px; text-align: center; }

/* ---- приветствие ---- */
.obx .ob-wel { text-align: center; padding: 16px 6px 0; }
.obx .ob-wel__logo { height: 26px; width: auto; display: block; margin: 0 auto; }
.obx .ob-wel__ic { width: 84px; height: 84px; border-radius: 24px; margin: 16px auto 0; display: grid; place-items: center; background: linear-gradient(160deg,#ffe3ef,#ffc5dc); color: #3a0d22; box-shadow: 0 14px 30px rgba(255,158,196,.35); }
.obx .ob-wel__ic svg { width: 40px; height: 40px; }
.obx .ob-wel__t { font-size: 28px; font-weight: 600; letter-spacing: -.56px; line-height: 1.14; margin-top: 20px; color: var(--ink); }
.obx .ob-wel__s { font-size: 14px; color: var(--sub); line-height: 1.55; margin-top: 10px; }
.obx .ob-wel__list { margin-top: 24px; display: flex; flex-direction: column; gap: 10px; text-align: left; }
.obx .ob-wel__list .ob-info { margin-top: 0; }
