/* Reuse earlier styling, add compact grid */ 
/* Basic reset and layout */
* { box-sizing: border-box; }
:root {
  --bg: #f7f7fb;
  --card: #fff;
  --text: #111;
  --muted: #666;
  --border: #e5e7eb;
  --primary: #1f7aec;
  --danger: #ef4444;
  --ok: #10b981;
  --warn: #f59e0b;
  --radius: 14px;
  --shadow: 0 6px 20px rgba(0,0,0,.06);
}
html, body { height: 100%; }
body {
  margin: 0;
  font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}
.container { max-width: 1100px; margin: 0 auto; padding: 16px; }
.header { display:flex; gap:16px; align-items:flex-end; justify-content:space-between; flex-wrap: wrap; }
h1 { margin: 0; font-size: 28px; }
h2 { margin: 0 0 8px; font-size: 18px; }
h3 { margin: 0; font-size: 18px; }
.muted { color: var(--muted); }
.small { font-size: 12px; }
.right { text-align: right; }
.actions { display:flex; gap:8px; align-items:center; }
.date-input { padding:8px 10px; border:1px solid var(--border); border-radius:10px; background:#fff; }

.btn { background: var(--primary); border:1px solid var(--primary); color:#fff; padding:10px 14px; border-radius:12px; cursor:pointer; transition:transform .05s ease, box-shadow .2s ease, background .2s ease; box-shadow:0 3px 10px rgba(31,122,236,.25); }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn.outline { background:#fff; color:var(--text); border:1px solid var(--border); box-shadow:none; }
.btn.primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn.block { width: 100%; }
.hidden { display:none !important; }

.card { background: var(--card); border:1px solid var(--border); border-radius: var(--radius); padding:16px; box-shadow: var(--shadow); }
.grid { display:grid; grid-template-columns: 1fr 1fr 140px 140px 140px; gap:12px; }
.grid-compact { display:grid; grid-template-columns: 1fr 1fr 160px 1fr; gap:12px; }
.field { display:flex; flex-direction:column; gap:6px; }
.field.sm input { padding: 9px 10px; }
.field input, .field select, input, select { padding:12px 12px; border:1px solid var(--border); border-radius:10px; background:#fff; }
.field.end { align-self:end; }
.toolbar { display:flex; gap:12px; align-items:center; justify-content:space-between; margin-top: 12px; }
.filter { display:flex; gap:8px; align-items:center; }

.cards { display:grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; margin: 16px 0; }
.colleague .row { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.colleague .row.gap { gap: 8px; flex-wrap: wrap; }
.colleague .name-row { display:flex; align-items:center; gap:8px; }
.badge { display:inline-block; padding: 3px 8px; border-radius: 999px; font-size: 12px; border:1px solid var(--border); background:#fff; }
.badge.ok { background:#ecfdf5; border-color:#bbf7d0; color:#065f46; }
.badge.warn { background:#fffbeb; border-color:#fde68a; color:#7c2d12; }
.badge.due { background:#fef2f2; border-color:#fecaca; color:#7f1d1d; }
.badge.on { background:#eff6ff; border-color:#bfdbfe; color:#1e40af; }

.duo { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.settings h2 { margin-bottom:8px; }
.hint { margin-top: 8px; font-size: 12px; color: var(--muted); }
.footer { text-align:center; font-size:12px; color:var(--muted); padding: 8px 0 24px; }

@media (max-width: 850px) { .grid { grid-template-columns: 1fr 1fr; } .grid-compact { grid-template-columns: 1fr 1fr; } }
@media print { body { background:#fff; } .print-hide, .header .actions { display:none !important; } .container { max-width:100%; padding:8mm; } .card { box-shadow:none; border-color:#ddd; } .cards { grid-template-columns: repeat(2, 1fr); gap: 8mm; } }
