/* Agndalo — Design system */

:root {
  /* Palette */
  --ag-ink: #1A1814;
  --ag-ink-2: #2D2A24;
  --ag-mute: #6B655B;
  --ag-mute-2: #9C968B;
  --ag-line: #E8E2D5;
  --ag-line-2: #F0EBDF;
  --ag-cream: #FBF8F3;
  --ag-cream-2: #F5F1E8;
  --ag-paper: #FFFFFF;

  --ag-primary: #0F4F3C;
  --ag-primary-hover: #0B3D2E;
  --ag-primary-soft: #E3EEE9;
  --ag-primary-tint: #F1F7F4;

  --ag-accent: #E87B5C;
  --ag-accent-soft: #FBE6DD;

  --ag-wa: #25D366;
  --ag-wa-ink: #128C7E;
  --ag-wa-soft: #DCFCE7;

  --ag-warn: #C77A1E;
  --ag-warn-soft: #FCEFD7;
  --ag-danger: #B43A2E;
  --ag-danger-soft: #FAE3DF;
  --ag-info: #2A5A9E;
  --ag-info-soft: #E3ECF8;

  /* Type */
  --ag-display: "Bricolage Grotesque", "Geist", ui-sans-serif, system-ui, sans-serif;
  --ag-ui: "Geist", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --ag-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Radii */
  --ag-r-sm: 6px;
  --ag-r-md: 10px;
  --ag-r-lg: 14px;
  --ag-r-xl: 20px;
  --ag-r-pill: 999px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  font-family: var(--ag-ui);
  font-size: 14px;
  color: var(--ag-ink);
  background: var(--ag-cream);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
}

h1, h2, h3, h4 {
  font-family: var(--ag-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--ag-ink);
}

button { font-family: inherit; }

/* Density variants applied via data-density on .ag-app */
.ag-app[data-density="comfy"] { --ag-pad-card: 22px; --ag-row-h: 56px; }
.ag-app[data-density="regular"] { --ag-pad-card: 18px; --ag-row-h: 48px; }
.ag-app[data-density="compact"] { --ag-pad-card: 14px; --ag-row-h: 40px; }

/* ──────────────────────────── App shell ──────────────────────────── */

.ag-app {
  display: grid;
  grid-template-columns: 232px 1fr;
  min-height: 100vh;
  background: var(--ag-cream);
}

.ag-sidebar {
  background: var(--ag-cream);
  border-right: 1px solid var(--ag-line);
  display: flex;
  flex-direction: column;
  padding: 18px 14px;
  gap: 22px;
  position: sticky;
  top: 0;
  height: 100vh;
}

.ag-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px 2px;
}
.ag-brand-mark {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: var(--ag-primary);
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--ag-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.04em;
}
.ag-brand-name {
  font-family: var(--ag-display);
  font-weight: 600;
  font-size: 19px;
  letter-spacing: -0.03em;
  color: var(--ag-ink);
}
.ag-brand-name span { color: var(--ag-primary); }

.ag-nav { display: flex; flex-direction: column; gap: 2px; }
.ag-nav-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ag-mute-2);
  padding: 14px 10px 6px;
}
.ag-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: var(--ag-r-md);
  font-size: 13.5px;
  color: var(--ag-ink-2);
  cursor: default;
  border: none;
  background: transparent;
  text-align: left;
  width: 100%;
  font-weight: 500;
}
.ag-nav-item span { white-space: nowrap; }
.ag-nav-item:hover { background: var(--ag-cream-2); }
.ag-nav-item.is-active {
  background: var(--ag-paper);
  color: var(--ag-primary);
  box-shadow: inset 0 0 0 1px var(--ag-line);
}
.ag-nav-item.is-active .ag-nav-icon { color: var(--ag-primary); }
.ag-nav-icon { width: 18px; height: 18px; color: var(--ag-mute); flex: none; }
.ag-nav-badge {
  margin-left: auto;
  font-family: var(--ag-mono);
  font-size: 10.5px;
  background: var(--ag-primary);
  color: #fff;
  padding: 1px 6px;
  border-radius: var(--ag-r-pill);
  font-weight: 500;
}
.ag-nav-item:not(.is-active) .ag-nav-badge {
  background: var(--ag-line);
  color: var(--ag-mute);
}

.ag-sidebar-foot {
  margin-top: auto;
  padding: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid var(--ag-line);
  padding-top: 14px;
}
.ag-sidebar-foot .ag-avatar { width: 32px; height: 32px; font-size: 12px; }
.ag-foot-name { font-size: 13px; font-weight: 500; line-height: 1.2; }
.ag-foot-sub { font-size: 11.5px; color: var(--ag-mute); line-height: 1.2; }

