/* МОСКИТНЫЕ СЕТКИ ОНЛАЙН — SHARED STYLES v5 */
:root{
  --bg:#f4f4f7;--white:#fff;--s2:#f8f8fa;--s3:#ededf2;
  --border:#e2e2ea;--border2:#cbcbd6;
  --accent:#2563eb;--al:#eff6ff;--ad:#1d4ed8;
  --text:#111118;--t2:#6b6b7a;--t3:#a5a5b5;
  --green:#16a34a;--gl:#f0fdf4;
  --red:#dc2626;--rl:#fef2f2;
  --yellow:#ca8a04;--yl:#fefce8;
  --orange:#ea580c;--ol:#fff7ed;
  --sh0:0 1px 3px rgba(0,0,0,.07);
  --sh:0 4px 16px rgba(0,0,0,.07),0 2px 6px rgba(0,0,0,.04);
  --shl:0 20px 48px rgba(0,0,0,.11);
  --r:12px;--rs:8px;
  --font:'Outfit',sans-serif;--mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;min-height:100vh}
.tb{background:rgba(255,255,255,.93);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;padding:0 16px;height:56px;display:flex;align-items:center;gap:10px}
.tb-logo{font-size:14px;font-weight:800;color:var(--accent);letter-spacing:-.3px;flex:1;text-decoration:none;line-height:1.2}
.tb-logo span{color:var(--text)}
.tbtn{padding:7px 14px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:var(--font);transition:all .15s;display:inline-flex;align-items:center;text-decoration:none}
.tbtn-g{background:none;color:var(--t2);border:1px solid var(--border2)}.tbtn-g:hover{background:var(--s3);color:var(--text)}
.tbtn-p{background:var(--accent);color:#fff}.tbtn-p:hover{background:var(--ad)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:var(--r);font-size:15px;font-weight:600;cursor:pointer;border:none;font-family:var(--font);transition:all .15s;text-decoration:none}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:var(--ad);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.3)}
.btn-o{background:none;color:var(--accent);border:1.5px solid var(--accent)}.btn-o:hover{background:var(--al)}
.btn-g{background:none;color:var(--t2);border:1px solid var(--border2)}.btn-g:hover{background:var(--s3);color:var(--text)}
.btn-s{background:var(--green);color:#fff}.btn-s:hover{background:#15803d}
.btn-r{background:var(--red);color:#fff}
.btn-full{width:100%}.btn-lg{padding:16px 28px;font-size:16px}.btn-sm{padding:8px 14px;font-size:13px}
.field{margin-bottom:14px}
.fl{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px}
.fh{font-size:12px;color:var(--t3);font-weight:400;margin-left:4px}
.fi{width:100%;padding:11px 14px;border-radius:var(--rs);border:1.5px solid var(--border);background:var(--white);font-size:15px;font-family:var(--font);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none}
.fi:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fi::placeholder{color:var(--t3)}
textarea.fi{resize:vertical;min-height:72px}
.card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sh0)}
.cp{padding:20px}
.divider{height:1px;background:var(--border);margin:16px 0}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.b-green{background:var(--gl);color:var(--green)}.b-blue{background:var(--al);color:var(--accent)}
.b-yellow{background:var(--yl);color:var(--yellow)}.b-red{background:var(--rl);color:var(--red)}
.b-gray{background:var(--s3);color:var(--t2)}.b-orange{background:var(--ol);color:var(--orange)}
.str{width:44px;height:24px;background:var(--border2);border-radius:12px;position:relative;transition:background .2s;flex-shrink:0;cursor:pointer}
.str.on{background:var(--green)}.sth{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.str.on .sth{transform:translateX(20px)}
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:9999;pointer-events:none;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--text);color:#fff;padding:11px 18px;border-radius:var(--r);font-size:14px;font-weight:600;box-shadow:var(--shl);animation:toastIn .25s ease;white-space:nowrap}
.toast-err{background:var(--red)}.toast-ok{background:var(--green)}
@keyframes toastIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none;align-items:center;justify-content:center;padding:16px}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--r);box-shadow:var(--shl);padding:24px 20px;width:100%;max-width:420px}
.modal h3{font-size:18px;font-weight:800;margin-bottom:8px}
.modal p{font-size:14px;color:var(--t2);margin-bottom:16px;line-height:1.5}
.modal-btns{display:flex;gap:10px;flex-direction:column}
/* CART ANIMATION */
@keyframes cartBump{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
.cart-bump{animation:cartBump .3s ease}
@keyframes flyUp{0%{transform:translateY(0) scale(1);opacity:1}100%{transform:translateY(-120px) scale(.3);opacity:0}}
.fly-anim{animation:flyUp .5s ease forwards;pointer-events:none;position:fixed;z-index:300;font-size:28px}
/* BANNER */
.producer-banner{border-radius:var(--r);padding:12px 16px;margin:12px 16px 0;font-size:14px;line-height:1.5;display:flex;align-items:flex-start;gap:10px;border:1px solid rgba(37,99,235,.2);background:var(--al);color:var(--ad)}
.banner-text{flex:1;font-weight:500}
.banner-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--accent);padding:0;opacity:.5;flex-shrink:0;line-height:1}
.banner-close:hover{opacity:1}
/* STATS */
.stat-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
.stat-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.sc{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:13px 10px;text-align:center;box-shadow:var(--sh0)}
.sc .sv{font-size:22px;font-weight:800;color:var(--text);font-family:var(--mono);letter-spacing:-1px}
.sc .sl{font-size:10px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.sc .ss{font-size:11px;color:var(--t2);margin-top:2px}
.sc.c-accent .sv{color:var(--accent)}.sc.c-green .sv{color:var(--green)}.sc.c-orange .sv{color:var(--orange)}.sc.c-yellow .sv{color:var(--yellow)}
/* CATALOG */
.cat-item{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:10px}
.cat-item.unavail{opacity:.55;border-style:dashed}
.ci-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.ci-label{font-size:11px;font-weight:700;color:var(--t2);display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}
.ci-input{width:100%;padding:8px 10px;border-radius:var(--rs);border:1.5px solid var(--border);font-size:14px;font-family:var(--font);color:var(--text);outline:none;background:var(--bg);-webkit-appearance:none;appearance:none;transition:border-color .15s}
.ci-input:focus{border-color:var(--accent);background:var(--white)}
.ci-price-row{display:flex;align-items:center;gap:6px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rs);overflow:hidden;transition:border-color .15s}
.ci-price-row:focus-within{border-color:var(--accent);background:var(--white)}
.ci-price-row input{flex:1;border:none;background:transparent;padding:9px 10px;font-size:16px;font-weight:700;font-family:var(--mono);color:var(--text);outline:none;-webkit-appearance:none}
.ci-price-row span{padding-right:12px;font-size:14px;font-weight:600;color:var(--t2)}
/* HISTORY ITEM */
.hist-item{background:var(--white);border-radius:var(--r);border:1px solid var(--border);margin-bottom:10px;overflow:hidden;box-shadow:var(--sh0)}
.hi-head{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.hi-num{font-size:14px;font-weight:800;color:var(--accent);font-family:var(--mono)}
.hi-date{font-size:12px;color:var(--t2);flex:1}.hi-total{font-size:15px;font-weight:800;font-family:var(--mono)}
.hi-items{padding:10px 16px}
.hi-row{font-size:13px;color:var(--t2);padding:3px 0;display:flex;justify-content:space-between;border-bottom:1px dashed var(--border)}
.hi-row:last-child{border:none}
.hi-foot{padding:9px 16px;border-top:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}
