:root{
  --gutter:16px;

  --bd-weak:1px solid rgba(255,255,255,.10);
  --bd-soft:1px solid rgba(255,255,255,.08);

  --shadow:0 18px 52px rgba(0,0,0,.52);
  --shadow-soft:0 14px 34px rgba(0,0,0,.22);

  --glass-bg:
    radial-gradient(900px 120px at 30% 0%, rgba(160,120,255,.16), transparent 60%),
    radial-gradient(700px 120px at 80% 0%, rgba(88,242,140,.11), transparent 60%),
    rgba(11,13,18,.62);
  --glass-filter:blur(16px) saturate(170%);

  --surface-bg:
    radial-gradient(140% 120% at 30% 20%, rgba(255,255,255,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));

  --card-bg:
    radial-gradient(140% 180% at 10% 0%, rgba(160,120,255,.14), transparent 60%),
    radial-gradient(120% 160% at 95% 0%, rgba(88,242,140,.10), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    rgba(0,0,0,.18);

  --font-ui:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-display:"Unbounded",var(--font-ui);

  --cartdock-base: 12px;

  --ok: rgba(88,242,140,.92);
  --ok-bd: rgba(88,242,140,.28);
  --ok-bg: rgba(88,242,140,.10);

  --danger: rgba(255,70,90,.96);
  --danger-bd: rgba(255,70,90,.46);
  --danger-bg: rgba(255,70,90,.18);

  --info: rgba(200,180,255,.96);
  --info-bd: rgba(160,120,255,.22);
  --info-bg: rgba(160,120,255,.10);

  /* =========================
     CART DOCK TIP (уведомления)
     ========================= */
  --cdtip-z: 210000; /* выше модалки 200000 */
  --cdtip-maxw: 420px;
  --cdtip-pad-y: 10px;
  --cdtip-pad-x: 12px;
  --cdtip-radius: 14px;
  --cdtip-bd: 1px solid rgba(255,255,255,.14);
  --cdtip-bg:
    radial-gradient(220% 160% at 18% 0%, rgba(160,120,255,.18), transparent 60%),
    radial-gradient(220% 160% at 92% 10%, rgba(88,242,140,.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015)),
    rgba(11,13,18,.90);
  --cdtip-filter: blur(12px) saturate(160%);
  --cdtip-shadow: 0 18px 52px rgba(0,0,0,.40);
  --cdtip-text: rgba(255,255,255,.92);
}

.u-hidden{ display:none !important; }

/* =========================
   CART DOCK
   ========================= */
.cartdock{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  z-index:110;
  width:min(1120px, calc(100% - (var(--gutter) * 2)));
  pointer-events:none;
  bottom:calc(var(--cartdock-base) + var(--cartdock-footeroverlap, 0px) + env(safe-area-inset-bottom));
}

.cartdock__inner{
  pointer-events:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;

  padding:10px 12px;
  border-radius:18px;
  border:var(--bd-weak);
  background:var(--glass-bg);
  backdrop-filter:var(--glass-filter);
  -webkit-backdrop-filter:var(--glass-filter);
  box-shadow:0 16px 44px rgba(0,0,0,.35);
}

.cartdock__meta{
  min-width:0;
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.cartdock__topline{
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.cartdock__kpis{
  min-width:0;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
}

.cartdock__kpi{
  min-width:0;
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-wrap:nowrap;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
  cursor:pointer; /* кликабельно для подсказок */
}

.cartdock__kpiVal{
  font-family:var(--font-display);
  font-weight:950;
  font-size:13px;
  color:rgba(255,255,255,.95);
  white-space:nowrap;
  line-height:1.05;
  cursor:pointer; /* кликабельно для подсказок */
}
.cartdock__kpiVal .cartdock__lvlNum{
  display:inline-block;
  margin-left:6px;
  color:rgba(255,255,255,.88);
}

.cartdock__kpiLabel{
  font-family:var(--font-ui);
  font-weight:900;
  font-size:12px;
  color:rgba(255,255,255,.72);
  white-space:nowrap;
  flex:0 0 auto;
  line-height:1.05;
}

.cartdock__kpiValGroup{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-width:0;
}

.cartdock__kpiSub{
  min-width:0;
  font-family:var(--font-ui);
  font-weight:850;
  font-size:12px;
  color:rgba(255,255,255,.72);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.05;
}

.cartdock__kpiSep{
  color:rgba(255,255,255,.26);
  flex:0 0 auto;
  line-height:1.05;
}

.cartdock__monoIcon{
  width:16px;
  height:16px;
  object-fit:contain;
  display:inline-block;
  transform:translateY(1px);
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.22));
}

.cartdock__bar{
  height:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.16);
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  cursor:pointer;
}
.cartdock__barFill{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(160,120,255,.55), rgba(88,242,140,.42));
  box-shadow:0 0 18px rgba(88,242,140,.10);
  transition:width .28s ease;
}

