/* ===== Шрифты ===== */
/* SF Pro Text — системный шрифт Apple (берётся из ОС через -apple-system).
   Локальные .ttf подхватятся, если положены в vendor/fonts/. Inter (OFL) —
   запасной шрифт с полноценной кириллицей для не-Apple систем. */
@font-face{font-family:"SF Pro Text";font-style:normal;font-weight:300;font-display:swap;src:local("SF Pro Text Light"),url("../vendor/fonts/SFProText-Light.ttf") format("truetype")}
@font-face{font-family:"SF Pro Text";font-style:normal;font-weight:400;font-display:swap;src:local("SF Pro Text Regular"),url("../vendor/fonts/SFProText-Regular.ttf") format("truetype")}
@font-face{font-family:"SF Pro Text";font-style:normal;font-weight:500;font-display:swap;src:local("SF Pro Text Medium"),url("../vendor/fonts/SFProText-Medium.ttf") format("truetype")}
@font-face{font-family:"SF Pro Text";font-style:normal;font-weight:600;font-display:swap;src:local("SF Pro Text Semibold"),url("../vendor/fonts/SFProText-Semibold.ttf") format("truetype")}
@font-face{font-family:"SF Pro Text";font-style:normal;font-weight:700;font-display:swap;src:local("SF Pro Text Bold"),url("../vendor/fonts/SFProText-Bold.ttf") format("truetype")}
@font-face{font-family:"Inter Variable";font-style:normal;font-display:swap;font-weight:100 900;
  src:url("../vendor/fonts/inter-cyrillic-wght-normal.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:"Inter Variable";font-style:normal;font-display:swap;font-weight:100 900;
  src:url("../vendor/fonts/inter-latin-wght-normal.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ===== Токены iOS 26 — Светлая тема ===== */
:root{
  /* Системные фоны (grouped) */
  --bg:#F2F2F7;            /* systemGroupedBackground */
  --surface:#FFFFFF;       /* secondarySystemGroupedBackground (карточки/списки) */
  --panel:#EFEFF4;         /* подложки/наведение */
  --panel2:rgba(120,120,128,.12); /* fill tertiary — поля поиска */
  --chrome:rgba(255,255,255,.72); /* материал баров */

  /* Текст (labels) */
  --ink:#000000;                       /* label */
  --ink2:rgba(60,60,67,.6);            /* secondaryLabel */
  --ink3:rgba(60,60,67,.3);            /* tertiaryLabel */
  --ink4:rgba(60,60,67,.18);           /* quaternaryLabel */

  /* Разделители */
  --line:rgba(60,60,67,.16);           /* separator (non-opaque) */
  --line2:#C6C6C8;                     /* opaqueSeparator */

  /* Системный синий — акцент */
  --accent:#007AFF;
  --accent-deep:#0062CC;
  --accent-soft:rgba(0,122,255,.12);   /* tinted fill */

  /* Системные семантические цвета */
  --ok:#34C759;   --ok-soft:rgba(52,199,89,.15);
  --bad:#FF3B30;  --bad-soft:rgba(255,59,48,.15);
  --warn:#FF9500; --warn-soft:rgba(255,149,0,.16);
  --info:#5856D6; --info-soft:rgba(88,86,214,.14);

  --feat:var(--accent-soft);

  /* Тени iOS — мягкие и неглубокие */
  --shadow:0 0 0 .5px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.06);
  --shadow-lg:0 10px 40px -8px rgba(0,0,0,.22), 0 0 0 .5px rgba(0,0,0,.05);

  /* Скругления (continuous-стиль iOS) */
  --r:12px; --r-lg:18px; --r-pill:980px;

  --serif:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","SF Pro","Inter Variable","Segoe UI",system-ui,sans-serif;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro","Inter Variable","Segoe UI",system-ui,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --ease:cubic-bezier(.32,.72,0,1);   /* iOS spring-подобная кривая */
}
html[data-theme="dark"]{
  --bg:#000000;
  --surface:#1C1C1E;
  --panel:#2C2C2E;
  --panel2:rgba(120,120,128,.24);
  --chrome:rgba(30,30,32,.72);

  --ink:#FFFFFF;
  --ink2:rgba(235,235,245,.6);
  --ink3:rgba(235,235,245,.3);
  --ink4:rgba(235,235,245,.16);

  --line:rgba(84,84,88,.55);
  --line2:#38383A;

  --accent:#0A84FF;
  --accent-deep:#409CFF;
  --accent-soft:rgba(10,132,255,.22);

  --ok:#30D158;  --ok-soft:rgba(48,209,88,.2);
  --bad:#FF453A; --bad-soft:rgba(255,69,58,.2);
  --warn:#FF9F0A;--warn-soft:rgba(255,159,10,.2);
  --info:#5E5CE6;--info-soft:rgba(94,92,230,.24);

  --feat:var(--accent-soft);
  --shadow:0 0 0 .5px rgba(255,255,255,.05), 0 1px 3px rgba(0,0,0,.5);
  --shadow-lg:0 16px 50px -10px rgba(0,0,0,.7), 0 0 0 .5px rgba(255,255,255,.06);
}
*{box-sizing:border-box}
html{color-scheme:light}
html[data-theme="dark"]{color-scheme:dark}
:root{accent-color:var(--accent)}
html,body{margin:0;height:100%}
body{background:var(--bg); color:var(--ink); font-family:var(--sans); font-size:15px; line-height:1.42; letter-spacing:-.01em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; transition:background .35s var(--ease), color .35s var(--ease)}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; letter-spacing:inherit}
input,textarea,select{font-family:inherit; font-size:inherit; color:inherit; letter-spacing:inherit}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:none; opacity:.8}
::selection{background:var(--accent-soft)}
:focus-visible{outline:2.5px solid var(--accent); outline-offset:2px; border-radius:8px}

