/* ============================================================
   Помощник по анализам — дизайн-система (портирована из прототипа
   artifacts/prototypes/med-mobile-app-prototype.html).
   Mobile-first. Тёмная/светлая тема по prefers-color-scheme,
   с ручным переопределением через <html data-theme="light|dark">.
   ============================================================ */

:root{
  --bg:#0c0d10;--panel:#15161b;--card:#1b1d24;--card-2:#22242d;--border:#2a2c36;
  --ink:#f3f4f7;--ink-soft:#b9bcc9;--ink-mut:#888c9b;
  --brand:#2dd4bf;--brand-2:#14b8a6;--brand-soft:#2dd4bf1f;--brand-ink:#062a26;
  --accent:#7c5cff;--accent-soft:#7c5cff22;
  --ok:#22c55e;--ok-soft:#22c55e1c;--warn:#f59e0b;--warn-soft:#f59e0b1c;--danger:#ef4444;--danger-soft:#ef44441c;
  --sans:-apple-system,system-ui,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,monospace;
  --shadow:0 8px 30px rgba(0,0,0,.45);
}

/* светлая тема — авто по системе */
@media (prefers-color-scheme: light){
  :root{
    --bg:#eef0f4;--panel:#ffffff;--card:#ffffff;--card-2:#f4f6f9;--border:#e6e8ee;
    --ink:#16181d;--ink-soft:#4d5160;--ink-mut:#6f7480;
    --brand-soft:#2dd4bf22;--accent-soft:#7c5cff18;--shadow:0 10px 34px rgba(20,30,60,.12);
    --ok-soft:#22c55e18;--warn-soft:#f59e0b18;--danger-soft:#ef444418;
  }
}

/* ручное переопределение темы (кнопка-тогл) — перебивает системную */
html[data-theme="dark"]{
  --bg:#0c0d10;--panel:#15161b;--card:#1b1d24;--card-2:#22242d;--border:#2a2c36;
  --ink:#f3f4f7;--ink-soft:#b9bcc9;--ink-mut:#888c9b;
  --brand-soft:#2dd4bf1f;--accent-soft:#7c5cff22;--shadow:0 8px 30px rgba(0,0,0,.45);
  --ok-soft:#22c55e1c;--warn-soft:#f59e0b1c;--danger-soft:#ef44441c;
}
html[data-theme="light"]{
  --bg:#eef0f4;--panel:#ffffff;--card:#ffffff;--card-2:#f4f6f9;--border:#e6e8ee;
  --ink:#16181d;--ink-soft:#4d5160;--ink-mut:#6f7480;
  --brand-soft:#2dd4bf22;--accent-soft:#7c5cff18;--shadow:0 10px 34px rgba(20,30,60,.12);
  --ok-soft:#22c55e18;--warn-soft:#f59e0b18;--danger-soft:#ef444418;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;}
/* Доступность (аудитория 50+): базовый шрифт ≥16px, читаемый интерлиньяж,
   тач-цели ≥44px. См. FRONTEND_PLAN §4. */
body{overflow:hidden;font-size:16px;line-height:1.5;}

/* ---------- app shell (полноэкранное мобильное приложение) ---------- */
#app{
  display:flex;flex-direction:column;
  height:100vh;height:100dvh;
  max-width:480px;margin:0 auto;
  background:var(--bg);position:relative;overflow:hidden;
}
@media (min-width:520px){
  #app{border-left:1px solid var(--border);border-right:1px solid var(--border);}
}

.body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.body::-webkit-scrollbar{display:none;}
.pad{padding:14px 16px calc(20px + env(safe-area-inset-bottom));}

/* ---------- app bar ---------- */
.appbar{display:flex;align-items:center;gap:6px;padding:calc(8px + env(safe-area-inset-top)) 10px 8px;flex:0 0 auto;}
.appbar .back{font-size:28px;line-height:1;color:var(--ink-soft);cursor:pointer;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;user-select:none;}
.appbar h2{font-size:1.15rem;font-weight:700;flex:1;padding-left:4px;}
.appbar .act{font-size:20px;color:var(--brand);cursor:pointer;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;}

/* ---------- bottom nav ---------- */
.tabbar{flex:0 0 auto;height:calc(62px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--border);background:var(--panel);display:flex;}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--ink-mut);font:600 11px var(--sans);text-decoration:none;cursor:pointer;}
.tabbar a .ic{font-size:21px;}
.tabbar a.active{color:var(--brand);}