.cartdock__hint{
  font-family:var(--font-ui);
  font-weight:850;
  font-size:12px;
  color:rgba(255,255,255,.66);
  line-height:1.25;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.cartdock__meta.is-bump{ animation:cdMetaBump .22s ease; }
@keyframes cdMetaBump{
  0%{ transform:translateY(0) scale(1); filter:brightness(1); }
  40%{ transform:translateY(-1px) scale(1.01); filter:brightness(1.05); }
  100%{ transform:translateY(0) scale(1); filter:brightness(1); }
}

.cartdock__btn{
  position:relative;
  width:50px;
  height:50px;
  border-radius:16px;
  border:var(--bd-weak);
  background:var(--surface-bg);
  color:rgba(255,255,255,.92);
  cursor:pointer;
  display:grid;
  place-items:center;
  box-shadow:var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.10);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  transition:transform .14s ease, filter .18s ease, border-color .18s ease;
}
.cartdock__btn:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  border-color:rgba(255,255,255,.18);
}

.cartdock__badge{
  position:absolute;
  right:-6px;
  top:-6px;
  min-width:20px;
  height:20px;
  padding:0 7px;
  border-radius:999px;
  border:1px solid var(--danger-bd);
  background:
    radial-gradient(14px 10px at 30% 25%, rgba(255,255,255,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,90,110,.98), rgba(210,25,55,.94));
  color:rgba(255,255,255,.98);
  font-family:var(--font-display);
  font-weight:950;
  font-size:11px;
  line-height:20px;
  text-align:center;
  box-shadow:0 16px 36px rgba(0,0,0,.30), 0 0 0 1px rgba(0,0,0,.18) inset;
  pointer-events:none;
}

/* =========================
   CART DOCK TIP / NOTIFICATION (CSS-ONLY)
   Элемент создавай в JS с классом .cartdocktip
   Позицию (left/top) выставляй в JS и/или через --cdtip-x/--cdtip-y.
   Чтобы показать — добавь .is-open, чтобы скрыть — убери .is-open.
   ========================= */
.cartdocktip{
  position:fixed;
  z-index:var(--cdtip-z);
    /* ✅ ВАЖНО: применяем координаты, которые выставляет JS */
  left: var(--cdtip-x, 12px);
  top:  var(--cdtip-y, 12px);

  /* позицию всё равно ставит JS (left/top), но центрируем “ощущение” */
  max-width:min(var(--cdtip-maxw), calc(100vw - 24px));
  box-sizing:border-box;

  padding:var(--cdtip-pad-y) var(--cdtip-pad-x);
  border-radius:var(--cdtip-radius);
  border:var(--cdtip-bd);
  background:var(--cdtip-bg);
  box-shadow:var(--cdtip-shadow);

  -webkit-backdrop-filter:var(--cdtip-filter);
  backdrop-filter:var(--cdtip-filter);

  color:var(--cdtip-text);
  font-family:var(--font-ui);
  font-weight:900;              /* было 850 — сделаем чуть “увереннее” */
  font-size:13px;               /* чуть крупнее для центра */
  letter-spacing:.01em;
  line-height:1.25;

  word-break:break-word;
  overflow-wrap:anywhere;

  /* красивое “появление” */
  opacity:0;
  visibility:hidden;
  pointer-events:none;

  transform:translateY(10px) scale(.985);
  transform-origin:center;
  transition:
    opacity .16s ease,
    transform .18s cubic-bezier(.2,.9,.2,1),
    visibility 0s linear .18s;

  /* ✅ легкий “glow” без перебора */
  outline:1px solid rgba(255,255,255,.06);
  outline-offset:-1px;

  
}