.app{display:grid; grid-template-columns:260px 1fr; min-height:100vh}

/* ===== Сайдбар (iPadOS/macOS style) ===== */
.side{background:var(--surface); border-right:.5px solid var(--line2); padding:18px 12px; display:flex; flex-direction:column; gap:2px; position:sticky; top:0; height:100vh; overflow-y:auto}
html[data-theme="dark"] .side{background:#1C1C1E}
.brand{display:flex; align-items:center; gap:11px; padding:8px 10px 18px}
.brand .mark{width:34px; height:34px; border-radius:9px; flex:none; background:linear-gradient(180deg,#0A84FF,#007AFF); display:grid; place-items:center; color:#fff; font-family:var(--serif); font-size:18px; font-weight:700; box-shadow:0 1px 3px rgba(0,122,255,.4)}
.brand .wm{font-family:var(--serif); font-size:18px; letter-spacing:.02em; font-weight:700}
.brand .wm small{display:block; font-family:var(--sans); font-size:10px; letter-spacing:.06em; color:var(--ink3); font-weight:600; margin-top:1px; text-transform:uppercase}
.navlbl{font-size:12px; letter-spacing:.01em; color:var(--ink3); padding:16px 12px 5px; font-weight:600}
.nav{display:flex; align-items:center; gap:11px; padding:8px 11px; border-radius:9px; color:var(--ink); font-weight:400; font-size:15px; transition:background .15s var(--ease); text-align:left; width:100%; -webkit-tap-highlight-color:transparent}
.nav .ic{width:28px; height:28px; border-radius:7px; display:inline-flex; align-items:center; justify-content:center; font-size:15px; color:#fff; background:var(--grays-gray,#8E8E93); flex:none}
.nav[data-go="dash"] .ic{background:#007AFF}
.nav[data-go="zakazy"] .ic{background:#FF9500}
.nav[data-go="klienty"] .ic{background:#34C759}
.nav[data-go="tovary"] .ic{background:#AF52DE}
.nav[data-go="report"] .ic{background:#5856D6}
.nav[data-go="dohody"] .ic{background:#30B0C7}
.nav[data-go="rashody"] .ic{background:#FF3B30}
.nav .ct{margin-left:auto; font-size:14px; color:var(--ink3); font-variant-numeric:tabular-nums}
.nav:hover{background:var(--panel)}
.nav:active{background:var(--line)}
.nav.on{background:var(--accent-soft); color:var(--accent); font-weight:500}
.nav.on .ct{color:var(--accent)}
.side-foot{margin-top:auto; padding-top:14px; margin-top:18px; border-top:.5px solid var(--line); display:flex; flex-direction:column; gap:1px}
.sbtn{display:flex; align-items:center; gap:11px; padding:9px 11px; border-radius:9px; color:var(--ink); font-size:14px; font-weight:400; transition:background .15s; text-align:left}
.sbtn .ic-svg{color:var(--accent)}
.sbtn:hover{background:var(--panel)}
.theme-tg{display:flex; align-items:center; gap:11px; padding:9px 11px; border-radius:9px; color:var(--ink); font-size:14px; font-weight:400}
.theme-tg .ic-svg{color:var(--accent)}
.theme-tg:hover{background:var(--panel)}
.theme-tg .sw{margin-left:auto; width:51px; height:31px; border-radius:980px; background:var(--line2); position:relative; transition:background .3s var(--ease); flex:none}
.theme-tg .sw::after{content:""; position:absolute; top:2px; left:2px; width:27px; height:27px; border-radius:50%; background:#fff; box-shadow:0 3px 8px rgba(0,0,0,.15), 0 1px 1px rgba(0,0,0,.16); transition:transform .3s var(--ease)}
html[data-theme="dark"] .theme-tg .sw{background:#34C759}
html[data-theme="dark"] .theme-tg .sw::after{transform:translateX(20px)}

/* ===== Основная область ===== */
.main{padding:30px clamp(18px,4vw,48px) 90px; max-width:1180px; width:100%}
.pagehead{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:22px; flex-wrap:wrap}
.pagehead h1{font-family:var(--serif); font-weight:700; font-size:34px; margin:0; letter-spacing:-.022em; line-height:1.05}
.pagehead .sub{color:var(--ink2); margin-top:5px; font-size:15px; letter-spacing:-.01em}

/* ===== Кнопки iOS ===== */
.btn{display:inline-flex; align-items:center; gap:7px; padding:10px 18px; border-radius:var(--r); font-weight:600; font-size:15px; letter-spacing:-.01em; transition:transform .1s var(--ease), background .16s, box-shadow .16s, opacity .16s; -webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(.96); opacity:.85}
.btn.primary{background:var(--accent); color:#fff}
.btn.primary:hover{background:var(--accent-deep)}
.btn.ghost{background:var(--panel2); color:var(--accent); font-weight:600}
.btn.ghost:hover{background:var(--line)}
.btn.sm{padding:8px 14px; font-size:14px; border-radius:10px}
.btn[disabled]{opacity:.35; pointer-events:none}

/* ===== Сегментированный выбор месяца ===== */
.month-pick{display:inline-flex; align-items:center; gap:2px; background:var(--panel2); border-radius:10px; padding:3px}
.month-pick button{width:32px; height:30px; border-radius:8px; color:var(--accent); font-size:16px; display:grid; place-items:center; transition:background .15s}
.month-pick button:hover{background:var(--surface)}
.month-pick .lbl{padding:0 12px; font-weight:600; min-width:128px; text-align:center; font-size:15px; letter-spacing:-.01em}

/* ===== Карточки KPI ===== */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:14px}
.card{background:var(--surface); border-radius:var(--r-lg); padding:20px 22px; box-shadow:var(--shadow); position:relative; overflow:hidden}
.card .k{font-size:14px; color:var(--ink2); font-weight:500; display:flex; align-items:center; gap:7px; letter-spacing:-.01em}
.card .v{font-family:var(--serif); font-size:38px; font-weight:700; margin-top:10px; letter-spacing:-.03em; line-height:1; font-variant-numeric:tabular-nums}
.card .v.neg{color:var(--bad)}
.card.feat{background:var(--surface)}
.card.feat .k{color:var(--accent); font-weight:600}
.card.feat::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--accent)}

.ministrip{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:24px}
.mini{background:var(--surface); border-radius:var(--r); padding:15px 18px; box-shadow:var(--shadow)}
.mini .k{font-size:13px; color:var(--ink2); font-weight:500; letter-spacing:-.01em}
.mini .v{font-size:22px; font-weight:600; margin-top:4px; font-variant-numeric:tabular-nums; letter-spacing:-.02em}

.sectn{font-size:13px; letter-spacing:.01em; text-transform:uppercase; color:var(--ink2); font-weight:600; margin:28px 4px 10px}

/* ===== Графики ===== */
.charts-2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.chart{background:var(--surface); border-radius:var(--r-lg); padding:18px 20px 14px; box-shadow:var(--shadow); margin-bottom:14px}
.chart .ch-h{font-size:17px; font-weight:600; margin-bottom:3px; letter-spacing:-.02em}
.chart .ch-s{font-size:13px; color:var(--ink3); margin-bottom:14px; letter-spacing:-.01em}
.chart svg:not(.ic-svg){display:block; width:100%; height:auto}
.legend{display:flex; gap:16px; margin-top:12px; flex-wrap:wrap}
.legend span{display:inline-flex; align-items:center; gap:6px; font-size:13px; color:var(--ink2)}
.legend i{width:10px; height:10px; border-radius:3px}

.attn{display:flex; flex-direction:column; gap:9px}
.attn-row{display:flex; align-items:center; gap:13px; padding:13px 16px; background:var(--surface); border-radius:13px; box-shadow:var(--shadow); transition:background .16s; cursor:pointer}
.attn-row:hover{background:var(--panel)}
.attn-row .who{font-weight:600}
.attn-row .det{color:var(--ink2); font-size:14px}
.attn-row .sp{margin-left:auto}

/* ===== Тулбар + поиск ===== */
.toolbar{display:flex; gap:10px; align-items:center; margin-bottom:14px; flex-wrap:wrap}
.search{flex:1; min-width:180px; position:relative}
.search input{width:100%; padding:10px 14px 10px 38px; border:none; border-radius:10px; background:var(--panel2); font-size:15px; transition:box-shadow .16s, background .16s}
.search input::placeholder{color:var(--ink3)}
.search input:focus{outline:none; background:var(--surface); box-shadow:0 0 0 3.5px var(--accent-soft), inset 0 0 0 1px var(--accent)}
.search .si{position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--ink3)}
.tb-actions{display:flex; gap:8px; flex-wrap:wrap}

/* ===== Панель фильтров ===== */
.filter-panel{background:var(--surface); border-radius:var(--r-lg); padding:16px 18px; margin-bottom:14px; box-shadow:var(--shadow)}
.filter-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px}
.fl{display:flex; flex-direction:column; gap:6px}
.fl label{font-size:13px; font-weight:600; letter-spacing:-.01em; color:var(--ink2)}
.fl select, .fl input{padding:10px 12px; border:none; border-radius:10px; background:var(--panel2); font-size:15px; transition:box-shadow .16s, background .16s; color:var(--ink); accent-color:var(--accent)}
.fl select{appearance:none; -webkit-appearance:none; padding-right:34px; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23007AFF' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 11px center; cursor:pointer}
.fl input[type="date"]{cursor:text}
.fl input[type="date"]::-webkit-calendar-picker-indicator{cursor:pointer; opacity:.6; border-radius:4px}
.fl input[type="date"]::-webkit-calendar-picker-indicator:hover{opacity:1}
.fl select:focus, .fl input:focus{outline:none; background:var(--surface); box-shadow:0 0 0 3.5px var(--accent-soft), inset 0 0 0 1px var(--accent)}
.filter-foot{display:flex; justify-content:space-between; align-items:center; margin-top:14px}
.filter-count{font-size:14px; color:var(--ink2)}

.selhint{font-size:13px; color:var(--ink3); margin:-2px 4px 10px}

/* ===== Таблицы как сгруппированные списки iOS ===== */
.tablewrap{background:var(--surface); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow)}
.tscroll{overflow-x:auto}
table{border-collapse:collapse; width:100%; font-size:15px}
thead th{text-align:left; padding:11px 16px; font-size:13px; letter-spacing:-.01em; color:var(--ink2); font-weight:500; background:transparent; white-space:nowrap; border-bottom:.5px solid var(--line)}
tbody td{padding:13px 16px; border-top:.5px solid var(--line); white-space:nowrap; vertical-align:middle; letter-spacing:-.01em}
tbody tr:first-child td{border-top:none}
tbody tr{transition:background .12s; cursor:pointer}
tbody tr:hover{background:var(--panel)}
tbody tr.sel{background:var(--accent-soft)}
tbody tr.sel:hover{background:var(--accent-soft)}
td.num{font-variant-numeric:tabular-nums; text-align:right}
td.wrap{white-space:normal; max-width:280px; color:var(--ink2)}
tfoot td{background:var(--panel)}
.tglink{font-weight:500; color:var(--accent)}

/* ===== Бейджи iOS ===== */
.badge{display:inline-flex; align-items:center; gap:5px; padding:3px 10px; border-radius:var(--r-pill); font-size:13px; font-weight:590; white-space:nowrap; letter-spacing:-.01em}
.badge::before{content:""; width:7px; height:7px; border-radius:50%; background:currentColor}
.b-ok{background:var(--ok-soft); color:var(--ok)}
.b-bad{background:var(--bad-soft); color:var(--bad)}
.b-warn{background:var(--warn-soft); color:var(--warn)}
.b-info{background:var(--info-soft); color:var(--info)}
.b-mute{background:var(--panel2); color:var(--ink2)}

.empty{padding:64px 24px; text-align:center; color:var(--ink2)}
.empty .e1{font-family:var(--serif); font-size:22px; font-weight:600; color:var(--ink); margin-bottom:8px; letter-spacing:-.02em}
.empty .e2{font-size:15px; max-width:380px; margin:0 auto 20px; line-height:1.45}

/* ===== Оверлей + лист/визард iOS ===== */
.overlay{position:fixed; inset:0; background:rgba(0,0,0,.32); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); display:grid; place-items:center; z-index:50; padding:20px; animation:fade .25s var(--ease)}
@keyframes fade{from{opacity:0}to{opacity:1}}
.wiz{width:min(540px,100%); background:var(--surface); border-radius:26px; box-shadow:var(--shadow-lg); padding:28px 30px 24px; position:relative; animation:pop .4s var(--ease)}
html[data-theme="dark"] .wiz{background:#1C1C1E}
@keyframes pop{from{opacity:0; transform:translateY(24px) scale(.97)}to{opacity:1; transform:none}}
.wiz-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:18px}
.wiz-eyebrow{font-size:13px; letter-spacing:-.01em; color:var(--ink2); font-weight:600}
.wiz-close{width:30px; height:30px; border-radius:50%; display:grid; place-items:center; color:var(--ink2); font-size:17px; background:var(--panel2)}
.wiz-close:hover{background:var(--line); color:var(--ink)}
.prog{display:flex; gap:5px; margin-bottom:22px}
.prog i{height:4px; flex:1; border-radius:3px; background:var(--line); transition:background .3s var(--ease)}
.prog i.done{background:var(--accent)}
.prog i.cur{background:var(--accent)}
.stepwrap{min-height:150px; position:relative}
.step{animation:slidein .38s var(--ease)}
.step.back{animation:slideback .38s var(--ease)}
@keyframes slidein{from{opacity:0; transform:translateX(26px)}to{opacity:1; transform:none}}
@keyframes slideback{from{opacity:0; transform:translateX(-26px)}to{opacity:1; transform:none}}
.step .q{font-family:var(--serif); font-size:26px; font-weight:700; letter-spacing:-.025em; margin-bottom:5px; line-height:1.15}
.step .hint{font-size:14px; color:var(--ink2); margin-bottom:18px; letter-spacing:-.01em}
.optional-tag{font-size:12px; font-weight:600; color:var(--ink2); background:var(--panel2); padding:2px 9px; border-radius:var(--r-pill); margin-left:8px; vertical-align:middle}
.field input, .field textarea{width:100%; padding:14px 16px; border:none; border-radius:13px; background:var(--panel2); font-size:18px; transition:box-shadow .16s, background .16s; letter-spacing:-.01em}
.field input:focus, .field textarea:focus{outline:none; background:var(--surface); box-shadow:0 0 0 4px var(--accent-soft), inset 0 0 0 1.5px var(--accent)}
.field textarea{resize:vertical; min-height:90px; font-size:16px; line-height:1.5}
.field .affix{position:relative}
.field .affix .cur{position:absolute; right:18px; top:50%; transform:translateY(-50%); color:var(--ink3); font-weight:600; pointer-events:none}
.field .affix input{padding-right:42px}
.chips{display:flex; flex-wrap:wrap; gap:10px}
.chip{display:inline-flex; align-items:center; gap:9px; padding:11px 16px; border-radius:13px; background:var(--panel2); font-size:16px; font-weight:500; transition:all .14s var(--ease)}
.chip:hover{background:var(--line)}
.chip.on{background:var(--accent); color:#fff; font-weight:600}
.chip .kbd{font-family:var(--mono); font-size:11px; color:var(--ink3); background:var(--surface); border-radius:6px; padding:2px 6px; line-height:1}
.chip.on .kbd{color:#fff; background:rgba(255,255,255,.22)}
.suggest{margin-top:10px; border-radius:13px; overflow:hidden; max-height:206px; overflow-y:auto; background:var(--surface); box-shadow:var(--shadow); border:.5px solid var(--line)}
.sg{display:flex; align-items:center; gap:11px; padding:11px 15px; cursor:pointer; transition:background .12s; border-top:.5px solid var(--line)}
.sg:first-child{border-top:none}
.sg:hover, .sg.hl{background:var(--accent-soft)}
.sg .av{width:32px; height:32px; border-radius:50%; background:var(--accent-soft); display:grid; place-items:center; font-size:13px; font-weight:700; color:var(--accent); flex:none}
.sg .nm{font-weight:600; font-size:15px}
.sg .mt{font-size:13px; color:var(--ink2)}
.preview{margin-top:18px; padding:15px 18px; border-radius:14px; background:var(--accent-soft); display:flex; align-items:center; gap:16px; animation:pop .3s var(--ease)}
.preview .pk{font-size:13px; color:var(--accent); font-weight:600; letter-spacing:-.01em}
.preview .pv{font-family:var(--serif); font-size:26px; font-weight:700; color:var(--accent); font-variant-numeric:tabular-nums; letter-spacing:-.02em}
.preview .pv.neg{color:var(--bad)}
.preview .pmeta{font-size:13px; color:var(--accent); opacity:.8}
.wiz-foot{display:flex; align-items:center; gap:10px; margin-top:24px}
.wiz-foot .back{color:var(--accent); font-weight:600; padding:11px 16px; border-radius:var(--r)}
.wiz-foot .back:hover{background:var(--panel2)}
.wiz-foot .spacer{flex:1}
.review{display:flex; flex-direction:column; gap:0; max-height:230px; overflow-y:auto; overflow-x:hidden; margin:8px 0 0; background:var(--panel2); border-radius:13px; padding:0; scrollbar-width:thin; scrollbar-color:var(--ink3) transparent}
.review::-webkit-scrollbar{width:8px}
.review::-webkit-scrollbar-thumb{background:var(--ink3); border-radius:4px}
.review::-webkit-scrollbar-track{background:transparent}
.rev-row{display:flex; gap:14px; padding:13px 14px; cursor:pointer; background:transparent}
.rev-row+.rev-row{margin-top:0; border-top:.5px solid var(--line)}
.rev-row:hover{background:var(--panel)}
.rev-row .rk{width:150px; flex:none; color:var(--ink2); font-size:15px; letter-spacing:-.01em}
.rev-row .rv{font-weight:500; font-size:15px; letter-spacing:-.01em}
.rev-row .edit{margin-left:auto; opacity:0; color:var(--accent); font-size:13px; font-weight:600}
.rev-row:hover .edit{opacity:1}

/* ===== Тост iOS ===== */
.toast{position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(20px); background:rgba(40,40,42,.82); -webkit-backdrop-filter:blur(20px) saturate(180%); backdrop-filter:blur(20px) saturate(180%); color:#fff; padding:13px 22px; border-radius:var(--r-pill); font-weight:600; font-size:15px; box-shadow:var(--shadow-lg); opacity:0; transition:all .35s var(--ease); z-index:90; display:flex; align-items:center; gap:9px; letter-spacing:-.01em}
.toast.show{opacity:1; transform:translateX(-50%)}
.toast .ok{color:var(--ok)}

/* ===== Мобильный таб-бар ===== */
.topbar-m{display:none}
@media (max-width:820px){
  .app{grid-template-columns:1fr}
  .side{position:fixed; bottom:0; left:0; right:0; top:auto; height:auto; flex-direction:row; border-right:none; border-top:.5px solid var(--line2); padding:8px 8px calc(8px + env(safe-area-inset-bottom)); z-index:40; gap:2px; overflow-x:auto; background:var(--chrome); -webkit-backdrop-filter:blur(24px) saturate(180%); backdrop-filter:blur(24px) saturate(180%)}
  .brand,.navlbl,.side-foot{display:none}
  .nav{flex-direction:column; gap:3px; padding:6px 6px; font-size:10px; min-width:60px; flex:1; color:var(--ink2); font-weight:500}
  .nav .ic{width:30px; height:30px; font-size:17px; border-radius:8px}
  .nav.on{background:transparent; color:var(--accent)}
  .nav .ct{display:none}
  .main{padding:14px 14px 110px; max-width:100%}
  .topbar-m{display:flex; align-items:center; justify-content:space-between; padding:14px 14px 0; gap:10px}
  .topbar-m .wm{font-family:var(--serif); letter-spacing:.01em; font-weight:700; font-size:20px}
  .topbar-m .tm-actions{display:flex; gap:8px}
  .cards,.ministrip,.charts-2{grid-template-columns:1fr}
  .pagehead h1{font-size:28px}
  .wiz{padding:24px 22px 22px}
  .rev-row .rk{width:118px}
}
@media (max-width:480px){
  .cards .card .v{font-size:32px}
  .step .q{font-size:22px}
  .field input,.field textarea{font-size:16px}
}
@media (prefers-reduced-motion:reduce){ *{animation-duration:.001ms !important; transition-duration:.05ms !important} }

/* ===== Скроллбары ===== */
*{scrollbar-width:thin; scrollbar-color:var(--ink4) transparent}
::-webkit-scrollbar{width:11px; height:11px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background-color:var(--ink4); border-radius:10px; border:3px solid transparent; background-clip:padding-box; transition:background-color .2s}
::-webkit-scrollbar-thumb:hover{background-color:var(--ink3)}
::-webkit-scrollbar-corner{background:transparent}

/* ===== Клик по строке → карточка ===== */
tr.rowlink{cursor:pointer; transition:background .12s}
tr.rowlink:hover td{background:var(--panel)}

/* ===== Копирование значения по клику ===== */
.copyrow{cursor:pointer; transition:background .12s}
.copyrow:hover{background:var(--panel)}
.copyrow .edit{opacity:0; transition:opacity .12s; color:var(--accent)}
.copyrow:hover .edit{opacity:1}

/* ===== Прокрутка длинных модалок (карточек) ===== */
.modal-card{max-height:90vh; display:flex; flex-direction:column}
.modal-card .wiz-top{flex:none; margin-bottom:14px}
.modal-card .wiz-foot{flex:none; margin-top:16px; padding-top:14px; border-top:.5px solid var(--line)}
.modal-body{flex:1 1 auto; min-height:0; overflow-y:auto; margin:0 -8px; padding:0 8px}
.modal-body .review{max-height:260px}

/* ===== SVG-иконки ===== */
.ic-svg{display:inline-block; vertical-align:-0.18em; flex:none}
.nav .ic{display:inline-flex; align-items:center; justify-content:center}
.nav .ic .ic-svg{color:#fff}
.btn .ic-svg{vertical-align:-0.2em; margin-right:1px}
.sbtn .ic-svg, .theme-tg .ic-svg{vertical-align:-0.22em}
.tm-actions .btn.sm .ic-svg{margin:0; vertical-align:-0.2em}
.search .si .ic-svg{vertical-align:-0.28em}
.toast .ok .ic-svg{vertical-align:-0.18em}
.card .v{letter-spacing:-.03em}

/* ===== Позиции заказа (мульти-товар) ===== */
.items-list{display:flex; flex-direction:column; gap:8px; margin:8px 0 10px}
.item-chip{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 12px; background:var(--panel); border:1px solid var(--line); border-radius:12px}
.item-chip .ic-nm{font-weight:600}
.item-chip .ic-mt{font-size:12px; color:var(--ink2); margin-top:2px}
.item-del{flex:none; width:28px; height:28px; border:none; border-radius:8px; background:transparent; color:var(--ink3); cursor:pointer; display:grid; place-items:center}
.item-del:hover{background:var(--bad-soft); color:var(--bad)}
.items-empty{color:var(--ink3); padding:8px 0 10px}
.items-tot{font-size:13px; color:var(--ink2); margin:-2px 0 12px}
.item-form{background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:12px}
.item-form .if-row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.item-form .if-row3{display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-top:10px}
.item-form .field{position:relative}
.item-form .field label{display:block; font-size:12px; color:var(--ink2); margin-bottom:4px}
.item-form input{width:100%; padding:9px 11px; border:1px solid var(--line2); border-radius:10px; background:var(--surface); color:var(--ink); font:inherit; font-size:14px}
.item-form input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.item-form .additem{margin-top:12px}
.item-form .suggest{position:absolute; z-index:5; left:0; right:0; top:100%; margin-top:4px}
@media(max-width:520px){ .item-form .if-row, .item-form .if-row3{grid-template-columns:1fr 1fr} }

/* ===== Блок пользователя в сайдбаре ===== */
.userbox{display:flex; align-items:center; gap:8px; margin-top:10px; padding:8px 11px; border-top:1px solid var(--line); }
.userbox .ub-info{flex:1; min-width:0}
.userbox .ub-nm{font-weight:600; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.userbox .ub-role{font-size:11px; color:var(--ink3)}
.userbox .ub-out{flex:none; width:28px; height:28px; display:grid; place-items:center; border-radius:8px; color:var(--ink3); text-decoration:none}
.userbox .ub-out:hover{background:var(--bad-soft); color:var(--bad)}

/* ===== Экран входа ===== */
.login-wrap{min-height:100vh; display:grid; place-items:center; padding:24px}
.login-card{width:100%; max-width:380px; background:var(--surface); border:1px solid var(--line); border-radius:20px; padding:30px 28px; box-shadow:0 10px 40px rgba(0,0,0,.22)}
.login-brand{display:flex; align-items:center; gap:12px; margin-bottom:22px}
.login-brand .mark{width:42px; height:42px; border-radius:11px; flex:none; background:linear-gradient(180deg,#0A84FF,#007AFF); display:grid; place-items:center; color:#fff; font-family:var(--serif); font-size:22px; font-weight:700; box-shadow:0 2px 8px rgba(0,122,255,.4)}
.login-brand .wm{font-family:var(--serif); font-weight:700; font-size:20px; letter-spacing:.08em; line-height:1; color:var(--ink)}
.login-brand .wm small{display:block; font-size:10px; letter-spacing:.32em; color:var(--ink3); font-weight:600; margin-top:4px}
.login-title{font-size:15px; color:var(--ink2); margin-bottom:14px}
.login-lbl{display:block; font-size:12px; color:var(--ink2); margin:12px 0 5px}
.login-inp{width:100%; padding:11px 13px; border:1px solid var(--line2); border-radius:11px; background:var(--panel); color:var(--ink); font:inherit; font-size:15px}
.login-inp:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.login-btn{width:100%; margin-top:20px; justify-content:center}
.login-err{background:var(--bad-soft); color:var(--bad); border-radius:10px; padding:10px 12px; font-size:13px; margin-bottom:6px}