/* ---------- ui atoms ---------- */
.btn{display:block;width:100%;min-height:50px;text-align:center;padding:14px;border:none;border-radius:14px;background:var(--brand);color:var(--brand-ink);font:700 16px var(--sans);cursor:pointer;transition:.15s;}
.btn:active{transform:scale(.98);}
.btn.sec{background:var(--card-2);color:var(--ink);border:1px solid var(--border);}
.btn.ok{background:var(--ok);color:#04230f;}
.btn.ghost{background:transparent;color:var(--brand);border:1px solid var(--brand);}
.btn.danger{background:var(--danger);color:#fff;}
.btn[disabled]{opacity:.45;cursor:default;}
/* 16px у инпутов — иначе iOS Safari зумит при фокусе */
.field{width:100%;min-height:50px;padding:13px 14px;border:1px solid var(--border);border-radius:13px;background:var(--card-2);color:var(--ink);font:600 16px var(--sans);margin-bottom:11px;}
.field::placeholder{color:var(--ink-mut);font-weight:500;}
.field:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft);}
.field.err{border-color:var(--danger);}
.lbl{font:600 12px var(--sans);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px 2px;}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:14px;}
.muted{color:var(--ink-soft);font-size:14px;line-height:1.55;}
.tiny{color:var(--ink-mut);font-size:12.5px;line-height:1.5;}
.err-msg{color:var(--danger);font-size:13px;margin:-4px 2px 11px;min-height:16px;}
.link{color:var(--brand);cursor:pointer;}

/* дисклеймер (юр. — раздел 7 контракта, рендерится дословно) */
.disc{display:flex;gap:8px;align-items:flex-start;background:var(--warn-soft);border:1px solid var(--warn);border-radius:11px;padding:10px 12px;color:var(--ink-soft);font-size:12.5px;line-height:1.5;}
.disc b{color:var(--warn);}
.disc.danger{background:var(--danger-soft);border-color:var(--danger);}
.brandbadge{display:inline-flex;align-items:center;gap:5px;font:600 11px var(--mono);color:var(--brand);background:var(--brand-soft);padding:4px 10px;border-radius:99px;}

/* status pills / dots */
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:0 0 auto;}
.dot.g{background:var(--ok);}.dot.y{background:var(--warn);}.dot.r{background:var(--danger);}
.sevpill{display:inline-flex;align-items:center;gap:6px;font:700 11px var(--sans);padding:5px 11px;border-radius:99px;}
.sevpill.ok{background:var(--ok-soft);color:var(--ok);}
.sevpill.att{background:var(--warn-soft);color:var(--warn);}
.sevpill.urg{background:var(--danger-soft);color:var(--danger);}

/* marker card */
.marker{display:flex;gap:11px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border);}
.marker:last-child{border-bottom:none;}
.marker.tap{cursor:pointer;}
.marker.tap:active{opacity:.7;}
.marker .m-info{color:var(--ink-mut);font-size:12px;}
.marker .mhead{display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
.marker .mname{font-weight:700;font-size:15px;}
.marker .mval{font:700 15px var(--mono);}
.marker .mval.g{color:var(--ok);}.marker .mval.y{color:var(--warn);}.marker .mval.r{color:var(--danger);}
.marker .mref{font:12px var(--mono);color:var(--ink-mut);}
.marker .mexp{font-size:13px;color:var(--ink-soft);line-height:1.55;margin-top:4px;}
.barwrap{height:6px;background:var(--card-2);border-radius:99px;margin-top:7px;position:relative;overflow:hidden;}
.barzone{position:absolute;top:0;bottom:0;background:var(--ok-soft);border-radius:99px;}
.barmark{position:absolute;top:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--panel);}
.barmark.g{background:var(--ok);}.barmark.y{background:var(--warn);}.barmark.r{background:var(--danger);}

