/* ----- layout -------------------------------------------------- */
body{ margin:0; }
.dashboard-container{ padding:20px 16px 120px; } /* extra bottom ώστε να μη σκεπάζει η sticky bar */

.page-title{
  margin:0 0 16px;
  font-size:34px; line-height:1.2; color:#0b1d2a;
}
.page-title small{ font-weight:400; font-size:.6em; color:#50606b; }

/* ----- search -------------------------------------------------- */
.search-bar{ display:flex; gap:10px; justify-content:center; margin:10px 0 24px; }
.search-input{
  width:min(520px, 90%); padding:10px 14px; font-size:16px;
  border:1px solid #d6dbe0; border-radius:10px; outline:none;
}
.btn{ border:none; cursor:pointer; border-radius:10px; font-weight:700; }
.btn-search{ padding:10px 16px; background:#eceff1; color:#253443; }

/* ----- grid & cards ------------------------------------------- */
.product-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(280px, 1fr));
  gap:24px;
}
@media (max-width:1100px){
  .product-grid{ grid-template-columns: repeat(2, minmax(260px, 1fr)); }
}
@media (max-width:640px){
  .product-grid{ grid-template-columns: 1fr; }
}

.product-card{
  background:#0f1923; /* σκοτεινό πλαίσιο όπως στο screenshot */
  color:#fff;
  border-radius:18px;
  padding:18px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.product-id{ color:#bec8d2; margin-bottom:10px; }

/* ------- image (όλες ίδιες, λίγο μεγαλύτερες, χωρίς κόψιμο) ---- */
.media{
  height:320px;                    /* λίγο μεγαλύτερο από πριν */
  border-radius:12px;
  background:#111a22;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  margin-bottom:12px;
}
.media-img{
  max-width:100%;
  max-height:100%;
  width:auto; height:auto;
  object-fit:contain;              /* ΔΕΝ κόβεται ποτέ */
  display:block;
}
.media-placeholder{
  color:#ffbdbd; opacity:.9; font-size:14px;
}

/* ------- info rows -------------------------------------------- */
.p-row{ margin:6px 0; }
.p-label{ color:#ffb74d; font-weight:700; margin-right:6px; }
.p-val{ color:#e8f1f8; }

/* ------- stock badge ------------------------------------------ */
.stock-badge{
  display:inline-block; padding:6px 10px; border-radius:14px;
  font-weight:700; margin:8px 0 12px;
}
.stock-badge.in { background:#e8f5e9; color:#2e7d32; }
.stock-badge.out{ background:#ffebee; color:#c62828; }

/* ------- actions in card -------------------------------------- */
.card-actions{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.inline{ display:inline; }
.btn-cart{
  background:#11a955; color:#fff; padding:10px 14px;
}
.request-form{ display:inline-flex; gap:8px; align-items:center; }
.qty-input{
  width:84px; padding:6px 8px; border:1px solid #d0d7de; border-radius:8px; color:#0b1d2a;
}
.btn-request{
  background:#ffefc1; color:#7a6115; padding:10px 14px;
}
.already-note{ font-size:13px; color:#d7dde3; }

.compare-toggle{ display:inline-flex; align-items:center; gap:8px; cursor:pointer; user-select:none; }
.compare-toggle input{ width:18px; height:18px; }

/* ------- flash ------------------------------------------------- */
.flash{ margin:10px auto 16px; padding:10px 14px; border-radius:8px; width:min(760px, 95%); }
.flash-success{ background:#e8f5e9; color:#1b5e20; border:1px solid #c8e6c9; }

/* ------- bottom page actions (στο κέντρο, όπως πριν) ----------- */
.page-actions{
  margin:26px 0 0;
  display:flex; justify-content:center; gap:14px; flex-wrap:wrap;
}
.btn-goto-cart{ background:#11a955; color:#fff; padding:12px 20px; }
.btn-back     { background:#607D8B; color:#fff; padding:12px 20px; }
.page-actions .btn:hover{ filter:brightness(1.05); }

/* ------- sticky compare bar ----------------------------------- */
.sticky-compare{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:999;
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  background:#05131b; color:#fff; padding:10px 14px; border-radius:12px;
  box-shadow: 0 -6px 22px rgba(0,0,0,.35);
}
.sticky-compare .chips{ display:flex; gap:6px; flex:1 1 auto; overflow:auto; }
.chip{ background:#0d2a36; padding:6px 10px; border-radius:16px; font-size:14px; white-space:nowrap; }
.btn-clear{ background:#f44336; color:#fff; padding:8px 12px; }
.btn-compare-now{ background:#0abf53; color:#fff; padding:10px 14px; border-radius:10px; text-decoration:none; }
.no-results{ text-align:center; color:#6d7a86; }
