/* Hallmark · macrostructure: Operational Console · tone: calm command · anchor hue: teal-blue */
@import url("/static/tokens.css");

* { box-sizing: border-box; }
html, body { min-height: 100%; overflow-x: clip; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--color-ink);
  background:
    linear-gradient(180deg, var(--color-paper) 0%, var(--color-paper-2) 100%);
  letter-spacing: 0;
}
a { color: inherit; text-decoration: none; }
.text-brand { color: var(--color-accent-strong); }
.text-brand:hover { color: var(--color-accent); }
button, input, select, textarea { font: inherit; }
button, a, input, select, textarea { transition: background-color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), opacity var(--dur-fast) var(--ease-out); }
:focus-visible { outline: 3px solid color-mix(in oklch, var(--color-focus), transparent 35%); outline-offset: 2px; }

.app-shell { min-height: 100vh; }
.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: color-mix(in oklch, var(--color-surface), transparent 6%);
  border-bottom: var(--rule-hairline) solid var(--color-rule);
  backdrop-filter: blur(14px);
}
.topbar-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 760;
  color: var(--color-ink);
  white-space: nowrap;
}
.brand-mark {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  background: var(--color-accent);
  color: var(--color-surface);
  font-size: var(--text-sm);
}
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-2xs);
  flex-wrap: wrap;
}
.nav-link {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 var(--space-sm);
  border-radius: var(--radius-md);
  color: var(--color-muted);
  font-size: var(--text-sm);
  white-space: nowrap;
}
.nav-link:hover { background: var(--color-accent-soft); color: var(--color-accent-strong); }
.version-pill {
  padding: 5px 9px;
  border: var(--rule-hairline) solid var(--color-rule);
  border-radius: 999px;
  color: var(--color-subtle);
  font-size: var(--text-xs);
  white-space: nowrap;
}
.page-main {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-lg);
}
.auth-layout {
  min-height: calc(100vh - 112px);
  display: grid;
  place-items: center;
  padding: var(--space-lg) 0;
}
.auth-card {
  width: min(100%, 420px);
  background: var(--color-surface);
  border: var(--rule-hairline) solid var(--color-rule);
  border-radius: var(--radius-lg);
  box-shadow: 0 18px 48px color-mix(in oklch, var(--color-ink), transparent 92%);
}
.auth-divider {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin: var(--space-md) 0;
  color: var(--color-subtle);
  font-size: var(--text-xs);
}
.auth-divider::before, .auth-divider::after {
  content: "";
  height: 1px;
  flex: 1;
  background: var(--color-rule);
}

.page-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.page-title { font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.1; font-weight: 760; margin: 0; overflow-wrap: anywhere; }
.page-subtitle { margin: 6px 0 0; color: var(--color-muted); font-size: var(--text-sm); }
.section-title { font-size: var(--text-sm); font-weight: 700; color: var(--color-ink); margin: 0 0 var(--space-sm); }
.section-label { font-size: var(--text-xs); font-weight: 720; color: var(--color-subtle); text-transform: uppercase; letter-spacing: .06em; border-bottom: var(--rule-hairline) solid var(--color-rule); padding-bottom: var(--space-xs); margin-bottom: var(--space-sm); }

.card, .kpi-card, .sync-card, .form-card {
  background: var(--color-surface);
  border: var(--rule-hairline) solid var(--color-rule);
  border-radius: var(--radius-lg);
  box-shadow: 0 1px 2px color-mix(in oklch, var(--color-ink), transparent 94%), 0 10px 30px color-mix(in oklch, var(--color-ink), transparent 97%);
}
.card { overflow: hidden; }
.panel { padding: var(--space-lg); }
.subpanel { background: var(--color-surface-raised); border: var(--rule-hairline) solid var(--color-rule); border-radius: var(--radius-md); padding: var(--space-md); }