.cartdocktip.is-measuring{
  opacity:0 !important;
  visibility:hidden !important;
  transform:none !important;
  transition:none !important;
  pointer-events:none !important;
}
.cartdocktip.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
  transition:
    opacity .16s ease,
    transform .18s cubic-bezier(.2,.9,.2,1),
    visibility 0s linear 0s;
}

/* опциональная “стрелка” */
.cartdocktip--arrow::after{
  content:"";
  position:absolute;
  width:12px;
  height:12px;
  left: var(--cdtip-arrow-x, 50%);
  transform: translateX(-50%) rotate(45deg);

  /* по умолчанию стрелка снизу тултипа (тултип над доком) */
  bottom:-6px;

  background:rgba(11,13,18,.92);
  border-right:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
  border-radius:3px;

  box-shadow:0 14px 26px rgba(0,0,0,.22);

}
.cartdocktip--top.cartdocktip--arrow::after{
  bottom:auto;
  top:-6px;
  border-right:0;
  border-bottom:0;
  border-left:1px solid rgba(255,255,255,.12);
  border-top:1px solid rgba(255,255,255,.12);
}

/* =========================
   CART MODAL
   ========================= */
.cmodal{
  position:fixed;
  inset:0;
   z-index: 200000; 
  display:flex;
  align-items:center;
  justify-content:center;
  padding:calc(env(safe-area-inset-top) + 52px) 14px calc(env(safe-area-inset-bottom) + 52px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .14s ease, visibility 0s linear .14s;
}
.cmodal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transition:opacity .14s ease, visibility 0s linear 0s;
}
.cmodal__backdrop{
  position:absolute;
  inset:0;
  border:0;
  cursor:pointer;
  background:rgba(0,0,0,.52);
  opacity:0;
  -webkit-backdrop-filter:blur(16px) saturate(170%);
  backdrop-filter:blur(16px) saturate(170%);
  transition:opacity .14s ease;
}
.cmodal.is-open .cmodal__backdrop{ opacity:1; }

.cmodal__panel{
  position:relative;
  width:min(600px, 100%);
  border-radius:24px;
  border:var(--bd-weak);
  background:
    radial-gradient(900px 260px at 15% 0%, rgba(160,120,255,.15), transparent 60%),
    radial-gradient(900px 260px at 95% 0%, rgba(88,242,140,.10), transparent 62%),
    rgba(11,13,18,.96);
  box-shadow:var(--shadow);
  overflow:hidden;

  display:flex;
  flex-direction:column;

  max-height:calc(100vh - 104px - env(safe-area-inset-top) - env(safe-area-inset-bottom));

  transform:translateY(8px) scale(.992);
  opacity:0;
  transition:transform .18s cubic-bezier(.2,.9,.2,1), opacity .14s ease;
  z-index: 1000;
}
.cmodal.is-open .cmodal__panel{
  transform:translateY(0) scale(1);
  opacity:1;
}

.cmodal__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(140% 220% at 20% 0%, rgba(160,120,255,.12), transparent 58%),
    radial-gradient(140% 220% at 95% 0%, rgba(88,242,140,.08), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01)),
    rgba(8,10,14,.62);
  -webkit-backdrop-filter:blur(16px) saturate(170%);
  backdrop-filter:blur(16px) saturate(170%);
}
.cmodal__title{
  font-family:var(--font-display);
  font-weight:950;
  letter-spacing:.02em;
  font-size:15px;
  color:rgba(255,255,255,.95);
}
.cmodal__x{
  width:34px;
  height:34px;
  border-radius:12px;
  border:var(--bd-weak);
  background:var(--surface-bg);
  color:rgba(255,255,255,.92);
  display:grid;
  place-items:center;
  font-family:var(--font-display);
  font-weight:950;
  font-size:13px;
  cursor:pointer;
  box-shadow:var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .14s ease, filter .18s ease, border-color .18s ease;
}
.cmodal__x:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  border-color:rgba(255,255,255,.18);
}

.cmodal__body{
  flex:1 1 auto;
  min-height:0;

  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px;
}

/* =========================
   Items list
   ========================= */
.cmodal__items{
  flex:0 1 auto;      /* НЕ растягиваться, но уметь сжиматься */
  min-height:0;
  overflow:auto;

  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;

  border-radius:16px;
  border:var(--bd-soft);
  background:rgba(255,255,255,.03);
  padding:10px;

  display:flex;
  flex-direction:column;
  gap:10px;
}