/* history row */
.hrow{display:flex;gap:12px;align-items:center;padding:13px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.hrow:last-child{border-bottom:none;}
.hicon{width:42px;height:42px;border-radius:12px;background:var(--card-2);display:flex;align-items:center;justify-content:center;font-size:19px;flex:0 0 auto;}
.hrow .ht{font-weight:700;font-size:15px;}
.hrow .hd{font-size:12.5px;color:var(--ink-mut);margin-top:2px;}

/* list rows / settings */
.lrow{display:flex;align-items:center;gap:12px;min-height:48px;padding:14px 2px;border-bottom:1px solid var(--border);font-size:15px;cursor:pointer;}
.lrow .li{font-size:17px;width:24px;text-align:center;}
.lrow .lc{flex:1;}
.lrow .lr{color:var(--ink-mut);font-size:12px;}

/* upload dropzone */
.drop{border:2px dashed var(--border);border-radius:18px;padding:30px 16px;text-align:center;background:var(--card);}
.drop .ic{font-size:40px;}
.drop h3{font-size:15px;font-weight:700;margin:10px 0 4px;}
.upbtns{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;}
.upbtns .btn{font-size:13px;padding:14px 8px;}

/* processing */
.proc{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:30px;text-align:center;}
.spinner{width:64px;height:64px;border-radius:50%;border:5px solid var(--card-2);border-top-color:var(--brand);animation:spin 1s linear infinite;margin-bottom:22px;}
@keyframes spin{to{transform:rotate(360deg);}}
.steps{margin-top:24px;width:100%;text-align:left;display:flex;flex-direction:column;gap:12px;}
.step{display:flex;align-items:center;gap:11px;font-size:13px;color:var(--ink-mut);}
.step.done{color:var(--ink);}.step.now{color:var(--brand);font-weight:700;}
.step .sc{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;flex:0 0 auto;}
.step.done .sc{background:var(--ok);border-color:var(--ok);color:#fff;}
.step.now .sc{border-color:var(--brand);}

/* chart */
.chart{height:160px;position:relative;margin:8px 0 4px;}
.chart svg{width:100%;height:100%;overflow:visible;}
.legend{display:flex;gap:14px;font-size:11px;color:var(--ink-soft);margin-top:6px;}
.legend span{display:flex;align-items:center;gap:5px;}

/* segmented */
.seg{display:flex;background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:3px;gap:3px;}
.seg button{flex:1;min-height:44px;padding:11px 8px;border:none;border-radius:9px;background:transparent;color:var(--ink-soft);font:600 14px var(--sans);cursor:pointer;}
.seg button.on{background:var(--brand);color:var(--brand-ink);}

/* paywall */
.plan{border:1px solid var(--border);border-radius:15px;padding:14px;margin-bottom:11px;position:relative;}
.plan.best{border-color:var(--brand);background:var(--brand-soft);}
.plan .ptag{position:absolute;top:-9px;right:14px;background:var(--brand);color:var(--brand-ink);font:700 9px var(--sans);padding:3px 9px;border-radius:99px;text-transform:uppercase;}
.plan .pname{font-weight:700;font-size:14px;}
.plan .pprice{font:800 20px var(--sans);margin:3px 0;}
.plan .pprice small{font-size:12px;color:var(--ink-mut);font-weight:500;}
.plan .pfeat{font-size:11.5px;color:var(--ink-soft);}

/* consent screen */
.scrollbox{background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:13px;font-size:13px;color:var(--ink-soft);line-height:1.6;max-height:210px;overflow-y:auto;}
.check{display:flex;gap:11px;align-items:flex-start;min-height:44px;padding:13px;background:var(--card);border:1px solid var(--border);border-radius:12px;margin-top:11px;cursor:pointer;}
.check.on{border-color:var(--brand);}
.check .box{width:24px;height:24px;border-radius:7px;border:2px solid var(--brand);flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:14px;}
.check.on .box{background:var(--brand);color:var(--brand-ink);}
.check .ct{font-size:13.5px;color:var(--ink-soft);line-height:1.5;}

/* hero / splash */
.hero{display:flex;flex-direction:column;height:100%;padding:calc(30px + env(safe-area-inset-top)) 22px calc(30px + env(safe-area-inset-bottom));background:radial-gradient(ellipse at top,var(--brand-soft),transparent 65%);}
.hero .logo{font-size:54px;text-align:center;margin-top:28px;}
.hero h1{font-size:1.7rem;font-weight:800;text-align:center;margin-top:14px;letter-spacing:-.02em;}
.hero .sub{color:var(--ink-soft);text-align:center;font-size:14.5px;margin-top:10px;line-height:1.55;}
.hero .feats{margin:auto 0;display:flex;flex-direction:column;gap:14px;}
.hfeat{display:flex;gap:12px;align-items:center;font-size:14.5px;}
.hfeat .hi{width:38px;height:38px;border-radius:11px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;font-size:18px;flex:0 0 auto;}

/* empty state */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:50px 24px;gap:6px;}
.empty .eic{font-size:46px;}
.empty h3{font-size:15px;font-weight:700;}

.spacer{height:10px;}
.row{display:flex;gap:8px;}
.row>*{flex:1;}

/* theme toggle (плавающая кнопка, для разработки/удобства) */
.theme-tgl{position:absolute;top:calc(10px + env(safe-area-inset-top));right:14px;z-index:40;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--panel);color:var(--ink-soft);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;}

/* модальный диалог (подтверждение удаления, просмотр документов) */
.modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:24px;z-index:60;}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:20px;max-width:340px;width:100%;max-height:80%;overflow-y:auto;box-shadow:var(--shadow);}
.modal h3{font-size:17px;font-weight:700;margin-bottom:8px;}

