/* css/styles.css */
:root{
  --bg:#0f1119;
  --panel:#1a1e2b;
  --panel2:#141827;
  --text:#e8eaf2;
  --muted:#a7afc7;
  --border:rgba(255,255,255,.10);

  /* строго заданные акценты */
  --brand1:#004643;
  --brand-mid:#1a8f75;
  --brand-gold:#e8a832;
  --brand2:#ff9a24;
  --danger:#ff4d6d;

  --accent: var(--brand1);
  --gradient-brand: linear-gradient(90deg, var(--brand1) 0%, var(--brand-mid) 40%, var(--brand-gold) 72%, var(--brand2) 100%);
  --gradient-brand-soft: linear-gradient(90deg, rgba(0,70,67,.92) 0%, rgba(26,143,117,.88) 40%, rgba(232,168,50,.85) 72%, rgba(255,154,36,.88) 100%);
  --gradient-brand-135: linear-gradient(135deg, rgba(0,70,67,.95) 0%, rgba(26,143,117,.9) 40%, rgba(232,168,50,.88) 72%, rgba(255,154,36,.85) 100%);
  --shadow: 0 18px 50px rgba(0,0,0,.35);
  --r:16px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* компактная сетка отступов */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --control-h: 38px;
  --control-h-sm: 32px;
  --radius-panel: 14px;
  --radius-control: 10px;
}
*{ box-sizing:border-box; }
html,body{ height:100%; }
html{
  color-scheme: dark;
  overflow-x:hidden;
}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  overflow-x:hidden;
  background:
    radial-gradient(1200px 700px at 15% 10%, rgba(0,70,67,.22), transparent 60%),
    radial-gradient(800px 500px at 42% 12%, rgba(26,143,117,.14), transparent 55%),
    radial-gradient(900px 600px at 85% 20%, rgba(255,154,36,.10), transparent 60%),
    var(--bg);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    var(--gradient-brand-soft),
    linear-gradient(180deg, rgba(15,17,25,0) 0%, rgba(15,17,25,0) 10%, rgba(15,17,25,.35) 45%, rgba(15,17,25,.70) 72%, rgba(15,17,25,1) 100%);
  background-blend-mode:multiply;
  filter:saturate(1.05);
  opacity:.80;
}

.container{ position:relative; z-index:1; max-width:1200px; margin:0 auto; padding:var(--space-md); }
.container--wide{ width:100%; max-width:min(1680px, 100%); box-sizing:border-box; }
.container--narrow{ max-width:720px; }
a{ color:inherit; }
button,input,textarea,select{ font:inherit; color:inherit; }

.topbar{
  position:sticky; top:0; z-index:50;
  height:44px;
  display:flex; align-items:center; gap:var(--space-sm); flex-wrap:nowrap;
  padding:6px 10px;
  background:linear-gradient(180deg, rgba(20,24,39,.92), rgba(20,24,39,.72));
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  box-shadow:var(--shadow);
  backdrop-filter: blur(10px);
  overflow:hidden;
  transition: height .18s ease, padding .18s ease;
}
.topbar.siteTopbar{
  overflow:visible;
  max-width:100%;
  min-width:0;
}
.topbar::before{
  content:"";
  position:absolute;
  left:-1px; right:-1px; top:-1px;
  height:4px;
  background:var(--gradient-brand-soft);
  border-top-left-radius:18px;
  border-top-right-radius:18px;
}
.topbar.compact{
  height:36px;
  padding:4px 8px;
}

.topbar{ --icon: 1rem; --tap: 2.25rem; }
.topbar.compact{ --icon: .95rem; --tap: 2rem; }

