/* ═══════════════════════════════════════════════════════════════
   Enterprise Meal Access System — pages/settings.css
═══════════════════════════════════════════════════════════════ */

/* ── SETTINGS ─────────────────────────────────────────────────── */
.cn-settings-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 16px;
}
.cn-settings-section-head {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.cn-settings-section-body { padding: 0 20px; }
.cn-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.cn-setting-row:last-child { border-bottom: none; }
.cn-setting-label { font-size: 13.5px; font-weight: 500; color: var(--text-primary); }
.cn-setting-desc  { font-size: 12px; color: var(--text-muted); margin-top: 2px; line-height: 1.4; }
.cn-setting-control { flex-shrink: 0; display: flex; align-items: center; gap: 8px; }
.cn-setting-control .cn-form-input { width: 120px; }

/* ── CONSUMPTION RULES (embedded in settings) ────────────────── */
.cn-rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
.cn-rule-card {
  background: var(--surface-hover);
  border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: 12px;
  padding: 16px 18px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  transition: border-color .15s;
}
.cn-rule-card.enabled { border-left-color: var(--accent); }
.cn-rule-icon {
  width: 36px; height: 36px;
  border-radius: 9px;
  background: var(--surface);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cn-rule-body { flex: 1; }
.cn-rule-name { font-size: 13.5px; font-weight: 600; color: var(--text-primary); }
.cn-rule-desc { font-size: 12px; color: var(--text-muted); margin-top: 3px; line-height: 1.5; }
.cn-rule-val  { font-size: 12px; font-weight: 600; color: var(--accent); margin-top: 6px; }
.cn-rule-toggle { flex-shrink: 0; }

/* ── SCAN SIMULATION (admin) ──────────────────────────────────── */
.cn-sim-result {
  text-align: center;
  padding: 28px 20px;
}
.cn-sim-icon   { font-size: 44px; margin-bottom: 8px; }
.cn-sim-code   {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 3px 12px;
  border-radius: 20px;
  display: inline-block;
  margin-bottom: 8px;
}
.cn-sim-code.approved { background: rgba(16,185,129,.1); color: #047857; }
.cn-sim-code.rejected { background: rgba(239,68,68,.1);  color: #b91c1c; }
.cn-sim-name   { font-size: 20px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.cn-sim-sub    { font-size: 13px; color: var(--text-muted); }
.cn-sim-detail { font-size: 12px; color: var(--text-muted); margin-top: 6px; line-height: 1.5; max-width: 300px; margin-inline: auto; }
