:root{
  --pad:12px;
  --gap:12px;
  --radius:14px;
  --bg:#f9fafb;
  --surface:#ffffff;
  --border:#e5e7eb;
  --text:#111827;
  --muted:#6b7280;
  --primary:#2563eb;
  --primary-hover:#1d4ed8;
  --danger:#e11d48;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
.app{display:grid; grid-template-rows:auto 1fr auto; min-height:100vh; overflow-x:hidden;}

/* topbar (поиск будет динамически) */
.topbar{
  display:flex;
  gap:var(--gap);
  padding:var(--pad);
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:10;
}
.topbar input[type=search], .topbar button{display:none}

/* view */
.view {
  padding: var(--pad);
  padding-bottom: calc(56px + env(safe-area-inset-bottom, 0px) + 20px); /* Увеличиваем отступ */
  overflow-y: auto;
  overflow-x: hidden;
  margin-bottom: 56px; /* Добавляем margin снизу */
}
/* grid & card */
.grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--gap); width:100%}
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:var(--pad);
  display:flex;
  flex-direction:column;
  gap:8px;
  box-shadow:0 2px 4px rgba(0,0,0,.04);
  min-width:0;
}
.card:hover{transform:none}
.card img{width:100%;height:140px;object-fit:cover;border-radius:10px;background:#f3f4f6}

.row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.product-title{font-weight:600}
.price{font-weight:600;color:var(--primary); white-space:nowrap}

/* actions: сердечко + корзина */
.card-actions{display:flex;gap:10px;align-items:center;justify-content:flex-start}
.card-actions .fav-btn{margin-left:auto}

/* кнопка избранного */
.fav-btn{
  -webkit-tap-highlight-color: transparent;
  display:inline-grid;
  place-items:center;
  width:44px;
  height:40px;
  border-radius:10px;
  border:1px solid var(--border);
  background:transparent;
  cursor:pointer;
  transition:background .12s, border-color .12s, color .12s;
  color:var(--muted);
  font-size:18px;
}
.fav-btn:hover{background:#f3f4f6}
.fav-btn.active{
  background:rgba(225,29,72,0.08);
  color:var(--danger);
  border-color:rgba(225,29,72,0.18);
}

/* кнопка корзины */
.cart-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  position:relative;
  height:40px;
  transition:background .12s, border-color .12s, color .12s, transform .08s;
  color:var(--text);
}
.cart-btn .btn-label{display:inline;font-size:14px}
.cart-btn.in-cart{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}


/* нижняя панель */
.bottombar{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  background:var(--surface);
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:20;
  height:70px;
  padding-bottom:calc(env(safe-area-inset-bottom, 0px));

}
.bottombar .tab{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 0;border:0;background:none;color:var(--muted);cursor:pointer}
.bottombar .tab i{font-size:18px;margin-bottom:4px}
.bottombar .tab.active{color:var(--primary);font-weight:600}

/* cart list */
.list{display:flex;flex-direction:column;gap:10px}
.item{display:flex;gap:10px;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--pad)}
.qty{display:flex;gap:6px;align-items:center}
.qty button{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer}
.empty{text-align:center;color:var(--muted);padding:30px 10px}

/* нижняя панель оплаты в корзине */
.paybar{position:sticky;bottom:0;left:0;right:0;padding:var(--pad);background:linear-gradient(180deg, rgba(249,250,251,0) 0%, rgba(249,250,251,1) 30%);} 
.pay-btn{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--primary);background:var(--primary);color:#fff;font-weight:600;cursor:pointer}

/* диалог оплаты */
.dialog{border:0;border-radius:14px;padding:0;max-width:420px;width:calc(100% - 32px)}
.dialog::backdrop{background:rgba(0,0,0,.4)}
.dialog-body{padding:16px}
.dialog-title{font-weight:700;margin-bottom:8px}
.dialog-text{color:var(--text);margin-bottom:12px}
.dialog-actions{display:flex;gap:10px}
.close-btn{padding:12px 16px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer}

/* админ-панель */
.admin{margin-top:16px}
.admin h3{margin:0 0 8px 0;font-size:16px}
.admin-form{display:grid;gap:8px}
.admin-form input,.admin-form textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:10px;font:inherit}
.admin-form button{padding:10px 12px;border-radius:10px;border:1px solid var(--primary);background:var(--primary);color:#fff;cursor:pointer}
.admin-list .item button{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer}

/* всплывающий "+1" */
.bump{
  position:absolute;
  right:10px;
  top:-8px;
  font-weight:700;
  animation:bumpAnim .7s ease forwards;
  pointer-events:none;
}
.bump.minus{color:var(--danger)}
@keyframes bumpAnim{
  0%{transform:translateY(0);opacity:1}
  100%{transform:translateY(-22px);opacity:0}
}

/* доступность */
button{font-family:inherit}
/* убрать системный прямоугольный хайлайт при тапе и outline */
*, button, .tab, .fav-btn, .cart-btn, .qty button{ -webkit-tap-highlight-color: transparent; }
button:focus, .tab:focus, .fav-btn:focus, .cart-btn:focus, .qty button:focus{ outline: none; }

/* адаптация для узких экранов */
@media (max-width: 380px){
  :root{ --pad:8px; --gap:6px; --radius:12px; }
  .view{padding:var(--pad)}
  .card{padding:6px}
  .card img{height:110px}
  .product-title{font-size:13px}
  .price{font-size:13px}
  .cart-btn{gap:6px;padding:4px 8px;height:34px}
  .cart-btn .btn-label{font-size:12.5px}
  .fav-btn{width:38px;height:34px}
}


.wide-btn {
    width: 100%;
    padding: 12px 16px;
    border-radius: 12px;
    border: 1px solid var(--primary); /* Граница с основным цветом */
    background-color: white;       /* Белый фон */
    color: var(--primary);          /* Основной цвет текста */
    font-weight: 600;
    cursor: pointer;
    /*  Дополнительно, чтобы лучше смотрелась на белом фоне */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* Легкая тень */
}
}

.wide-btn-white:hover {
    background-color: #f0f0f0; /* Немного темнее при наведении */
    border-color: #0056b3; /* Цвет границы при наведении, если хотите */
    color: #0056b3;       /* Цвет текста при наведении */
}
.admin-product-delete-button {
    padding: 6px 10px;       /* Отступы */
    border-radius: 8px;      /* Скругление углов */
    border: 1px solid var(--border); /* Граница с цветом из переменной --border */
    background: var(--surface);      /* Фон из переменной --surface */
    color: #000;             /* Цвет текста (можно изменить, если нужно) */
    font-size: 14px;         /* Размер шрифта */
    white-space: nowrap;     /* Чтобы текст "Удалить" не переносился */
    cursor: pointer;         /* Курсор-указатель */
    box-sizing: border-box;  /* Учитывает padding и border в общем размере */
}

.admin-product-delete-button:hover {
    background: #e0e0e0; /* Пример цвета при наведении */
    border-color: var(--primary); /* Пример цвета границы при наведении */
}