/* Debt-Free SG Tracker - minimal mobile-first styles */
.dfsg-wrap { max-width: 900px; margin: 0 auto; padding: 16px; }
.dfsg-header { margin-bottom: 12px; }
.dfsg-header-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.dfsg-sub { margin: 4px 0 0; color: #666; }
.dfsg-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 900px) { .dfsg-grid { grid-template-columns: 1fr 1fr; } }

.dfsg-card { background: #fff; border: 1px solid #e7e7e7; border-radius: 16px; padding: 14px; box-shadow: 0 2px 10px rgba(0,0,0,0.03); }
.dfsg-divider { height: 1px; background: #eee; margin: 12px 0; }
.dfsg-muted { color: #666; }
.dfsg-strong { font-weight: 700; }
.dfsg-note { margin-top: 8px; color: #0a7; min-height: 18px; }
.dfsg-code { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; background: #f6f6f6; border: 1px solid #eee; padding: 3px 8px; border-radius: 999px; display: inline-block; margin: 4px 6px 0 0; }

.dfsg-form-grid { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 700px) { .dfsg-form-grid { grid-template-columns: 1fr 1fr; } }

.dfsg-form-row label { display: block; font-size: 12px; color: #666; margin-bottom: 4px; }
.dfsg-form-row input, .dfsg-form-row select { width: 100%; padding: 10px 10px; border: 1px solid #ddd; border-radius: 10px; font-size: 14px; }

.dfsg-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.dfsg-actions-tight { justify-content: flex-start; }

.dfsg-btn { background: #111; color: #fff; border: none; border-radius: 12px; padding: 10px 14px; cursor: pointer; font-size: 14px; }
.dfsg-btn:hover { opacity: 0.92; }
.dfsg-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.dfsg-btn-secondary { background: #f3f3f3; color: #111; border: 1px solid #e5e5e5; }
.dfsg-btn-danger { background: #c0392b; color: #fff; }

.dfsg-table { width: 100%; display: grid; gap: 8px; }
.dfsg-table-head { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 8px; font-size: 12px; color: #666; }
.dfsg-table-row { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 8px; align-items: center; background: #fafafa; border: 1px solid #eee; border-radius: 12px; padding: 10px; }
@media (max-width: 650px) {
  .dfsg-table-head { display: none; }
  .dfsg-table-row { grid-template-columns: 1fr; }
  .dfsg-actions { justify-content: flex-start; }
}

.dfsg-pill { display: inline-block; padding: 4px 10px; border-radius: 999px; background: #eee; font-size: 12px; }
.dfsg-pill-ok { background: #dff7e9; color: #0a7; border: 1px solid #bfead2; }

.dfsg-edit-panel { margin: 8px 0 14px; background: #fff; border: 1px solid #eee; border-radius: 16px; padding: 12px; }

.dfsg-summary { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 12px; }
@media (min-width: 900px) { .dfsg-summary { grid-template-columns: repeat(4, 1fr); } }
.dfsg-sum-card { background: #fafafa; border: 1px solid #eee; border-radius: 16px; padding: 12px; }
.dfsg-sum-label { font-size: 12px; color: #666; }
.dfsg-sum-val { font-size: 16px; font-weight: 800; margin-top: 6px; }

.dfsg-dues { display: grid; gap: 10px; }
.dfsg-due-card { display: flex; justify-content: space-between; align-items: center; gap: 10px; background: #fafafa; border: 1px solid #eee; border-radius: 16px; padding: 12px; }
.dfsg-due-meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 6px; }

.dfsg-month-nav { display: flex; gap: 8px; }
.dfsg-check { display: inline-flex; align-items: center; cursor: pointer; position: relative; }
.dfsg-check input { position: absolute; opacity: 0; width: 1px; height: 1px; left: 0; top: 0; }
.dfsg-check-ui { width: 46px; height: 28px; border-radius: 999px; border: 1px solid #ddd; background: #fff; position: relative; transition: 0.15s; }
.dfsg-check-ui:after { content: ""; width: 22px; height: 22px; border-radius: 50%; background: #ddd; position: absolute; top: 2px; left: 2px; transition: 0.15s; }
.dfsg-check input:checked + .dfsg-check-ui { background: #dff7e9; border-color: #bfead2; }
.dfsg-check input:checked + .dfsg-check-ui:after { left: 22px; background: #0a7; }

/* Paid/Pending button group */
.dfsg-status { display: inline-flex; gap: 8px; align-items: center; }
.dfsg-set-status.is-active { outline: 2px solid rgba(0,0,0,0.12); }

/* Active state stronger (app-like) */
.dfsg-set-status.is-active { box-shadow: 0 6px 16px rgba(0,0,0,0.10); transform: translateY(-1px); }
