/* ============================================================
   Page: satinalma_oneri — Toplu Satınalma Sipariş Önerisi
   ============================================================ */
.so-page { padding: var(--space-5); }
.so-head { margin-bottom: var(--space-4); }
.so-title { font-size: var(--fs-xl); font-weight: 800; margin: 0; color: var(--text); }
.so-sub { margin: 4px 0 0; color: var(--text-muted); font-size: var(--fs-sm); max-width: 760px; }

.so-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-3); margin-bottom: var(--space-4); }
.so-stat { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: var(--space-3) var(--space-4); }
.so-stat-val { font-size: var(--fs-xl); font-weight: 800; color: var(--text); line-height: 1.1; }
.so-stat-lbl { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 2px; }
.so-stat--warn .so-stat-val { color: var(--yellow); }

.so-group { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); margin-bottom: var(--space-4); overflow: hidden; }
.so-group-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border); background: var(--surface-alt); }
.so-group-sup { font-weight: 800; color: var(--navy); font-size: var(--fs-md); display: flex; align-items: baseline; gap: var(--space-3); flex-wrap: wrap; }
.so-group-meta { font-size: var(--fs-xs); font-weight: 600; color: var(--text-muted); }
.so-group-sub { color: var(--brand); }
.so-none { color: var(--yellow); }
.so-create svg { width: 15px; height: 15px; }

.so-table { width: 100%; }
.so-table tbody tr:hover { background: var(--row-hover); }
.so-pname { font-weight: 700; color: var(--text); }
.so-pcode { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 2px; }
.so-line { font-weight: 700; }
.so-qty { width: 76px; padding: 5px 8px; border: 1.5px solid var(--border-strong); border-radius: var(--radius-sm); text-align: right; font: inherit; font-weight: 700; color: var(--text); background: var(--surface); outline: none; box-sizing: border-box; }
.so-qty:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-glow); }

.so-empty { display: flex; flex-direction: column; align-items: center; gap: 12px; color: var(--text-muted); text-align: center; padding: var(--space-10) var(--space-4); background: var(--surface); border: 1px dashed var(--border); border-radius: var(--radius-lg); font-size: var(--fs-sm); }
.so-empty svg { width: 46px; height: 46px; color: var(--green); }

@media (max-width: 560px) { .so-stats { grid-template-columns: 1fr; } }
