/* Minimal base styles for the boilerplate. Replace with your design system. */
:root {
    --fg: #14181f;
    --muted: #5b6675;
    --bg: #ffffff;
    --accent: #2f6df6;
    --danger: #d23b3b;
    --border: #e3e7ee;
}
* { box-sizing: border-box; }
body {
    margin: 0;
    font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    color: var(--fg);
    background: var(--bg);
}
.topbar {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1rem 1.5rem; border-bottom: 1px solid var(--border);
}
.topbar nav a { margin-left: 1rem; text-decoration: none; color: var(--fg); }
.brand { font-weight: 700; text-decoration: none; color: var(--fg); }
main { max-width: 960px; margin: 0 auto; padding: 2rem 1.5rem; }
.btn {
    display: inline-block; padding: .6rem 1.1rem; border: 0; border-radius: 8px;
    background: var(--accent); color: #fff; cursor: pointer; text-decoration: none;
}
.btn--secondary { background: #eef1f6; color: var(--fg); }
.btn--danger { background: var(--danger); }
textarea, input { width: 100%; padding: .6rem; border: 1px solid var(--border); border-radius: 8px; }
.grid, .plan-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 1rem; }
.job, .plan-card { border: 1px solid var(--border); border-radius: 10px; padding: .75rem; }
.job img, .plan-card img { width: 100%; border-radius: 6px; }
.messages, .alert { list-style: none; padding: .75rem 1rem; border-radius: 8px; }
.alert--error, .error { color: var(--danger); }
.footer { padding: 2rem 1.5rem; color: var(--muted); border-top: 1px solid var(--border); }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: .5rem; border-bottom: 1px solid var(--border); }