.cmodal__empty{
  padding:12px;
  border-radius:14px;
  border:var(--bd-soft);
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.72);
  font-weight:850;
  text-align:center;
}

/* item row */
.citem{
  position:relative;
  display:grid;
  grid-template-columns:64px minmax(0,1fr);
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 160% at 20% 0%, rgba(160,120,255,.11), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012)),
    rgba(0,0,0,.16);
  box-shadow:0 14px 34px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
}
.citem__imgwrap{
  width:64px;
  height:64px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  display:grid;
  place-items:center;
}
.citem__img{ width:100%; height:100%; object-fit:contain; display:block; }
.citem__ph{
  width:100%;
  height:100%;
  background:
    radial-gradient(120% 160% at 20% 0%, rgba(160,120,255,.10), transparent 60%),
    radial-gradient(120% 160% at 95% 20%, rgba(88,242,140,.08), transparent 60%),
    rgba(0,0,0,.18);
}
.citem__main{ min-width:0; display:flex; flex-direction:column; gap:8px; }

.citem__name{
  min-width:0;
  padding-right:92px;
  font-family:var(--font-display);
  font-weight:950;
  font-size:12.5px;
  color:rgba(255,255,255,.94);
  display:flex;
  align-items:center;
  gap:8px;
}
.citem__title{
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.citem__sub{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.citem__price{
  flex:1 1 auto;
  min-width:0;
  font-family:var(--font-display);
  font-weight:950;
  font-size:13px;
  color:rgba(255,255,255,.92);
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}

.citem__badge{
  position:absolute;
  top:10px;
  right:10px;
  z-index:2;
  pointer-events:none;
  max-width:48%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cbadge{
  height:18px;
  line-height:18px;
  padding:0 8px;
  border-radius:999px;
  font-family:var(--font-display);
  font-weight:950;
  font-size:10px;
  letter-spacing:.03em;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.84);
  opacity:.92;
}
.cbadge--auction{
  border-color: rgba(160,120,255,.35);
  background: linear-gradient(90deg, rgba(160,120,255,.28), rgba(88,242,140,.12));
  color: rgba(255,255,255,.95);
}

/* qty controls */
.cqty{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:36px;
  padding:0 6px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(140% 180% at 20% 0%, rgba(160,120,255,.14), transparent 55%),
    radial-gradient(140% 180% at 95% 20%, rgba(88,242,140,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)),
    rgba(0,0,0,.14);
  box-shadow:0 18px 46px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.08);
}
.cqty__btn{
  width:30px; height:30px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.12);
  color:rgba(255,255,255,.94);
  font-family:var(--font-display);
  font-weight:950;
  font-size:14px;
  cursor:pointer;
  transition:transform .12s ease, filter .18s ease;
}
.cqty__btn:hover{ transform:translateY(-1px); filter:brightness(1.06); }
.cqty__num{
  min-width:2ch;
  text-align:center;
  font-family:var(--font-display);
  font-weight:950;
  font-size:12px;
  color:rgba(255,255,255,.92);
}

/* =========================
   Footer / summary / steps
   ========================= */
.cmodal__footer{
  border-radius:16px;
  border:var(--bd-soft);
  background:rgba(255,255,255,.03);
  padding:10px;
  min-height:0;
  overflow:hidden;
}

.csummary{ display:flex; flex-direction:column; gap:10px; }
.csummary__rows{ display:flex; flex-direction:column; gap:10px; }

.csummary__row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.csummary__rows .csummary__row:last-child{ border-bottom:0; padding-bottom:0; }

.csummary__label{
  color:rgba(255,255,255,.70);
  font-weight:850;
  min-width:0;
  font-size:12.5px;
}
.csummary__value{
  font-family:var(--font-display);
  font-weight:950;
  font-variant-numeric:tabular-nums;
  color:rgba(255,255,255,.95);
  white-space:nowrap;
  font-size:13px;
}
.csummary__value--discount{ color:var(--ok); }

.cflow{ display:flex; flex-direction:column; gap:8px; }

.cstep{
  position:relative;
  border-radius:14px;
  border:var(--bd-soft);
  background:var(--card-bg);
  box-shadow:0 16px 46px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
}

.cstep__head{
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    rgba(0,0,0,.12);
}

.cstep__line{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  min-height:36px;
  min-width:0;
  flex-wrap:nowrap;
}
.cstep__line > *{ min-width:0; }

