.landing {
  display: grid;
  gap: 28px;
}

.landing-hero {
  min-height: clamp(0px, calc(100dvh - var(--topbar-height) - 84px), 620px);
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1.05fr);
  gap: 30px;
  align-items: center;
}

.landing-copy {
  display: grid;
  gap: 18px;
  max-width: 620px;
}

.landing-copy > .badge {
  justify-self: start;
}

.landing-copy h1 {
  margin: 0;
  font-size: clamp(40px, 7vw, 76px);
  line-height: 0.98;
  letter-spacing: 0;
}

.landing-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}

.landing-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.filter-bar {
  display: grid;
  grid-template-columns: minmax(180px, 1.4fr) repeat(5, minmax(120px, 1fr));
  gap: 10px;
  align-items: end;
}

.filter-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-preview {
  display: grid;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--card);
  box-shadow: var(--shadow);
  padding: 14px;
}

.preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.preview-board {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 12px;
}

.metric {
  display: grid;
  gap: 4px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--card) 84%, var(--bg-soft));
}

.metric strong {
  font-size: 26px;
  line-height: 1;
}

.metric span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.ticket-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--card);
}

.ticket-card:hover {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
}

.ticket-card-title {
  margin: 0;
  font-size: 16px;
}

.ticket-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 12px;
}

.timeline {
  display: grid;
  gap: 10px;
}

.timeline--compact {
  gap: 8px;
}

.timeline-item {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px;
  background: color-mix(in srgb, var(--card) 92%, var(--bg-soft));
}

.timeline-item--internal {
  border-style: dashed;
}

.timeline-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 6px;
}

.kanban-preview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.kanban-column {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 160px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--card) 86%, var(--bg-soft));
}

.kanban-column h3 {
  margin: 0;
  font-size: 13px;
}

.settings-list {
  display: grid;
  gap: 10px;
}

.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.settings-row--stack {
  display: grid;
  align-items: stretch;
}

.settings-row p {
  margin: 4px 0 0;
  color: var(--muted);
}

.permission-grid {
  display: grid;
  gap: 8px;
}

.permission-row {
  display: grid;
  grid-template-columns: 180px repeat(6, minmax(84px, 1fr));
  gap: 6px;
  align-items: center;
}

.permission-cell {
  min-height: 34px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--card) 84%, var(--bg-soft));
  color: var(--muted);
  font-weight: 750;
}

.permission-cell.is-on {
  color: var(--success);
  background: color-mix(in srgb, var(--success) 12%, transparent);
}

.check-grid {
  display: grid;
  gap: 8px;
}

.check-grid--inline {
  grid-template-columns: repeat(7, minmax(48px, 1fr));
}

.check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 7px 9px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--card) 88%, var(--bg-soft));
}

.compact-title {
  margin: 0;
  font-size: 15px;
}

@media (max-width: 980px) {
  .landing-hero,
  .preview-board,
  .filter-bar {
    grid-template-columns: 1fr;
  }

  .landing-hero {
    min-height: auto;
    padding-top: 22px;
  }

  .permission-row {
    grid-template-columns: 1fr;
  }

  .check-grid--inline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