.btn, .submit-btn, .button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  min-height: 36px;
  padding: 0 var(--space-md);
  border: var(--rule-hairline) solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 680;
  white-space: nowrap;
}
.btn-primary, .submit-btn.primary, .btn-blue { color: var(--color-surface); background: var(--color-accent); border-color: var(--color-accent); }
.btn-primary:hover, .submit-btn.primary:hover, .btn-blue:hover { background: var(--color-accent-strong); transform: translateY(-1px); }
.btn-green { color: var(--color-surface); background: var(--color-green); border-color: var(--color-green); }
.btn-gray, .btn-secondary { color: var(--color-ink); background: var(--color-surface-raised); border-color: var(--color-rule-strong); }
.btn-danger { color: var(--color-red); background: var(--color-red-soft); border-color: color-mix(in oklch, var(--color-red), transparent 70%); }
.btn:disabled, .submit-btn:disabled { opacity: .58; cursor: not-allowed; transform: none; }
.link-muted { color: var(--color-muted); font-size: var(--text-sm); }
.link-muted:hover { color: var(--color-accent-strong); }

.form-input, .control, input[type="text"], input[type="datetime-local"], select, textarea {
  width: 100%;
  min-height: 36px;
  border: var(--rule-hairline) solid var(--color-rule-strong);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-ink);
  padding: 8px 11px;
  font-size: var(--text-sm);
  outline: none;
}
textarea.form-input { min-height: 96px; resize: vertical; }
.form-input:hover, .control:hover, input:hover, select:hover, textarea:hover { border-color: color-mix(in oklch, var(--color-accent), var(--color-rule) 55%); }
.form-input:focus, .control:focus, input:focus, select:focus, textarea:focus { border-color: var(--color-focus); box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-focus), transparent 82%); }
.form-label { display: block; font-size: var(--text-sm); font-weight: 650; color: var(--color-ink); margin-bottom: 6px; }
.form-hint { color: var(--color-subtle); font-size: var(--text-xs); margin-top: 5px; }

.kpi-row, .stat-mini, .sync-kpis { display: grid; gap: var(--space-sm); }
.kpi-row { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-bottom: var(--space-lg); }
.kpi-card { padding: var(--space-lg); }
.kpi-num, .sync-kpi-num { font-family: var(--font-display); font-size: var(--text-2xl); line-height: 1; font-weight: 800; color: var(--color-ink); }
.kpi-label, .sync-kpi-label { margin-top: 7px; color: var(--color-subtle); font-size: var(--text-xs); }
.metric-accent { color: var(--color-accent); }
.metric-green { color: var(--color-green); }
.metric-red { color: var(--color-red); }
.metric-violet { color: var(--color-violet); }

.dashboard-grid, .sync-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--space-md); }
.sync-grid { grid-template-columns: 1.1fr .9fr; }
.health-bar { height: 7px; border-radius: 999px; background: var(--color-paper-2); overflow: hidden; margin-top: var(--space-xs); }
.health-bar-fill { height: 100%; border-radius: inherit; background: var(--color-accent); }
.fill-good { background: var(--color-green); }
.fill-mid { background: var(--color-amber); }
.fill-bad { background: var(--color-red); }
.city-row, .action-row, .person-row, .template-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 10px 0;
  border-bottom: var(--rule-hairline) solid var(--color-rule);
}
.city-row:last-child, .action-row:last-child, .person-row:last-child, .template-row:last-child { border-bottom: 0; }
.row-name { min-width: 56px; font-size: var(--text-sm); font-weight: 680; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.row-meta { color: var(--color-subtle); font-size: var(--text-xs); white-space: nowrap; }
.person-password-form {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(120px, 1fr) auto;
  gap: var(--space-xs);
  align-items: center;
}
.person-admin-toggle {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  color: var(--color-muted);
  font-size: var(--text-sm);
  font-weight: 650;
}
.person-admin-toggle input { width: auto; }
.compact-input { min-height: 32px; padding-top: 6px; padding-bottom: 6px; }
.metric-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; background: var(--color-amber); }
.warn-card { border-left: 4px solid var(--color-amber); }
.danger-card { border-left: 4px solid var(--color-red); }