.brand{ display:flex; flex-direction:column; gap:2px; margin-right:auto; min-width:0; max-width:52vw; }
.brand b{ letter-spacing:.2px; font-size:0.95rem; line-height:1.1; }
.brand span{ color:var(--muted); font-size:0.75rem; transition: opacity .18s ease, width .18s ease; }
.topbar.compact .brand span{
  opacity:0;
  width:0;
  height:0;
  overflow:hidden;
  pointer-events:none;
}
.brand b{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.tab{
  min-height:44px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  user-select:none;
  font-weight:900;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, padding .18s ease;
}
.tab:hover{ transform: translateY(-1px); background:rgba(255,255,255,.06); }
.tab[aria-pressed="true"]{
  border-color: rgba(255,154,36,.55);
  background: linear-gradient(180deg, rgba(255,154,36,.18), rgba(0,70,67,.08));
  box-shadow: 0 0 0 3px rgba(255,154,36,.10) inset;
}
.tabIcon{ font-size:16px; line-height:1; }
.tabText{ display:inline; }
.topbar.compact .tabText{ display:none; }
@media (max-width: 768px){
  .container{ padding:var(--space-sm); }
  .brand{ max-width:44vw; }
  .topbar{ height:auto; padding:5px 8px; gap:6px; flex-wrap:wrap; }
  .topbar.compact{ height:auto; padding:4px 8px; }
  .tabText{ display:none; }
  .headerNav{ gap:4px; }
}

.pill{
  min-height:var(--control-h-sm);
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
}
.headerNav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  min-width:0;
  overflow-x:auto;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.headerNav::-webkit-scrollbar{ display:none; }
.navLink{
  min-height:var(--control-h-sm);
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  text-decoration:none;
  font-weight:900;
  font-size:13px;
  white-space:nowrap;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.navLink:hover{ transform: translateY(-1px); background:rgba(255,255,255,.06); }
.topbar.compact .navLink{ padding:8px 10px; min-height:36px; font-size:12px; }

/* Акцентные кнопки в шапке (admin/operator/login) */
.navBtn{
  min-height:var(--control-h-sm);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:6px 12px;
  border-radius:var(--radius-control);
  border:0;
  background: var(--brand2);
  color:#fff;
  text-decoration:none;
  font-weight:1000;
  transition: transform .12s ease, filter .12s ease;
  white-space:nowrap;
  flex:0 0 auto;
}
.navBtn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
.navBtn:active{ transform: translateY(0); }
.topbar.compact .navBtn{ min-height:36px; padding:6px 12px; font-size:12px; }

@media (max-width: 768px){
  .navBtn{ padding:6px 10px; min-height:36px; font-size:12px; border-radius:8px; }
}
.iconBtn{
  width: var(--tap);
  height: var(--tap);
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  border-radius:12px;
  display:inline-grid;
  place-items:center;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.topbar.compact .iconBtn{ border-radius:10px; }
.iconBtn:hover{ transform: translateY(-1px); background:rgba(255,255,255,.06); }
.iconBtn:active{ transform: translateY(0); }
.iconBtn span, .iconBtn i, .iconBtn svg{ font-size: var(--icon); line-height:1; }
.iconBtn--categories{ display:none; }
@media (max-width: 980px){
  .iconBtn--categories{ display:inline-grid; }
}
.ico{ width:1em; height:1em; display:inline-block; vertical-align:-0.1em; }
.dot{ width:9px; height:9px; border-radius:50%; background: rgba(167,175,199,.5); }
.dot.ok{ background: rgba(34,197,94,.9); }
.dot.err{ background: rgba(255,77,109,.95); }

.grid{ margin-top:var(--space-md); display:grid; grid-template-columns:1fr; gap:var(--space-md); }
.panel{
  border:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius:var(--radius-panel);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.panel .hd{
  padding:10px var(--space-md);
  display:flex; justify-content:space-between; align-items:center;
  gap:var(--space-sm); flex-wrap:wrap;
  border-bottom:1px solid var(--border);
  background: rgba(0,0,0,.10);
}
.panel .hd h2{ margin:0; font-size:14px; font-weight:1000; }
.panel .hd .sub{ margin-top:2px; color:var(--muted); font-size:11px; line-height:1.3; }
.panel .bd{ padding:var(--space-md); }

.btn{
  min-height:var(--control-h);
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  padding:7px 11px;
  border-radius:var(--radius-control);
  cursor:pointer;
  font-weight:900;
  font-size:13px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.btn.loading{
  opacity:.85;
  pointer-events:none;
}
.btn.loading::after{
  content:"";
  width:14px; height:14px;
  margin-left:10px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.22);
  border-top-color: rgba(255,255,255,.9);
  display:inline-block;
  animation: spin .8s linear infinite;
  vertical-align:-2px;
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.06); box-shadow:0 12px 30px rgba(255,154,36,.08); }
.btn.primary{
  color:#fff;
  border-color: rgba(0,70,67,.65);
  background: var(--gradient-brand-135);
  box-shadow: 0 12px 30px rgba(0,70,67,.18);
}
.btn.danger{
  border-color: rgba(255,77,109,.50);
  background: linear-gradient(180deg, rgba(255,77,109,.20), rgba(255,77,109,.10));
}
.btn.small{ min-height:var(--control-h-sm); padding:5px 9px; border-radius:9px; font-size:12px; }

.btn.pulse{ animation: pulse .24s ease; }
@keyframes pulse{ from{ transform:scale(1); } 50%{ transform:scale(1.03);} to{ transform:scale(1);} }

.row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.hint{ color:var(--muted); font-size:12px; line-height:1.35; }
.error{ color:#ffd1da; font-weight:900; font-size:12px; }
.okmsg{ color:#c7f9d6; font-weight:900; font-size:12px; }
.code{
  font-family:var(--mono);
  font-size:12px;
  padding:2px 6px;
  border-radius:8px;
  border:1px solid rgba(255,154,36,.35);
  background: rgba(255,154,36,.10);
  color: #ffe8c7;
  display:inline-block;
}
.check{
  min-height:44px;
  display:inline-flex; align-items:center; gap:10px;
  padding:9px 10px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius:12px;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  user-select:none;
}

.form{ display:grid; grid-template-columns: 1fr 1fr; gap:var(--space-md); }
.form--single{ grid-template-columns:1fr; }
.form--checkout{ grid-template-columns:1fr 1fr; }
@media (max-width: 820px){
  .form, .form--checkout{ grid-template-columns:1fr; }
}
.form .full, .form .span-2{ grid-column:1 / -1; }
label{ display:flex; flex-direction:column; gap:var(--space-xs); font-size:11px; color:var(--muted); font-weight:900; }
input[type="text"], input[type="url"], input[type="number"], input[type="tel"], input[type="email"], input[type="password"], textarea, select{
  width:100%;
  min-height:var(--control-h);
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background: var(--panel);
  padding:7px 10px;
  outline:none;
  font-size:14px;
}
input[type="date"]{
  width:100%;
  min-height:var(--control-h);
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background: var(--panel);
  padding:7px 10px;
  outline:none;
  color:var(--text);
}
input::placeholder, textarea::placeholder{ color: rgba(167,175,199,.75); }
select{
  color-scheme: dark;
}
select option{
  background-color: var(--panel);
  color: var(--text);
}
input:focus, textarea:focus, select:focus, input[type="date"]:focus{ border-color: rgba(255,154,36,.45); box-shadow: 0 0 0 3px rgba(255,154,36,.10); }
input[type="date"]::-webkit-calendar-picker-indicator{ filter: invert(1); opacity:.85; }
textarea{ min-height:72px; resize:vertical; }
.full{ grid-column: 1 / -1; }

.page-panel{ margin-top:var(--space-md); }
.page-actions{ margin-top:var(--space-md); justify-content:flex-end; gap:var(--space-sm); }
.authAlert{ margin-top:var(--space-md); }
.authFormActions{
  display:flex;
  flex-direction:column;
  gap:var(--space-sm);
}
.authFootHint{
  margin-top:14px;
  text-align:center;
  line-height:1.4;
}
.consentRow{
  display:flex;
  gap:var(--space-sm);
  align-items:flex-start;
  font-size:12px;
  line-height:1.35;
  color:var(--muted);
}
.consentRow input[type="checkbox"]{
  width:18px;
  height:18px;
  min-height:18px;
  margin-top:2px;
  flex-shrink:0;
}
.datePickRow{ display:flex; gap:var(--space-sm); flex-wrap:wrap; margin-top:var(--space-xs); }
.panel--nested{ box-shadow:none; margin-top:var(--space-xs); }
.panel--nested .bd{ padding:var(--space-sm) var(--space-md); }

table{ width:100%; border-collapse:collapse; font-size:13px; }
thead th{ text-align:left; font-size:11px; color:var(--muted); background: rgba(0,0,0,.22); border-bottom:1px solid var(--border); padding:8px 10px; position:sticky; top:0; z-index:1; }
tbody td{ border-bottom:1px solid var(--border); padding:8px 10px; vertical-align:top; }
.tableWrap{ max-height:480px; overflow:auto; border:1px solid var(--border); border-radius:var(--radius-panel); }

.storeGrid{ display:grid; grid-template-columns: 1fr; gap:var(--space-md); align-items:start; }
.catalogLayout{ width:100%; max-width:100%; min-width:0; }
.catalogPanel{ box-shadow:none; border:0; background:transparent; min-width:0; max-width:100%; }
.catalogPanel .bd{ padding:0; min-width:0; max-width:100%; }
.catalogCountHint{
  margin:0 0 var(--space-sm);
  font-size:11px;
  color:var(--muted);
}
.promoCarousel{
  margin-bottom:var(--space-sm);
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;
}
.promoHd{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--space-sm);
  margin:0 0 var(--space-sm);
}
.promoHd b{ font-size:14px; }
.promoViewport{
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;
}
.promoTrack{
  display:flex;
  flex-wrap:nowrap;
  align-items:stretch;
  gap:var(--space-md);
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:scroll;
  overflow-y:hidden;
  scroll-padding-inline:var(--space-sm);
  padding:0 var(--space-sm) 6px;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  touch-action:pan-x;
  scrollbar-width:none;
  cursor:grab;
  user-select:none;
}
.promoTrack.is-dragging{
  cursor:grabbing;
}
.promoTrack.is-dragging .promoCard{ pointer-events:none; }
.promoTrack::-webkit-scrollbar{ display:none; }
.promoCard{
  flex:0 0 auto;
  cursor:pointer;
  width:min(300px, calc((100% - var(--space-md)) / 2));
  max-width:300px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-panel);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow:hidden;
  text-align:left;
  color:inherit;
  cursor:default;
  display:grid;
  grid-template-columns:112px 1fr;
  gap:0;
  padding:0;
  font:inherit;
  appearance:none;
  -webkit-appearance:none;
}
.promoCard:focus-visible{
  outline:2px solid rgba(255,154,36,.65);
  outline-offset:2px;
}
.promoImg{
  position:relative;
  background: rgba(0,0,0,.18);
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px;
  min-height:104px;
  overflow:hidden;
}
.promoImg img{ width:100%; height:88px; object-fit:contain; display:block; }
.promoImgBadge{
  position:absolute;
  z-index:2;
  font-weight:1000;
  font-size:10px;
  line-height:1.2;
  border-radius:4px;
  padding:4px 6px;
  max-width:calc(100% - 8px);
  box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.promoImgBadge--sale{
  top:4px;
  right:4px;
  background:#e53935;
  color:#fff;
  text-align:center;
}
.promoImgBadge--bb{
  right:4px;
  bottom:4px;
  background:rgba(55,60,70,.82);
  color:#fff;
  font-weight:700;
  font-size:9px;
}
.promoImgBadge--bb b{ font-weight:1000; }
.promoMeta{ padding:10px 12px; display:flex; flex-direction:column; gap:6px; min-width:0; justify-content:center; }
.promoName{
  font-weight:1000;
  font-size:13px;
  line-height:1.3;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  white-space:normal;
}
.promoPrice{ display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.promoPrice .old{ color:rgba(255,255,255,.55); text-decoration:line-through; font-size:12px; }
.promoPrice .new{ font-weight:1000; font-size:15px; }
.promoActions{ margin-top:2px; cursor:default; }
.promoBuyBtn{
  width:100%;
  padding:6px 8px;
  font-size:12px;
  line-height:1.2;
}
.promoStepper{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.promoStepBtn{
  min-width:28px;
  padding:4px 8px;
}
.promoQty{
  min-width:1.4em;
  text-align:center;
  font-weight:1000;
  font-size:13px;
}

.promoName[data-promo-open]{ cursor:pointer; }
@media (min-width:768px){
  .promoCard{ width:min(300px, calc((100% - 2 * var(--space-md)) / 3)); }
}
@media (min-width:1200px){
  .promoCard{ width:min(320px, calc((100% - 3 * var(--space-md)) / 4)); }
}
.cards{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--space-sm);
  width:100%;
  min-width:0;
}
.cards > .hint{ grid-column:1 / -1; margin:0; }
.card{
  width:100%;
  min-width:0;
  max-width:none;
  border:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius:var(--radius-panel);
  overflow:hidden;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
  position:relative;
  display:flex;
  flex-direction:column;
  content-visibility:auto;
  contain-intrinsic-size:240px 210px;
}
@media (min-width:768px){
  .cards{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}
@media (min-width:1024px){
  .cards{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
}
@media (min-width:1600px){
  .cards{ grid-template-columns:repeat(5, minmax(0, 1fr)); }
}
.card:hover{ transform: translateY(-2px); border-color: rgba(255,154,36,.45); box-shadow:0 20px 50px rgba(255,154,36,.10); }
.card.clickable{ cursor:pointer; }
.card .img{
  height:118px;
  background: rgba(0,0,0,.18);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.card .img .promoImgBadge{ z-index:3; pointer-events:none; }
.card .img .quickViewBtn{ z-index:4; }
.card .price--promo{
  display:flex;
  align-items:baseline;
  gap:6px;
  flex-wrap:wrap;
}
.card .priceOld{
  color:rgba(255,255,255,.5);
  text-decoration:line-through;
  font-size:12px;
  font-weight:700;
}
.card .priceNew{
  color:var(--brand2);
  font-weight:1000;
  font-size:15px;
}
.card .img:hover .quickViewBtn{ opacity:1; pointer-events:auto; }
.quickViewBtn{
  position:absolute;
  inset:0;
  margin:auto;
  width:max-content;
  max-width:92%;
  min-height:36px;
  padding:6px 10px;
  border-radius:var(--radius-control);
  border:1px solid rgba(255,255,255,.25);
  background:rgba(15,17,25,.72);
  color:#fff;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.quickViewBtn.show,
.quickViewBtn:focus-visible{ opacity:1; pointer-events:auto; }
@media (max-width:768px){
  .card .img:hover .quickViewBtn{ opacity:0; pointer-events:none; }
  .quickViewBtn.show{ opacity:1; pointer-events:auto; }
}
.card .img img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.card .ct{ padding:8px 10px 10px; display:flex; flex-direction:column; gap:5px; flex:1; min-width:0; }
.card h3{
  margin:0;
  font-size:13px;
  line-height:1.25;
  display:-webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.cardTitleLink{
  color:inherit;
  text-decoration:none;
}
.cardTitleLink:hover{ color:var(--brand2); }
.btn.disabled,
a.btn.disabled{
  opacity:.45;
  pointer-events:none;
}
.desc{ margin:0; color:var(--muted); font-size:11px; line-height:1.3; }
.cardFoot{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:6px;
  margin-top:auto;
  min-width:0;
}
.price{ font-weight:1000; font-size:14px; line-height:1.2; }
.addRow{
  display:flex;
  gap:6px;
  align-items:center;
  justify-content:stretch;
  flex-wrap:nowrap;
  width:100%;
  min-width:0;
}
.addRow .btn.addToCartBtn{ width:100%; min-height:var(--control-h-sm); padding:6px 8px; font-size:12px; }
.qty{ width:72px; max-width:100%; min-height:var(--control-h-sm); padding:6px 8px; }
.cardStepper{
  width:100%;
  min-width:0;
  max-width:100%;
  min-height:var(--control-h-sm);
  padding:2px;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background: rgba(255,255,255,.03);
  display:grid;
  grid-template-columns:34px 1fr 34px;
  align-items:center;
  gap:2px;
  box-sizing:border-box;
}
.cardStepper .cardStepQty{
  text-align:center;
  font-weight:1000;
  font-size:13px;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cardStepper .cardStepBtn{
  width:34px;
  height:34px;
  min-width:34px;
  min-height:34px;
  max-width:34px;
  padding:0;
  border-radius:8px;
  display:grid;
  place-items:center;
  font-size:16px;
  line-height:1;
}
.badge{ position:absolute; top:6px; left:6px; z-index:2; padding:4px 8px; border-radius:999px; font-weight:1000; font-size:11px; }
.badge--promo{
  border:1px solid rgba(255,77,109,.55);
  background:#ff4d6d;
  color:#fff;
}

.filters{ margin-bottom:var(--space-sm); }
.filtersRow{ display:flex; gap:var(--space-sm); flex-wrap:wrap; align-items:center; }
.filtersField{ display:flex; flex-direction:column; gap:var(--space-xs); color:var(--muted); font-size:11px; font-weight:900; }
.catalogPriceFilters{
  display:flex;
  align-items:center;
  gap:var(--space-sm);
  flex-wrap:wrap;
  margin-bottom:var(--space-sm);
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:var(--radius-control);
  background:rgba(0,0,0,.12);
  max-height:15vh;
}
.catalogPriceFilters .filtersLabel{
  font-size:11px;
  font-weight:900;
  color:var(--muted);
  white-space:nowrap;
}
.catalogPriceFilters input[type="number"]{
  width:68px;
  min-height:var(--control-h-sm);
  padding:5px 8px;
  font-size:13px;
}
.catalogPriceFilters .filtersSep{
  color:var(--muted);
  font-size:12px;
  user-select:none;
}
.seg{ display:flex; gap:4px; padding:3px; border:1px solid var(--border); border-radius:999px; background:rgba(0,0,0,.18); }
.segBtn{ min-height:30px; border:0; background:transparent; padding:5px 10px; border-radius:999px; cursor:pointer; font-weight:900; font-size:12px; color:var(--text); }
.segBtn[aria-pressed="true"], .segBtn.primary{ background: rgba(255,154,36,.18); color: #fff; }

.cartList{ display:flex; flex-direction:column; gap:6px; }
.cartItem{
  border:1px solid var(--border);
  border-radius:var(--radius-control);
  padding:8px 10px;
  background: rgba(0,0,0,.20);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cartTop{ display:flex; justify-content:space-between; align-items:flex-start; gap:var(--space-sm); }
.cartTop b{ font-size:13px; line-height:1.25; }
.cartMeta{ display:flex; gap:6px; flex-wrap:wrap; align-items:center; color:var(--muted); font-size:11px; }
.sumRow{ display:flex; justify-content:space-between; gap:var(--space-sm); padding-top:var(--space-sm); border-top:1px solid var(--border); font-weight:1000; font-size:14px; }
.sumRow--sub{ font-weight:600; font-size:13px; color:var(--muted); border-top:none; padding-top:4px; }
.sumRow--sub + .sumRow--sub{ padding-top:2px; }
.cartEmpty{ padding:var(--space-md); border:1px dashed rgba(255,255,255,.12); border-radius:var(--radius-panel); background: rgba(0,0,0,.18); text-align:center; }

.srOnly{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.siteTopbar{
  flex-wrap:wrap;
  gap:var(--space-sm);
  height:auto;
  min-height:44px;
  align-content:center;
  row-gap:6px;
}
.topbar.compact.siteTopbar{
  height:auto;
  min-height:36px;
}
.headerStack{ display:flex; flex-direction:column; gap:var(--space-sm); }

.devNotice{
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-panel);
  background: rgba(0,0,0,.16);
  overflow:hidden;
}
.devNoticeBtn{
  width:100%;
  border:0;
  background: transparent;
  color:inherit;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-sm);
  padding:8px 10px;
  font-weight:1000;
}
.devNoticeTitle{ font-size:12px; color:rgba(255,255,255,.92); }
.devNoticeTitle b{ color:#ffe8c7; }
.devNoticeChevron i{ font-size:12px; opacity:.8; transition: transform .15s ease; }
.devNotice:not(.collapsed) .devNoticeChevron i{ transform: rotate(180deg); }
.devNoticeBody{
  padding:0 10px 10px;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}
.siteBrand{ text-decoration:none; color:inherit; flex:0 0 auto; }
.headerSearchWrap{
  flex:1 1 200px;
  min-width:140px;
  max-width:420px;
  position:relative;
}
.storeSearchMobile{
  display:none;
  position:relative;
  margin:0 0 var(--space-sm);
}
.storeSearchInput{
  width:100%;
  min-height:var(--control-h);
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(0,0,0,.2);
  padding:8px 12px;
  color:var(--text);
  font-size:16px;
}
.headerSearch{
  width:100%;
  min-height:var(--control-h-sm);
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(0,0,0,.2);
  padding:6px 10px;
  color:var(--text);
  font-size:14px;
}
.headerAuth{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  flex:0 0 auto;
  position:relative;
  z-index:120;
}
.accountMenu{
  position:relative;
  display:none;
  align-items:center;
}
.accountBtn{
  min-height:var(--control-h-sm);
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:var(--radius-control);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: var(--text);
  font-weight:1000;
  cursor:pointer;
}
.accountBtn:hover{ background: rgba(255,255,255,.05); }
.accountBtn:active{ transform: translateY(1px); }
.accountBtn.open .accountChevron i{ transform: rotate(180deg); }
.accountIcon i{ font-size:16px; opacity:.95; }
.accountName{ max-width:160px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-size:13px; }
.accountChevron i{
  font-size:12px;
  opacity:.8;
  display:inline-block;
  transition: transform .15s ease;
}
.accountDropdown{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  min-width: 240px;
  max-width: min(320px, calc(100vw - 24px));
  border-radius:var(--radius-panel);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(20,24,39,.98);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  overflow:hidden;
  z-index:200;
}
.accountItem{
  display:flex;
  width:100%;
  border:0;
  background:transparent;
  color:inherit;
  text-decoration:none;
  padding:10px 12px;
  font-weight:900;
  font-size:13px;
  cursor:pointer;
  text-align:left;
}
.accountItem:hover{ background: rgba(255,255,255,.06); }
.accountItem.danger{ color:#ffd0d0; }
.accountSep{ height:1px; background: rgba(255,255,255,.10); }
.headerLoginBtn{ min-height:var(--control-h-sm); text-decoration:none; display:inline-flex; align-items:center; padding:6px 12px; font-size:13px; }
.headerUserName{ font-size:13px; color:var(--muted); max-width:120px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.headerCartBtn{ position:relative; text-decoration:none; }
.headerCartBadge{
  position:absolute;
  top:-4px;
  right:-4px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  background:var(--danger);
  color:#fff;
  font-size:11px;
  font-weight:1000;
  display:grid;
  place-items:center;
}
.categoryBar{
  display:flex;
  gap:6px;
  overflow-x:auto;
  padding:4px;
  margin-top:var(--space-sm);
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  background:rgba(0,0,0,.12);
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.categoryBar::-webkit-scrollbar{ display:none; }
.categoryTab{
  flex:0 0 auto;
  min-height:34px;
  padding:6px 11px;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  color:var(--text);
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  white-space:nowrap;
}
.categoryTab.active,
.categoryTab[aria-pressed="true"]{
  background:rgba(255,154,36,.18);
  border-color:rgba(255,154,36,.45);
}
.siteFooter{ margin-top:var(--space-sm); padding:var(--space-md) 0 var(--space-sm); border-top:1px solid var(--border); }
.siteFooterInner{ display:flex; flex-wrap:wrap; gap:var(--space-sm) var(--space-md); justify-content:center; font-size:12px; }

/* Store tab bar (like admin nav, but horizontal) */
.storeTabBar{
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px;
  margin-top:var(--space-sm);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
  border-radius:var(--radius-panel);
  overflow-x:auto;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.storeTabBar::-webkit-scrollbar{ display:none; }
.storeTab{
  flex:0 0 auto;
  min-height:34px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  color: var(--text);
  border-radius:var(--radius-control);
  padding:6px 11px;
  cursor:pointer;
  font-weight:1000;
  font-size:12px;
  transition: background .15s ease, transform .12s ease, border-color .15s ease;
}
.storeTab:hover{ transform: translateY(-1px); background: rgba(255,255,255,.05); }
.storeTab.active,
.storeTab[aria-pressed="true"]{
  border-color: rgba(255,154,36,.55);
  background: rgba(255,154,36,.16);
}
@media (max-width: 768px){
  .storeTab{ min-height:32px; padding:5px 10px; font-size:11px; }
}
.categoryBarMount{ margin-top:var(--space-sm); }
.storeShell{
  display:grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap:var(--space-md);
  align-items:start;
  margin-top:var(--space-sm);
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:clip;
}
.catSidebar{
  position:sticky;
  top:56px;
  align-self:start;
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-panel);
  background: rgba(0,0,0,.14);
  overflow:hidden;
  max-height: calc(100vh - 80px);
}
.catSidebarInner{ padding:var(--space-sm); }
.catSidebar .hint{ margin:0 0 var(--space-sm); font-size:11px; }
.catSidebar .categoryBar{
  display:flex;
  flex-direction:column;
  gap:6px;
  overflow:auto;
  padding:0;
  margin:0;
  border:0;
  border-radius:0;
  background: transparent;
}
.catGroup{ margin:0 0 var(--space-sm); }
.catSub{ display:flex; flex-direction:column; gap:6px; margin-top:6px; padding-left:10px; border-left:1px solid rgba(255,255,255,.08); }
.catSidebar .categoryTab{
  width:100%;
  justify-content:flex-start;
}
.storeMain{
  min-width:0;
  max-width:100%;
  overflow-x:clip;
}
.storeSection,
.storeMount,
#storeMount{
  width:100%;
  max-width:100%;
  min-width:0;
}
.storeSection{ margin-top:0; }
@media (max-width: 980px){
  .storeShell{ grid-template-columns: 1fr; }
  .catSidebar{ display:none; }
}

.drawer.drawer--left{
  left:0;
  right:auto;
  border-left:0;
  border-right:1px solid var(--border);
  transform: translateX(-102%);
}
.drawer.drawer--left.open{ transform: translateX(0); }

.pre{ margin:var(--space-sm) 0 0; white-space:pre-wrap; background:#0b1020; border:1px solid rgba(255,255,255,.08); color:#e8eaf2; border-radius:var(--radius-panel); padding:var(--space-md); font-family:var(--mono); font-size:12px; line-height:1.4; }
.cartEmptyIcon{ font-size:22px; opacity:.95; margin-bottom:var(--space-xs); }
.cartEmptyText{ font-weight:1000; font-size:14px; }
.page-footer{ margin-top:var(--space-md); }
.checkout-panel .form{ gap:var(--space-md); }
.checkoutSummary{
  margin-bottom:var(--space-md);
  padding:var(--space-md);
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  background:rgba(255,255,255,.02);
}

.addressField{ position:relative; }
.address-suggestions{
  position:absolute;
  left:0; right:0;
  top:100%;
  margin-top:6px;
  z-index:40;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: #1a1e2b;
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  overflow:hidden;
  transform: translateY(-2px);
  opacity: 0;
  transition: opacity .12s ease, transform .12s ease;
  max-height: 220px;
}
.address-suggestions[style*="display: block"]{ opacity:1; transform: translateY(0); }
.suggestion-item,
button.suggestion-item{
  display:block;
  width:100%;
  text-align:left;
  border:0;
  background:transparent;
  color:inherit;
  font:inherit;
  cursor:pointer;
}
button.suggestion-item{
  padding:10px 12px;
  cursor:pointer;
  border-top:1px solid rgba(255,255,255,.06);
  font-weight:900;
  font-size:13px;
}
.suggestion-item:first-child{ border-top:0; }
.suggestion-item:hover{ background: rgba(255,255,255,.06); }

/* simple modal overlay already in index.html */
.overlay{ position:fixed; inset:0; z-index:100; background: rgba(0,0,0,.65); display:none; align-items:center; justify-content:center; padding:var(--space-md); }
.overlay.show{ display:flex; }
.modal{ width:min(860px, 100%); border:1px solid var(--border); background: rgba(20,24,39,.92); border-radius:var(--radius-panel); box-shadow: var(--shadow); overflow:hidden; max-height:92vh; display:flex; flex-direction:column; }
.modalHd{ padding:10px var(--space-md); display:flex; justify-content:space-between; align-items:center; gap:var(--space-sm); border-bottom:1px solid var(--border); flex-shrink:0; }
.modalHd b{ font-size:14px; }
.modalClose{ min-width:36px; min-height:36px; border:1px solid var(--border); background: rgba(255,255,255,.05); border-radius:var(--radius-control); cursor:pointer; font-weight:1000; display:grid; place-items:center; font-size:18px; }
.modalBd{ padding:var(--space-md); overflow:auto; }
.modalGrid{ display:grid; grid-template-columns: 1.05fr .95fr; gap:var(--space-md); }
.product-details .bd{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:var(--space-md);
  align-items:start;
}
@media (max-width:860px){
  .product-details .bd{ grid-template-columns:1fr; }
}
.product-details .modalImg{ min-height:140px; max-height:50vh; }
.page-content{ max-width:720px; margin:0 auto; line-height:1.6; }
.page-content h1{ margin:0 0 12px; font-size:1.35rem; }
.page-content h2{ font-size:1.05rem; margin:1.25em 0 .5em; }
.page-content ul{ padding-left:1.25em; margin:.5em 0 1em; }
.page-content li{ margin:.35em 0; }
.page-content p{ margin:.65em 0; }
.page-content .contactBlock{ margin-top:1em; padding-top:1em; border-top:1px solid var(--border); }
.panel--narrow{ max-width:640px; margin-left:auto; margin-right:auto; }
.orderOut{
  text-align:left;
  margin:16px 0;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.15);
  font-size:13px;
  line-height:1.45;
  white-space:pre-wrap;
}
@media (max-width: 860px){ .modalGrid{ grid-template-columns:1fr; } }
.modalImg{
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  overflow:hidden;
  background: rgba(0,0,0,.20);
  min-height:140px;
  max-height:50vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.modalImg img{
  width:100%;
  height:auto;
  max-height:50vh;
  object-fit:contain;
  display:block;
}
.chip{ display:inline-flex; gap:6px; align-items:center; padding:5px 9px; border-radius:999px; border:1px solid var(--border); background: rgba(255,255,255,.04); font-size:11px; color:var(--muted); font-weight:900; }
.chip strong{ color:var(--text); }
.btn.block{ display:flex; width:100%; justify-content:center; align-items:center; }
.modalChips{ display:flex; gap:var(--space-sm); flex-wrap:wrap; margin-bottom:var(--space-sm); }
.modalDescPanel{ box-shadow:none; }
.modalDescPanel .bd{ padding:var(--space-sm) var(--space-md); }
.modalDescPanel .hint{ margin-bottom:var(--space-xs); }
.modalDescText{ white-space:pre-wrap; line-height:1.35; font-size:13px; }
.modalAddBar{ justify-content:flex-end; margin-top:var(--space-sm); flex-wrap:wrap; gap:var(--space-sm); }
.storeMount{ margin-top:var(--space-md); }
.storeAlert{ margin-top:var(--space-md); }

/* Mobile cart bar + drawer */
.mobileCartBar{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:80;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
  background: linear-gradient(180deg, rgba(15,17,25,.10), rgba(15,17,25,.85));
  border-top:1px solid var(--border);
  backdrop-filter: blur(10px);
}
.mobileCartBar .inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.badgeCount{
  min-width:28px;
  height:28px;
  display:inline-grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,154,36,.45);
  background: rgba(255,154,36,.14);
  font-weight:1000;
  font-size:12px;
  color:#ffe8c7;
}

.drawer{
  position:fixed;
  top:0; right:0;
  height:100%;
  width:min(420px, 92vw);
  z-index:95;
  background: rgba(20,24,39,.95);
  border-left:1px solid var(--border);
  box-shadow: var(--shadow);
  transform: translateX(102%);
  transition: transform .18s ease;
  display:flex;
  flex-direction:column;
}
.drawer.open{ transform: translateX(0); }
.drawer .hd{
  padding:10px var(--space-md);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-sm);
  border-bottom:1px solid var(--border);
  background: rgba(0,0,0,.10);
  flex-shrink:0;
}
.drawer .bd{
  padding:var(--space-md);
  overflow:auto;
  flex:1;
}

/* Desktop: hide mobile bar and drawer trigger */
@media (min-width: 981px){
  .mobileCartBar{ display:none !important; }
}

/* Mobile UI components exist in DOM always; hide by default */
.mobileNav{ display:none; }
.orderCta{ display:none; }

@media (min-width: 981px){
  .mobileNav{ display:none !important; }
  .orderCta{ display:none !important; }
  /* desktop: keep drawer as side panel */
  .drawer{ top:0; right:0; left:auto; bottom:auto; transform: translateX(102%); border-top:0; border-radius:0; }
  .drawer.open{ transform: translateX(0); }
}

.spinner{
  width:16px; height:16px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.16);
  border-top-color: rgba(255,154,36,.95);
  display:inline-block;
  animation: spin .8s linear infinite;
}
@keyframes spin{ to{ transform: rotate(360deg); } }

/* Compact / tablet: упрощённая шапка и нижняя панель (769–980px и уже) */
@media (max-width: 980px){
  body{ padding-bottom: calc(54px + env(safe-area-inset-bottom, 0px)); }
  .pill{ min-height:32px; padding:5px 9px; }
  .pill #statusText{ display:none; }
  .headerSearchWrap{ display:none !important; }
  .storeSearchMobile{ display:block; }
  .siteTopbar .headerNav,
  .siteTopbar #headerCartBtn,
  .siteTopbar #btnHeaderFilters{ display:none !important; }
  .siteTopbar .headerAuth{
    gap:4px;
    flex-shrink:0;
  }
  .siteTopbar #navRegister{ display:none; }
  .siteTopbar .headerLoginBtn{
    min-height:32px;
    padding:5px 10px;
    font-size:12px;
  }
  .siteTopbar .accountBtn{
    min-height:32px;
    padding:5px 8px;
    gap:4px;
  }
  .siteTopbar .accountName,
  .siteTopbar .accountChevron{ display:none; }
  .siteTopbar .pill{ flex-shrink:0; }

  .mobileCartBar{ display:none !important; }
  .mobileNav{
    display:block !important;
    position:fixed;
    left:0; right:0; bottom:0;
    z-index:85;
    padding:6px 8px calc(6px + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(180deg, rgba(15,17,25,.05), rgba(15,17,25,.90));
    border-top:1px solid var(--border);
    backdrop-filter: blur(10px);
  }
  .mobileNav .inner{
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns: repeat(5, 1fr);
    gap:8px;
  }
  .mobileNavBtn{
    min-height:42px;
    border:1px solid var(--border);
    background: rgba(255,255,255,.03);
    border-radius:var(--radius-panel);
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    font-weight:1000;
    position:relative;
    cursor:pointer;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
    color:inherit;
    font:inherit;
  }
  .mobileNavBtn .label{ display:none; }
  .mobileNavBtn--active{
    border-color:rgba(255,154,36,.45);
    background:rgba(255,154,36,.12);
  }
  .mobileNavBadge{
    position:absolute;
    top:6px; right:10px;
    min-width:20px; height:20px;
    padding:0 6px;
    border-radius:999px;
    display:inline-grid;
    place-items:center;
    border:1px solid rgba(255,154,36,.55);
    background: rgba(255,154,36,.16);
    color:#ffe8c7;
    font-size:11px;
  }
  .orderCta{
    position:fixed;
    left:12px; right:12px;
    bottom: calc(68px + env(safe-area-inset-bottom, 0px));
    z-index:86;
    min-height:var(--control-h);
    border-radius:var(--radius-panel);
    border:1px solid rgba(0,70,67,.65);
    background: var(--gradient-brand-135);
    box-shadow: 0 18px 50px rgba(0,0,0,.45);
    color:#fff;
    font-weight:1100;
    display:none !important;
    align-items:center;
    justify-content:center;
  }
  .orderCta.show{ display:flex !important; }
}

/* Mobile: bottom navigation + sheet ergonomics */
@media (max-width: 768px){
  .cards{ gap:var(--space-sm); }
  .cards{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .card{ max-width:none; }
  .card .img{ height:110px; flex-shrink:0; }
  .card .ct{
    flex:1;
    min-height:0;
    overflow:hidden;
  }
  .card h3{
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .card .desc{
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .addRow{ flex-direction:column; align-items:stretch; }
  .addRow .qty{ width:100%; }
  .addRow .btn{ width:100%; min-height:var(--control-h); }
  .cardStepper{
    grid-template-columns:38px 1fr 38px;
    min-height:var(--control-h);
  }
  .cardStepper .cardStepBtn{
    width:38px;
    height:38px;
    min-width:38px;
    min-height:38px;
    max-width:38px;
  }

  .modal{ width:100%; border-radius:var(--radius-panel); }
  .modalBd{ padding:var(--space-sm) var(--space-md); }
  .modalAddBar{ position:sticky; bottom:0; background: linear-gradient(180deg, rgba(20,24,39,0), rgba(20,24,39,.96) 40%); padding-top:var(--space-sm); }
  .modalAddBar .btn{ width:100%; min-height:var(--control-h); }

  .drawer{
    top:auto; right:auto; left:0; bottom:0;
    width:100%;
    height: calc(92vh);
    max-height: calc(92vh);
    border-left:0;
    border-top:1px solid var(--border);
    border-top-left-radius:18px;
    border-top-right-radius:18px;
    transform: translateY(102%);
    transition: transform .22s ease;
    will-change: transform;
  }
  .drawer.open{ transform: translateY(40%); } /* half-open by default */
  .drawer.full{ transform: translateY(0); }
  .drawer .hd{ position:relative; }
  .dragHandle::before{
    content:""; position:absolute; left:50%; top:10px; transform:translateX(-50%);
    width:46px; height:5px; border-radius:999px; background: rgba(255,255,255,.16);
  }

  .sheet{ display:flex; flex-direction:column; height:100%; }
  .sheetBody{ overflow:auto; padding-bottom:var(--space-sm); }
  .sheetFooter{
    position:sticky;
    bottom:0;
    padding-top:var(--space-sm);
    background: linear-gradient(180deg, rgba(20,24,39,0), rgba(20,24,39,.96) 35%);
    border-top:1px solid rgba(255,255,255,.08);
  }
  .sheetFooter .btn{ width:100%; min-height:var(--control-h); }
  .sheetFooter .btn.danger{ width:auto; }
}

.searchField{ position:relative; }
.prodSearchSug{ z-index:45; }

.cardStepper.modalStepper{
  justify-content:stretch;
  width:100%;
  max-width:280px;
  margin-left:auto;
}

/* Desktop: плавающая панель корзины (каталог на всю ширину) */
.catalogCartDock{
  display:none;
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:75;
  padding:8px 12px calc(8px + env(safe-area-inset-bottom, 0px));
  background: linear-gradient(180deg, rgba(15,17,25,.05), rgba(15,17,25,.92));
  border-top:1px solid var(--border);
  backdrop-filter: blur(12px);
}
.catalogCartDock.show{ display:block; }
@media (max-width:980px){
  .catalogCartDock{ display:none !important; }
}
body.catalogDockOpen{ padding-bottom:64px; }
@media (min-width:981px){
  body.catalogDockOpen .scrollTopBtn{ bottom:88px; }
}
.catalogCartDockInner{
  max-width:min(1680px, 100%);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.catalogCartDockSum{ font-size:14px; }
.catalogCartDockSum b{ font-size:16px; margin:0 4px; }
.catalogCartDockActions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.catalogCartDockActions .btn{
  min-height:var(--control-h-sm);
  display:inline-flex;
  align-items:center;
}

.scrollTopBtn{
  position:fixed;
  right:16px;
  bottom:100px;
  z-index:90;
  width:48px; height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(20,24,39,.55);
  color:var(--text);
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 24px rgba(0,0,0,.35);
  backdrop-filter: blur(8px);
  transition: opacity .2s ease, transform .2s ease;
  opacity:0;
  transform: scale(.9);
  pointer-events:none;
}
.scrollTopBtn.show{
  display:flex;
  opacity:1;
  transform: scale(1);
  pointer-events:auto;
}
@media (max-width: 768px){
  .scrollTopBtn{
    right:auto;
    left:16px;
    bottom: calc(88px + env(safe-area-inset-bottom, 0px));
  }
}

.cartFlyDot{
  position:fixed;
  left:0; top:0;
  width:28px; height:28px;
  margin:-14px 0 0 -14px;
  border-radius:50%;
  background: radial-gradient(circle at 30% 30%, var(--brand2), var(--brand-mid) 55%, var(--brand1));
  box-shadow:0 4px 14px rgba(0,0,0,.4);
  z-index:300;
  pointer-events:none;
  transition: transform .45s cubic-bezier(.2,.8,.2,1), opacity .45s ease;
  opacity:.95;
}

.mobileNavBadge.cartBadgePulse{
  animation: cartPop .45s ease;
}
@keyframes cartPop{
  0%{ transform: scale(1); }
  40%{ transform: scale(1.28); }
  100%{ transform: scale(1); }
}

.ordersList{ display:flex; flex-direction:column; gap:var(--space-sm); }
@media (min-width:1100px){
  .ordersList--grid{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap:var(--space-sm);
    align-items:start;
  }
}
.orderCard{
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  padding:10px var(--space-md);
  background: rgba(0,0,0,.18);
}
.orderCardHd{ display:flex; align-items:center; justify-content:space-between; gap:var(--space-sm); flex-wrap:wrap; }
.orderCardBody{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 220px);
  gap:var(--space-md);
  align-items:start;
}
@media (max-width:720px){
  .orderCardBody{ grid-template-columns:1fr; }
}
.orderCardSide{ min-width:0; }
.orderCardSide select.adminSelect,
.orderCardSide select.btn,
.orderCardSide .btn.block{
  width:100%;
  min-height:var(--control-h-sm);
}
.orderCardSide .btn.block + .btn.block{ margin-top:var(--space-sm); }
.orderCardItems{
  margin-top:var(--space-sm);
  border-top:1px solid var(--border);
  padding-top:var(--space-sm);
}
.orderToolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-sm);
  flex-wrap:wrap;
  margin-bottom:var(--space-sm);
}

.pulse{ animation: cartPop .45s ease; }

/* --- Admin dashboard layout --- */
.adminContainer{ max-width:min(1680px, calc(100vw - 24px)); }
.adminTopbar{ position:sticky; top:0; z-index:60; }
.adminBurger{ display:none; }

.adminShell{
  margin-top:var(--space-md);
  display:grid;
  grid-template-columns: 200px 1fr;
  gap:var(--space-md);
  align-items:start;
  min-height: calc(100vh - 110px);
}

.adminSidebar{
  position:sticky;
  top:56px;
  height: calc(100vh - 80px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-panel);
  background:#0a0f17;
  overflow:hidden;
}
.adminSideInner{
  padding:var(--space-sm);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.adminNavItem{
  min-height:var(--control-h-sm);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  color: var(--text);
  border-radius:var(--radius-control);
  display:flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  cursor:pointer;
  font-weight:1000;
  font-size:13px;
  transition: background .15s ease, transform .12s ease, border-color .15s ease;
}
.adminNavItem i{ width:18px; text-align:center; opacity:.95; }
.adminNavItem:hover{ transform: translateY(-1px); background: rgba(255,255,255,.05); }
.adminNavItem.active{
  border-color: rgba(255,154,36,.55);
  background: rgba(255,154,36,.16);
}

.adminContent{
  min-width:0;
  padding:0;
}
.adminModules{
  display:grid;
  gap:var(--space-md);
  align-items:start;
}
.adminModules > .panel{ min-width:0; }
.adminModules--products{
  grid-template-columns: 1fr;
}
.adminProductsTableWrap{
  overflow:auto;
  max-height:min(62vh, 720px);
}
.adminProductsTable th:last-child,
.adminProductsTable td:last-child{
  width:1%;
  white-space:nowrap;
}
.adminProductsRowActions{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}
.adminProductsRowActions .btn.small{
  padding:5px 9px;
  font-size:11px;
  white-space:nowrap;
}
.adminProductsFormPanel{
  margin-top:0;
}
.adminProductsForm{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}
.adminProductsForm label:has(textarea),
.adminProductsForm #fSourceWrap,
.adminProductsForm #formMsg,
.adminProductsForm .row,
.adminProductsForm #dbHint{
  grid-column:1 / -1;
}
@media (max-width: 720px){
  .adminProductsForm{ grid-template-columns:1fr; }
}
@media (min-width: 1100px){
  .adminModules--settings{
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
  .adminModules--single{
    grid-template-columns: 1fr;
  }
}
.adminModule--full{ grid-column: 1 / -1; }
.adminContent .panel .hd{
  flex-wrap:wrap;
  gap:10px;
}

.operatorTopbar .brand b{ font-size:1.02rem; }
.operatorTopbar .headerNav{ flex-wrap:nowrap; }
.adminContent .tableWrap,
.adminContent .table{
  width:100%;
}
.adminContent .table{ font-size:13px; }
.adminSelect{
  min-height:var(--control-h-sm);
  padding:6px 10px;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--text);
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  color-scheme:dark;
}
.adminSelect option{
  background-color:#181c2a;
  color:var(--text);
}
.adminSection{ display:none; animation: fadeIn .14s ease; }
.adminSection.active{ display:block; }
@keyframes fadeIn{
  from{ opacity:0; transform: translateY(4px); }
  to{ opacity:1; transform: translateY(0); }
}

@media (max-width: 980px){
  .adminShell{ grid-template-columns: 1fr; }
  .adminBurger{ display:inline-grid; }
  .adminSidebar{
    position:fixed;
    top:0;
    left:0;
    height:100vh;
    width: 260px;
    z-index:120;
    transform: translateX(-105%);
    transition: transform .18s ease;
  }
  .adminSidebar.open{ transform: translateX(0); }
  .adminContent{ padding-top:0; }
}

.adminImportModal{ width:min(920px, 100%); }
.adminImportPaste{
  width:100%;
  min-height:140px;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(0,0,0,.22);
  padding:10px 12px;
  color:var(--text);
  font-family:var(--mono, ui-monospace, monospace);
  font-size:12px;
  line-height:1.4;
  resize:vertical;
}
.adminImportPasteLabel{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:11px;
  font-weight:900;
  color:var(--muted);
}
.adminImportCheck{ margin:10px 0; }
.adminImportPreviewWrap{ margin-top:12px; }
.adminImportPreviewTitle{ margin-bottom:6px; }
.adminImportPreviewScroll{
  overflow:auto;
  max-height:180px;
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
}
.adminImportPreview{ font-size:12px; margin:0; }
.adminImportPreview th,
.adminImportPreview td{ white-space:nowrap; max-width:160px; overflow:hidden; text-overflow:ellipsis; }
.adminImportMapWrap{ margin-top:14px; }
.adminImportMapGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 12px;
}
@media (max-width:720px){
  .adminImportMapGrid{ grid-template-columns:1fr; }
}
.adminImportMapRow{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.adminImportMapField{
  font-size:11px;
  font-weight:900;
  color:var(--muted);
}
.adminImportMapRow select,
.adminImportColNum{
  min-height:36px;
  width:72px;
  flex-shrink:0;
  border-radius:var(--radius-control);
  border:1px solid var(--border);
  background:rgba(0,0,0,.2);
  padding:6px 8px;
  color:var(--text);
  font-size:13px;
}
.adminImportMapInputWrap{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.adminImportColHint{
  font-size:11px;
  line-height:1.3;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.adminImportMapHint{ margin:0 0 8px; font-size:12px; }
.adminImportSummary{ margin-top:12px; white-space:pre-wrap; }
.adminImportErrors{ margin-top:8px; white-space:pre-wrap; font-size:12px; }
.adminImportActions{ margin-top:14px; justify-content:flex-end; gap:8px; }

.checkoutPayBlock{
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:var(--radius-panel);
  background:rgba(0,0,0,.12);
}
.payMethodRow{ margin-top:6px; }
.chip--accent{
  background:var(--brand1);
  color:#fff;
  border-color:transparent;
}
.orderCard--new{
  border-color:var(--brand1);
  box-shadow:0 0 0 1px rgba(0,70,67,.35);
}
.opNewOrderBanner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin:12px 0 0;
  padding:12px 14px;
  border-radius:var(--radius-panel);
  border:1px solid var(--brand1);
  background:linear-gradient(135deg, rgba(0,70,67,.25), rgba(171,209,198,.12));
  animation: opBannerPulse 1.2s ease 2;
}
.opNewOrderBanner[hidden]{ display:none !important; }
.opNewOrderBannerBody{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
}
@keyframes opBannerPulse{
  0%, 100%{ transform:scale(1); }
  50%{ transform:scale(1.01); }
}

.orderDaySection{ margin-top:14px; }
.orderDaySectionHd{
  margin:0 0 10px;
  font-size:1rem;
  display:flex;
  align-items:center;
  gap:8px;
}
.orderDaySeg{ margin-top:8px; }
.orderQuickBtns{
  display:flex;
  flex-direction:column;
  gap:var(--space-sm);
  margin:var(--space-sm) 0;
}