/* toast */
.toast{position:absolute;left:50%;bottom:84px;transform:translateX(-50%);z-index:70;background:var(--ink);color:var(--bg);font:600 13px var(--sans);padding:10px 16px;border-radius:99px;box-shadow:var(--shadow);max-width:80%;text-align:center;}

/* ============ bottom-sheet попап маркера ============ */
.app--sheet .body{overflow:hidden;}            /* лочим скролл фона */
.sheet-overlay{position:absolute;inset:0;z-index:80;background:rgba(0,0,0,.5);opacity:0;transition:opacity .25s ease;display:flex;align-items:flex-end;}
.sheet-overlay.show{opacity:1;}
.sheet{width:100%;max-height:85vh;background:var(--panel);border-radius:22px 22px 0 0;box-shadow:0 -8px 30px rgba(0,0,0,.45);transform:translateY(100%);transition:transform .25s ease;display:flex;flex-direction:column;overflow:hidden;}
.sheet.show{transform:translateY(0);}
.sheet-handle{flex:0 0 auto;display:flex;justify-content:center;padding:10px 0 2px;cursor:grab;touch-action:none;}
.sheet-handle::before{content:"";width:42px;height:5px;border-radius:99px;background:var(--border);}
.sheet-top{display:flex;align-items:flex-start;gap:8px;padding:4px 14px 8px;}
.sheet-top .st-main{flex:1;min-width:0;}
.sheet-top h2{font-size:1.15rem;font-weight:800;line-height:1.2;}
.sheet-x{flex:0 0 auto;width:44px;height:44px;border:none;background:transparent;color:var(--ink-soft);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;}
.sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px calc(22px + env(safe-area-inset-bottom));}
.ms-sub{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap;}
.ms-sub .mval{font:700 15px var(--mono);}
.ms-block{margin:18px 0;}
.ms-block h3{font-size:14.5px;font-weight:700;margin-bottom:6px;}
.ms-block p,.ms-block li{font-size:14.5px;color:var(--ink-soft);line-height:1.55;}
.ms-block ul{padding-left:20px;margin:4px 0;}
.ms-block li{margin:5px 0;}
.ms-warn-card{background:var(--warn-soft);border:1px solid var(--warn);border-radius:14px;padding:12px 13px;}
.ms-warn-card h3{color:var(--warn);}
.ms-doc{background:var(--brand-soft);border:1px solid var(--brand);border-radius:14px;padding:12px 13px;font-size:14px;}
.ms-detail{display:inline-block;margin:4px 0 8px;color:var(--brand);font-weight:700;text-decoration:none;font-size:14.5px;}

/* шкала-градусник */
.ms-scale{margin:16px 0 6px;}
.ms-track{position:relative;height:14px;background:var(--card-2);border-radius:99px;}
.ms-zone{position:absolute;top:0;bottom:0;background:var(--ok-soft);border:1px solid var(--ok);border-radius:99px;}
.ms-dot{position:absolute;top:50%;width:22px;height:22px;border-radius:50%;border:3px solid var(--panel);transform:translate(-50%,-50%);box-shadow:0 1px 5px rgba(0,0,0,.35);z-index:2;}
.ms-dot.g{background:var(--ok);}.ms-dot.y{background:var(--warn);}.ms-dot.r{background:var(--danger);}
.ms-ticks{position:relative;height:16px;margin-top:8px;font:600 11px var(--mono);color:var(--ink-mut);}
.ms-ticks span{position:absolute;transform:translateX(-50%);white-space:nowrap;}
.ms-ticks .ms-norm{color:var(--ok);}
.ms-yourval{margin-top:12px;font-weight:700;font-size:14.5px;}
.ms-yourval.g{color:var(--ok);}.ms-yourval.y{color:var(--warn);}.ms-yourval.r{color:var(--danger);}

/* динамика: подпись тренда */
.trendlbl{font:700 13px var(--sans);}
.trendlbl.up{color:var(--warn);} .trendlbl.down{color:var(--brand);} .trendlbl.flat{color:var(--ink-soft);}

/* PWA install banner */
.install-banner{display:flex;align-items:center;gap:10px;background:var(--brand-soft);border:1px solid var(--brand);border-radius:14px;padding:11px 12px;margin-bottom:14px;}
.install-banner .ib-ic{font-size:22px;}
.install-banner .ib-t{flex:1;font-size:12.5px;line-height:1.4;}
.install-banner .ib-t b{font-size:13px;}
.install-banner .ib-go{background:var(--brand);color:var(--brand-ink);border:none;border-radius:10px;padding:9px 12px;font:700 12px var(--sans);cursor:pointer;flex:0 0 auto;}
.install-banner .ib-x{color:var(--ink-mut);cursor:pointer;font-size:16px;width:24px;text-align:center;flex:0 0 auto;}