.filter-bar { padding: var(--space-sm); margin-bottom: var(--space-md); display: flex; flex-wrap: wrap; gap: var(--space-xs); align-items: center; }
.filter-bar select, .filter-bar input { width: auto; min-width: 112px; }
.task-list { overflow: hidden; }
.task-row {
  display: grid;
  grid-template-columns: 112px minmax(180px, 1fr) 92px 72px 96px 128px 32px;
  gap: var(--space-sm);
  align-items: center;
  padding: 11px var(--space-md);
  border-bottom: var(--rule-hairline) solid var(--color-rule);
}
.task-row:last-child { border-bottom: 0; }
.task-row:hover { background: var(--color-surface-raised); }
.task-title { min-width: 0; color: var(--color-ink); font-size: var(--text-sm); font-weight: 650; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.task-cell { min-width: 0; color: var(--color-muted); font-size: var(--text-xs); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.delete-btn { width: 28px; height: 28px; display: grid; place-items: center; border: 0; border-radius: var(--radius-sm); background: transparent; color: var(--color-subtle); cursor: pointer; }
.delete-btn:hover { background: var(--color-red-soft); color: var(--color-red); }

.status-todo, .status-progress, .status-done, .status-cancelled, .status-ok, .status-bad, .task-tag, .person-chip, .priority-chip, .status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: var(--text-xs);
  line-height: 1;
  white-space: nowrap;
}
.status-todo { background: var(--color-paper-2); color: var(--color-muted); }
.status-progress { background: var(--color-accent-soft); color: var(--color-accent-strong); }
.status-done, .status-ok { background: var(--color-green-soft); color: var(--color-green); }
.status-cancelled, .status-bad { background: var(--color-red-soft); color: var(--color-red); }
.status-pill { gap: 6px; padding: 6px 10px; font-weight: 680; }
.task-tag { padding: 4px 8px; background: var(--color-paper-2); color: var(--color-muted); }
.task-tag.overdue { background: var(--color-red-soft); color: var(--color-red); }

.priority-urgent { border-left: 4px solid var(--color-red); }
.priority-high { border-left: 4px solid var(--color-amber); }
.priority-chip {
  gap: 6px;
  padding: 8px 13px;
  border: var(--rule-hairline) solid var(--color-rule-strong);
  background: var(--color-surface);
  color: var(--color-muted);
  cursor: pointer;
}
.priority-chip:hover { border-color: var(--color-accent); color: var(--color-accent-strong); }
.priority-chip.active { background: var(--color-accent-soft); border-color: var(--color-accent); color: var(--color-accent-strong); }
.priority-chip.urgent.active { background: var(--color-red-soft); border-color: var(--color-red); color: var(--color-red); }
.priority-chip.high.active { background: var(--color-amber-soft); border-color: var(--color-amber); color: color-mix(in oklch, var(--color-amber), var(--color-ink) 25%); }
.person-chip {
  padding: 7px 10px;
  border: var(--rule-hairline) solid var(--color-rule);
  background: var(--color-surface-raised);
  color: var(--color-muted);
  cursor: pointer;
}
.person-chip:hover, .person-chip.selected { background: var(--color-accent-soft); border-color: var(--color-accent); color: var(--color-accent-strong); }

.stat-mini { grid-template-columns: repeat(5, minmax(0, 1fr)); margin-bottom: var(--space-md); }
.stat-item-mini, .sync-kpi { background: var(--color-surface); border: var(--rule-hairline) solid var(--color-rule); border-radius: var(--radius-lg); padding: var(--space-md); }
.stat-item-mini { text-align: left; }
.stat-value { font-size: var(--text-xl); font-weight: 800; line-height: 1; }
.stat-label { color: var(--color-subtle); font-size: var(--text-xs); margin-top: 6px; }
.work-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-sm);
}
.plan-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-xs);
  padding: 9px 0;
  border-bottom: var(--rule-hairline) solid var(--color-rule);
}
.plan-item:last-of-type { border-bottom: 0; }

