/* ── Online Shop Page ── */
.oshop-page { min-height: 100%; }

.os-header-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.os-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.os-mobile-list {
  display: none;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.os-mobile-list.is-visible { display: flex; }

.os-mobile-card {
  padding: var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  cursor: pointer;
}

.os-mobile-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: 6px;
  font-family: var(--font-bn);
}

.os-mobile-card-body {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-bn);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-bottom: 10px;
}

.os-mobile-toggle { margin-top: 4px; }

.os-title-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  border-left: 4px solid #059669;
  padding-left: var(--space-sm);
}

.os-title-wrap .page-title-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  color: var(--color-text-secondary);
}

.os-title-wrap .page-title-back:hover {
  background: #ecfdf5;
  color: #059669;
}

.os-title-wrap .page-title-back svg { width: 20px; height: 20px; }

.os-shop-card {
  margin-top: var(--space-lg);
  padding: var(--space-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border-top: 3px solid #059669;
}

.os-shop-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
}

.os-shop-card-title {
  font-family: var(--font-bn);
  font-size: var(--text-md);
  font-weight: 700;
}

.os-toggle-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-bn);
  font-size: var(--text-sm);
}

.os-toggle {
  position: relative;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}

.os-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.os-toggle-slider {
  position: absolute;
  inset: 0;
  background: #d1d5db;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s;
}

.os-toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
}

.os-toggle input:checked + .os-toggle-slider {
  background: #059669;
}

.os-toggle input:checked + .os-toggle-slider::before {
  transform: translateX(20px);
}

.os-shop-link-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.os-shop-link {
  flex: 1;
  min-width: 200px;
  padding: 10px 14px;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius-sm);
  font-family: var(--font-en);
  font-size: var(--text-sm);
  color: #047857;
}

.os-shop-note {
  margin-top: var(--space-sm);
  font-family: var(--font-bn);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.os-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

.os-stat-card {
  padding: var(--space-md) var(--space-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.os-stat-card.is-online { border-top: 3px solid #059669; }
.os-stat-card.is-offline { border-top: 3px solid #6b7280; }
.os-stat-card.is-value { border-top: 3px solid #047857; }

.os-stat-label {
  display: block;
  font-family: var(--font-bn);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: 4px;
}

.os-stat-value {
  font-family: var(--font-en);
  font-size: var(--text-xl);
  font-weight: 700;
}

.os-stat-card.is-online .os-stat-value { color: #059669; }
.os-stat-card.is-offline .os-stat-value { color: #6b7280; }

.os-table-meta {
  margin: var(--space-md) 0 var(--space-sm);
  font-family: var(--font-bn);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.os-table-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.os-table-card.is-hidden { display: none; }
.os-table-scroll { overflow-x: auto; }

.os-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
}

.os-table thead { background: #ecfdf5; }

.os-table th {
  padding: 12px 14px;
  font-family: var(--font-bn);
  font-size: var(--text-xs);
  font-weight: 700;
  color: #047857;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

.os-table td {
  padding: 12px 14px;
  font-family: var(--font-bn);
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--color-border-light);
}

.os-table tbody tr:hover { background: #f0fdf4; }

.os-cell-money { font-family: var(--font-en); white-space: nowrap; }

.os-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: 600;
}

.os-badge.is-on { background: #ecfdf5; color: #059669; }
.os-badge.is-off { background: #f3f4f6; color: #6b7280; }

.os-empty-state { display: none; text-align: center; padding: var(--space-xl); }
.os-empty-state.is-visible { display: block; }

.os-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  z-index: 300;
  padding: 12px 20px;
  background: #111827;
  color: #fff;
  border-radius: var(--radius-md);
  font-family: var(--font-bn);
  font-size: var(--text-sm);
  transition: transform 0.3s ease;
}

.os-toast.is-visible { transform: translateX(-50%) translateY(0); }
.os-toast.is-error { background: #991b1b; }

.os-detail-meta { margin-bottom: var(--space-md); }

.os-detail-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-border-light);
  font-family: var(--font-bn);
  font-size: var(--text-sm);
}

@media (max-width: 992px) {
  .os-stats-grid { grid-template-columns: 1fr; }
  .os-table-card { display: none !important; }
  .os-mobile-list.is-visible { display: flex; }
  .os-search-box { min-width: 0; }
}

@media (max-width: 768px) {
  .os-toolbar { flex-direction: column; align-items: stretch; }
  .os-search-box { width: 100%; min-width: 0; }
  .os-table-card { display: none; }
  .os-mobile-list.is-visible { display: flex; }
}
