/* Scope everything to the app container */
#budget-app {
  --ink:#111;
  --bg:#f7f7fb;
  --card:#fff;
  --line:#e7e7ee;
  --accent:#2563eb; /* blue */
  --danger:#ef4444;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--ink);
  background: var(--bg);
  margin-left: 10px;
  margin-right: 10px;
  padding: 16px;
  border: 2px solid #000;
  border-radius: 10px;
}

#budget-app h1 {
  display: inline-block;
  background: #fff;
  border: 2px solid #000;
  border-radius: 8px;
  padding: 2px 10px 4px;
  margin: 0 0 12px 0;
  color: var(--accent);
}

#budget-app .toolbar {
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 12px;
}
#budget-app button {
  cursor: pointer; border: 1px solid #cfd2dc; background: #fff; border-radius: 8px; padding: 8px 10px;
}
#budget-app .danger { border-color: var(--danger); color: var(--danger); }

#budget-app .totals {
  display: grid; gap: 10px; grid-template-columns: repeat(3, minmax(0,1fr));
  margin-bottom: 12px;
}
#budget-app .total-box {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: 10px;
}
#budget-app .total-box .label { font-size: 12px; opacity: .8; }
#budget-app .total-box .value { font-weight: 700; font-size: 18px; }

#budget-app .columns {
  display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0,1fr));
}
#budget-app .panel {
  background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: 12px;
}
#budget-app .panel h2 { margin: 0 0 8px 0; color: var(--accent); }

#budget-app .list { display: flex; flex-direction: column; gap: 8px; }
#budget-app .card {
  border: 1px solid var(--line); border-radius: 10px; background: #fff; overflow: hidden;
}
#budget-app .card .row { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 10px 12px; align-items: center; }
#budget-app .card .row + .row { border-top: 1px solid var(--line); }
#budget-app .card .title { font-weight: 700; }
#budget-app .muted { opacity: .8; font-size: 12px; }

#budget-app .chips { display: inline-flex; gap: 6px; align-items: center; flex-wrap: wrap; }
#budget-app .chip { font-size: 12px; padding: 3px 8px; border-radius: 999px; background: #f1f5ff; border: 1px solid #d9e2ff; }

#budget-app dialog {
  border: 1px solid var(--line); border-radius: 10px; padding: 14px; width: min(640px, 92vw);
  color: #111; background: #fff;
}
#budget-app dialog::backdrop { background: rgba(0,0,0,.45); }
#budget-app form.grid { display: grid; gap: 10px; grid-template-columns: 1fr 1fr; }
#budget-app form h3 { grid-column: 1 / -1; margin: 0 0 4px 0; color: var(--accent); }
#budget-app form label { display: grid; gap: 6px; }
#budget-app input[type="text"], #budget-app input[type="number"], #budget-app select, #budget-app textarea {
  border: 1px solid #cfd2dc; border-radius: 8px; padding: 7px 9px; background: #fff;
}
#budget-app .dialog-actions { grid-column: 1 / -1; display: flex; gap: 8px; justify-content: flex-end; margin-top: 6px; }

#budget-app fieldset.assign {
  grid-column: 1 / -1; border: 1px solid var(--line); border-radius: 8px; padding: 8px;
}
#budget-app fieldset.assign legend { padding: 0 4px; }
#budget-app .assign .mode { display: inline-flex; gap: 6px; align-items: center; margin-right: 14px; }
/*#budget-app .assign .checks { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 6px; margin-top: 6px; }*/
/*uniform checkboxes + name alignment inside the split people list */
#budget-app .assign .checks { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 8px; }
#budget-app .assign .checks label {
    display: grid;
    grid-template-columns: 18px 1fr; /* checkbox | name */
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fafafa;
}

#budget-app .assign .checks input[type="checkbox"] {
    margin: 0;  /* kill default vertical offset */
    justify-self: center;
}

#budget-app .assign .checks label > * {
    line-height: 1.2;   /* keeps name from "bouncing vertically" */
}

#budget-app .hidden { display: none; }

#budget-app .pill {
  font-size: 12px; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--line); background: #fafafa;
}

/* fix to stop css clashing */
#budget-app strong {
  color: inherit;
  text-decoration: none;
  font-weight: 700;
}

@media (max-width: 768px) {
  #budget-app .totals { grid-template-columns: 1fr; }
  #budget-app .columns { grid-template-columns: 1fr; }  
}

/*@media (prefers-color-scheme: dark) {
  #budget-app {
    color-scheme: light;
  }
}*/

/*@media (prefers-color-scheme: dark) {
  body {
    background: #333;
    color: #f9f9f9;
  }

  #budget-app {
    --bg: #333;
    --ink: #f9f9f9;
    --card: #1c1c1c;
    --line: #555;
  }
}*/