.kanban-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-sm); }
.kanban-col {
  background: color-mix(in oklch, var(--color-paper-2), var(--color-surface) 28%);
  border: var(--rule-hairline) solid var(--color-rule);
  border-radius: var(--radius-lg);
  min-height: 180px;
  padding: var(--space-sm);
}
.kanban-col.drag-over { border-color: var(--color-accent); box-shadow: inset 0 0 0 1px var(--color-accent); background: var(--color-accent-soft); }
.kanban-col-header { display: flex; align-items: center; justify-content: space-between; padding: 2px 4px var(--space-sm); font-size: var(--text-sm); font-weight: 760; }
.kanban-card {
  background: var(--color-surface);
  border: var(--rule-hairline) solid var(--color-rule);
  border-left: 4px solid transparent;
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  margin-bottom: var(--space-xs);
  cursor: grab;
  font-size: var(--text-sm);
}
.kanban-card:hover { transform: translateY(-1px); box-shadow: 0 8px 24px color-mix(in oklch, var(--color-ink), transparent 93%); }
.kanban-card.dragging { opacity: .45; transform: scale(.98); }
.kanban-card.p-urgent { border-left-color: var(--color-red); }
.kanban-card.p-high { border-left-color: var(--color-amber); }
.task-meta { display: flex; gap: 6px; margin-top: var(--space-xs); flex-wrap: wrap; }
.empty-state { padding: var(--space-xl); text-align: center; color: var(--color-subtle); }
.empty-drop { padding: var(--space-lg) var(--space-sm); text-align: center; color: var(--color-subtle); font-size: var(--text-xs); }

.sync-card { padding: var(--space-lg); }
.sync-kpis { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: var(--space-sm); }
.action-row { justify-content: space-between; }
.detail-list { max-height: 320px; overflow: auto; border: var(--rule-hairline) solid var(--color-rule); border-radius: var(--radius-md); }
.detail-item { padding: 9px 11px; border-bottom: var(--rule-hairline) solid var(--color-rule); font-size: var(--text-xs); color: var(--color-muted); }
.detail-item:last-child { border-bottom: 0; }
.result-success { background: var(--color-green-soft); color: var(--color-green); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); }
.result-error { background: var(--color-red-soft); color: var(--color-red); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); }

.template-card { padding: var(--space-lg); margin-bottom: var(--space-sm); }
.template-card.featured { border-color: color-mix(in oklch, var(--color-violet), transparent 70%); background: linear-gradient(180deg, var(--color-surface), var(--color-violet-soft)); }
.template-card.standard { border-color: color-mix(in oklch, var(--color-accent), transparent 70%); background: linear-gradient(180deg, var(--color-surface), var(--color-accent-soft)); }
.info-box { border-radius: var(--radius-lg); padding: var(--space-lg); border: var(--rule-hairline) solid var(--color-rule); background: var(--color-surface-raised); }
.info-box.accent { background: var(--color-accent-soft); border-color: color-mix(in oklch, var(--color-accent), transparent 70%); }
code { font-family: var(--font-mono); background: var(--color-paper-2); border-radius: var(--radius-sm); padding: 2px 5px; }

@media (max-width: 900px) {
  .topbar-inner { align-items: flex-start; flex-direction: column; padding-top: var(--space-sm); padding-bottom: var(--space-sm); }
  .version-pill { display: none; }
  .dashboard-grid, .sync-grid, .work-plan-grid { grid-template-columns: 1fr; }
  .kpi-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .task-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-xs); }
  .task-row select { width: auto; min-width: 120px; }
  .task-title { order: 2; flex: 1 0 100%; }
  .task-cell { order: 3; width: auto; max-width: 46%; }
  .delete-btn { margin-left: auto; }
  .kanban-grid { grid-template-columns: 1fr; }
  .stat-mini { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 520px) {
  .page-main { padding: var(--space-md); }
  .page-head { align-items: flex-start; flex-direction: column; }
  .kpi-row, .sync-kpis, .stat-mini { grid-template-columns: 1fr; }
  .filter-bar select, .filter-bar input, .filter-bar .btn { width: 100%; }
  .city-row, .person-row, .template-row, .action-row { align-items: flex-start; flex-direction: column; }
  .person-password-form { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: 1ms !important; scroll-behavior: auto !important; }
}