/* Main */
.ag-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ag-topbar {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px 32px;
  border-bottom: 1px solid var(--ag-line);
  background: var(--ag-cream);
  position: sticky; top: 0; z-index: 20;
}
.ag-page-title {
  font-family: var(--ag-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.025em;
}
.ag-search {
  flex: 1;
  max-width: 420px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--ag-paper);
  border: 1px solid var(--ag-line);
  padding: 7px 12px;
  border-radius: var(--ag-r-md);
  font-size: 13px;
  color: var(--ag-mute);
}
.ag-search input {
  border: none; outline: none; background: transparent;
  flex: 1; font: inherit; color: var(--ag-ink);
}
.ag-search kbd {
  font-family: var(--ag-mono);
  font-size: 10.5px;
  padding: 1px 5px;
  border: 1px solid var(--ag-line);
  border-radius: 4px;
  color: var(--ag-mute);
  background: var(--ag-cream);
}
.ag-topbar-spacer { flex: 1; }
.ag-icon-btn {
  width: 34px; height: 34px;
  display: grid; place-items: center;
  border-radius: var(--ag-r-md);
  border: 1px solid var(--ag-line);
  background: var(--ag-paper);
  color: var(--ag-ink-2);
  cursor: default;
  position: relative;
}
.ag-icon-btn:hover { background: var(--ag-cream-2); }
.ag-icon-btn .ag-dot {
  position: absolute; top: 7px; right: 7px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--ag-accent); border: 1.5px solid var(--ag-paper);
}

.ag-page { padding: 24px 32px 48px; min-width: 0; }

/* ──────────────────────────── Primitives ──────────────────────────── */

.ag-card {
  background: var(--ag-paper);
  border: 1px solid var(--ag-line);
  border-radius: var(--ag-r-lg);
  padding: var(--ag-pad-card, 18px);
}
.ag-card-hd {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.ag-card-title {
  font-family: var(--ag-display);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.ag-card-sub { font-size: 12.5px; color: var(--ag-mute); }

.ag-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 13px;
  border-radius: var(--ag-r-md);
  font-size: 13px;
  font-weight: 500;
  border: 1px solid transparent;
  cursor: default;
  font-family: inherit;
  white-space: nowrap;
  background: var(--ag-paper);
  color: var(--ag-ink);
  border-color: var(--ag-line);
}
.ag-btn:hover { background: var(--ag-cream-2); }
.ag-btn.primary {
  background: var(--ag-primary); color: #fff; border-color: var(--ag-primary);
}
.ag-btn.primary:hover { background: var(--ag-primary-hover); }
.ag-btn.ghost { background: transparent; border-color: transparent; color: var(--ag-ink-2); }
.ag-btn.ghost:hover { background: var(--ag-cream-2); }
.ag-btn svg { width: 14px; height: 14px; }

.ag-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 500;
  padding: 2px 7px;
  border-radius: var(--ag-r-pill);
  background: var(--ag-cream-2);
  color: var(--ag-ink-2);
  white-space: nowrap;
}
.ag-badge.wa { background: var(--ag-wa-soft); color: var(--ag-wa-ink); }
.ag-badge.wa svg { width: 11px; height: 11px; }
.ag-badge.web { background: var(--ag-info-soft); color: var(--ag-info); }
.ag-badge.walk { background: var(--ag-cream-2); color: var(--ag-mute); }
.ag-badge.confirmed { background: var(--ag-primary-soft); color: var(--ag-primary); }
.ag-badge.pending { background: var(--ag-warn-soft); color: var(--ag-warn); }
.ag-badge.cancelled { background: var(--ag-danger-soft); color: var(--ag-danger); }
.ag-badge.new { background: var(--ag-accent-soft); color: var(--ag-accent); }

.ag-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 600;
  font-size: 13px;
  flex: none;
  color: #fff;
  letter-spacing: -0.02em;
}

.ag-divider { height: 1px; background: var(--ag-line); margin: 14px 0; }

/* tab pills */
.ag-tabs {
  display: inline-flex;
  padding: 3px;
  background: var(--ag-cream-2);
  border-radius: var(--ag-r-md);
  gap: 2px;
}
.ag-tab {
  padding: 5px 12px;
  border-radius: 7px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ag-mute);
  cursor: default;
  border: none;
  background: transparent;
  font-family: inherit;
}
.ag-tab.is-active {
  background: var(--ag-paper);
  color: var(--ag-ink);
  box-shadow: 0 1px 2px rgba(26,24,20,.06);
}

/* tabular nums */
.tnum { font-variant-numeric: tabular-nums; }
.mono { font-family: var(--ag-mono); }
