/* СНАБ·МАСТЕР — приложение мастера.
   Дизайн: «между Apple и Петровичем» — светло, с воздухом, но крупно
   и рабоче. Один акцент #E14B17 (тот же, что в PDF-документах).
   Фирменный элемент — «рулетка»: разделитель с рисками, как на
   измерительной ленте; он же стоит в шапках смет и договоров. */

:root{
  --bg:#F4F3F0;          /* гипсовый светлый */
  --card:#FFFFFF;
  --ink:#191A1C;
  --mut:#73767B;
  --line:#E6E4DF;
  --accent:#E14B17;      /* сигнальный оранжевый — жилет/разметка */
  --accent-dim:#FBE9E2;
  --ok:#178A4C;
  --ok-dim:#E2F3E9;
  --warn:#B7791F;
  --warn-dim:#F8EFD9;
  --danger:#C2271A;
  --r-card:18px; --r-btn:16px; --r-in:14px;
  --tap:48px;
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
html,body{height:100%}
body{
  background:var(--bg);color:var(--ink);
  font:16px/1.45 -apple-system,BlinkMacSystemFont,'SF Pro Text','Segoe UI',Roboto,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overscroll-behavior-y:none;
}
.app{min-height:100%;display:flex;flex-direction:column}
.screen{flex:1;padding:calc(12px + var(--sat)) 16px calc(96px + var(--sab));max-width:560px;width:100%;margin:0 auto}

/* ---------- фирменная «рулетка» ---------- */
.ruler{height:9px;margin:10px 0 14px;border-bottom:1.5px solid var(--ink);
  background:
    repeating-linear-gradient(90deg, var(--ink) 0 1.5px, transparent 1.5px 8px) left bottom/100% 4px no-repeat,
    repeating-linear-gradient(90deg, var(--ink) 0 1.5px, transparent 1.5px 40px) left bottom/100% 9px no-repeat;
}
.ruler.dim{border-color:var(--line)}
.ruler.dim{background:
    repeating-linear-gradient(90deg, var(--line) 0 1.5px, transparent 1.5px 8px) left bottom/100% 4px no-repeat,
    repeating-linear-gradient(90deg, var(--line) 0 1.5px, transparent 1.5px 40px) left bottom/100% 9px no-repeat;}

/* ---------- шапки ---------- */
.brand{display:flex;align-items:baseline;gap:2px;font-weight:800;font-size:21px;letter-spacing:.02em;padding:6px 0 0}
.brand b{color:var(--accent)}
.topbar{display:flex;align-items:center;gap:6px;min-height:48px;margin:0 -6px 4px}
.topbar .back{width:44px;height:44px;border:0;background:none;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.topbar .back:active{background:rgba(0,0,0,.06)}
.topbar h1{font-size:21px;font-weight:800;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.h-sub{color:var(--mut);font-size:14px;margin:-2px 0 8px}

.sect{margin:22px 0 10px}
.sect .t{font-size:12.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--mut)}

/* ---------- карточки ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-card);padding:16px;box-shadow:0 1px 2px rgba(20,18,14,.04)}
.card+.card{margin-top:10px}
.card.tap:active{transform:scale(.99);background:#FCFBF9}
.row{display:flex;align-items:center;gap:12px}
.row .grow{flex:1;min-width:0}
.muted{color:var(--mut)}
.small{font-size:13.5px}
.big{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.ell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---------- кнопки ---------- */
.btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  min-height:58px;padding:0 18px;border-radius:var(--r-btn);border:0;
  font:inherit;font-size:17px;font-weight:700;color:#fff;background:var(--accent);cursor:pointer}
.btn:active{filter:brightness(.93)}
.btn:disabled{opacity:.45}
.btn.sec{background:var(--card);color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line);font-weight:600}
.btn.danger{background:transparent;color:var(--danger);border:1.5px solid var(--line)}
.btn.sm{min-height:46px;font-size:15.5px;width:auto;padding:0 16px}
.btn svg{width:21px;height:21px;flex:none}
.btn-row{display:flex;gap:10px}
.btn-row .btn{flex:1}
.carrot{display:flex;align-items:center;gap:12px;width:100%;min-height:56px;padding:0 16px;margin-top:10px;
  border-radius:var(--r-btn);border:1.5px dashed #CFCBC2;background:transparent;color:var(--mut);
  font:inherit;font-size:15.5px;font-weight:600;text-align:left}
.carrot .soon{margin-left:auto;font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  background:#ECEAE4;border-radius:99px;padding:4px 9px;color:#8B8E93}

/* ---------- формы ---------- */
.field{margin-top:12px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--mut);margin:0 2px 6px}
.in{width:100%;min-height:54px;padding:0 14px;font:inherit;font-size:17px;color:var(--ink);
  background:var(--card);border:1.5px solid var(--line);border-radius:var(--r-in);outline:none}
textarea.in{min-height:84px;padding:13px 14px;resize:vertical}
.in:focus{border-color:var(--ink)}
.in::placeholder{color:#A9ACB0}
select.in{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2373767B' stroke-width='2.2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* степпер: число + крупные −/+ */
.step{display:flex;align-items:stretch;background:var(--card);border:1.5px solid var(--line);border-radius:var(--r-in);overflow:hidden}
.step button{width:52px;border:0;background:none;font-size:26px;font-weight:600;color:var(--ink);flex:none}
.step button:active{background:rgba(0,0,0,.06)}
.step input{flex:1;min-width:0;border:0;outline:none;text-align:center;font:inherit;font-size:19px;font-weight:700;min-height:52px;background:transparent;font-variant-numeric:tabular-nums}

/* чипы */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{min-height:46px;padding:0 16px;border-radius:13px;border:1.5px solid var(--line);background:var(--card);
  font:inherit;font-size:16px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center}
.chip.on{border-color:var(--ink);background:var(--ink);color:#fff}
.seg{display:flex;background:#ECEAE4;border-radius:13px;padding:3px}
.seg button{flex:1;min-height:46px;border:0;border-radius:11px;background:transparent;font:inherit;font-size:15.5px;font-weight:600;color:var(--mut)}
.seg button.on{background:var(--card);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.08);font-weight:700}

/* галочки/тумблеры */
.check{display:flex;align-items:center;gap:12px;min-height:var(--tap);padding:4px 2px;font-size:16.5px}
.check .box{width:26px;height:26px;border-radius:8px;border:2px solid #C9C6BF;flex:none;display:flex;align-items:center;justify-content:center;background:var(--card)}
.check.on .box{background:var(--ink);border-color:var(--ink)}
.check .box svg{width:16px;height:16px;stroke:#fff;stroke-width:3;fill:none;display:none}
.check.on .box svg{display:block}
.switchrow{display:flex;align-items:center;min-height:var(--tap);gap:12px}
.switchrow .grow b{display:block;font-size:16px}
.switchrow .grow span{font-size:13px;color:var(--mut)}
.tgl{width:52px;height:32px;border-radius:99px;background:#D8D5CE;border:0;position:relative;flex:none;transition:background .15s}
.tgl::after{content:'';position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .15s}
.tgl.on{background:var(--ok)}
.tgl.on::after{left:23px}

/* ---------- статусы ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:99px;font-size:12.5px;font-weight:700;background:#ECEAE4;color:#5E6166}
.pill.acc{background:var(--accent-dim);color:var(--accent)}
.pill.ok{background:var(--ok-dim);color:var(--ok)}
.pill.warn{background:var(--warn-dim);color:var(--warn)}

/* трекер заказа */
.track{margin:6px 0}
.tstep{display:flex;gap:14px;position:relative;padding-bottom:22px}
.tstep:last-child{padding-bottom:0}
.tstep::before{content:'';position:absolute;left:13px;top:30px;bottom:2px;width:2px;background:var(--line)}
.tstep:last-child::before{display:none}
.tstep.done::before{background:var(--ink)}
.tdot{width:28px;height:28px;border-radius:50%;border:2px solid var(--line);background:var(--card);flex:none;display:flex;align-items:center;justify-content:center;z-index:1}
.tdot svg{width:15px;height:15px;display:none}
.tstep.done .tdot{background:var(--ink);border-color:var(--ink)}
.tstep.done .tdot svg.i-check{display:block;stroke:#fff}
.tstep.cur .tdot{border-color:var(--accent);background:var(--accent)}
.tstep.cur .tdot svg.i-cur{display:block;stroke:#fff;fill:none}
.tstep .tl{padding-top:3px}
.tstep .tl b{font-size:16px;font-weight:700;color:var(--mut)}
.tstep.done .tl b,.tstep.cur .tl b{color:var(--ink)}
.tstep.cur .tl b{color:var(--accent)}
.tstep .tl span{display:block;font-size:13px;color:var(--mut)}

/* плитки замера */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.tile .v{font-size:21px;font-weight:800;font-variant-numeric:tabular-nums}
.tile .k{font-size:12.5px;color:var(--mut);margin-top:1px}

/* результат калькулятора / смет */
.lines{margin-top:6px}
.line{display:flex;align-items:center;gap:10px;min-height:46px;border-bottom:1px solid var(--line)}
.line:last-child{border-bottom:0}
.line .n{flex:1;min-width:0;font-size:15.5px}
.line .n span{display:block;font-size:12.5px;color:var(--mut)}
.line .q{font-weight:800;font-size:17px;font-variant-numeric:tabular-nums;white-space:nowrap}
.line input.qin{width:74px;text-align:right;min-height:42px;padding:0 10px;font-size:17px;font-weight:800;border:1.5px solid var(--line);border-radius:10px;background:var(--card);font-variant-numeric:tabular-nums}
.total{display:flex;justify-content:space-between;align-items:baseline;margin-top:12px;padding-top:12px;border-top:1.5px solid var(--ink)}
.total b{font-size:22px;font-variant-numeric:tabular-nums}

/* редактор сметы */
.eline{border:1px solid var(--line);border-radius:14px;padding:12px;margin-top:10px;background:var(--card)}
.eline .top{display:flex;gap:8px}
.eline input.name{flex:1;min-width:0;border:0;border-bottom:1.5px solid var(--line);font:inherit;font-size:16px;font-weight:600;min-height:40px;outline:none;background:transparent}
.eline input.name:focus{border-color:var(--ink)}
.eline .del{width:40px;height:40px;border:0;background:none;color:var(--mut);font-size:20px;border-radius:10px}
.eline .nums{display:flex;gap:8px;margin-top:10px;align-items:center}
.eline .nums input{width:0;flex:1;min-height:46px;text-align:right;padding:0 10px;font:inherit;font-size:16px;font-weight:700;border:1.5px solid var(--line);border-radius:11px;font-variant-numeric:tabular-nums;background:var(--card)}
.eline .nums select{flex:none;width:84px;min-height:46px;font-size:15px}
.eline .lt{margin-left:auto;font-weight:800;font-size:16px;font-variant-numeric:tabular-nums;white-space:nowrap}

/* отклики дилеров */
.resp .price{font-size:26px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.resp .meta{font-size:14px;color:var(--mut);margin-top:2px}
.stars{display:inline-flex;gap:1px;vertical-align:-2px}
.stars svg{width:15px;height:15px;fill:#D9D6CF}
.stars svg.f{fill:var(--warn)}
.bigstars{display:flex;justify-content:center;gap:8px;margin:8px 0 4px}
.bigstars button{width:50px;height:50px;border:0;background:none;padding:0}
.bigstars svg{width:44px;height:44px;fill:#D9D6CF}
.bigstars button.f svg{fill:var(--warn)}
.review{border-top:1px solid var(--line);padding:10px 0 2px;font-size:14.5px}
.review .d{font-size:12.5px;color:var(--mut)}

/* календарь */
.legend{display:flex;flex-wrap:wrap;gap:8px 14px;margin:8px 0 4px}
.legend .lg{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600}
.dot{width:11px;height:11px;border-radius:50%;flex:none}
.day{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.day .dn{width:64px;flex:none;font-size:13.5px;color:var(--mut);padding-top:5px}
.day .dn b{display:block;font-size:16px;color:var(--ink)}
.day.today .dn b{color:var(--accent)}
.day .jobs{flex:1;display:flex;flex-direction:column;gap:6px}
.job{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:7px 11px;font-size:14px;font-weight:600}
.job .ad{font-weight:400;color:var(--mut);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.day .free{font-size:13.5px;color:#B9BCC0;padding-top:6px}

/* бригады */
.ava{width:46px;height:46px;border-radius:50%;background:#ECEAE4;color:#6E7176;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;flex:none;overflow:hidden}
.ava img{width:100%;height:100%;object-fit:cover}

/* ---------- нижняя навигация ---------- */
.tabs{position:fixed;left:0;right:0;bottom:0;display:flex;background:rgba(252,251,249,.92);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-top:1px solid var(--line);padding:6px 8px calc(6px + var(--sab));z-index:30}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;min-height:54px;justify-content:center;
  text-decoration:none;color:#8B8E93;font-size:11.5px;font-weight:700;border-radius:12px}
.tab svg{width:25px;height:25px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.tab.on{color:var(--ink)}
.tab:active{background:rgba(0,0,0,.05)}

/* ---------- toast / sheet ---------- */
.toast{position:fixed;left:50%;bottom:calc(86px + var(--sab));transform:translateX(-50%);
  background:var(--ink);color:#fff;font-size:15px;font-weight:600;padding:12px 18px;border-radius:13px;
  max-width:88%;text-align:center;z-index:60;box-shadow:0 6px 24px rgba(0,0,0,.25)}
.sheet-wrap{position:fixed;inset:0;background:rgba(20,18,14,.45);z-index:50;display:flex;align-items:flex-end}
.sheet{background:var(--bg);width:100%;border-radius:22px 22px 0 0;padding:18px 16px calc(20px + var(--sab));max-height:88vh;overflow:auto;animation:up .18s ease}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.sheet h2{font-size:19px;font-weight:800;margin-bottom:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

.empty{padding:34px 12px;text-align:center;color:var(--mut)}
.empty b{display:block;color:var(--ink);font-size:17px;margin-bottom:4px}
.note{font-size:13px;color:var(--mut);margin-top:10px;line-height:1.4}
.link{color:var(--accent);font-weight:700;text-decoration:none}
.spin{margin:40px auto;width:30px;height:30px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