.cstep__label{
  flex:0 0 auto;
  font-family:var(--font-display);
  font-weight:950;
  font-size:12px;
  color:rgba(255,255,255,.90);
  white-space:nowrap;
}

.cstep__value{
  display:none;
  min-width:0;
  max-width:100%;
  font-family:var(--font-ui);
  font-weight:900;
  font-size:12.5px;
  color:rgba(255,255,255,.92);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  flex:1 1 auto;
}

.cinput{
  height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.94);
  padding:0 10px;
  outline:none;
  font-weight:850;
  font-family:var(--font-ui);
  letter-spacing:.01em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:border-color .18s ease, box-shadow .18s ease, filter .18s ease;
  min-width:0;
  flex:1 1 auto;
}
.cinput--mini{
  height:30px;
  border-radius:10px;
  padding:0 9px;
  font-size:12.5px;
}
.cinput:focus-visible{
  border-color:rgba(160,120,255,.34);
  box-shadow:0 0 0 3px rgba(160,120,255,.16), inset 0 1px 0 rgba(255,255,255,.06);
}
.cinput.is-readonly{
  background:rgba(0,0,0,.10);
  opacity:.92;
}

/* input states for promo */
.cinput.is-ok{
  border-color: var(--ok-bd);
  box-shadow:0 0 0 3px rgba(88,242,140,.10), inset 0 1px 0 rgba(255,255,255,.06);
}
.cinput.is-error{
  border-color: rgba(255,120,140,.22);
  box-shadow:0 0 0 3px rgba(255,120,140,.10), inset 0 1px 0 rgba(255,255,255,.06);
}
.cinput.is-loading{
  border-color: var(--info-bd);
  box-shadow:0 0 0 3px rgba(160,120,255,.10), inset 0 1px 0 rgba(255,255,255,.06);
}

/* wrapper for input + chips */
.cinputwrap{
  position:relative;
  flex:1 1 auto;
  min-width:0;
}
.cinputwrap .cinput{ width:100%; }

/* chips overlay */
.cnickchips{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
  padding:0 8px;
  pointer-events:none;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
}
.cnickchips[hidden]{ display:none; }
.cnickchips::-webkit-scrollbar{ display:none; }

.cnickchip{
  pointer-events:auto;
  height:24px;
  padding:0 9px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.78);
  font-family:var(--font-display);
  font-weight:950;
  font-size:11px;
  cursor:pointer;
  opacity:.82;
  white-space:nowrap;
  transition:transform .12s ease, filter .18s ease, opacity .18s ease, border-color .18s ease;
}
.cnickchip:hover{
  transform:translateY(-1px);
  filter:brightness(1.08);
  opacity:.95;
  border-color:rgba(255,255,255,.18);
}

/* locked */
.cstep.is-locked .cstep__value{ display:block; }
.cstep.is-locked .cinput{ display:none; }
.cstep.is-locked .cinputwrap{ display:none; }

.cstep.is-ok .cstep__value{
  color:var(--ok);
  text-shadow:0 0 18px rgba(88,242,140,.08);
}
.cstep.is-ok.is-locked{ border-color:var(--ok-bd); }
.cstep.is-ok.is-locked .cstep__head{
  box-shadow:0 0 0 1px rgba(88,242,140,.08) inset;
}

.cstep__editbtn{
  height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.14);
  color:rgba(255,255,255,.86);
  font-weight:950;
  font-size:12px;
  cursor:pointer;
  transition:transform .12s ease, filter .18s ease, border-color .18s ease;
  -webkit-tap-highlight-color:transparent;
  white-space:nowrap;
  flex:0 0 auto;
}
.cstep__editbtn:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  border-color:rgba(255,255,255,.18);
}

/* unified message block (inline flow, mobile-safe) */
.cmsg{
  margin:0 10px 10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.14);
  color:rgba(255,255,255,.74);
  font-weight:850;
  font-size:12px;
  line-height:1.35;
  box-shadow:0 18px 52px rgba(0,0,0,.22);
}
.cmsg.is-hidden{ display:none; }
.cmsg.is-error{
  border-color:rgba(255,120,140,.22);
  background:rgba(255,120,140,.10);
  color:rgba(255,170,180,.96);
}
.cmsg.is-ok{
  border-color:var(--ok-bd);
  background:var(--ok-bg);
  color:var(--ok);
}
.cmsg.is-loading{
  border-color:var(--info-bd);
  background:var(--info-bg);
  color:var(--info);
}

