You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1479 lines
71 KiB
1479 lines
71 KiB
<!DOCTYPE html> |
|
<html lang="ru"> |
|
<head> |
|
<meta charset="UTF-8"> |
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|
<title>Карта приложения — Клиника Оленевой</title> |
|
|
|
<link rel="preconnect" href="https://fonts.googleapis.com"> |
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> |
|
<link href="https://fonts.googleapis.com/css2?family=PT+Sans:wght@400;700&family=PT+Sans+Narrow:wght@400;700&display=swap" rel="stylesheet"> |
|
|
|
<style> |
|
:root { |
|
--teal: #166B63; |
|
--teal-dark: #0F4A44; |
|
--teal-50: #E3F4F2; |
|
--teal-100: #C7E8E4; |
|
--teal-200: #9BD6CE; |
|
--warm-50: #FDF8EE; |
|
--warm-100: #F5EDDF; |
|
--warm-200: #E8DCC5; |
|
--accent: #E04E44; |
|
|
|
--fg-1: #1F2A37; |
|
--fg-2: #3E4C5D; |
|
--fg-3: #5A6B7B; |
|
--fg-4: #8596A8; |
|
|
|
--border: #E4EAF2; |
|
--border-soft: #EEF2F7; |
|
|
|
/* phase tints */ |
|
--p0: #6B7A8C; /* существует */ |
|
--p0bg: #F0F3F7; |
|
--p1: #166B63; /* фаза 1 */ |
|
--p1bg: #E3F4F2; |
|
--p15: #C77A4C; /* фаза 1.5 */ |
|
--p15bg:#FBEFE4; |
|
--p2A: #2E9B6B; /* группа A */ |
|
--p2Abg:#E4F4EC; |
|
--p2B: #3C6EA8; /* группа B */ |
|
--p2Bbg:#E4EDF8; |
|
--p2C: #B63D35; /* группа C */ |
|
--p2Cbg:#FBE4E4; |
|
--p2D: #8B5BA9; /* группа D */ |
|
--p2Dbg:#F1E7F8; |
|
--skip: #B0BAC7; |
|
--skipbg:#F4F6FA; |
|
|
|
--font-sans: 'PT Sans', system-ui, sans-serif; |
|
--font-display: 'PT Sans Narrow', 'PT Sans', system-ui, sans-serif; |
|
} |
|
|
|
* { box-sizing: border-box; } |
|
html, body { margin: 0; padding: 0; } |
|
body { |
|
font-family: var(--font-sans); |
|
color: var(--fg-1); |
|
background: |
|
radial-gradient(1200px 600px at 0% 0%, var(--warm-100) 0%, transparent 55%), |
|
radial-gradient(1000px 500px at 100% 100%, var(--teal-50) 0%, transparent 50%), |
|
#F7F9FC; |
|
min-height: 100vh; |
|
-webkit-font-smoothing: antialiased; |
|
} |
|
|
|
.wrap { |
|
max-width: 1480px; |
|
margin: 0 auto; |
|
padding: 32px 32px 60px; |
|
} |
|
|
|
/* ---------- Top bar ---------- */ |
|
.topbar { |
|
display: flex; |
|
align-items: flex-end; |
|
justify-content: space-between; |
|
gap: 24px; |
|
margin-bottom: 28px; |
|
} |
|
.topbar h1 { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 56px; |
|
line-height: 1; |
|
margin: 0 0 6px; |
|
letter-spacing: -0.5px; |
|
} |
|
.topbar .lede { |
|
font-size: 16px; |
|
color: var(--fg-3); |
|
max-width: 640px; |
|
line-height: 1.5; |
|
} |
|
.topbar .meta { |
|
text-align: right; |
|
font-size: 12px; |
|
color: var(--fg-4); |
|
line-height: 1.6; |
|
} |
|
.topbar .meta b { color: var(--fg-2); display: block; font-weight: 700; font-size: 13px; } |
|
.topbar .meta a { |
|
display: inline-flex; align-items: center; gap: 6px; |
|
margin-top: 8px; |
|
padding: 8px 14px; |
|
background: var(--teal); |
|
color: #fff; |
|
text-decoration: none; |
|
border-radius: 999px; |
|
font-size: 13px; |
|
font-weight: 700; |
|
} |
|
.topbar .meta a:hover { background: var(--teal-dark); } |
|
|
|
/* ---------- Legend ---------- */ |
|
.legend { |
|
display: flex; |
|
flex-wrap: wrap; |
|
gap: 8px; |
|
background: #fff; |
|
border: 1px solid var(--border); |
|
border-radius: 14px; |
|
padding: 12px 14px; |
|
margin-bottom: 32px; |
|
font-size: 12.5px; |
|
} |
|
.legend-item { |
|
display: inline-flex; |
|
align-items: center; |
|
gap: 6px; |
|
padding: 5px 10px 5px 6px; |
|
border-radius: 999px; |
|
font-weight: 600; |
|
} |
|
.legend-item .dot { |
|
width: 9px; height: 9px; border-radius: 999px; display: inline-block; |
|
} |
|
.legend-item .num { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 15px; |
|
margin-right: 2px; |
|
width: 18px; height: 18px; |
|
display: inline-flex; align-items: center; justify-content: center; |
|
border-radius: 999px; |
|
background: rgba(255,255,255,0.6); |
|
color: inherit; |
|
} |
|
|
|
/* ---------- Phase rows ---------- */ |
|
.phase { |
|
margin-bottom: 28px; |
|
background: #fff; |
|
border-radius: 22px; |
|
border: 1px solid var(--border); |
|
overflow: hidden; |
|
} |
|
.phase-head { |
|
display: flex; |
|
align-items: center; |
|
gap: 16px; |
|
padding: 18px 22px 14px; |
|
border-bottom: 1px solid var(--border-soft); |
|
} |
|
.phase-num { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 32px; |
|
width: 56px; |
|
height: 56px; |
|
border-radius: 16px; |
|
display: flex; |
|
align-items: center; |
|
justify-content: center; |
|
flex-shrink: 0; |
|
letter-spacing: -1px; |
|
} |
|
.phase-title { |
|
font-size: 22px; |
|
font-weight: 700; |
|
margin: 0 0 2px; |
|
} |
|
.phase-sub { |
|
font-size: 13px; |
|
color: var(--fg-3); |
|
margin: 0; |
|
max-width: 720px; |
|
line-height: 1.45; |
|
} |
|
.phase-aside { |
|
margin-left: auto; |
|
display: flex; |
|
gap: 22px; |
|
text-align: right; |
|
flex-shrink: 0; |
|
} |
|
.phase-aside .stat { |
|
font-size: 11px; |
|
color: var(--fg-4); |
|
text-transform: uppercase; |
|
letter-spacing: .6px; |
|
font-weight: 700; |
|
} |
|
.phase-aside .stat-v { |
|
font-family: var(--font-display); |
|
font-size: 24px; |
|
font-weight: 700; |
|
color: var(--fg-1); |
|
letter-spacing: -.5px; |
|
margin-top: 2px; |
|
} |
|
|
|
.phase-body { |
|
padding: 18px 22px 22px; |
|
} |
|
|
|
/* Group within phase 2 */ |
|
.group { |
|
margin-bottom: 18px; |
|
} |
|
.group:last-child { margin-bottom: 0; } |
|
.group-head { |
|
display: flex; |
|
align-items: baseline; |
|
gap: 10px; |
|
margin-bottom: 10px; |
|
} |
|
.group-letter { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 20px; |
|
width: 28px; height: 28px; |
|
display: inline-flex; align-items: center; justify-content: center; |
|
border-radius: 8px; |
|
color: #fff; |
|
} |
|
.group-name { |
|
font-size: 15px; |
|
font-weight: 700; |
|
color: var(--fg-1); |
|
} |
|
.group-meta { |
|
font-size: 12px; |
|
color: var(--fg-4); |
|
margin-left: auto; |
|
} |
|
|
|
/* Cards grid */ |
|
.cards { |
|
display: grid; |
|
grid-template-columns: repeat(auto-fill, minmax(232px, 1fr)); |
|
gap: 12px; |
|
} |
|
.card { |
|
background: #fff; |
|
border: 1px solid var(--border); |
|
border-radius: 14px; |
|
padding: 0; |
|
overflow: hidden; |
|
transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; |
|
cursor: pointer; |
|
text-decoration: none; |
|
color: inherit; |
|
display: flex; |
|
flex-direction: column; |
|
} |
|
.card:hover { |
|
transform: translateY(-2px); |
|
box-shadow: 0 12px 30px rgba(15,30,40,.10); |
|
border-color: var(--teal-200); |
|
} |
|
.card-existing { background: #fff; } |
|
.card-future { background: #FCFDFE; border-style: dashed; } |
|
.card-skip { opacity: .55; cursor: default; } |
|
.card-skip:hover { transform: none; box-shadow: none; border-color: var(--border); } |
|
|
|
/* mini phone preview */ |
|
.mini { |
|
position: relative; |
|
height: 150px; |
|
margin: 10px 10px 0; |
|
border-radius: 12px; |
|
overflow: hidden; |
|
background: #F7F9FC; |
|
border: 1px solid var(--border-soft); |
|
} |
|
.mini-future { |
|
background: repeating-linear-gradient(45deg, #FAFBFD, #FAFBFD 8px, #F2F5F9 8px, #F2F5F9 16px); |
|
} |
|
.mini .mini-status { |
|
height: 14px; |
|
background: rgba(0,0,0,0.04); |
|
} |
|
.mini .mini-content { |
|
padding: 8px 10px; |
|
display: flex; |
|
flex-direction: column; |
|
gap: 4px; |
|
} |
|
.mini .mini-bar { |
|
height: 6px; |
|
border-radius: 3px; |
|
background: #E4EAF2; |
|
} |
|
.mini .mini-bar.solid { background: var(--teal); } |
|
.mini .mini-bar.warm { background: var(--warm-200); } |
|
.mini .mini-bar.short { width: 60%; } |
|
.mini .mini-bar.med { width: 80%; } |
|
|
|
.mini-title { |
|
position: absolute; |
|
bottom: 8px; left: 10px; right: 10px; |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 18px; |
|
color: var(--fg-1); |
|
line-height: 1.1; |
|
letter-spacing: -.3px; |
|
text-shadow: 0 1px 0 rgba(255,255,255,.5); |
|
} |
|
.mini-future .mini-title { color: var(--fg-3); } |
|
|
|
.card-body { |
|
padding: 12px 14px 14px; |
|
} |
|
.card-name { |
|
font-size: 14px; |
|
font-weight: 700; |
|
margin: 0 0 4px; |
|
line-height: 1.25; |
|
} |
|
.card-desc { |
|
font-size: 12px; |
|
color: var(--fg-3); |
|
line-height: 1.45; |
|
margin: 0 0 8px; |
|
} |
|
.card-tags { |
|
display: flex; |
|
flex-wrap: wrap; |
|
gap: 4px; |
|
} |
|
.tag { |
|
font-size: 10.5px; |
|
padding: 2px 7px; |
|
border-radius: 999px; |
|
background: var(--p0bg); |
|
color: var(--p0); |
|
font-weight: 700; |
|
text-transform: uppercase; |
|
letter-spacing: .3px; |
|
} |
|
.tag.live { background: var(--p0bg); color: var(--p0); } |
|
.tag.p1 { background: var(--p1bg); color: var(--p1); } |
|
.tag.p15 { background: var(--p15bg); color: var(--p15); } |
|
.tag.a { background: var(--p2Abg); color: var(--p2A); } |
|
.tag.b { background: var(--p2Bbg); color: var(--p2B); } |
|
.tag.c { background: var(--p2Cbg); color: var(--p2C); } |
|
.tag.d { background: var(--p2Dbg); color: var(--p2D); } |
|
.tag.skip { background: var(--skipbg);color: var(--skip); } |
|
|
|
/* Card status corner */ |
|
.card-status { |
|
position: absolute; |
|
top: 8px; right: 8px; |
|
font-size: 10px; |
|
font-weight: 700; |
|
padding: 3px 8px; |
|
border-radius: 999px; |
|
background: rgba(255,255,255,0.92); |
|
backdrop-filter: blur(4px); |
|
box-shadow: 0 1px 3px rgba(0,0,0,.06); |
|
text-transform: uppercase; |
|
letter-spacing: .4px; |
|
} |
|
|
|
/* Segments table */ |
|
.segments { |
|
margin-top: 36px; |
|
background: #fff; |
|
border: 1px solid var(--border); |
|
border-radius: 22px; |
|
overflow: hidden; |
|
} |
|
.seg-head { |
|
padding: 18px 22px 14px; |
|
border-bottom: 1px solid var(--border-soft); |
|
} |
|
.seg-head h2 { |
|
font-family: var(--font-display); |
|
font-size: 28px; |
|
margin: 0 0 4px; |
|
font-weight: 700; |
|
letter-spacing: -.5px; |
|
} |
|
.seg-head p { |
|
font-size: 13px; |
|
color: var(--fg-3); |
|
margin: 0; |
|
max-width: 720px; |
|
line-height: 1.5; |
|
} |
|
.seg-table { |
|
width: 100%; |
|
border-collapse: collapse; |
|
font-size: 13px; |
|
} |
|
.seg-table th { |
|
text-align: left; |
|
padding: 12px 18px; |
|
background: var(--border-soft); |
|
font-size: 11px; |
|
text-transform: uppercase; |
|
letter-spacing: .5px; |
|
color: var(--fg-4); |
|
font-weight: 700; |
|
border-bottom: 1px solid var(--border); |
|
} |
|
.seg-table th:first-child { padding-left: 22px; } |
|
.seg-table th:last-child { padding-right: 22px; text-align: right; } |
|
.seg-table td { |
|
padding: 12px 18px; |
|
border-bottom: 1px solid var(--border-soft); |
|
vertical-align: top; |
|
} |
|
.seg-table td:first-child { padding-left: 22px; } |
|
.seg-table td:last-child { padding-right: 22px; text-align: right; } |
|
.seg-table tr:last-child td { border-bottom: 0; } |
|
.seg-num { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 16px; |
|
color: var(--fg-3); |
|
width: 28px; |
|
display: inline-block; |
|
} |
|
.seg-name { font-weight: 700; color: var(--fg-1); } |
|
.seg-rev { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 17px; |
|
color: var(--teal); |
|
} |
|
.seg-job { color: var(--fg-3); font-size: 12.5px; } |
|
.prio { |
|
display: inline-flex; |
|
align-items: center; |
|
gap: 6px; |
|
font-weight: 700; |
|
font-size: 12px; |
|
padding: 4px 10px; |
|
border-radius: 999px; |
|
} |
|
.prio.high { background: var(--teal-50); color: var(--teal-dark); } |
|
.prio.mid { background: var(--warm-100); color: #8B6334; } |
|
.prio.low { background: var(--skipbg); color: var(--skip); } |
|
|
|
/* Phase 2 grid: groups side by side */ |
|
.groups-grid { |
|
display: grid; |
|
grid-template-columns: repeat(auto-fit, minmax(440px, 1fr)); |
|
gap: 18px; |
|
} |
|
.group-block { |
|
border: 1px solid var(--border); |
|
border-radius: 16px; |
|
padding: 14px 16px; |
|
background: #FCFDFE; |
|
} |
|
|
|
/* Footnotes */ |
|
.foot { |
|
margin-top: 32px; |
|
display: grid; |
|
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); |
|
gap: 14px; |
|
} |
|
.foot-card { |
|
background: #fff; |
|
border: 1px solid var(--border); |
|
border-radius: 14px; |
|
padding: 14px 16px; |
|
} |
|
.foot-card .ti { |
|
font-size: 11px; |
|
font-weight: 700; |
|
color: var(--fg-4); |
|
text-transform: uppercase; |
|
letter-spacing: .5px; |
|
margin-bottom: 6px; |
|
} |
|
.foot-card .vl { |
|
font-family: var(--font-display); |
|
font-weight: 700; |
|
font-size: 22px; |
|
letter-spacing: -.4px; |
|
margin-bottom: 4px; |
|
} |
|
.foot-card .ds { |
|
font-size: 12px; |
|
color: var(--fg-3); |
|
line-height: 1.5; |
|
} |
|
|
|
/* ---------- Compact mini icon variants ---------- */ |
|
.mi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; padding: 12px 10px 0; } |
|
.mi-tile { aspect-ratio: 1; border-radius: 8px; background: var(--teal-50); } |
|
.mi-tile.warm { background: var(--warm-100); } |
|
.mi-tile.med { background: var(--teal-100); } |
|
|
|
.mi-list { padding: 12px 10px 0; display: flex; flex-direction: column; gap: 5px; } |
|
.mi-list-row { height: 22px; border-radius: 6px; background: #F0F3F7; display: flex; align-items: center; gap: 6px; padding: 0 8px; } |
|
.mi-list-row .av { width: 14px; height: 14px; border-radius: 999px; background: var(--teal-100); flex-shrink: 0; } |
|
.mi-list-row .ln { flex: 1; height: 4px; background: #DCE2EA; border-radius: 2px; } |
|
|
|
.mi-meds { padding: 12px 10px 0; display: flex; flex-direction: column; gap: 6px; } |
|
.mi-pill-row { display: flex; align-items: center; gap: 6px; padding: 4px 6px; background: var(--warm-100); border-radius: 8px; } |
|
.mi-pill { width: 14px; height: 14px; border-radius: 4px; background: var(--accent); flex-shrink: 0; } |
|
.mi-pill.b { background: var(--teal); } |
|
.mi-pill.c { background: #C77A4C; } |
|
.mi-pill-row .ln { flex: 1; height: 3px; background: rgba(0,0,0,.1); border-radius: 2px; } |
|
|
|
.mi-chart { padding: 12px 10px 0; } |
|
.mi-chart svg { width: 100%; display: block; } |
|
|
|
.mi-chat { padding: 12px 10px 0; display: flex; flex-direction: column; gap: 4px; } |
|
.mi-bubble { max-width: 80%; height: 8px; border-radius: 4px 4px 4px 1px; background: #fff; border: 1px solid var(--border); } |
|
.mi-bubble.me { align-self: flex-end; background: var(--teal); border: 0; border-radius: 4px 4px 1px 4px; } |
|
.mi-bubble.ai { background: linear-gradient(90deg, var(--p15), var(--p15bg)); border: 0; } |
|
|
|
.mi-cal { |
|
padding: 12px 10px 0; |
|
display: grid; |
|
grid-template-columns: repeat(7,1fr); |
|
gap: 3px; |
|
} |
|
.mi-cal-d { aspect-ratio: 1; border-radius: 4px; background: #F0F3F7; } |
|
.mi-cal-d.on { background: var(--teal); } |
|
.mi-cal-d.miss { background: var(--accent); opacity: .5; } |
|
.mi-cal-d.today { background: var(--warm-200); } |
|
|
|
/* dependency arrow row */ |
|
.deps { |
|
margin-top: 18px; |
|
padding: 14px 16px; |
|
border-radius: 12px; |
|
background: var(--warm-50); |
|
border: 1px dashed var(--warm-200); |
|
font-size: 12.5px; |
|
color: var(--fg-2); |
|
line-height: 1.5; |
|
} |
|
.deps b { color: var(--teal-dark); } |
|
.deps .arrow { color: var(--p15); font-weight: 700; } |
|
</style> |
|
</head> |
|
<body> |
|
|
|
<div class="wrap"> |
|
|
|
<div class="topbar"> |
|
<div> |
|
<h1>Карта развития приложения</h1> |
|
<div class="lede"> |
|
Все экраны прототипа разложены по фазам стратегии 23 апр 2026. Видно — что работает сегодня, что добавляем в Фазу 1, что строим под сегменты в Фазе 2. |
|
</div> |
|
</div> |
|
<div class="meta"> |
|
<b>Клиника Оленевой · Мобильное приложение</b> |
|
Стратегия от 23 апр 2026 · версия 1 |
|
<br> |
|
<a href="index.html">↗ Открыть прототип</a> |
|
<a href="/strategy.html" style="margin-top: 6px; background: var(--teal-50); color: var(--teal-dark); border: 1px solid var(--teal-100);">📋 Концепция развития</a> |
|
</div> |
|
</div> |
|
|
|
<div class="legend"> |
|
<span class="legend-item" style="background: var(--p0bg); color: var(--p0);"> |
|
<span class="num" style="background: var(--p0); color: #fff;">0</span> |
|
Сейчас в прототипе |
|
</span> |
|
<span class="legend-item" style="background: var(--p1bg); color: var(--p1);"> |
|
<span class="num" style="background: var(--p1); color: #fff;">1</span> |
|
Фаза 1 · Транзакционная база |
|
</span> |
|
<span class="legend-item" style="background: var(--p15bg); color: var(--p15);"> |
|
<span class="num" style="background: var(--p15); color: #fff;">1.5</span> |
|
Фаза 1.5 · Коммуникация |
|
</span> |
|
<span class="legend-item" style="background: var(--p2Abg); color: var(--p2A);"> |
|
<span class="num" style="background: var(--p2A); color: #fff;">A</span> |
|
Самопомощь хроников |
|
</span> |
|
<span class="legend-item" style="background: var(--p2Cbg); color: var(--p2C);"> |
|
<span class="num" style="background: var(--p2C); color: #fff;">C</span> |
|
Пред-оп подготовка |
|
</span> |
|
<span class="legend-item" style="background: var(--p2Bbg); color: var(--p2B);"> |
|
<span class="num" style="background: var(--p2B); color: #fff;">B</span> |
|
Сурдология |
|
</span> |
|
<span class="legend-item" style="background: var(--p2Dbg); color: var(--p2D);"> |
|
<span class="num" style="background: var(--p2D); color: #fff;">D</span> |
|
АСИТ + астма |
|
</span> |
|
<span class="legend-item" style="background: var(--skipbg); color: var(--skip);"> |
|
<span class="num" style="background: var(--skip); color: #fff;">—</span> |
|
Не делаем |
|
</span> |
|
</div> |
|
|
|
<!-- ============== Phase 0: Сейчас в прототипе ============== --> |
|
<div class="phase"> |
|
<div class="phase-head"> |
|
<div class="phase-num" style="background: var(--p0bg); color: var(--p0);">0</div> |
|
<div> |
|
<h2 class="phase-title">Сейчас в прототипе</h2> |
|
<p class="phase-sub">16 экранов: транзакционное ядро (запись + ближайший приём + врачи) и базовая идентификация. Точка отсчёта.</p> |
|
</div> |
|
<div class="phase-aside"> |
|
<div><div class="stat">Экранов</div><div class="stat-v">16</div></div> |
|
<div><div class="stat">Покрытие</div><div class="stat-v">~30%</div></div> |
|
</div> |
|
</div> |
|
<div class="phase-body"> |
|
<div class="cards"> |
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-grid"><div class="mi-tile warm"></div><div class="mi-tile"></div><div class="mi-tile med"></div><div class="mi-tile"></div><div class="mi-tile med"></div><div class="mi-tile warm"></div></div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Главная</h3> |
|
<p class="card-desc">Запись CTA, специализации, ближайший приём. Витрина услуг.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-list"><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div></div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Врачи + карточка</h3> |
|
<p class="card-desc">Каталог, фильтры, рейтинги, расписание, отзывы.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-list"><div class="mi-list-row" style="background: var(--teal-50)"><span class="av"></span><span class="ln" style="background: var(--teal-200)"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div></div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Запись на приём</h3> |
|
<p class="card-desc">4-шаговый флоу: специализация → врач → время → подтверждение.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-list"><div class="mi-list-row" style="background: var(--warm-100)"><span class="av" style="background: var(--accent)"></span><span class="ln"></span></div><div class="mi-list-row"><span class="av"></span><span class="ln"></span></div></div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Мои приёмы</h3> |
|
<p class="card-desc">Предстоящие и прошедшие. Деталь приёма с заключением.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-chat"><div class="mi-bubble"></div><div class="mi-bubble me"></div><div class="mi-bubble"></div><div class="mi-bubble me" style="width:50%"></div></div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Чат с оператором</h3> |
|
<p class="card-desc">Один универсальный чат — справки, переносы, расписание.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 14px 10px 0; display:flex; flex-direction:column; align-items:center; gap:8px;"> |
|
<div style="width:40px; height:40px; border-radius:999px; background: var(--warm-100);"></div> |
|
<div style="height:6px; width:60%; background: #E4EAF2; border-radius: 3px;"></div> |
|
<div style="height:4px; width:80%; background: #EEF2F7; border-radius: 2px;"></div> |
|
</div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Профиль + QR + семья</h3> |
|
<p class="card-desc">Идентификация, QR пациента, члены семьи, бонусы.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div class="mi-chart"> |
|
<svg viewBox="0 0 100 60"> |
|
<rect x="0" y="10" width="100" height="20" fill="#E8F5EE" opacity=".6"/> |
|
<polyline points="5,15 25,18 45,22 65,30 85,42 95,48" fill="none" stroke="var(--accent)" stroke-width="1.5"/> |
|
<polyline points="5,12 25,15 45,18 65,25 85,32 95,38" fill="none" stroke="var(--p2B)" stroke-width="1.5" stroke-dasharray="2 2"/> |
|
</svg> |
|
</div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Аудиограмма</h3> |
|
<p class="card-desc">Тест слуха + просмотр готового результата.</p> |
|
<div class="card-tags"><span class="tag live">в проде</span></div> |
|
</div> |
|
</a> |
|
|
|
<a class="card card-existing" href="index.html"> |
|
<div class="mini"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height:8px; background: var(--teal); border-radius: 4px; width: 45%; margin-bottom: 8px;"></div> |
|
<div style="height:6px; background: var(--border); border-radius: 3px; margin-bottom: 4px;"></div> |
|
<div style="height:6px; background: var(--border); border-radius: 3px; margin-bottom: 4px; width:70%"></div> |
|
<div style="height:6px; background: var(--border); border-radius: 3px; width: 50%;"></div> |
|
</div> |
|
<span class="card-status">✓</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Восстановление</h3> |
|
<p class="card-desc">Прототип бегунка после операции — таймлайн, лекарства.</p> |
|
<div class="card-tags"><span class="tag live">основа для C</span></div> |
|
</div> |
|
</a> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- ============== Phase 1: Транзакционная база ============== --> |
|
<div class="phase"> |
|
<div class="phase-head"> |
|
<div class="phase-num" style="background: var(--p1bg); color: var(--p1);">1</div> |
|
<div> |
|
<h2 class="phase-title">Транзакционная база</h2> |
|
<p class="phase-sub">Ради чего пациент <em>не удалит приложение между визитами</em>. Детерминированные функции — без LLM, без живого диалога с врачом. Минимум юридических и регламентных рисков.</p> |
|
</div> |
|
<div class="phase-aside"> |
|
<div><div class="stat">Новых экранов</div><div class="stat-v">+8</div></div> |
|
<div><div class="stat">Охват</div><div class="stat-v">100%</div></div> |
|
</div> |
|
</div> |
|
<div class="phase-body"> |
|
<div class="cards"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 8px; background: var(--p1); border-radius: 4px; width: 70%; margin-bottom: 8px;"></div> |
|
<div class="mi-pill-row" style="background: var(--p1bg)"><span class="mi-pill b"></span><span class="ln"></span></div> |
|
<div class="mi-pill-row" style="background: var(--p1bg); margin-top:4px"><span class="mi-pill b"></span><span class="ln"></span></div> |
|
<div class="mi-pill-row" style="background: var(--warm-50); margin-top:4px"><span class="mi-pill" style="background: var(--p2A)"></span><span class="ln"></span></div> |
|
</div> |
|
<span class="card-status" style="background: var(--p1); color: #fff;">★ Фундамент</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">План лечения с приёма</h3> |
|
<p class="card-desc">Главный новый объект. Диагноз, препараты с расписанием, процедуры, контрольный приём, запись в 1 клик.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span><span class="tag">источник правды</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div class="mi-meds"> |
|
<div class="mi-pill-row"><span class="mi-pill"></span><span class="ln"></span><span style="font-size:9px; color: var(--p1); font-weight:700">8:00</span></div> |
|
<div class="mi-pill-row"><span class="mi-pill b"></span><span class="ln"></span><span style="font-size:9px; color: var(--p1); font-weight:700">13:00</span></div> |
|
<div class="mi-pill-row"><span class="mi-pill c"></span><span class="ln"></span><span style="font-size:9px; color: var(--p1); font-weight:700">20:00</span></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Карточка препарата</h3> |
|
<p class="card-desc">Детали назначения: дозировка, дни, что осталось, инструкция, побочки.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div class="mi-list"> |
|
<div class="mi-list-row" style="background: var(--p2Abg)"><span class="av" style="background: var(--p2A)"></span><span class="ln" style="background: var(--p2A); opacity: .4"></span></div> |
|
<div class="mi-list-row" style="background: var(--p2Abg)"><span class="av" style="background: var(--p2A)"></span><span class="ln" style="background: var(--p2A); opacity: .4"></span></div> |
|
<div class="mi-list-row" style="background: var(--warm-100)"><span class="av" style="background: var(--p2C)"></span><span class="ln" style="background: var(--p2C); opacity: .4"></span></div> |
|
<div class="mi-list-row" style="background: var(--p1bg)"><span class="av" style="background: var(--p1)"></span><span class="ln" style="background: var(--p1); opacity: .4"></span></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Медкарта со «срок годности»</h3> |
|
<p class="card-desc">Анализы, аудиограммы, снимки + статус «годен до». Критично для пред-опа.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span><span class="tag">расширение</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 14px 10px 0; display:flex; flex-direction:column; gap:8px;"> |
|
<div style="background:#fff; border-radius: 8px; padding: 8px; border: 1px solid var(--border);"> |
|
<div style="height:5px; background: var(--p1); border-radius: 2px; width: 60%; margin-bottom: 4px;"></div> |
|
<div style="height:4px; background: var(--border); border-radius: 2px; width: 80%;"></div> |
|
</div> |
|
<div style="background: var(--p1); color:#fff; height: 22px; border-radius: 8px; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:700;">ЗАКАЗАТЬ</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Заказ справок</h3> |
|
<p class="card-desc">Справка ФНС, выписки, счета. 1 клик. Готовая в приложении.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span><span class="tag">retention-якорь</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="background: var(--p1bg); border-radius: 10px; padding: 8px;"> |
|
<div style="height:5px; background: var(--p1); border-radius: 2px; width: 80%; margin-bottom: 4px;"></div> |
|
<div style="height:4px; background: var(--p1); opacity:.5; border-radius: 2px; width: 60%;"></div> |
|
</div> |
|
<div style="display: flex; gap:4px; margin-top:8px"> |
|
<div style="flex:1; height: 18px; background: var(--p1); border-radius: 6px;"></div> |
|
<div style="flex:1; height: 18px; background: var(--p1bg); border-radius: 6px; border: 1px solid var(--p1)"></div> |
|
</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Главная: «эпизод лечения»</h3> |
|
<p class="card-desc">Альтернативная главная для повторных. Активный диагноз, день курса, что делать сегодня.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span><span class="tag">переосмысление</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 5px; background: var(--p1); border-radius: 2px; width: 50%; margin-bottom:6px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 80%; margin-bottom:4px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%; margin-bottom:8px"></div> |
|
<div style="display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 4px;"> |
|
<div style="height: 22px; background: var(--p1bg); border-radius: 6px;"></div> |
|
<div style="height: 22px; background: var(--p1bg); border-radius: 6px;"></div> |
|
<div style="height: 22px; background: var(--p1bg); border-radius: 6px;"></div> |
|
</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Чек-лист подготовки к приёму</h3> |
|
<p class="card-desc">Не забыть карту/анализы, маршрут до кабинета, тригеры 24ч/2ч/15мин.</p> |
|
<div class="card-tags"><span class="tag p1">усиление</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 5px; background: var(--p1); border-radius: 2px; width: 60%; margin-bottom:8px"></div> |
|
<div style="display: flex; align-items: center; gap: 8px; margin-bottom: 6px;"> |
|
<div style="width:12px; height:12px; border-radius: 999px; background: var(--p2A);"></div> |
|
<div style="flex:1; height: 4px; background: var(--p2A); border-radius: 2px;"></div> |
|
<div style="width:12px; height:12px; border-radius: 999px; background: var(--p2A);"></div> |
|
<div style="flex:1; height: 4px; background: var(--p2A); border-radius: 2px;"></div> |
|
<div style="width:12px; height:12px; border-radius: 999px; background: var(--border-soft); border: 1.5px solid var(--p1)"></div> |
|
</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-top: 6px;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Эпизод лечения</h3> |
|
<p class="card-desc">Сводка: первичный → процедуры → контроль. Видна траектория.</p> |
|
<div class="card-tags"><span class="tag p1">фаза 1</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="display:flex; gap:6px; margin-bottom: 6px;"> |
|
<div style="flex:1; height: 32px; background: #fff; border-radius: 6px; border: 1px solid var(--border);"></div> |
|
<div style="flex:1; height: 32px; background: #fff; border-radius: 6px; border: 1px solid var(--border);"></div> |
|
</div> |
|
<div style="height: 5px; background: var(--p1); border-radius: 2px; width: 70%; margin-bottom:4px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 80%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Семейный профиль (расширение)</h3> |
|
<p class="card-desc">Переключение между профилями ребёнка/пожилого. Критично для аденоидов и ЧБД.</p> |
|
<div class="card-tags"><span class="tag p1">усиление</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<div class="deps"> |
|
<b>Зависимость:</b> структурированные назначения от МИС. Если API отдаёт препарат + дозу + курс — план собирается автоматически. Если только PDF — врач заполняет в виджете шаблонами по нозологиям. <span class="arrow">→</span> Решение определяет сроки Фазы 1. |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- ============== Phase 1.5: Коммуникация ============== --> |
|
<div class="phase"> |
|
<div class="phase-head"> |
|
<div class="phase-num" style="background: var(--p15bg); color: var(--p15);">1.5</div> |
|
<div> |
|
<h2 class="phase-title">Коммуникационная надстройка</h2> |
|
<p class="phase-sub">Живой и AI-диалог по поводу лечения. Поверх стабильной Фазы 1. Требует регламентов SLA, безопасности и отдельной выкладки — поэтому отделено от Фазы 1.</p> |
|
</div> |
|
<div class="phase-aside"> |
|
<div><div class="stat">Новых экранов</div><div class="stat-v">+4</div></div> |
|
</div> |
|
</div> |
|
<div class="phase-body"> |
|
<div class="cards"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div class="mi-chat" style="padding-top:14px"> |
|
<div class="mi-bubble"></div> |
|
<div class="mi-bubble" style="width:60%"></div> |
|
<div class="mi-bubble me" style="background: var(--p15)"></div> |
|
<div class="mi-bubble" style="width:80%"></div> |
|
</div> |
|
<span class="card-status" style="background: var(--p15); color:#fff;">SLA</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Чат с медицинским консьержем</h3> |
|
<p class="card-desc">Дежурный врач/фельдшер по протоколам. 80% рутины, эскалация лечащему. Не прямой чат с врачом.</p> |
|
<div class="card-tags"><span class="tag p15">фаза 1.5</span><span class="tag">регламент</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div class="mi-chat" style="padding-top:14px"> |
|
<div class="mi-bubble"></div> |
|
<div class="mi-bubble ai" style="width:80%"></div> |
|
<div class="mi-bubble ai" style="width:65%"></div> |
|
<div class="mi-bubble me" style="background: var(--p15)"></div> |
|
</div> |
|
<span class="card-status" style="background: var(--p15); color:#fff;">Shadow</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">AI-помощник (RAG)</h3> |
|
<p class="card-desc">Знает базу знаний клиники, план лечения. Сначала shadow-mode под валидацией консьержа.</p> |
|
<div class="card-tags"><span class="tag p15">фаза 1.5</span><span class="tag">риск</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="display:flex; gap: 6px; margin-bottom: 6px;"> |
|
<div style="flex:1; height: 30px; background: var(--p1bg); border-radius: 8px;"></div> |
|
<div style="flex:1; height: 30px; background: var(--p15bg); border-radius: 8px;"></div> |
|
</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 4px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Маршрутизатор каналов</h3> |
|
<p class="card-desc">Куда писать: оператор, консьерж или AI. Без когнитивной нагрузки на пациента.</p> |
|
<div class="card-tags"><span class="tag p15">UX-вызов</span></div> |
|
</div> |
|
</div> |
|
|
|
<div class="card card-future"> |
|
<div class="mini mini-future"> |
|
<div class="mini-status"></div> |
|
<div style="padding: 14px 10px 0;"> |
|
<div style="height: 5px; background: var(--p15); border-radius: 2px; width: 50%; margin-bottom:6px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom:4px"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%; margin-bottom:8px"></div> |
|
<div style="display: flex; gap: 4px;"> |
|
<div style="flex:1; height: 6px; background: var(--p2A); border-radius: 3px;"></div> |
|
<div style="flex:1; height: 6px; background: var(--warm-200); border-radius: 3px;"></div> |
|
<div style="flex:1; height: 6px; background: var(--p2C); border-radius: 3px;"></div> |
|
</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Триаж тревожности</h3> |
|
<p class="card-desc">«Норма / срочно / неотложно» — AI оценивает и эскалирует к консьержу или 112.</p> |
|
<div class="card-tags"><span class="tag p15">безопасность</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- ============== Phase 2: Сегментные модули ============== --> |
|
<div class="phase"> |
|
<div class="phase-head"> |
|
<div class="phase-num" style="background: linear-gradient(135deg, var(--p2A), var(--p2C), var(--p2B), var(--p2D)); color: #fff;">2</div> |
|
<div> |
|
<h2 class="phase-title">Сегментные модули</h2> |
|
<p class="phase-sub">Углубление по приоритетным группам сегментов. Порядок запуска: <b>A → C → B → D</b>. Каждый модуль опирается на план лечения и медкарту из Фазы 1.</p> |
|
</div> |
|
<div class="phase-aside"> |
|
<div><div class="stat">Групп</div><div class="stat-v">4</div></div> |
|
<div><div class="stat">Новых экранов</div><div class="stat-v">~25</div></div> |
|
</div> |
|
</div> |
|
<div class="phase-body"> |
|
|
|
<div class="groups-grid"> |
|
|
|
<!-- Group A --> |
|
<div class="group-block" style="background: linear-gradient(180deg, var(--p2Abg) 0%, #fff 60%);"> |
|
<div class="group-head"> |
|
<span class="group-letter" style="background: var(--p2A);">A</span> |
|
<span class="group-name">Самопомощь хроников</span> |
|
<span class="group-meta">первый запуск · охват ~тысячи в мес.</span> |
|
</div> |
|
<p style="font-size: 12.5px; color: var(--fg-3); margin: 0 0 12px; line-height: 1.5;"> |
|
Промывания, полоскания, ингаляции. Видео-библиотека техник + ежедневный трекер + дневник симптомов в связке. Главный мотиватор — «промываю 5 дней, насморк уменьшился с 4 до 2». |
|
</p> |
|
<div class="cards" style="grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 6px;"> |
|
<div style="aspect-ratio: 1; background: var(--p2A); border-radius: 8px; position:relative;"><div style="position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff;">▶</div></div> |
|
<div style="aspect-ratio: 1; background: var(--p2Abg); border-radius: 8px;"></div> |
|
<div style="aspect-ratio: 1; background: var(--p2Abg); border-radius: 8px;"></div> |
|
<div style="aspect-ratio: 1; background: var(--p2Abg); border-radius: 8px;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Библиотека техник</h3> |
|
<p class="card-desc">10–15 видео-инструкций: промывание, полоскание, ингаляция.</p> |
|
<div class="card-tags"><span class="tag a">A</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div class="mi-cal"> |
|
<div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d miss"></div><div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d on"></div> |
|
<div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d on"></div><div class="mi-cal-d miss"></div><div class="mi-cal-d on"></div><div class="mi-cal-d today"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Трекер комплаенса</h3> |
|
<p class="card-desc">Ежедневные отметки, стрики, сводка для врача.</p> |
|
<div class="card-tags"><span class="tag a">A</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 14px 10px 0;"> |
|
<svg viewBox="0 0 100 50" style="width:100%;"> |
|
<polyline points="0,5 15,8 30,12 45,18 60,28 75,35 90,42 100,46" fill="none" stroke="var(--p2A)" stroke-width="2"/> |
|
<circle cx="100" cy="46" r="3" fill="var(--p2A)"/> |
|
</svg> |
|
<div style="display: flex; justify-content: space-between; margin-top:4px;"> |
|
<span style="font-size:10px; color: var(--fg-4); font-weight:700">Симптом 4</span> |
|
<span style="font-size:10px; color: var(--p2A); font-weight:700">→ 2</span> |
|
</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Дневник симптомов</h3> |
|
<p class="card-desc">Видна динамика — главный мотиватор продолжать.</p> |
|
<div class="card-tags"><span class="tag a">A</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="background: var(--p2A); color:#fff; padding: 6px 8px; border-radius: 8px; font-size: 10px; font-weight:700; margin-bottom: 6px;">8:00 — Промыть нос</div> |
|
<div style="background: var(--p2Abg); padding: 6px 8px; border-radius: 8px; font-size: 9px; color: var(--p2A); margin-bottom: 4px;">13:00 Ингаляция</div> |
|
<div style="background: var(--p2Abg); padding: 6px 8px; border-radius: 8px; font-size: 9px; color: var(--p2A);">20:00 Полоскание</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Расписание дня</h3> |
|
<p class="card-desc">Утро/день/вечер из плана. Уведомления.</p> |
|
<div class="card-tags"><span class="tag a">A</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- Group C --> |
|
<div class="group-block" style="background: linear-gradient(180deg, var(--p2Cbg) 0%, #fff 60%);"> |
|
<div class="group-head"> |
|
<span class="group-letter" style="background: var(--p2C);">C</span> |
|
<span class="group-name">Пред-операционная подготовка</span> |
|
<span class="group-meta">3 сегмента одним модулем · ~50 млн</span> |
|
</div> |
|
<p style="font-size: 12.5px; color: var(--fg-3); margin: 0 0 12px; line-height: 1.5;"> |
|
Закрывает FESS, аденоиды, вазотомию. Две половины: <b>сомневающиеся</b> после пред-оп приёма и <b>решившиеся</b> в 6-недельной подготовке. У нас уже есть прототип «Восстановление» — это вторая половина. |
|
</p> |
|
<div class="cards" style="grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 5px; background: var(--p2C); border-radius: 2px; width: 60%; margin-bottom: 6px;"></div> |
|
<div style="display:flex; flex-direction:column; gap:4px;"> |
|
<div style="height: 16px; background: var(--p2Cbg); border-radius: 6px;"></div> |
|
<div style="height: 16px; background: var(--p2Cbg); border-radius: 6px;"></div> |
|
</div> |
|
<div style="background: var(--p2C); color:#fff; height: 18px; border-radius: 6px; margin-top: 6px; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:700;">РЕШИТЬСЯ</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Сомневающийся пациент</h3> |
|
<p class="card-desc">Кейсы, метод (FESS/лазер), цена/рассрочка, чат с хирургом.</p> |
|
<div class="card-tags"><span class="tag c">C</span><span class="tag">возврат</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="display:flex; align-items:center; gap: 4px; margin-bottom: 6px;"> |
|
<div style="width:10px; height:10px; border-radius:999px; background: var(--p2C);"></div> |
|
<div style="flex:1; height: 3px; background: var(--p2C); opacity: .5;"></div> |
|
<div style="width:10px; height:10px; border-radius:999px; background: var(--p2C);"></div> |
|
<div style="flex:1; height: 3px; background: var(--p2C); opacity: .5;"></div> |
|
<div style="width:10px; height:10px; border-radius:999px; background: var(--p2C); opacity: .3;"></div> |
|
</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 4px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Бегунок 6 недель</h3> |
|
<p class="card-desc">Чек-листы, анализы (срок годности!), запись на операцию.</p> |
|
<div class="card-tags"><span class="tag c">C</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 14px 10px 0;"> |
|
<div style="background: var(--p2C); color: #fff; height: 28px; border-radius: 8px; display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:700; margin-bottom: 6px;">ДЕНЬ ОПЕРАЦИИ</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 3px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 80%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Чек-лист дня операции</h3> |
|
<p class="card-desc">Что взять, во сколько, голод, маршрут, контакт.</p> |
|
<div class="card-tags"><span class="tag c">C</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-existing"> |
|
<div class="mini"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 8px; background: var(--p1); border-radius: 4px; width: 45%; margin-bottom: 6px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 4px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%;"></div> |
|
</div> |
|
<span class="card-status">✓ есть</span> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Восстановление (есть)</h3> |
|
<p class="card-desc">Уже в прототипе — основа второй половины Группы C.</p> |
|
<div class="card-tags"><span class="tag c">C</span><span class="tag live">в проде</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- Group B --> |
|
<div class="group-block" style="background: linear-gradient(180deg, var(--p2Bbg) 0%, #fff 60%);"> |
|
<div class="group-head"> |
|
<span class="group-letter" style="background: var(--p2B);">B</span> |
|
<span class="group-name">Сурдология</span> |
|
<span class="group-meta">пожизненный LTV · самый нестандартный UX</span> |
|
</div> |
|
<p style="font-size: 12.5px; color: var(--fg-3); margin: 0 0 12px; line-height: 1.5;"> |
|
Возврат после демо (2–3 мес «уходят думать») + обслуживание после покупки. Каталог как маркетплейс, аудио-демо, паспорт аппарата, шеринг с близким, сервисный календарь. |
|
</p> |
|
<div class="cards" style="grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 6px;"> |
|
<div style="aspect-ratio: 1; background: var(--p2Bbg); border-radius: 10px; display:flex; align-items:center; justify-content:center; font-size:18px;">🦻</div> |
|
<div style="aspect-ratio: 1; background: var(--p2Bbg); border-radius: 10px;"></div> |
|
<div style="aspect-ratio: 1; background: var(--p2Bbg); border-radius: 10px;"></div> |
|
<div style="aspect-ratio: 1; background: var(--p2Bbg); border-radius: 10px;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Каталог аппаратов</h3> |
|
<p class="card-desc">Маркетплейс моделей с калькулятором, рассрочкой, шерингом.</p> |
|
<div class="card-tags"><span class="tag b">B</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 14px 10px 0; display:flex; flex-direction: column; align-items: center;"> |
|
<div style="display:flex; align-items: end; gap:3px; height: 40px;"> |
|
<div style="width:6px; height:30%; background: var(--p2B); border-radius: 2px;"></div> |
|
<div style="width:6px; height:50%; background: var(--p2B); border-radius: 2px;"></div> |
|
<div style="width:6px; height:80%; background: var(--p2B); border-radius: 2px;"></div> |
|
<div style="width:6px; height:60%; background: var(--p2B); border-radius: 2px;"></div> |
|
<div style="width:6px; height:40%; background: var(--p2B); border-radius: 2px;"></div> |
|
</div> |
|
<div style="font-size: 9px; color: var(--p2B); font-weight:700; margin-top: 4px;">Слышу с аппаратом</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Аудио-демо</h3> |
|
<p class="card-desc">Сравнение «без аппарата / с аппаратом» в наушниках. На любом устройстве.</p> |
|
<div class="card-tags"><span class="tag b">B</span><span class="tag">конверсия</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="background: var(--p2B); color: #fff; padding: 8px; border-radius: 10px; margin-bottom: 4px;"> |
|
<div style="font-size: 8px; opacity: .7; font-weight:700">МОЯ МОДЕЛЬ</div> |
|
<div style="font-size: 11px; font-weight:700; margin-top:2px;">Phonak Audéo</div> |
|
</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 4px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Паспорт аппарата</h3> |
|
<p class="card-desc">Сервисный календарь, расходники, калибровка раз в год.</p> |
|
<div class="card-tags"><span class="tag b">B</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="height: 5px; background: var(--p2B); border-radius: 2px; width: 50%; margin-bottom: 6px;"></div> |
|
<div class="mi-list-row" style="background: var(--p2Bbg)"><span class="av" style="background: var(--p2B)"></span><span class="ln" style="background: var(--p2B); opacity: .4"></span></div> |
|
<div class="mi-list-row" style="background: var(--p2Bbg); margin-top:4px"><span class="av" style="background: var(--p2B)"></span><span class="ln" style="background: var(--p2B); opacity: .4"></span></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Дневник адаптации</h3> |
|
<p class="card-desc">Первые 90 дней с аппаратом — сложности, успехи, советы.</p> |
|
<div class="card-tags"><span class="tag b">B</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- Group D --> |
|
<div class="group-block" style="background: linear-gradient(180deg, var(--p2Dbg) 0%, #fff 60%);"> |
|
<div class="group-head"> |
|
<span class="group-letter" style="background: var(--p2D);">D</span> |
|
<span class="group-name">АСИТ + контроль астмы</span> |
|
<span class="group-meta">самая высокая ответственность · с верификацией</span> |
|
</div> |
|
<p style="font-size: 12.5px; color: var(--fg-3); margin: 0 0 12px; line-height: 1.5;"> |
|
Курс 3–5 лет: «не начал», «бросил в первые месяцы». Ежедневный дневник симптомов, пыльцевой календарь, навигатор побочки. Без верификации аллерголога не запускаем. |
|
</p> |
|
<div class="cards" style="grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));"> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="display: flex; align-items: end; gap: 2px; height: 50px;"> |
|
<div style="flex:1; height: 30%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 50%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 80%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 100%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 70%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 40%; background: var(--p2D); border-radius: 2px;"></div> |
|
<div style="flex:1; height: 25%; background: var(--p2D); border-radius: 2px;"></div> |
|
</div> |
|
<div style="font-size:9px; color: var(--p2D); font-weight:700; margin-top: 4px;">Берёза · пик 18 апр</div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Пыльцевой календарь</h3> |
|
<p class="card-desc">Прогноз концентрации аллергена на неделю вперёд.</p> |
|
<div class="card-tags"><span class="tag d">D</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 14px 10px 0;"> |
|
<div style="display: flex; gap: 3px; margin-bottom: 8px;"> |
|
<div style="flex:1; height: 6px; background: var(--p2A); border-radius: 3px;"></div> |
|
<div style="flex:1; height: 6px; background: var(--warm-200); border-radius: 3px;"></div> |
|
<div style="flex:1; height: 6px; background: #E8E8F0; border-radius: 3px;"></div> |
|
<div style="flex:1; height: 6px; background: #E8E8F0; border-radius: 3px;"></div> |
|
</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 4px;"></div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; width: 70%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Дневник симптомов АСИТ</h3> |
|
<p class="card-desc">Чихание, заложенность, глаза. Видит аллерголог перед визитом.</p> |
|
<div class="card-tags"><span class="tag d">D</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="background: var(--p2D); color: #fff; padding: 6px 8px; border-radius: 8px; font-size: 10px; font-weight:700; margin-bottom: 4px;">⚠ Зуд во рту?</div> |
|
<div style="background: var(--p2Dbg); padding: 4px 8px; border-radius: 6px; height: 14px; margin-bottom: 3px;"></div> |
|
<div style="background: var(--p2Dbg); padding: 4px 8px; border-radius: 6px; height: 14px; width: 70%;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Навигатор побочки</h3> |
|
<p class="card-desc">Зуд, отёк — норма / осторожно / срочно. Удерживает на курсе.</p> |
|
<div class="card-tags"><span class="tag d">D</span></div> |
|
</div> |
|
</div> |
|
<div class="card card-future"> |
|
<div class="mini mini-future" style="height: 110px;"> |
|
<div style="padding: 12px 10px 0;"> |
|
<div style="display:flex; align-items: center; gap: 4px;"> |
|
<div style="width:10px; height:10px; border-radius:999px; background: var(--p2D);"></div> |
|
<div style="flex:1; height: 3px; background: var(--p2D); opacity: .5;"></div> |
|
<div style="width:10px; height:10px; border-radius:999px; background: var(--p2D); opacity: .5;"></div> |
|
</div> |
|
<div style="font-size:9px; color: var(--p2D); font-weight:700; margin-top:6px;">Год 1 из 5</div> |
|
<div style="height: 4px; background: var(--border); border-radius: 2px; margin-top: 4px;"></div> |
|
</div> |
|
</div> |
|
<div class="card-body"> |
|
<h3 class="card-name">Дорожная карта 5 лет</h3> |
|
<p class="card-desc">Видеть длинный путь — главный мотив не бросить.</p> |
|
<div class="card-tags"><span class="tag d">D</span></div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
|
|
</div> |
|
|
|
<div class="deps"> |
|
<b>Зависимости:</b> все 4 группы используют <b>план лечения</b> и <b>медкарту</b> из Фазы 1 как источник правды. Группа D дополнительно требует верификации контента аллергологом и добавления его в каталог врачей. <span class="arrow">→</span> Без Фазы 1 модули не строятся. |
|
</div> |
|
</div> |
|
</div> |
|
|
|
<!-- ============== Сегменты ============== --> |
|
<div class="segments"> |
|
<div class="seg-head"> |
|
<h2>10 сегментов сквозь призму приложения</h2> |
|
<p>Бизнес-сегментация клиники наложена на фазы. Видно, какой модуль закрывает какие сегменты и где у нас «не делаем».</p> |
|
</div> |
|
<table class="seg-table"> |
|
<thead> |
|
<tr> |
|
<th>Сегмент</th> |
|
<th>Главная работа в App (повторный)</th> |
|
<th>Группа</th> |
|
<th>Выручка / год</th> |
|
<th>Приоритет</th> |
|
</tr> |
|
</thead> |
|
<tbody> |
|
<tr> |
|
<td><span class="seg-num">1</span><span class="seg-name">Заблокированный нос (FESS)</span></td> |
|
<td class="seg-job">Пред-оп бегунок · восстановление · контроль 3/6/12 мес</td> |
|
<td><span class="tag c">C</span></td> |
|
<td><span class="seg-rev">~30 млн</span></td> |
|
<td><span class="prio high">● высокий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">2</span><span class="seg-name">Амбулаторный поток</span></td> |
|
<td class="seg-job">План лечения · процедуры самопомощи · дневник</td> |
|
<td><span class="tag p1">1</span> <span class="tag a">A</span></td> |
|
<td><span class="seg-rev">~120 млн</span></td> |
|
<td><span class="prio high">● высший</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">3</span><span class="seg-name">Дети + аденоиды</span></td> |
|
<td class="seg-job">Семейный профиль · подготовка ребёнка · детский бегунок</td> |
|
<td><span class="tag c">C</span></td> |
|
<td><span class="seg-rev">~25 млн</span></td> |
|
<td><span class="prio high">● высокий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">4</span><span class="seg-name">Сурдология</span></td> |
|
<td class="seg-job">Каталог · аудио-демо · паспорт аппарата · сервис</td> |
|
<td><span class="tag b">B</span></td> |
|
<td><span class="seg-rev">~20 млн</span></td> |
|
<td><span class="prio high">● высокий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">5</span><span class="seg-name">Сложные хроники + ЧБД</span></td> |
|
<td class="seg-job">Самопомощь · АСИТ-трекер · семейный профиль</td> |
|
<td><span class="tag a">A</span> <span class="tag d">D</span></td> |
|
<td><span class="seg-rev">часть 120 млн</span></td> |
|
<td><span class="prio high">● высокий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">6</span><span class="seg-name">Зависимость от капель</span></td> |
|
<td class="seg-job">Возврат сомневающихся · компактный бегунок · восстановление</td> |
|
<td><span class="tag c">C</span></td> |
|
<td><span class="seg-rev">часть хирургии</span></td> |
|
<td><span class="prio high">● высокий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">7</span><span class="seg-name">Пульмонология</span></td> |
|
<td class="seg-job">Дневник астмы · ингаляторы · триггеры</td> |
|
<td><span class="tag d">D</span></td> |
|
<td><span class="seg-rev">средний</span></td> |
|
<td><span class="prio mid">◐ средний</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">8</span><span class="seg-name">Социальные храпуны</span></td> |
|
<td class="seg-job">Образовательный контент · СИПАП-трекер</td> |
|
<td><span class="tag skip">—</span></td> |
|
<td><span class="seg-rev">низкий</span></td> |
|
<td><span class="prio low">○ низкий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">9</span><span class="seg-name">Фониатрия</span></td> |
|
<td class="seg-job">Срочная запись (короткое окно)</td> |
|
<td><span class="tag skip">—</span></td> |
|
<td><span class="seg-rev">очень низкий</span></td> |
|
<td><span class="prio low">○ низкий</span></td> |
|
</tr> |
|
<tr> |
|
<td><span class="seg-num">10</span><span class="seg-name">Check-up + Второе мнение</span></td> |
|
<td class="seg-job">Разовая услуга · бренд Оленевой</td> |
|
<td><span class="tag skip">—</span></td> |
|
<td><span class="seg-rev">единичный</span></td> |
|
<td><span class="prio low">○ низкий</span></td> |
|
</tr> |
|
</tbody> |
|
</table> |
|
</div> |
|
|
|
<!-- ============== Footnotes ============== --> |
|
<div class="foot"> |
|
<div class="foot-card"> |
|
<div class="ti">Принцип</div> |
|
<div class="vl">Удержание, не привлечение</div> |
|
<div class="ds">Первичных приводит сайт и реклама. Приложение — инструмент углубления для повторных. 2 из 3 пациентов клиники — повторные.</div> |
|
</div> |
|
<div class="foot-card"> |
|
<div class="ti">Дизайн-сдвиг</div> |
|
<div class="vl">Из «витрины» в «эпизод лечения»</div> |
|
<div class="ds">Главная сейчас построена для первичного. Нужна альтернативная главная: активный диагноз, день курса, что делать сегодня.</div> |
|
</div> |
|
<div class="foot-card"> |
|
<div class="ti">Что не делаем</div> |
|
<div class="vl">Отдельные «первичные» модули</div> |
|
<div class="ds">Базовый минимум (запись, цены, врачи) уже работает. Специализированных первичных потоков под каждый сегмент строить не нужно.</div> |
|
</div> |
|
<div class="foot-card"> |
|
<div class="ti">Исключения</div> |
|
<div class="vl">Пациент уходит думать</div> |
|
<div class="ds">Сурдология (2–3 мес до покупки), хирургия (решение об операции), АСИТ (3–5 лет курса) — там «первичный в App» ≠ «первый визит».</div> |
|
</div> |
|
</div> |
|
|
|
</div> |
|
|
|
</body> |
|
</html>
|
|
|