  :root{--font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    --mono:ui-monospace,'SF Mono',Menlo,Consolas,monospace;}
  :root{--bg:#0d0f12;--panel:#14181d;--panel2:#1b2027;--line:#262d36;
    --txt:#e8edf2;--dim:#8a96a3;--acc:#ff5a1f;--acc2:#22d3a6;--warn:#f5c542;
    --sh1:0 1px 3px rgba(0,0,0,.25),0 1px 2px rgba(0,0,0,.15);
    --sh2:0 4px 16px rgba(0,0,0,.3),0 2px 6px rgba(0,0,0,.18);
    --press:rgba(255,255,255,.04);--skel:rgba(255,255,255,.07);
    --neg:#ff6b6b;--neg-soft:#ff6b6b55}
  html[data-theme="light"]{--bg:#f4f6f9;--panel:#ffffff;--panel2:#eef1f5;--line:#dde2e9;
    --txt:#1a2230;--dim:#6b7785;--acc:#ff5a1f;--acc2:#0d9b76;--warn:#b8860b;
    --sh1:0 1px 3px rgba(20,30,50,.08),0 1px 2px rgba(20,30,50,.04);
    --sh2:0 6px 20px rgba(20,30,50,.1),0 2px 8px rgba(20,30,50,.06);
    --press:rgba(20,30,50,.03);--skel:rgba(20,30,50,.06);
    --neg:#d92d20;--neg-soft:#d92d2055}
  *{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
  html,body{max-width:100%;overflow-x:hidden}
  /* iOS: запретить резиновый bounce-эффект страницы — он временно сдвигает viewport
     и fixed-элементы (тулбар) пропадают с экрана во время анимации */
  html{overscroll-behavior-y:none}
  /* не выделять текст при тапах по интерактивным элементам (поля ввода и итоги — оставляем) */
  body{-webkit-user-select:none;user-select:none}
  input,textarea,#repOut,footer{-webkit-user-select:text;user-select:text}
  /* ── видимый фокус с клавиатуры (доступность) ──
     показываем рамку только при навигации с клавиатуры, не при кликах мышью */
  :focus-visible{outline:2px solid var(--acc);outline-offset:2px}
  /* поля ввода уже подсвечиваются своей рамкой/тенью — не дублируем обводкой */
  input:focus-visible,textarea:focus-visible{outline:none}
  :focus:not(:focus-visible){outline:none}
  body{background:
      radial-gradient(900px 500px at 110% -10%, rgba(255,90,31,.10), transparent 60%),
      radial-gradient(700px 400px at -10% 110%, rgba(34,211,166,.08), transparent 60%),var(--bg);
    color:var(--txt);font-family:var(--font);min-height:100vh;-webkit-font-smoothing:antialiased;
    transition:background .35s ease, color .35s ease}
  /* плавная смена темы для основных поверхностей */
  .card,.tile,.crumb,.filter,.sug,#themeBtn,#widgetsBtn,.starbtn,.toolbar select{
    transition:background .35s ease, color .35s ease, border-color .35s ease, box-shadow .25s ease, transform .12s ease}
  html[data-theme="light"] body{background:
      radial-gradient(900px 500px at 110% -10%, rgba(255,90,31,.06), transparent 60%),
      radial-gradient(700px 400px at -10% 110%, rgba(13,155,118,.05), transparent 60%),var(--bg)}
  .wrap{max-width:680px;margin:0 auto;padding:18px 16px calc(74px + env(safe-area-inset-bottom,0px))}
  .wrap.page-hidden{display:none!important}
  header{display:flex;align-items:center;gap:12px;padding:10px 0 14px}
  #themeBtn,#widgetsBtn{flex:none;width:42px;height:42px;border-radius:11px;background:var(--panel2);
    border:1px solid var(--line);color:var(--txt);font-size:20px;cursor:pointer;display:grid;place-items:center;
    transition:.15s;line-height:1}
  #widgetsBtn{margin-left:auto}
  #splash{position:fixed;inset:0;z-index:10002;background:var(--bg);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
    transition:opacity .5s ease, visibility .5s ease}
  #splash.hide{opacity:0;visibility:hidden;pointer-events:none}
  #splashLogo{width:min(58vw,260px);height:auto;
    animation:splashIn .7s cubic-bezier(.22,.61,.36,1) both}
  #splashSub{font-family:var(--mono);font-size:13px;color:var(--dim);letter-spacing:1px;
    animation:splashSubIn .6s ease .25s both}
  @keyframes splashIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
  @keyframes splashSubIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion: reduce){
    #splashLogo,#splashSub{animation:none}
  }
  #themeBtn:active,#widgetsBtn:active,#journalBtn:active{transform:scale(.95)}
  .logo{width:42px;height:42px;border-radius:11px;flex:none;background:linear-gradient(135deg,var(--acc),#ff8a3d);
    display:grid;place-items:center;font-size:22px;box-shadow:0 6px 22px rgba(255,90,31,.35)}
  .logo-img{height:44px;width:auto;flex:none;object-fit:contain}
  h1{font-size:18px;font-weight:800;letter-spacing:-.4px;line-height:1.1}
  .sub{font-size:12px;color:var(--dim);font-family:var(--mono)}

  /* хлебные крошки */
  .crumbs{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:14px;font-size:13px}
  .crumb{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:7px 11px;
    cursor:pointer;color:var(--txt);font-weight:600;display:flex;align-items:center;gap:6px;transition:.13s}
  .crumb:hover{border-color:var(--acc)}
  .crumb.cur{background:linear-gradient(135deg,rgba(255,90,31,.18),rgba(255,90,31,.05));border-color:rgba(255,90,31,.45)}
  .crumb.ghost{color:var(--dim);cursor:default;background:none;border-color:transparent}
  .crumb .ic{font-size:15px}
  .sep{color:var(--dim);font-family:var(--mono)}

  .step-title{font-size:12px;color:var(--dim);text-transform:uppercase;letter-spacing:.6px;
    font-weight:700;margin:2px 2px 10px;font-family:var(--mono)}
  @keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  /* направленный слайд между шагами */
  @keyframes slideFwd{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:none}}
  @keyframes slideBack{from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:none}}
  #screen{animation:fadeIn .2s ease both}
  #screen.slide-fwd{animation:slideFwd .28s cubic-bezier(.22,.61,.36,1) both}
  #screen.slide-back{animation:slideBack .28s cubic-bezier(.22,.61,.36,1) both}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
  .screen > *{animation:fadeInUp .26s cubic-bezier(.22,.61,.36,1) both}
  /* лёгкий каскад появления элементов */
  .screen > *:nth-child(1){animation-delay:0s}
  .screen > *:nth-child(2){animation-delay:.03s}
  .screen > *:nth-child(3){animation-delay:.06s}
  .screen > *:nth-child(4){animation-delay:.09s}
  .screen > *:nth-child(n+5){animation-delay:.11s}
  @media (prefers-reduced-motion: reduce){
    #screen,.screen,.screen > *{animation:none}
  }
  .searchbox{position:relative}
  .searchbox input{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    padding:14px 16px;border-radius:12px;font-size:16px;outline:none;font-family:var(--font);transition:.18s ease, box-shadow .18s ease}
  /* постоянная строка поиска на главном */
  .hero{margin-bottom:14px}
  .hero-row{display:flex;gap:9px;align-items:stretch}
  /* поиск Google — только на ПК */
  .gsearch{display:none}
  @media (min-width:1000px){
    .gsearch{display:flex;align-items:center;gap:10px;margin-bottom:12px;
      background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:6px 6px 6px 16px;
      box-shadow:var(--sh1)}
    .gsearch:focus-within{border-color:var(--acc);box-shadow:0 0 0 4px rgba(255,90,31,.08)}
    .gicon{font-size:16px;flex:none;opacity:.7}
    .ginput{flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:15px;
      font-family:var(--font);padding:10px 0}
    .gbtn{flex:none;background:linear-gradient(135deg,var(--acc),#ff8a3d);color:#000;border:none;
      border-radius:10px;padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font)}
    .gbtn:active{transform:scale(.97)}
  }
  .hero .field{position:relative;flex:1}
  .hero input{width:100%;background:var(--panel2);border:1.5px solid var(--line);color:var(--txt);
    padding:15px 44px 15px 16px;border-radius:14px;font-size:16px;outline:none;font-family:var(--font);transition:.18s ease}
  .hero input:focus{border-color:var(--acc);box-shadow:0 0 0 4px rgba(255,90,31,.08)}
  .hero .clr{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;
    color:var(--dim);font-size:18px;cursor:pointer;padding:6px 8px;border-radius:8px;display:none}
  .hero .clr:hover{color:var(--acc)}
  .hero .clr.show{display:block}
  .micbtn{flex:none;width:54px;background:var(--panel2);border:1.5px solid var(--line);color:var(--dim);
    font-size:22px;border-radius:14px;cursor:pointer;display:grid;place-items:center;transition:.15s;line-height:1}
  .micbtn:hover{border-color:var(--acc);color:var(--acc)}
  .micbtn:active{transform:scale(.96)}
  .micbtn.live{border-color:var(--acc);color:var(--acc);background:rgba(255,90,31,.08);animation:micPulse 1s ease-in-out infinite}
  @keyframes micPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.7}}
  .hero-suggest{margin-top:8px;display:flex;flex-direction:column;gap:6px}
  .searchbox input:hover{box-shadow:0 8px 24px rgba(0,0,0,.1)}
  .searchbox input:focus{border-color:var(--acc);box-shadow:0 0 0 4px rgba(255,90,31,.08)}
  .suggest{margin-top:8px;display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
  .sug{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);
    border-radius:11px;padding:11px 13px;cursor:pointer;font-size:14.5px;transition:.18s ease, border-color .18s ease, transform .18s ease;
    will-change:transform,border-color}
  .sug:hover{border-color:var(--acc);transform:translateX(2px)}
  .sug:active{transform:translateX(1px) scale(.995)}
  .suggest-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--panel);border:1px solid var(--line);
    border-radius:11px;padding:11px 13px;cursor:pointer;font-size:14.5px;transition:.18s ease, border-color .18s ease, transform .18s ease;
    will-change:transform,border-color}
  .suggest-item:hover{border-color:var(--acc);transform:translateX(2px)}
  .suggest-item:active{transform:translateX(1px) scale(.995)}
  .sug .bsm{font-size:11px;color:var(--dim);font-family:var(--mono);margin-left:auto}
  .sug-go{font-size:13px;color:var(--acc2);font-family:var(--mono);padding:10px 4px}

  .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
  .grid.three{grid-template-columns:repeat(3,1fr)}

  /* раскладка контент + сайдбар */
  .layout{display:block}
  .side-col{margin-top:14px;display:flex;flex-direction:column;gap:14px}
  .side-col .card{margin-bottom:0}
  /* порядок карточек: избранное → статистика → калькулятор маржи */
  #favCard{order:1} #statCard{order:2} #calcCard{order:3}

  /* ── широкие экраны (планшет / ПК): используем площадь ── */
  @media (min-width:720px){
    .wrap{max-width:900px;padding:22px 24px calc(74px + env(safe-area-inset-bottom,0px))}
    .grid{grid-template-columns:repeat(3,1fr);gap:11px}
    .grid.three{grid-template-columns:repeat(5,1fr);gap:11px}
  }
  @media (min-width:1000px){
    .layout{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:start}
    .main-col{min-width:0}
    .side-col{margin-top:0;display:flex;flex-direction:column;gap:14px;
      position:sticky;top:18px;align-self:start}
    .side-col .card{margin-bottom:0}
  }
  @media (min-width:1100px){
    .wrap{max-width:1240px;padding:26px 32px 32px}
    .grid{grid-template-columns:repeat(3,1fr);gap:13px}
    .grid.three{grid-template-columns:repeat(5,1fr);gap:13px}
  }
  @media (min-width:1300px){
    .grid{grid-template-columns:repeat(4,1fr)}
    .grid.three{grid-template-columns:repeat(6,1fr)}
  }
  .tile{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:15px 12px;
    cursor:pointer;display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;
    transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease, background .15s ease;
    text-align:left;color:var(--txt);min-height:52px;min-width:0;overflow:hidden;box-shadow:var(--sh1)}
  .tile > span{min-width:0;overflow-wrap:anywhere}
  /* плитка запчасти: текст сверху, кнопки рядом снизу */
  .tile.part{flex-direction:column;align-items:stretch;gap:11px;justify-content:space-between}
  .part-top{display:flex;align-items:center;gap:10px;min-width:0}
  .part-name{min-width:0;overflow-wrap:break-word;font-weight:600;line-height:1.25}
  .tile:hover{border-color:var(--acc);transform:translateY(-2px);box-shadow:var(--sh2)}
  .tile:active{transform:scale(.975) translateY(0);box-shadow:var(--sh1);background:var(--press)}
  .tile .ic{font-size:20px;flex:none}
  .tile.brand{flex-direction:column;justify-content:center;text-align:center;font-weight:700;gap:8px;padding:16px 10px;min-height:84px}
  .badge{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
    font-size:21px;font-weight:800;flex:none;line-height:1;position:relative;overflow:hidden;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 5px 14px rgba(0,0,0,.4)}
  .badge::after{content:'';position:absolute;inset:0;border-radius:12px;
    background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 55%);pointer-events:none}
  .badge svg{position:relative;z-index:1}
  .tile.brand span.bn{font-size:13.5px}
  .tile.add{border-style:dashed;color:var(--dim)}
  .tile.add:hover{color:var(--acc2);border-color:var(--acc2)}
  .tile-actions{display:flex;gap:7px;align-items:center;flex:none}
  .tile .alt{font-size:12.5px;color:var(--dim);font-family:var(--font);font-weight:600;
    background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:7px 11px;cursor:pointer;
    flex:1;text-align:center;transition:.13s}
  .tile .alt:hover{color:var(--acc2);border-color:var(--acc2)}
  .tile .alt:active{transform:scale(.96)}
  .filter{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    padding:11px 14px;border-radius:11px;font-size:15px;outline:none;font-family:var(--font);margin-bottom:10px}
  .filter:focus{border-color:var(--acc)}
  .hot{position:absolute;top:7px;right:9px;font-size:10px;color:var(--warn);font-family:var(--mono)}
  .tile.has-hot{position:relative}
  .tile.full{grid-column:1/-1;justify-content:center;
    background:linear-gradient(135deg,rgba(255,90,31,.18),rgba(255,90,31,.06));border-color:rgba(255,90,31,.4);margin:9px 0}

  .card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:14px;box-shadow:var(--sh1)}
  .stat-sum{font-size:13px;color:var(--dim);margin-bottom:10px}
  .stat-controls{display:flex;align-items:center;gap:8px;margin-bottom:12px}
  .stat-segs{display:flex;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:2px;flex:1}
  .stat-seg{flex:1;background:none;border:none;color:var(--dim);font-family:var(--font);font-size:11.5px;
    font-weight:700;padding:6px 4px;border-radius:7px;cursor:pointer;transition:.13s;white-space:nowrap}
  .stat-seg:hover{color:var(--txt)}
  .stat-seg.on{background:var(--acc);color:#000}
  .stat-reset{flex:none;background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    font-family:var(--font);font-size:11.5px;font-weight:600;padding:6px 10px;border-radius:8px;cursor:pointer;transition:.13s}
  .stat-reset:hover{color:var(--neg);border-color:var(--neg)}
  .stat-reset:active{transform:scale(.96)}
  .stat-h{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);font-weight:700;margin-bottom:8px;font-family:var(--mono)}
  .stat-row{margin-bottom:9px}
  .stat-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px}
  .stat-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .stat-val{font-size:12px;color:var(--dim);font-family:var(--mono);flex:none}
  .stat-bar{height:7px;background:var(--panel2);border-radius:5px;overflow:hidden}
  .stat-bar span{display:block;height:100%;border-radius:5px;transition:width .4s cubic-bezier(.22,.61,.36,1)}
  .parts-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
  .parts-model{flex:1;font-size:17px;font-weight:700;color:var(--txt);min-width:0;overflow-wrap:anywhere}
  .starbtn{flex:none;background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);
    white-space:nowrap;transition:.15s}
  .starbtn.on{background:var(--acc);color:#000;border-color:var(--acc)}
  .starbtn:active{transform:scale(.96)}
  label.lbl{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--dim);
    margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;font-weight:700;font-family:var(--mono)}
  .chips{display:flex;flex-wrap:wrap;gap:7px}
  .chip{font-size:12.5px;background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    padding:6px 11px;border-radius:20px;cursor:pointer;font-family:var(--mono);display:flex;align-items:center;gap:6px}
  .chip:hover{border-color:var(--acc);color:var(--txt)}
  .chip.fav{border-color:rgba(245,197,66,.4)}
  .chip .x{opacity:.5;font-weight:700}
  .chip .x:hover{opacity:1;color:var(--acc)}
  .empty{font-size:12px;color:var(--dim);font-family:var(--mono);padding:2px}
  .hint{font-size:12px;color:var(--dim);font-family:var(--mono);line-height:1.5}
  .bcount{font-size:10px;color:var(--dim);font-family:var(--mono);font-weight:600;line-height:1}
  .toolbar{display:flex;gap:10px;margin-bottom:14px;justify-content:flex-end;margin-top:-6px}
  select{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    padding:11px 12px;border-radius:11px;font-size:14px;outline:none;font-family:var(--font)}
  /* компактный выбор города — пилюля 📍 [Город ▾], не на всю ширину */
  .city-pick{display:inline-flex;align-items:center;gap:4px;background:var(--panel2);
    border:1px solid var(--line);border-radius:11px;padding:0 6px 0 11px;cursor:pointer;
    transition:.15s;max-width:100%}
  .city-pick:focus-within{border-color:var(--acc);box-shadow:0 0 0 4px rgba(255,90,31,.08)}
  .city-pick .city-ic{font-size:14px;flex:none;line-height:1}
  .city-pick select{flex:0 1 auto;width:auto;max-width:170px;background:none;border:none;
    padding:10px 4px;border-radius:0;font-weight:700;cursor:pointer;text-overflow:ellipsis;
    field-sizing:content}
  .city-pick select:focus{box-shadow:none}
  /* приветствие по времени суток + дата (только на главном экране) */
  .greet{margin-bottom:16px;animation:greetIn .35s ease both}
  .greet b{display:block;font-size:18px;font-weight:800;letter-spacing:-.3px;color:var(--txt);line-height:1.15}
  .greet span{font-size:12px;color:var(--dim);font-family:var(--mono);text-transform:capitalize}
  @keyframes greetIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion: reduce){ .greet{animation:none} }
  /* живой статус смены на карточке вечернего отчёта */
  .rep-card-status{margin-top:11px;padding-top:11px;border-top:1px solid var(--line);
    font-size:12.5px;font-family:var(--mono);color:var(--dim);display:flex;align-items:center;gap:7px}
  .rep-card-status.live{color:var(--acc2);font-weight:700}
  .rep-card-status.done{color:var(--txt)}
  .rcs-dot{width:8px;height:8px;border-radius:50%;background:var(--acc2);flex:none;
    animation:rcsPulse 1.8s ease-in-out infinite}
  @keyframes rcsPulse{0%{box-shadow:0 0 0 0 rgba(34,211,166,.45)}
    70%{box-shadow:0 0 0 7px rgba(34,211,166,0)}100%{box-shadow:0 0 0 0 rgba(34,211,166,0)}}
  @media (prefers-reduced-motion: reduce){ .rcs-dot{animation:none} }
  .collapse-ind{font-family:var(--mono);font-size:11px;color:var(--dim);font-weight:600}
  footer{text-align:center;color:var(--dim);font-size:11.5px;margin-top:18px;line-height:1.6;font-family:var(--mono)}
  .calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .calc-lbl{font-size:11px;color:var(--dim);margin-bottom:5px;font-family:var(--mono)}
  .calc-out{margin-top:14px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px;
    display:none}
  .calc-out.show{display:block}
  .calc-row{display:flex;justify-content:space-between;align-items:baseline;padding:5px 0;font-size:14px}
  .calc-row.total{border-top:1px solid var(--line);margin-top:6px;padding-top:10px;font-size:17px;font-weight:800}
  .calc-row .v{font-family:var(--mono);font-weight:700}
  .calc-row.profit .v{color:var(--acc2)}
  .calc-row.total .v{color:var(--acc)}

  /* ряды ввода движений и запчастей в отчёте */
  .rep-rows{display:flex;flex-direction:column;gap:8px}
  .rep-row{display:flex;gap:8px;align-items:stretch}
  .rep-row .rep-sign{flex:0 0 42px;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    border-radius:11px;font-size:18px;font-weight:800;cursor:pointer;font-family:var(--mono);padding:0}
  .rep-row .rep-sign.minus{color:var(--neg)}
  .rep-row .rep-sign.plus{color:var(--acc2)}
  .rep-row .rep-sum{flex:0 0 96px;margin-bottom:0}
  .rep-row .rep-txt{flex:1;margin-bottom:0}
  .rep-row .rep-del{flex:0 0 38px;background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    border-radius:11px;font-size:15px;cursor:pointer;padding:0}
  .rep-add{margin-top:8px;background:var(--panel2);border:1px dashed var(--line);color:var(--dim);
    border-radius:11px;padding:9px 14px;font-size:13px;cursor:pointer;font-family:var(--font);width:100%}
  .rep-add:hover{border-color:var(--acc);color:var(--txt)}

  /* модалка ручного ввода + синонимов */
  .sheet{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:flex-end;z-index:50}
  .sheet.show{display:flex}
  .sheet-inner{background:var(--panel);border:1px solid var(--line);border-radius:18px 18px 0 0;
    width:100%;max-width:680px;margin:0 auto;padding:18px 16px;animation:up .22s cubic-bezier(.22,.61,.36,1);
    max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding-bottom:calc(26px + env(safe-area-inset-bottom,0px));position:relative;
    box-shadow:0 -8px 40px rgba(0,0,0,.35)}
  .sheet-inner::before{content:'';display:block;width:38px;height:4px;border-radius:3px;
    background:var(--line);margin:0 auto 14px}
  @keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}

  /* отчёт по кассе (sheet) — на весь экран */
  #reportSheet{align-items:stretch}
  #reportSheet .sheet-inner{max-width:760px;height:100%;max-height:100%;border-radius:0;
    padding-top:calc(14px + env(safe-area-inset-top,0px));animation:fade .2s ease}
  #reportSheet .sheet-inner::before{display:none}
  @keyframes fade{from{opacity:.4}to{opacity:1}}
  #reportSheet>.sheet-inner>.lbl:first-child{position:sticky;top:0;z-index:3;
    background:var(--panel);margin:0 -16px 14px;padding:4px 16px 12px;
    border-bottom:1px solid var(--line);font-size:16px}

  /* ====== ЖУРНАЛ — страница (не sheet-оверлей) ====== */
  #journalSheet{
    display:none;position:fixed;top:0;left:0;right:0;
    bottom:calc(58px + env(safe-area-inset-bottom,0px));
    z-index:10;background:var(--bg);overflow:hidden}
  #journalSheet.page-active{display:block;animation:fade .18s ease}
  .jrn-page-inner{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;
    max-width:760px;margin:0 auto;padding:16px 16px calc(20px + env(safe-area-inset-bottom,0px));
    padding-top:calc(14px + env(safe-area-inset-top,0px));
    overscroll-behavior-y:contain}
  #journalTabs{display:none}   /* заменены нижним тулбаром */

  /* ====== НИЖНИЙ ТУЛБАР (мобайл) / ЛЕВЫЙ САЙДБАР (десктоп) ====== */
  #appNav{
    position:fixed;bottom:0;left:0;right:0;
    height:calc(58px + env(safe-area-inset-bottom,0px));
    display:flex;align-items:stretch;
    background:var(--panel2);border-top:1px solid var(--line);
    z-index:60;padding-bottom:env(safe-area-inset-bottom,0px);
    /* iOS Safari: выносим на отдельный GPU-слой — иначе fixed-элемент
       мерцает/исчезает при прокрутке и анимации viewport */
    -webkit-transform:translateZ(0);transform:translateZ(0);
    will-change:transform}
  .nav-brand{display:none}
  .nav-btn{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;background:none;border:none;cursor:pointer;color:var(--dim);
    font-family:var(--font);padding:6px 4px;transition:color .15s;position:relative}
  /* ::after оставлен (на десктопе переопределяется в фон активной кнопки);
     на мобайле статический подчёрк не показываем — его заменяет скользящий .nav-ind */
  .nav-btn::after{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;
    border-radius:2px;background:var(--acc);transform:scaleX(0);transition:transform .2s}
  .nav-btn.active{color:var(--acc)}
  .nav-ico{font-size:21px;line-height:1;transition:transform .15s}
  .nav-btn.active .nav-ico{transform:translateY(-1px)}
  .nav-lbl{font-size:10px;font-weight:700;line-height:1;letter-spacing:.2px}
  /* не закреплённые в тулбаре разделы прячем (мобайл). ДО @media, чтобы десктопный
     сайдбар мог их вернуть — там места хватает (см. memory: каскад display) */
  .nav-btn.nav-off{display:none}
  /* подсказка, что у «Главная» есть меню по долгому нажатию */
  .nav-btn.has-menu .nav-lbl::after{content:'⋯';margin-left:3px;opacity:.55;font-weight:900}

  /* ---- меню по долгому нажатию на «Главная» ---- */
  .nav-menu[hidden]{display:none}
  .nav-menu{position:fixed;inset:0;z-index:80}
  .nav-menu-back{position:absolute;inset:0;background:rgba(0,0,0,.35)}
  .nav-menu-pop{position:absolute;left:8px;
    bottom:calc(60px + env(safe-area-inset-bottom,0px));
    min-width:190px;background:var(--panel);border:1px solid var(--line);
    border-radius:14px;padding:6px;display:flex;flex-direction:column;gap:2px;
    box-shadow:0 12px 34px rgba(0,0,0,.45);animation:paneIn .16s ease}
  .nav-menu-item{display:flex;align-items:center;gap:11px;padding:12px 14px;
    border-radius:10px;background:none;border:none;color:var(--txt);
    font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;text-align:left}
  .nav-menu-item:active{background:var(--panel2)}
  .nav-menu-ico{font-size:18px;line-height:1}

  /* ---- настройка тулбара в профиле ---- */
  .prof-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
  .prof-tbtn{display:flex;align-items:center;gap:7px;padding:9px 13px;border-radius:11px;
    background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s}
  .prof-tbtn.on{background:var(--acc);border-color:var(--acc);color:#000}
  .prof-tbtn:active{transform:scale(.96)}

  #navUser{display:none}
  /* ====== ДЕСКТОП: левый сайдбар ====== */
  @media(min-width:900px){
    #appNav{
      position:fixed;top:0;left:0;bottom:0;right:auto;
      width:220px;height:auto;flex-direction:column;align-items:stretch;
      border-top:none;border-right:1px solid var(--line);
      padding-bottom:0;overflow:visible;gap:2px}
    .nav-brand{
      display:flex;align-items:center;gap:8px;
      padding:18px 12px 14px;border-bottom:1px solid var(--line);margin-bottom:6px;flex:none}
    .nav-logo{width:32px;height:32px;border-radius:8px;object-fit:contain;flex:none}
    .nav-title{font-size:13px;font-weight:800;line-height:1.2;color:var(--txt);
      flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .nav-btn{
      flex:none;flex-direction:row;align-items:center;justify-content:flex-start;
      gap:11px;padding:12px 16px;border-radius:10px;margin:0 8px;width:auto}
    .nav-btn.nav-off{display:flex}     /* в сайдбаре места хватает — показываем все разделы */
    .nav-btn.has-menu .nav-lbl::after{content:''}   /* на ПК подсказка-меню не нужна */
    .nav-btn::after{top:auto;bottom:0;left:0;right:0;height:100%;border-radius:10px;
      background:rgba(255,90,31,.1);z-index:-1}
    .nav-btn.active{color:var(--acc);background:rgba(255,90,31,.1)}
    .nav-btn.active::after{display:none}
    .nav-ind{display:none}   /* на десктопе индикатор — фон активной кнопки, скользящая полоса не нужна */
    .nav-ico{font-size:19px}
    .nav-lbl{font-size:13.5px;letter-spacing:0}
    .wrap{margin-left:220px;margin-right:auto;
      padding-bottom:32px;padding-top:24px}
    .wrap.page-hidden{display:none!important}
    #journalSheet{left:220px;bottom:0}
    #journalSheet.page-active{display:block}
    /* журнал во всю ширину на десктопе */
    .jrn-page-inner{max-width:none}
    /* баннер обновления — на ПК нет нижней панели, возвращаем нормальный отступ */
    #updBanner{bottom:calc(12px + env(safe-area-inset-bottom,0px))}
    /* вернуть toTop / toast в нормальное положение над нижней панелью (её нет на ПК) */
    #toTop{bottom:20px;right:20px}
    #toast{bottom:24px}
    /* кнопка свернуть/развернуть боковую панель — в шапке рядом с логотипом */
    #navToggle{
      display:flex;align-items:center;justify-content:center;
      flex:none;margin-left:auto;width:28px;height:28px;
      background:none;border:1px solid var(--line);color:var(--dim);
      border-radius:9px;cursor:pointer;
      font-size:16px;font-family:var(--mono);font-weight:800;line-height:1;
      transition:color .15s,border-color .15s}
    #navToggle:hover{color:var(--acc);border-color:var(--acc)}
    /* плавные переходы ширины панели */
    #appNav{transition:width .22s ease}
    .wrap{transition:margin-left .22s ease}
    #journalSheet{transition:left .22s ease}
    /* свёрнутое состояние */
    body.nav-col #appNav{width:64px}
    body.nav-col .nav-title{display:none}
    body.nav-col .nav-brand{flex-direction:column;justify-content:center;padding:14px 0 12px;gap:10px}
    body.nav-col .nav-lbl{display:none}
    body.nav-col .nav-btn{justify-content:center;padding:12px 0;gap:0;margin:0 4px}
    body.nav-col #navToggle{margin:0}
    body.nav-col .wrap{margin-left:64px}
    body.nav-col #journalSheet{left:64px}
    /* профиль — только мобайл, на десктопе есть виджет */
    .nav-profile-btn{display:none}
    /* виджет пользователя — снизу сайдбара */
    #navUser{display:flex;align-items:center;gap:10px;margin:auto 8px 4px;
      padding:10px 12px;border-radius:10px;border:1px solid var(--line);min-width:0;
      position:relative}
    .nav-ava{width:34px;height:34px;border-radius:50%;background:var(--acc);color:#fff;
      font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;
      flex-shrink:0;overflow:hidden;position:relative;user-select:none}
    .nav-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
    .nav-ava-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;
      background:var(--dim);border:2px solid var(--panel2);transition:background .3s}
    .nav-ava-dot.on{background:var(--acc2)}
    .nav-user-txt{flex:1;min-width:0;overflow:hidden}
    .nav-uname{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;
      text-overflow:ellipsis;color:var(--txt)}
    .nav-ustatus{display:flex;align-items:center;gap:5px;margin-top:2px}
    .nav-udot{width:7px;height:7px;border-radius:50%;background:var(--dim);
      flex-shrink:0;transition:background .3s}
    .nav-udot.on{background:var(--acc2)}
    .nav-ustate{font-size:11px;color:var(--dim);font-family:var(--mono);transition:color .3s}
    .nav-ustate.on{color:var(--acc2)}
    body.nav-col #navUser{padding:8px 0;justify-content:center;
      margin:auto 4px 4px;border:none;background:none}
    body.nav-col .nav-user-txt{display:none}
    /* popup-меню у виджета пользователя */
    #navUserPop{position:absolute;bottom:calc(100% + 6px);left:8px;right:8px;
      background:var(--panel);border:1px solid var(--line);border-radius:12px;
      padding:5px;display:none;flex-direction:column;gap:3px;box-shadow:var(--sh2);z-index:70}
    #navUser:hover #navUserPop{display:flex}
    body.nav-col #navUserPop{left:0;right:auto;min-width:190px}
    #navUserPop button{width:100%;text-align:left;background:none;border:none;
      color:var(--txt);font-family:var(--font);font-size:13px;font-weight:600;
      padding:9px 11px;border-radius:8px;cursor:pointer;transition:background .13s}
    #navUserPop button:hover{background:var(--panel2)}
    #navUserPop #navUserOut{color:var(--neg)}
    body.nav-col #navUserPop button span{display:none}
  }

  /* кнопка «Закрыть смену» */
  .rep-save{width:100%;background:linear-gradient(135deg,var(--acc),#ff8a3d);color:#000;border:none;
    border-radius:12px;padding:13px;font-size:14.5px;font-weight:800;cursor:pointer;font-family:var(--font)}
  .rep-save:active{transform:scale(.99)}
  .rep-save:disabled{opacity:.55;cursor:default}

  /* ===== ЖУРНАЛ СМЕН ===== */
  .auth-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
    background:#fff;color:#1f1f1f;border:1px solid var(--line);border-radius:12px;padding:12px;
    font-size:14.5px;font-weight:700;cursor:pointer;font-family:var(--font)}
  .auth-google svg{flex:none}
  .auth-google:active{transform:scale(.99)}
  .auth-google:disabled{opacity:.6;cursor:default}
  .auth-div{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--dim);
    font-size:12px;font-family:var(--mono)}
  .auth-div::before,.auth-div::after{content:'';flex:1;height:1px;background:var(--line)}
  .auth-err{color:var(--neg);font-size:13px;min-height:18px;margin:8px 0 2px;font-weight:600}
  .auth-btns{display:flex;gap:10px;margin-top:12px}
  .auth-btns>button{flex:1}
  .jrn-user{display:flex;align-items:center;justify-content:space-between;gap:10px;
    background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:11px 14px;margin-bottom:14px}
  .jrn-uinfo{flex:1;min-width:0}
  .jrn-uname{font-size:14.5px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .jrn-umail{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:1px;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .jrn-uacts{display:flex;gap:8px;flex:none}
  .jrn-user button{flex:none;background:none;border:1px solid var(--line);color:var(--dim);
    border-radius:9px;padding:6px 12px;font-size:13px;cursor:pointer;font-family:var(--font)}
  #authEditNick{padding:6px 11px;font-size:15px;line-height:1}
  .jrn-user button:active{transform:scale(.96)}

  /* ---- вкладки журнала ---- */
  .jrn-tabs{display:flex;gap:6px;background:var(--panel2);border:1px solid var(--line);
    border-radius:13px;padding:5px;margin-bottom:16px}
  .jrn-tab{flex:1;background:none;border:none;color:var(--dim);border-radius:9px;
    padding:9px 6px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:var(--font);
    transition:background .15s,color .15s}
  .jrn-tab.active{background:var(--acc);color:#000;box-shadow:0 2px 8px rgba(255,90,31,.3)}
  .jrn-tab:not(.active):active{background:var(--panel)}
  .jrn-pane{display:none;animation:paneIn .22s ease}
  .jrn-pane.active{display:block}
  @keyframes paneIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

  /* ── анимация перехода между страницами по вкладкам (только мобайл) ──
     На ПК сайдбар постоянный, резкая смена не мешает; на телефоне — плавный заезд. */
  @keyframes pageSlide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
  @media (max-width:999px){
    /* журнал (Смена/Статистика/История/Чат/Профиль): переопределяем тусклый fade на заезд */
    #journalSheet.page-active{animation:pageSlide .26s cubic-bezier(.22,.61,.36,1) both}
    /* возврат на «Главную»: класс .page-enter навешивается из navigateTo с reflow */
    .wrap.page-enter{animation:pageSlide .26s cubic-bezier(.22,.61,.36,1) both}
  }
  @media (prefers-reduced-motion:reduce){
    #journalSheet.page-active,.wrap.page-enter{animation:none}
  }

  /* ---- чат мастеров ---- */
  /* когда открыт чат — вся цепочка контейнеров растягивается на весь экран */
  #journalSheet.is-chat .jrn-page-inner{
    display:flex;flex-direction:column;overflow:hidden;
    padding-bottom:env(safe-area-inset-bottom,0px)}
  #journalSheet.is-chat #journalBox{flex:1;min-height:0;display:flex;flex-direction:column}
  #paneChat.active{display:flex;flex-direction:column;flex:1;min-height:0}
  .chat-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;
    padding:4px 2px;overscroll-behavior-y:contain}
  .chat-empty{color:var(--dim);text-align:center;padding:24px 8px;font-size:13px}
  .chat-msg{max-width:82%;align-self:flex-start;background:var(--panel2);
    border:1px solid var(--line);border-radius:13px;padding:7px 11px}
  .chat-msg.mine{align-self:flex-end;background:var(--acc);border-color:var(--acc);color:#000}
  .chat-head{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-bottom:2px}
  .chat-name{font-size:12.5px;font-weight:800}
  .chat-svc{font-size:11.5px;font-weight:700;color:var(--acc2)}
  .chat-msg.mine .chat-svc{color:#5a1a00}
  .chat-time{font-size:10.5px;color:var(--dim);font-family:var(--mono);margin-left:auto}
  .chat-msg.mine .chat-time{color:rgba(0,0,0,.5)}
  .chat-text{font-size:14px;line-height:1.35;white-space:pre-wrap;word-break:break-word}
  /* цитата (ответ на сообщение) внутри пузыря */
  .chat-quote{display:block;width:100%;text-align:left;cursor:pointer;
    background:var(--press);border:none;border-left:3px solid var(--acc);
    border-radius:7px;padding:5px 9px;margin-bottom:5px;font-family:var(--font)}
  .chat-quote-name{display:block;font-size:11.5px;font-weight:800;color:var(--acc)}
  .chat-quote-text{display:block;font-size:12.5px;color:var(--dim);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .chat-msg.mine .chat-quote{background:rgba(0,0,0,.1);border-left-color:#5a1a00}
  .chat-msg.mine .chat-quote-name{color:#5a1a00}
  .chat-msg.mine .chat-quote-text{color:rgba(0,0,0,.6)}
  /* подсветка при переходе к исходному сообщению */
  @keyframes chatFlash{0%,100%{box-shadow:0 0 0 0 transparent}
    25%{box-shadow:0 0 0 3px rgba(255,90,31,.55)}}
  .chat-flash{animation:chatFlash 1.1s ease}
  @media(prefers-reduced-motion:reduce){.chat-flash{animation:none}}
  /* панель «ответ на …» над полем ввода */
  .chat-reply-bar{display:flex;align-items:center;gap:9px;flex-shrink:0;
    background:var(--panel2);border:1px solid var(--line);border-left:3px solid var(--acc);
    border-radius:10px;padding:7px 10px;margin-bottom:6px}
  .chat-reply-bar[hidden]{display:none}
  .chat-reply-ic{font-size:15px;color:var(--acc);flex:none}
  .chat-reply-body{min-width:0;flex:1}
  .chat-reply-name{font-size:12px;font-weight:800;color:var(--acc)}
  .chat-reply-text{font-size:12.5px;color:var(--dim);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .chat-reply-x{flex:none;background:none;border:none;color:var(--dim);
    font-size:15px;cursor:pointer;padding:2px 4px;line-height:1}
  .chat-reply-x:active{transform:scale(.9)}
  .chat-input{display:flex;gap:8px;align-items:center;
    background:var(--bg);padding:10px 0 4px;flex-shrink:0}
  .chat-input .filter{flex:1;margin:0}
  .chat-attach{cursor:pointer;font-size:20px;flex:0 0 auto;
    width:44px;height:44px;display:flex;align-items:center;justify-content:center;
    border-radius:12px;background:var(--panel2);border:1px solid var(--line);
    user-select:none;transition:transform .15s}
  .chat-attach:active{transform:scale(.9)}
  .chat-img{max-width:260px;max-height:280px;border-radius:10px;
    margin-top:5px;display:block;cursor:pointer;object-fit:cover}
  .chat-upload-progress{font-size:12px;color:var(--dim);margin-top:3px}
  #chatSend{flex:0 0 auto;width:44px;height:44px;border:none;border-radius:12px;
    background:var(--acc);color:#000;font-size:18px;font-weight:800;cursor:pointer;
    display:flex;align-items:center;justify-content:center;font-family:var(--font)}
  #chatSend:active{transform:scale(.94)}

  /* бейдж непрочитанных на иконке чата */
  .chat-badge{position:absolute;top:1px;right:1px;min-width:16px;height:16px;
    border-radius:8px;background:#e53935;color:#fff;font-size:10px;font-weight:800;
    display:flex;align-items:center;justify-content:center;padding:0 3px;
    font-family:var(--mono);pointer-events:none;line-height:1;z-index:2}
  /* «X печатает…» */
  .chat-typing{font-size:12px;color:var(--dim);font-style:italic;
    padding:2px 4px 4px;min-height:18px;display:none;animation:paneIn .2s ease}
  /* реакции */
  .chat-reacts{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px;align-items:center}
  .chat-react{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;
    border-radius:20px;background:var(--panel);border:1px solid var(--line);
    font-size:13px;cursor:pointer;transition:all .12s;font-family:var(--font)}
  .chat-react:active{transform:scale(.92)}
  .chat-react.active{background:rgba(255,90,31,.18);border-color:var(--acc)}
  .chat-msg.mine .chat-react{background:rgba(0,0,0,.15);border-color:rgba(0,0,0,.2)}
  .chat-msg.mine .chat-react.active{background:rgba(0,0,0,.3);border-color:rgba(0,0,0,.4)}
  .chat-react span{font-size:11px;font-weight:700;color:var(--dim)}
  .chat-react-add{display:flex;gap:3px}
  .chat-react-opt{background:none;border:1px dashed var(--line);border-radius:20px;
    font-size:13px;padding:3px 6px;cursor:pointer;opacity:.45;
    transition:opacity .12s;line-height:1}
  .chat-react-opt:hover,.chat-react-opt:active{opacity:1}
  /* действия с сообщением (редактировать / удалить) */
  .chat-msg-acts{display:flex;gap:6px;margin-top:5px;justify-content:flex-end}
  .chat-msg-act{background:none;border:none;font-size:11.5px;color:var(--dim);
    cursor:pointer;padding:2px 7px;border-radius:6px;font-family:var(--font);
    transition:background .12s}
  .chat-msg-act:hover{background:var(--panel2)}
  .chat-msg.mine .chat-msg-act{color:rgba(0,0,0,.5)}
  .chat-msg.mine .chat-msg-act:hover{background:rgba(0,0,0,.12)}
  /* «изменено» + редактирование */
  .chat-edited{font-size:10px;color:var(--dim);margin-top:2px;font-style:italic}
  .chat-msg.mine .chat-edited{color:rgba(0,0,0,.4)}
  .chat-editing{outline:2px solid var(--acc);outline-offset:1px}
  /* удалённые */
  .chat-deleted .chat-text{color:var(--dim);font-style:italic;font-size:13px}

  /* ---- контекстное меню чата (ПКМ / долгое нажатие) ---- */
  .chat-ctx-menu[hidden]{display:none}
  .chat-ctx-menu{
    position:fixed;z-index:9998;
    background:var(--panel);border:1px solid var(--line);border-radius:16px;
    box-shadow:0 8px 32px rgba(0,0,0,.35);
    padding:10px;min-width:200px;
    animation:ctxPop .14s cubic-bezier(.22,.61,.36,1)}
  @keyframes ctxPop{
    from{opacity:0;transform:scale(.88)}
    to{opacity:1;transform:scale(1)}}
  .chat-ctx-reacts{display:flex;gap:2px;justify-content:space-around;padding:2px 0 4px}
  .chat-ctx-emoji{
    background:none;border:2px solid transparent;border-radius:50%;
    font-size:24px;width:44px;height:44px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:background .12s,border-color .12s;line-height:1}
  .chat-ctx-emoji:hover{background:var(--panel2)}
  .chat-ctx-emoji:active{transform:scale(.88)}
  .chat-ctx-emoji.active{border-color:var(--acc);background:rgba(255,90,31,.12)}
  .chat-ctx-sep{height:1px;background:var(--line);margin:6px 0}
  .chat-ctx-act{
    display:flex;width:100%;align-items:center;gap:9px;
    background:none;border:none;border-radius:10px;
    padding:11px 12px;font-size:14.5px;font-weight:600;
    color:var(--txt);cursor:pointer;font-family:var(--font);
    transition:background .12s;text-align:left}
  .chat-ctx-act:hover{background:var(--panel2)}
  .chat-ctx-act:active{background:var(--press)}
  .chat-ctx-del{color:var(--neg)}

  .jrn-note{font-size:11px;color:var(--dim);font-weight:500;font-family:var(--mono)}

  /* ---- выбор периода ---- */
  .jrn-period{display:flex;gap:6px;background:var(--panel2);border:1px solid var(--line);
    border-radius:11px;padding:4px;margin-bottom:14px}
  .jrn-period button{flex:1;background:none;border:none;color:var(--dim);border-radius:8px;
    padding:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font)}
  .jrn-period button.active{background:var(--acc);color:#000}

  /* ---- фильтры статистики ---- */
  .stats-filters{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
  .st-frow{display:flex;gap:7px;flex-wrap:wrap}
  .st-chip{background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:700;cursor:pointer;
    font-family:var(--font);transition:all .14s}
  .st-chip:active{transform:scale(.96)}
  .st-chip.on{background:rgba(255,90,31,.14);border-color:var(--acc);color:var(--txt)}

  /* ---- заголовок секции статистики ---- */
  .st-sec{font-size:13px;font-weight:800;color:var(--txt);margin:22px 0 10px;
    display:flex;align-items:center;gap:7px}
  .st-sec:first-child{margin-top:0}

  /* ---- KPI с трендом ---- */
  .st-kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .st-kpi{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:13px 15px;position:relative}
  .st-kpi.accent{grid-column:1/-1;background:linear-gradient(135deg,rgba(255,90,31,.14),rgba(255,138,61,.05));
    border-color:rgba(255,90,31,.4)}
  .st-kpi-l{display:block;font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-bottom:5px}
  .st-kpi-v{font-size:19px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
  .st-kpi.accent .st-kpi-v{color:var(--acc);font-size:26px}
  .st-kpi.neg .st-kpi-v{color:var(--neg)}
  .st-trend{position:absolute;top:13px;right:14px;font-size:11.5px;font-weight:800;font-family:var(--mono);
    padding:2px 7px;border-radius:7px}
  .st-trend.up{color:var(--acc2);background:rgba(34,211,166,.12)}
  .st-trend.down{color:var(--neg);background:rgba(255,107,107,.12)}
  .st-note{font-size:11px;color:var(--dim);font-family:var(--mono);margin-top:8px;text-align:center}

  /* ---- график динамики ---- */
  .st-chart{display:flex;align-items:flex-end;gap:4px;height:140px;
    background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:14px 12px 8px}
  .st-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;min-width:0}
  .st-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}
  .st-bar{width:72%;max-width:34px;min-height:2px;border-radius:5px 5px 2px 2px;
    background:linear-gradient(180deg,var(--acc),#ff8a3d);transition:height .35s ease}
  .st-bar.neg{background:var(--neg)}
  .st-xl{font-size:10px;color:var(--dim);font-family:var(--mono);white-space:nowrap;
    overflow:hidden;text-overflow:ellipsis;max-width:100%}

  /* ---- ключевые метрики ---- */
  .st-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .st-mtile{background:var(--panel2);border:1px solid var(--line);border-radius:13px;padding:12px 14px}
  .st-mtile span{display:block;font-size:11px;color:var(--dim);font-family:var(--mono);margin-bottom:4px}
  .st-mtile b{font-size:17px;font-weight:800;font-variant-numeric:tabular-nums}

  /* ---- структура затрат ---- */
  .st-stack{display:flex;height:16px;border-radius:8px;overflow:hidden;background:var(--line)}
  .st-stack .seg{height:100%}
  .st-stack .seg-parts{background:var(--acc)}
  .st-stack .seg-konf{background:var(--acc2)}
  .st-stack .seg-pct{background:var(--warn)}
  .st-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:12px;color:var(--dim)}
  .st-legend span{display:flex;align-items:center;gap:6px}
  .st-legend i{width:10px;height:10px;border-radius:3px;flex:none}
  .st-legend .dot-parts{background:var(--acc)}
  .st-legend .dot-konf{background:var(--acc2)}
  .st-legend .dot-pct{background:var(--warn)}

  /* ---- рекорды ---- */
  .st-records{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .st-rec{background:var(--panel2);border:1px solid var(--line);border-radius:13px;padding:12px 14px}
  .st-rec span{display:block;font-size:11px;color:var(--dim);font-family:var(--mono);margin-bottom:4px}
  .st-rec b{display:block;font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .st-rec em{font-style:normal;font-size:15px;font-weight:800;color:var(--acc);font-variant-numeric:tabular-nums}

  /* ---- кнопка «поделиться» ---- */
  .st-share{width:100%;margin-top:22px;background:var(--panel2);border:1px solid var(--line);
    color:var(--txt);border-radius:12px;padding:13px;font-size:14px;font-weight:700;cursor:pointer;
    font-family:var(--font);transition:all .14s}
  .st-share:hover{border-color:var(--acc);color:var(--acc)}
  .st-share:active{transform:scale(.99)}

  /* ---- шапка итогов ---- */
  .jrn-hero{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .jrn-htile{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:13px 15px}
  .jrn-htile span{display:block;font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-bottom:5px}
  .jrn-htile b{font-size:19px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
  .jrn-htile.profit{grid-column:1/-1;background:linear-gradient(135deg,rgba(255,90,31,.14),rgba(255,138,61,.06));
    border-color:rgba(255,90,31,.4)}
  .jrn-htile.profit b{color:var(--acc);font-size:26px}
  .jrn-htile b.neg{color:var(--neg)}

  /* ---- карточки по сервисам ---- */
  .jrn-stats{display:flex;flex-direction:column;gap:10px}
  .jrn-scard{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:13px 15px}
  /* в #statsBody карточки идут плоским списком (без flex-gap контейнера) —
     задаём отступ между карточками и между секциями вручную */
  #statsBody .jrn-scard,#statsBody .jrn-rcard{margin-bottom:10px}
  #statsBody .st-sec{margin-top:30px}
  #statsBody .st-sec:first-child{margin-top:0}
  .jrn-srow{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}
  .jrn-sname{font-size:14.5px;font-weight:800}
  .jrn-scount{font-size:11.5px;color:var(--dim);font-family:var(--mono);flex:none}
  .jrn-smetrics{display:flex;justify-content:space-between;gap:8px;margin-top:11px}
  .jrn-smetrics div{display:flex;flex-direction:column;gap:2px}
  .jrn-smetrics span{font-size:10.5px;color:var(--dim);font-family:var(--mono)}
  .jrn-smetrics b{font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}
  .jrn-smetrics b.neg{color:var(--neg)}

  /* ---- индикатор-полоска ---- */
  .jrn-bar{height:7px;background:var(--line);border-radius:5px;overflow:hidden}
  .jrn-bar span{display:block;height:100%;border-radius:5px;
    background:linear-gradient(90deg,var(--acc),#ff8a3d);transition:width .4s ease}

  /* ---- рейтинг сотрудников ---- */
  .jrn-rank{display:flex;flex-direction:column;gap:10px}
  .jrn-rcard{display:flex;align-items:center;gap:12px;background:var(--panel2);
    border:1px solid var(--line);border-radius:14px;padding:12px 14px}
  .jrn-rcard.top{border-color:rgba(255,90,31,.35)}
  .jrn-rno{font-size:22px;flex:none;width:34px;text-align:center;font-weight:800;color:var(--dim);font-family:var(--mono)}
  .jrn-rcard.top .jrn-rno{font-size:24px}
  .jrn-rmain{flex:1;min-width:0}
  .jrn-rtop{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:8px}
  .jrn-rname{font-size:14.5px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .jrn-rinc{font-size:15px;font-weight:800;color:var(--acc);font-variant-numeric:tabular-nums;flex:none}
  .jrn-rsub{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:7px}

  .jrn-totals{display:flex;gap:10px;flex-wrap:wrap}
  .jrn-tcard{flex:1;min-width:150px;background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
  .jrn-tttl{font-size:12px;font-weight:800;color:var(--acc);margin-bottom:8px;letter-spacing:.3px}
  .jrn-tttl span{color:var(--dim);font-weight:500;font-family:var(--mono);font-size:11px}
  .jrn-trow{display:flex;justify-content:space-between;gap:8px;font-size:13.5px;padding:3px 0}
  .jrn-trow b{font-variant-numeric:tabular-nums}
  .jrn-trow .neg{color:var(--neg)}
  .jrn-trow.profit{margin-top:4px;padding-top:7px;border-top:1px solid var(--line);font-weight:800}
  .jrn-trow.profit b{color:var(--acc);font-size:15px}
  /* ── Админ-обзор сервисов ── */
  .adm-title{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--dim);
    font-weight:700;font-family:var(--mono);margin-bottom:10px}
  .adm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
  .adm-card{background:var(--panel2);border:1px solid var(--line);border-radius:14px;
    padding:12px 12px 11px 16px;position:relative;min-width:0;overflow:hidden;
    transition:border-color .15s}
  .adm-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--line)}
  .adm-card.is-open{border-color:rgba(13,155,118,.4)}
  .adm-card.is-open::before{background:var(--acc2)}
  .adm-card.is-closed::before{background:var(--neg)}
  .adm-svc{font-size:14px;font-weight:800;margin-bottom:4px;padding-right:30px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .adm-status{font-size:11.5px;font-family:var(--mono);color:var(--dim)}
  .adm-status.open{color:var(--acc2);font-weight:700}
  .adm-status.closed{color:var(--neg)}
  .adm-who{font-size:11px;color:var(--dim);font-family:var(--mono);margin-top:5px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .adm-reset{position:absolute;top:8px;right:8px;background:none;border:1px solid var(--line);
    color:var(--dim);border-radius:7px;padding:3px 7px;font-size:15px;cursor:pointer;
    line-height:1;transition:color .13s,border-color .13s}
  .adm-reset:hover{color:var(--acc);border-color:var(--acc)}
  .adm-reset:active{transform:scale(.93)}

  /* ── страница «Админ» (Фаза 1) ── */
  .adm-sec{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:800;color:var(--txt);
    margin:20px 0 11px}
  .adm-sec:first-child{margin-top:2px}
  .adm-mini-btn{margin-left:auto;background:var(--panel2);border:1px solid var(--line);
    color:var(--txt);border-radius:9px;padding:6px 11px;font-size:12px;font-weight:700;
    cursor:pointer;font-family:var(--font)}
  .adm-mini-btn:active{transform:scale(.96)}
  .adm-period{display:flex;gap:6px;margin-bottom:12px}
  .adm-period button{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--dim);
    border-radius:10px;padding:8px 0;font-size:12.5px;font-weight:700;cursor:pointer;font-family:var(--font)}
  .adm-period button.active{background:var(--acc);color:#000;border-color:var(--acc)}
  .adm-kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:4px}
  .adm-kpi{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
  .adm-kpi span{display:block;font-size:11px;color:var(--dim);font-family:var(--mono);margin-bottom:4px}
  .adm-kpi b{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums}
  .adm-kpi b.acc{color:var(--acc)}
  .adm-kpi b.neg{color:var(--neg)}
  .adm-srow{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);
    border-radius:12px;padding:10px 12px;margin-bottom:8px}
  .adm-srow-main{flex:1;min-width:0}
  .adm-srow-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
  .adm-srow-top b{font-size:14px;font-weight:800}
  .adm-srow-inc{font-size:14px;font-weight:800;color:var(--acc);font-variant-numeric:tabular-nums;flex:none}
  .adm-srow-sub{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:3px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .adm-srow-acts{display:flex;gap:6px;flex:none}
  .adm-ic{background:none;border:1px solid var(--line);color:var(--dim);border-radius:8px;
    width:32px;height:32px;font-size:14px;cursor:pointer;line-height:1;transition:color .13s,border-color .13s}
  .adm-ic:hover{color:var(--acc);border-color:var(--acc)}
  .adm-ic-del:hover{color:var(--neg);border-color:var(--neg)}
  .adm-ic:active{transform:scale(.92)}
  @media (min-width:1000px){ .adm-kpis{grid-template-columns:repeat(4,1fr)} }

  /* ── объявление для всех (баннер сверху) ── */
  #annBanner{position:fixed;top:0;left:0;right:0;z-index:9000;
    display:flex;align-items:center;gap:10px;
    padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top,0px));
    background:linear-gradient(135deg,var(--acc),#ff8a3d);color:#000;
    font-size:13.5px;font-weight:600;line-height:1.35;
    box-shadow:0 4px 14px rgba(0,0,0,.28);animation:annIn .3s ease}
  #annBanner[hidden]{display:none}
  @keyframes annIn{from{transform:translateY(-100%)}to{transform:none}}
  .ann-ic{flex:none;font-size:16px}
  .ann-text{flex:1;min-width:0;white-space:pre-wrap;word-break:break-word}
  .ann-x{flex:none;background:rgba(0,0,0,.14);border:none;color:#000;border-radius:7px;
    width:26px;height:26px;font-size:13px;font-weight:800;cursor:pointer;line-height:1}
  .ann-x:active{transform:scale(.9)}

  /* ── редакторы в админке (объявление, точки) ── */
  .adm-ann-area{width:100%;min-height:70px;resize:vertical;background:var(--panel2);
    border:1px solid var(--line);color:var(--txt);border-radius:11px;padding:10px 12px;
    font-size:14px;font-family:var(--font);line-height:1.4}
  .adm-ann-row{display:flex;align-items:center;gap:10px;margin-top:9px}
  .adm-ann-row label{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--dim);cursor:pointer}
  .adm-save{margin-left:auto;background:var(--acc);color:#000;border:none;border-radius:10px;
    padding:9px 16px;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font)}
  .adm-save:active{transform:scale(.96)}
  .adm-srv-edit{background:var(--panel2);border:1px solid var(--line);border-radius:12px;
    padding:10px 12px;margin-bottom:8px;display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px}
  .adm-srv-edit.off{opacity:.55}
  .adm-srv-f{display:flex;flex-direction:column;min-width:0}
  .adm-srv-name{flex:1 1 140px}
  .adm-srv-num{flex:0 0 96px}
  .adm-srv-num2{flex:0 0 58px}
  .adm-srv-f input{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--txt);
    border-radius:8px;padding:8px 9px;font-size:13px;font-family:var(--font);min-width:0}
  .adm-srv-lbl{font-size:9.5px;color:var(--dim);font-family:var(--mono);margin-bottom:3px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .adm-srv-tog{flex:0 0 auto;background:none;border:1px solid var(--line);color:var(--dim);
    border-radius:8px;width:34px;height:34px;font-size:13px;cursor:pointer;line-height:1}
  .adm-srv-tog.on{color:var(--acc2);border-color:var(--acc2)}
  .adm-srv-tog:active{transform:scale(.92)}
  .adm-srv-edit .adm-ic-del{flex:0 0 auto;width:34px;height:34px}
  @media (max-width:560px){ .adm-srv-name{flex:1 1 100%} }
  .adm-add{width:100%;background:none;border:1px dashed var(--line);color:var(--dim);
    border-radius:11px;padding:10px;font-size:13px;font-weight:700;cursor:pointer;
    font-family:var(--font);margin-top:2px}
  .adm-add:active{transform:scale(.99)}
  .adm-hint{font-size:11.5px;color:var(--dim);margin:8px 0 2px;line-height:1.4}

  /* спиннер загрузки журнала (оставлен для обратной совместимости) */
  .jrn-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:48px 0;gap:14px;color:var(--dim);font-size:13px;font-family:var(--mono)}
  .jrn-loading::before{content:'';width:34px;height:34px;border:3px solid var(--line);
    border-top-color:var(--acc);border-radius:50%;animation:spin .75s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  @media(prefers-reduced-motion:reduce){.jrn-loading::before{animation:none;border-top-color:var(--line)}}

  /* ── скелетоны загрузки журнала (вместо спиннера) ── */
  .jrn-skel{margin-top:8px}
  .skel{position:relative;overflow:hidden;background:var(--panel2);
    border:1px solid var(--line);border-radius:14px}
  .skel::after{content:'';position:absolute;inset:0;transform:translateX(-100%);
    background:linear-gradient(90deg,transparent,var(--skel),transparent);
    animation:skelShine 1.3s ease-in-out infinite}
  @keyframes skelShine{100%{transform:translateX(100%)}}
  .skel-card{height:88px;margin-bottom:10px}
  .skel-card:last-child{margin-bottom:0}
  @media(prefers-reduced-motion:reduce){.skel::after{animation:none}}

  /* ── скользящий индикатор активной вкладки (мобайл) ── */
  .nav-ind{position:absolute;top:0;height:2px;border-radius:2px;background:var(--acc);
    left:0;width:0;opacity:0;pointer-events:none;
    transition:left .28s cubic-bezier(.22,.61,.36,1),width .28s cubic-bezier(.22,.61,.36,1),opacity .2s}
  @media(prefers-reduced-motion:reduce){.nav-ind{transition:opacity .2s}}

  /* ── pull-to-refresh (мобайл) ── */
  #ptr{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-100%);
    z-index:90;width:38px;height:38px;border-radius:50%;background:var(--panel);
    border:1px solid var(--line);box-shadow:var(--sh2);display:grid;place-items:center;
    opacity:0;will-change:transform}
  #ptr .ptr-spin{width:20px;height:20px;border-radius:50%;border:2.5px solid var(--line);
    border-top-color:var(--acc)}
  #ptr.ready .ptr-spin{border-top-color:var(--acc2)}
  #ptr.refreshing{transition:transform .25s ease}
  #ptr.refreshing .ptr-spin{animation:spin .7s linear infinite}
  @media(min-width:1000px){#ptr{display:none}}

  .jrn-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
  .jrn-item{background:var(--panel2);border:1px solid var(--line);border-radius:13px;overflow:hidden;cursor:pointer}
  .jrn-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px}
  .jrn-date{font-size:13.5px;font-weight:700}
  .jrn-srv{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:2px}
  .jrn-profit{font-size:16px;font-weight:800;color:var(--acc);font-variant-numeric:tabular-nums;flex:none}
  .jrn-detail{display:none;padding:4px 14px 14px;border-top:1px solid var(--line)}
  .jrn-item.open .jrn-detail{display:block}
  .jrn-drow{display:flex;justify-content:space-between;gap:8px;font-size:13.5px;padding:5px 0}
  .jrn-drow b{font-variant-numeric:tabular-nums}
  .jrn-drow.neg b{color:var(--neg)}
  .jrn-drow.profit{margin-top:4px;padding-top:8px;border-top:1px solid var(--line);font-weight:800}
  .jrn-drow.profit b{color:var(--acc);font-size:16px}
  .jrn-acts{display:flex;gap:8px;margin-top:12px}
  .jrn-edit,.jrn-del{flex:1;background:none;border-radius:10px;padding:9px;font-size:13px;
    font-weight:700;cursor:pointer;font-family:var(--font)}
  .jrn-edit{border:1px solid var(--acc);color:var(--acc)}
  .jrn-del{border:1px solid var(--neg-soft);color:var(--neg)}
  .jrn-edit:active,.jrn-del:active{transform:scale(.99)}
  .jrn-who{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:2px}
  .jrn-edmark{font-size:11px;color:var(--acc2);font-family:var(--mono)}
  .jrn-sep{height:1px;background:var(--line);margin:18px 0 4px}

  /* переключатель сервиса */
  .rep-srv{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:6px}
  .rep-srv .srv-btn{position:relative;flex:1;min-width:120px;background:var(--panel2);border:1px solid var(--line);
    color:var(--dim);border-radius:14px;padding:12px 10px;font-size:14.5px;font-weight:800;cursor:pointer;
    font-family:var(--font);line-height:1.25;text-align:center;
    transition:border-color .15s,background .15s,transform .1s,box-shadow .15s}
  .rep-srv .srv-btn:active{transform:scale(.98)}
  .rep-srv .srv-btn .s{display:block;font-size:11px;font-weight:500;opacity:.8;font-family:var(--mono);margin-top:3px}
  .rep-srv .srv-btn.active{border-color:var(--acc);color:var(--txt);background:rgba(255,90,31,.12);
    box-shadow:0 0 0 1px var(--acc) inset}
  .rep-srv .srv-btn.locked{cursor:not-allowed}
  .rep-srv .srv-btn.locked:not(.active){opacity:.4}
  .rep-srv .srv-btn.svc-live{border-color:var(--acc2);box-shadow:0 0 0 1px var(--acc2) inset}
  .rep-srv .srv-btn.svc-live::after{content:'🟢';position:absolute;top:8px;right:9px;font-size:10px;line-height:1}
  .rep-srv .srv-btn.svc-done{opacity:.5}
  .rep-srv .srv-btn.svc-done::after{content:'🔴';position:absolute;top:8px;right:9px;font-size:10px;line-height:1}

  /* статус смены + блокировка тела отчёта */
  .rep-status{font-size:13px;color:var(--dim);font-family:var(--mono);margin:12px 0;
    padding:11px 14px;border:1px dashed var(--line);border-radius:12px;text-align:center;line-height:1.45}
  .rep-status.on{color:var(--acc2);border-style:solid;border-color:var(--acc2);
    background:rgba(13,155,118,.08);font-weight:700}
  .rep-status.edit{color:var(--acc);border-style:solid;border-color:var(--acc);
    background:rgba(255,90,31,.10);font-weight:700}
  .rep-live{font-size:12.5px;color:var(--acc2);font-family:var(--mono);margin:0 0 10px;
    padding:9px 12px;border:1px solid var(--acc2);border-radius:10px;text-align:center;
    background:rgba(34,211,166,.08);line-height:1.4}
  .rep-live .rep-live-upd{display:block;margin-top:3px;color:var(--warn);font-weight:700}
  #repBody.locked{opacity:.4;pointer-events:none;filter:grayscale(.35)}

  /* читаемый вывод отчёта — плотная таблица */
  #repOut{background:none;border:none;padding:0;margin-top:16px}
  .rep-tbl{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:6px 16px}
  #repOut .calc-row{font-size:15px;padding:6px 0}
  #repOut .calc-row .v{font-variant-numeric:tabular-nums}
  #repOut .calc-row.bold{font-weight:800}
  #repOut .calc-row .v.neg{color:var(--neg)}
  #repOut .calc-row .v.pos{color:var(--acc2)}
  .rep-hr{height:1px;background:var(--line);margin:6px 0}
  #repOut .calc-row.profit{margin-top:2px;padding:11px 0 7px;font-size:18px;font-weight:900}
  #repOut .calc-row.profit .v{color:var(--acc);font-size:20px}

  .card[data-hidden="1"]{display:none!important}
  .wtog{display:flex;align-items:center;justify-content:space-between;gap:12px;
    background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:13px 14px;margin-bottom:8px;cursor:pointer}
  .wtog span{font-size:14.5px;font-weight:600}
  .wtog input{width:20px;height:20px;accent-color:var(--acc);cursor:pointer;flex:none}
  .mcode{display:inline-block;margin-left:7px;font-size:10.5px;font-family:var(--mono);color:var(--acc2);
    background:var(--panel2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;vertical-align:middle}
  #updBanner{position:fixed;left:12px;right:12px;bottom:calc(70px + env(safe-area-inset-bottom,0px));
    z-index:9999;display:flex;align-items:center;gap:10px;
    background:var(--panel);border:1px solid var(--acc);border-radius:14px;
    padding:12px 14px;box-shadow:var(--sh2);max-width:520px;margin:0 auto;
    animation:up .25s cubic-bezier(.22,.61,.36,1)}
  #updBanner span{flex:1;font-size:14px;font-weight:600;color:var(--txt)}
  #updBtn{flex:none;background:var(--acc);color:#000;border:none;border-radius:9px;
    padding:9px 16px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font)}
  #updBtn:active{transform:scale(.96)}
  #updClose{flex:none;background:none;border:none;color:var(--dim);font-size:16px;cursor:pointer;padding:4px 6px}
  #tour{position:fixed;inset:0;z-index:10000}
  #tour[hidden]{display:none}
  #tourHole{position:absolute;border-radius:14px;
    box-shadow:0 0 0 9999px rgba(0,0,0,.74);transition:all .35s cubic-bezier(.22,.61,.36,1);
    pointer-events:none;border:2px solid var(--acc);animation:tourPulse 1.9s ease-in-out infinite}
  @keyframes tourPulse{
    0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.74), 0 0 0 0 rgba(255,122,28,.5)}
    50%{box-shadow:0 0 0 9999px rgba(0,0,0,.74), 0 0 0 8px rgba(255,122,28,0)}}
  /* шаг про «долгое нажатие» — жест «зажми и держи»: лёгкий press + заполнение свечением */
  #tourHole.hold{animation:tourHold 1.5s ease-in-out infinite}
  @keyframes tourHold{
    0%{box-shadow:0 0 0 9999px rgba(0,0,0,.74), inset 0 0 0 0 rgba(255,122,28,0);transform:scale(1)}
    20%{transform:scale(.955)}
    65%{box-shadow:0 0 0 9999px rgba(0,0,0,.74), inset 0 0 0 70px rgba(255,122,28,.30);transform:scale(.955)}
    100%{box-shadow:0 0 0 9999px rgba(0,0,0,.74), inset 0 0 0 70px rgba(255,122,28,0);transform:scale(1)}}
  @media (prefers-reduced-motion: reduce){#tourHole,#tourHole.hold{animation:none}}
  #tourBox{position:absolute;left:16px;right:16px;max-width:460px;margin:0 auto;
    background:var(--panel);border:1px solid var(--line);border-top:3px solid var(--acc);
    border-radius:18px;padding:18px 18px 16px;box-shadow:var(--sh2);
    transition:top .35s ease, bottom .35s ease;animation:tourBoxIn .35s ease}
  @keyframes tourBoxIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  #tourHead{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
  #tourIco{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
    font-size:22px;background:var(--panel2);border:1px solid var(--line)}
  .tour-head-txt{min-width:0;padding-top:1px}
  #tourStep{font-size:10.5px;font-family:var(--mono);color:var(--acc);font-weight:700;
    text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px}
  #tourTitle{font-size:17px;font-weight:800;color:var(--txt);line-height:1.2}
  #tourText{font-size:14.5px;line-height:1.55;color:var(--dim);margin-bottom:14px}
  #tourDots{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
  #tourDots i{width:7px;height:7px;border-radius:50%;background:var(--line);transition:all .25s ease;cursor:pointer}
  #tourDots i.on{background:var(--acc);width:20px;border-radius:4px}
  #tourDots i.done{background:var(--acc);opacity:.5}
  #tourBtns{display:flex;align-items:center;gap:8px}
  #tourSkip{background:none;border:none;color:var(--dim);font-size:13.5px;cursor:pointer;font-family:var(--font);padding:8px 4px}
  #tourBack{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:10px;
    padding:10px 14px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:var(--font)}
  #tourBack[hidden]{display:none}
  #tourBack:active{transform:scale(.96)}
  #tourNext{background:var(--acc);color:#000;border:none;border-radius:10px;padding:10px 18px;
    font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font)}
  #tourNext:active{transform:scale(.96)}
  #toTop{position:fixed;right:16px;bottom:calc(78px + env(safe-area-inset-bottom,0px));z-index:40;
    width:46px;height:46px;border-radius:50%;background:var(--acc);color:#000;border:none;
    font-size:22px;font-weight:700;cursor:pointer;box-shadow:var(--sh2);
    display:grid;place-items:center;opacity:0;transform:translateY(10px) scale(.9);
    transition:.22s cubic-bezier(.22,.61,.36,1)}
  #toTop:not([hidden]){opacity:1;transform:translateY(0) scale(1)}
  #toTop:active{transform:scale(.92)}
  #toast{position:fixed;left:50%;bottom:calc(82px + env(safe-area-inset-bottom,0px));
    transform:translateX(-50%);z-index:10001;display:flex;flex-direction:column;gap:8px;
    align-items:center;pointer-events:none;width:max-content;max-width:90vw}
  .toast-item{background:var(--panel);color:var(--txt);border:1px solid var(--line);
    border-left:3px solid var(--acc);border-radius:11px;padding:11px 16px;font-size:14px;font-weight:600;
    box-shadow:var(--sh2);opacity:0;transform:translateY(10px);transition:.25s cubic-bezier(.22,.61,.36,1)}
  .toast-item.show{opacity:1;transform:translateY(0)}
  .qa-list{display:flex;flex-direction:column;gap:8px;margin-top:6px}
  .qa-btn{width:100%;text-align:left;background:var(--panel2);border:1px solid var(--line);
    color:var(--txt);border-radius:11px;padding:14px 16px;font-size:15px;font-weight:600;
    cursor:pointer;font-family:var(--font);transition:.13s}
  .qa-btn:hover{border-color:var(--acc)}
  .qa-btn:active{transform:scale(.985);background:var(--press)}
  .sheet h3{font-size:15px;margin-bottom:4px}
  .sheet p{font-size:12.5px;color:var(--dim);margin-bottom:12px;overflow-wrap:break-word;word-break:break-word}
  .sheet input{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    padding:13px 14px;border-radius:11px;font-size:16px;outline:none;font-family:var(--font);margin-bottom:10px}
  .sheet input:focus{border-color:var(--acc)}
  .syn,.btn-go{display:block;width:100%;text-align:left;background:var(--panel2);border:1px solid var(--line);
    color:var(--txt);padding:13px 14px;border-radius:11px;font-size:15px;margin-bottom:8px;cursor:pointer;font-family:var(--font)}
  .syn:hover{border-color:var(--acc);transform:translateY(-1px);box-shadow:var(--sh1)}
  .syn:active{transform:scale(.985);background:var(--press)}
  .syn small{color:var(--dim);font-family:var(--mono);font-size:11px}
  .btn-go{text-align:center;font-weight:700;background:linear-gradient(135deg,var(--acc),#ff8a3d);color:#000;border:none;
    box-shadow:0 4px 16px rgba(255,90,31,.25)}
  .btn-go:active{transform:scale(.985)}
  /* ===== ПАНЕЛЬ ПРОФИЛЯ (мобайл) ===== */
  .prof-hero{display:flex;flex-direction:column;align-items:center;gap:6px;
    padding:24px 16px 20px;text-align:center}
  .prof-ava{width:72px;height:72px;border-radius:50%;background:var(--acc);color:#fff;
    font-size:26px;font-weight:800;display:flex;align-items:center;justify-content:center;
    overflow:hidden;flex-shrink:0;margin-bottom:4px}
  .prof-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
  .prof-name{font-size:18px;font-weight:800;color:var(--txt)}
  .prof-email{font-size:12px;color:var(--dim);font-family:var(--mono);margin-top:1px}
  .prof-badge{display:inline-flex;align-items:center;gap:6px;margin-top:6px;
    background:var(--panel2);border:1px solid var(--line);border-radius:20px;
    padding:5px 13px;font-size:12px;font-weight:700;color:var(--dim);font-family:var(--mono)}
  .prof-bdot{width:8px;height:8px;border-radius:50%;background:var(--dim);
    flex-shrink:0;transition:background .3s}
  .prof-badge.on{color:var(--acc2);border-color:var(--acc2)}
  .prof-badge.on .prof-bdot{background:var(--acc2)}
  .prof-btns{display:flex;flex-direction:column;gap:8px;margin-top:4px}
  .prof-btn{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    border-radius:12px;padding:14px 16px;font-size:15px;font-weight:600;cursor:pointer;
    font-family:var(--font);text-align:left;transition:background .13s}
  .prof-btn:active{background:var(--press)}
  .prof-btn-out{color:var(--neg);border-color:rgba(255,107,107,.25)}
  .prof-settings{display:flex;flex-direction:column;gap:6px;margin-top:8px}
  .prof-srow{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    border-radius:12px;padding:14px 16px;font-size:15px;font-weight:600;cursor:pointer;
    font-family:var(--font);display:flex;align-items:center;justify-content:space-between;
    transition:background .13s}
  .prof-srow:active{background:var(--press)}
  .prof-sval{font-size:13px;color:var(--dim);font-family:var(--mono);font-weight:500}

  /* лёгкое проявление логотипа в шапке при загрузке */
  .logo-img{animation:logoIn .6s cubic-bezier(.22,.61,.36,1) both}
  @keyframes logoIn{from{opacity:0;transform:translateX(-8px) scale(.9)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion: reduce){.logo-img{animation:none}}