/* buttons */
.cbtn{
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:var(--surface-bg);
  color:rgba(255,255,255,.94);
  font-weight:950;
  font-family:var(--font-display);
  cursor:pointer;
  box-shadow:var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .14s ease, filter .18s ease, border-color .18s ease;
  padding:0 16px;
  white-space:nowrap;
}
.cbtn--mini{
  height:32px;
  border-radius:12px;
  padding:0 12px;
  font-size:12.5px;
}
.cbtn:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  border-color:rgba(255,255,255,.18);
}
.cbtn:disabled{ opacity:.55; cursor:not-allowed; transform:none; }
.cbtn--primary{
  border-color:rgba(160,120,255,.25);
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.10), transparent 55%),
    linear-gradient(90deg, rgba(160,120,255,.24), rgba(88,242,140,.14));
}

/* =========================
   PAY LINE
   ========================= */
.cpayline{ min-width:0; }
.cpayline__input{ min-width:0; }

/* =========================
   RUBLES UI
   ========================= */
.crublesline{
  gap:10px;
  min-width:0;
}
.crublespill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  height:30px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(140% 180% at 20% 0%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    rgba(0,0,0,.12);
  font-family:var(--font-display);
  font-weight:950;
  font-size:12px;
  color:rgba(255,255,255,.92);
  box-shadow:0 14px 34px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.06);
  min-width:0;
}
.cbtn--rubles{
  border-color: rgba(255,255,255,.18);
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.08), transparent 55%),
    linear-gradient(90deg, rgba(255,255,255,.08), rgba(160,120,255,.14));
}
.cbtn--rubles.is-on{
  border-color: rgba(88,242,140,.28);
  box-shadow:0 0 0 1px rgba(88,242,140,.10) inset, var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.10);
}

/* =========================
   AGREEMENT
   ========================= */
