@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  --bg:#F1F4F2;
  --surface:#FFFFFF;
  --border:#E0E6E2;
  --text:#1B241F;
  --text-muted:#647168;

  --accent:#1F5D52;
  --accent-dark:#143E37;
  --accent-soft:#E3EFEC;

  --yes:#2F7D5E;
  --yes-soft:#E3F3EC;
  --no:#7C8A82;
  --no-soft:#ECEFED;

  --danger:#B3432D;
  --danger-soft:#FBEAE5;

  --radius:10px;
  --radius-sm:6px;
  --shadow:0 1px 2px rgba(20,30,25,.06), 0 6px 16px rgba(20,30,25,.05);

  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-body:'Inter', system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{ font-family:var(--font-display); margin:0; letter-spacing:-0.01em; }
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
code{ font-family:monospace; background:var(--no-soft); padding:2px 5px; border-radius:4px; }

/* ===== Topbar ===== */
.topbar{
  background:var(--accent-dark);
  border-bottom:3px solid var(--accent);
}
.topbar-inner{
  max-width:1100px; margin:0 auto;
  display:flex; align-items:center; gap:24px;
  padding:14px 20px;
}
.brand{
  font-family:var(--font-display); font-weight:700; font-size:19px;
  color:#fff !important; text-decoration:none;
}
.topbar-nav{ display:flex; gap:18px; flex:1; }
.topbar-nav a{ color:#D7E6E1 !important; font-weight:500; font-size:14px; }
.topbar-nav a:hover{ color:#fff !important; text-decoration:none; }
.topbar-user{ display:flex; align-items:center; gap:12px; }
.user-name{ color:#D7E6E1; font-size:14px; }

/* ===== Layout ===== */
.page{ max-width:1100px; margin:0 auto; padding:28px 20px 60px; }
.page-head{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  margin-bottom:18px; flex-wrap:wrap;
}
.page-head-actions{ display:flex; gap:10px; }
.count{ color:var(--text-muted); font-weight:400; font-size:18px; }

.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:20px; align-items:start; }
@media (max-width:880px){ .grid-2{ grid-template-columns:1fr; } }

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
}
.card-title{
  font-size:16px; font-weight:600; margin-bottom:16px;
  padding-left:12px; border-left:3px solid var(--accent);
}

/* ===== Forms ===== */
.form{ display:flex; flex-direction:column; gap:14px; }
.form label{ display:flex; flex-direction:column; gap:6px; font-size:13px; font-weight:500; color:var(--text-muted); }
.form input[type=text], .form input[type=email], .form input[type=date], .form input[type=password], .form textarea{
  font-family:var(--font-body); font-size:14.5px; color:var(--text);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:9px 11px; background:#fff;
}
.form input:focus, .form textarea:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);
}
.form textarea{ resize:vertical; font-family:var(--font-body); }

.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 16px; }
.form-grid .span-2{ grid-column:1/-1; display:flex; flex-direction:column; gap:6px; }
@media (max-width:560px){ .form-grid{ grid-template-columns:1fr; } }

.form-inline{ flex-direction:row; flex-wrap:wrap; align-items:flex-end; gap:10px; }
.form-inline label{ min-width:130px; }
.form-inline .grow{ flex:1; }

.checkbox-row{ display:flex; gap:24px; flex-wrap:wrap; background:var(--accent-soft); padding:12px 14px; border-radius:var(--radius-sm); }
.checkbox-label{ display:flex !important; flex-direction:row !important; align-items:center; gap:8px; font-size:14px; color:var(--text) !important; font-weight:500 !important; cursor:pointer; }
.checkbox-label input{ width:17px; height:17px; accent-color:var(--accent); cursor:pointer; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  font-family:var(--font-body); font-weight:600; font-size:14px;
  padding:9px 16px; border-radius:var(--radius-sm); border:1px solid transparent;
  cursor:pointer; text-decoration:none !important; transition:filter .15s ease;
}
.btn:hover{ filter:brightness(0.95); }
.btn-primary{ background:var(--accent); color:#fff; }
.btn-secondary{ background:var(--accent-soft); color:var(--accent-dark); border-color:var(--accent-soft); }
.btn-ghost{ background:transparent; color:var(--text-muted); border-color:var(--border); }
.btn-danger-ghost{ background:transparent; color:var(--danger); border-color:var(--danger-soft); }
.btn-block{ width:100%; }
.btn-sm{ padding:5px 10px; font-size:12.5px; }

/* ===== Search ===== */
.search-bar{ display:flex; gap:10px; margin-bottom:20px; }
.search-bar input{
  flex:1; font-family:var(--font-body); font-size:14.5px;
  border:1px solid var(--border); border-radius:var(--radius-sm); padding:9px 12px;
}
.search-bar input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }

/* ===== Table ===== */
.table-wrap{ overflow-x:auto; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); }
.table{ width:100%; border-collapse:collapse; font-size:14px; }
.table th{ text-align:left; font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); padding:12px 14px; border-bottom:1px solid var(--border); background:#FAFBFA; }
.table td{ padding:11px 14px; border-bottom:1px solid var(--border); }
.table tbody tr:last-child td{ border-bottom:none; }
.table tbody tr:hover{ background:var(--accent-soft); cursor:pointer; }
.table-compact tbody tr:hover{ background:transparent; cursor:default; }
.table-action{ text-align:right; white-space:nowrap; }

/* ===== Badges ===== */
.badge{ display:inline-block; padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600; text-transform:capitalize; }
.badge-yes{ background:var(--yes-soft); color:var(--yes); }
.badge-no{ background:var(--no-soft); color:var(--no); }

/* ===== Misc ===== */
.muted{ color:var(--text-muted); font-size:13.5px; }
.center{ text-align:center; }
.empty-state{
  text-align:center; padding:50px 20px; background:var(--surface);
  border:1px dashed var(--border); border-radius:var(--radius);
}
.empty-state p{ color:var(--text-muted); margin-bottom:16px; }

.flash{ padding:12px 16px; border-radius:var(--radius-sm); font-size:14px; margin-bottom:18px; }
.flash-success{ background:var(--yes-soft); color:var(--yes); }
.flash-error{ background:var(--danger-soft); color:var(--danger); }

/* ===== Comment history ===== */
.comment-list{ list-style:none; margin:16px 0 0; padding:0; display:flex; flex-direction:column; gap:10px; }
.comment-item{ background:#FAFBFA; border:1px solid var(--border); border-radius:var(--radius-sm); padding:10px 14px; }
.comment-meta{ display:flex; align-items:center; gap:10px; font-size:12.5px; font-weight:600; color:var(--accent-dark); margin-bottom:4px; }
.comment-meta .btn{ margin-left:auto; }
.comment-text{ margin:0; font-size:14px; color:var(--text); white-space:pre-wrap; }

/* ===== Auth pages ===== */
.auth-page{ min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); padding:20px; }
.auth-card{
  width:100%; max-width:380px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:32px 28px;
}
.auth-title{ font-size:22px; color:var(--accent-dark); }