.cagree,
.cagree *{
  font-family:var(--font-ui);
  font-weight:850;
  font-size:12px;
  line-height:1.25;
}
.cagree a{
  color:rgba(160,120,255,.92);
  text-decoration:none;
}
.cagree a:hover{ text-decoration:underline; }

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width:1024px){
  :root{ --cartdock-base: 10px; }
  .cartdock{ left:0; right:0; width:100%; transform:none; padding:0 10px; }
  .cartdock__inner{ border-radius:16px; }

  .cmodal{
    padding:calc(env(safe-area-inset-top) + 44px) 12px calc(env(safe-area-inset-bottom) + 44px);
  }
  .cmodal__panel{
    border-radius:22px;
    max-height:calc(100vh - 88px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  }
}

@media (max-width:760px){
  .cmodal{
    align-items:center;          /* было flex-end */
    justify-content:center;
    min-height:100dvh;           /* лучше, чем 100vh на мобилках */
    padding:calc(env(safe-area-inset-top) + 12px) 10px
            calc(env(safe-area-inset-bottom) + 12px); /* симметрично */
  }

  .cmodal__panel{
    max-height:calc(100dvh - (env(safe-area-inset-top) + env(safe-area-inset-bottom) + 24px));
  }

  .cmodal__body{
    padding:10px;
    gap:10px;
    /* grid-template-rows:minmax(220px, 1fr) minmax(0, 1fr); */
  }
  .cmodal__footer{
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }

  .cartdock__inner{ gap:10px; padding:10px; }
  .cartdock__kpis{ gap:8px 12px; }
  .cartdock__kpiVal{ font-size:12.5px; }
  .cartdock__kpiSub{ font-size:11.5px; }
  .cartdock__kpiLabel{ font-size:11.5px; }

  .cartdock__hint{
    font-size:11px;
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
  }

  .cstep__line{
    padding:7px 8px;
    min-height:34px;
    gap:8px;
  }
  .cstep__label{ font-size:11.5px; }
  .cstep__editbtn{
    height:26px;
    padding:0 9px;
    font-size:11.5px;
  }

  .csummary__label{ font-size:11px; }
  .csummary__value{ font-size:12px; }
  .csummary__value--discount{ font-size:12px; }

  #cNickWrap.has-chips .cinput{
    padding-right:106px;
  }
  .cnickchips{ padding:0 6px; }
  .cnickchip{
    height:22px;
    padding:0 8px;
    font-size:10px;
  }

  .cpayline{
    display:grid;
    grid-template-columns:auto 1fr;
    grid-template-areas:
      "label input"
      "btn btn";
    gap:8px 10px;
    align-items:center;
  }
  .cpayline__label{ grid-area: label; }
  .cpayline__input{ grid-area: input; width:100%; }
  .cpayline__btn{
    grid-area: btn;
    width:100%;
    justify-self:stretch;
    height:36px;
    border-radius:14px;
  }

  .crublesline{
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:8px 10px;
    align-items:center;
  }
  .crublespill{
    justify-self:start;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  .cmsg{
    margin:0 8px 10px;
    font-size:11.5px;
  }

  .cagree, .cagree *{ font-size:11px; }

  .citem__name{ padding-right:84px; }
  .citem__badge{
    top:8px;
    right:8px;
    transform:scale(.94);
    transform-origin:top right;
  }

  /* tip mobile tuning */
  :root{ --cdtip-maxw: 340px; }
  .cartdocktip{
    position:fixed;
    z-index:var(--cdtip-z);

    left: var(--cdtip-x, 12px);
    top:  var(--cdtip-y, 12px);

    max-width:min(var(--cdtip-maxw), calc(100vw - 24px));
    box-sizing:border-box;
      font-size:12px;
      border-radius:14px;
      padding:10px 12px;
      max-width:min(var(--cdtip-maxw), calc(100vw - 20px));
  }
  
}

@media (max-width:360px){
  .cartdock__btn{ width:48px; height:48px; border-radius:15px; }
  .cartdock__badge{ transform:scale(.96); transform-origin:top right; }

  .cartdock__hint{ font-size:10.5px; }

  .citem__name{ padding-right:74px; }
  .cbadge--auction{ font-size:9px; padding:0 6px; }

  .cartdocktip{
    max-width: calc(100vw - 18px);
    padding: 8px 10px;
    font-size: 11px;
  }
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  .cartdock__btn,.cmodal,.cmodal__panel,.cmodal__backdrop,.cmodal__x,.cbtn,.cnickchip,
  .cartdock__barFill,
  .cartdocktip{
    transition:none!important;
    animation:none!important;
    transform:none!important;
  }
}


.cartdock {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  transform: translateZ(0); /* Иногда помогает с позиционированием */
}

.cartdock__inner {
  position: relative;
  left: 0;
  max-width: 1120px;
  margin: 0 auto;
}

/* Планшеты */
@media (max-width:1024px){
  .cmodal__items{
    max-height: clamp(180px, 45vh, 420px);
  }
}

/* Телефоны */
@media (max-width:760px){
  .cmodal__items{
    max-height: clamp(160px, 29vh, 320px);
  }

  /* опционально: гарантировать футеру “нормальную” высоту */
  .cmodal__footer{
    min-height: clamp(220px, 40vh, 420px);
  }
}

/* MOBILE: chips go UNDER the input (no overlay) */
@media (max-width:760px){
  /* делаем wrap колонкой: input сверху, chips снизу */
  #cNickWrap{
    display:flex;
    flex-direction:column;
    gap:6px;
  }

  /* отменяем “запас” справа под оверлей */
  #cNickWrap.has-chips .cinput{
    padding-right: 9px; /* или ваш дефолт */
  }

  /* chips больше не absolute-оверлей */
  #cNickChips.cnickchips{
    position:static;
    inset:auto;

    justify-content:flex-start;
    padding:0;

    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;

    /* маску можно убрать, чтобы не “резало” */
    -webkit-mask-image:none;
    mask-image:none;
  }

  /* чтобы чипы не сжимались */
  #cNickChips .cnickchip{
    flex:0 0 auto;
  }
    .citem__title{
    font-size: 11.5px;   /* было наследование — задаём явно */
    line-height: 1.15;
  }

  .citem__price{
    font-size: 12px;     /* было 13px в desktop */
    line-height: 1.1;
  }


}

html.is-modal-open,
body.is-modal-open{
  overflow: hidden !important;
  height: 100%;
}

/* чтобы “резина” не прокидывала скролл на фон */
.cmodal,
.cmodal__panel{
  overscroll-behavior: contain;
}

/* на всякий: фон-кнопка не должна тащить страницу */
.cmodal__backdrop{
  touch-action: none;
}