/* Header */

.site-header {
  background: rgba(246, 247, 244, 0.98);
  border-bottom: 1px solid var(--color-border);
}

.site-header__inner {
  display: grid;
  gap: var(--space-3);
  width: min(100% - 2rem, var(--container-wide));
  margin-inline: auto;
  padding-block: var(--space-3);
}

.site-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  width: fit-content;
  color: var(--color-text);
  text-decoration: none;
}

.site-brand:hover {
  color: var(--color-text);
}

.site-brand__mark {
  display: grid;
  flex: 0 0 2.5rem;
  width: 2.5rem;
  height: 2.5rem;
  place-items: center;
  color: var(--color-brand-contrast);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  background: var(--color-brand);
  border-radius: var(--radius-md);
}

.site-brand__text {
  display: grid;
  gap: 0.05rem;
}

.site-brand__name {
  font-weight: var(--weight-bold);
}

.site-brand__section {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.site-nav {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--space-2);
  max-width: 100%;
  padding-bottom: var(--space-1);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.site-nav::-webkit-scrollbar {
  display: none;
}

.site-nav a {
  flex: 0 0 auto;
  min-height: 2.5rem;
  padding: var(--space-2) var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  text-decoration: none;
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
  color: var(--color-text);
  background: var(--color-brand-soft);
  border-color: var(--color-brand-soft);
}

/* Footer */

.site-footer {
  padding-block: var(--space-8);
  color: var(--color-text-muted);
  background: var(--color-surface-soft);
  border-top: 1px solid var(--color-border);
}

.site-footer__inner {
  display: grid;
  gap: var(--space-4);
}

.site-footer p {
  margin-bottom: 0;
}

.site-footer nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.site-footer a {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* Breadcrumbs */

.breadcrumbs {
  margin-bottom: var(--space-5);
  color: var(--color-text-subtle);
  font-size: var(--text-sm);
}

.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: 0;
  margin: 0;
  list-style: none;
}

.breadcrumbs li {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin: 0;
}

.breadcrumbs li + li::before {
  content: "/";
  color: var(--color-text-subtle);
}

.breadcrumbs a {
  color: var(--color-text-muted);
  text-decoration: none;
}

.breadcrumbs a:hover {
  color: var(--color-brand-hover);
  text-decoration: underline;
}

/* Hero and search */

.hero-search {
  padding-block: var(--space-4) var(--space-8);
}

.hero-search__inner {
  display: grid;
  gap: var(--space-6);
  align-items: start;
}

.hero-search__content,
.page-hero,
.answer-card,
.section-block {
  padding: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.hero-search__content h1,
.page-hero h1 {
  max-width: 58rem;
}

.hero-search__content .lead,
.page-hero .lead {
  margin-bottom: 0;
}

.hero-search__panel,
.side-card,
.toc {
  padding: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.hero-search__panel h2,
.side-card h2,
.toc h2 {
  font-size: var(--text-lg);
}

.hero-search__panel p:last-child,
.side-card p:last-child {
  margin-bottom: 0;
}

.search-panel {
  display: grid;
  gap: var(--space-2);
  margin-block: var(--space-5) var(--space-4);
}

.search-panel input {
  padding: 0 var(--space-3);
}

.search-panel button,
.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--tap-target);
  padding: 0 var(--space-4);
  color: var(--color-brand-contrast);
  font-weight: var(--weight-semibold);
  text-decoration: none;
  background: var(--color-brand);
  border: 0;
  border-radius: var(--radius-md);
}

.search-panel button:hover,
.button-link:hover {
  color: var(--color-brand-contrast);
  background: var(--color-brand-hover);
}

/* Sections and layout */

.section-band {
  padding-block: var(--space-8);
}

.section-band--muted {
  background: var(--color-surface-soft);
  border-block: 1px solid var(--color-border);
}

.section-band--selection {
  padding-block: var(--space-10);
  background: var(--color-brand-softer);
  border-block: 1px solid var(--color-border);
}

.section-heading {
  max-width: 52rem;
  margin-bottom: var(--space-5);
}

.section-heading p:last-child {
  margin-bottom: 0;
  color: var(--color-text-muted);
}

.section-block + .section-block,
.section-block + .warning-box,
.section-block + .info-box,
.answer-card + .section-block,
.warning-box + .info-box,
.warning-box + .section-block,
.info-box + .faq-block,
.faq-block + .section-block,
.answer-card + .warning-box {
  margin-top: var(--space-6);
}

.content-layout {
  display: grid;
  gap: var(--space-6);
  align-items: start;
}

.content-layout__main,
.content-layout__aside {
  min-width: 0;
}

.content-layout__aside {
  display: grid;
  gap: var(--space-4);
}

.selection-panel {
  display: grid;
  gap: var(--space-5);
  align-items: center;
}

.selection-panel p:last-child {
  margin-bottom: 0;
}

/* Cards */

.card-grid,
.plant-grid,
.mini-grid,
.care-grid,
.method-grid,
.related-grid {
  display: grid;
  gap: var(--space-4);
}

.card {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  padding: var(--space-4);
  color: var(--color-text);
  text-decoration: none;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  transition: border-color var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard);
}

.card:hover {
  color: var(--color-text);
  border-color: var(--color-brand);
  box-shadow: var(--shadow-card);
}

.card__icon {
  display: grid;
  width: 2rem;
  height: 2rem;
  place-items: center;
  color: var(--color-brand-contrast);
  font-weight: var(--weight-bold);
  background: var(--color-brand);
  border-radius: var(--radius-md);
}

.card__label {
  color: var(--color-brand);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0;
  text-transform: uppercase;
}

.card span:last-child,
.compact-card span {
  color: var(--color-text-muted);
}

.mini-panel,
.care-fact,
.method-card {
  min-width: 0;
  padding: var(--space-4);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.mini-panel h3,
.care-fact h3,
.method-card h3 {
  font-size: var(--text-md);
}

.mini-panel p:last-child,
.care-fact p:last-child,
.method-card p:last-child {
  margin-bottom: 0;
  color: var(--color-text-muted);
}

.method-card {
  display: grid;
  gap: var(--space-4);
}

.method-card > p {
  margin-bottom: 0;
  color: var(--color-text-muted);
}

.method-card .info-box {
  padding: var(--space-4);
}

/* Plant card */

.plant-card {
  display: grid;
  min-width: 0;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.plant-card__visual {
  position: relative;
  min-height: 9rem;
  background: var(--color-brand-softer);
  border-bottom: 1px solid var(--color-border);
}

.plant-card__visual::before,
.plant-card__visual::after {
  content: "";
  position: absolute;
  background: var(--color-brand);
}

.plant-card__visual::before {
  left: 50%;
  bottom: 1.5rem;
  width: 0.25rem;
  height: 5.5rem;
  transform: translateX(-50%);
}

.plant-card__visual::after {
  left: 50%;
  bottom: 4.2rem;
  width: 5.5rem;
  height: 2.25rem;
  background:
    linear-gradient(90deg, transparent 48%, var(--color-brand) 48% 52%, transparent 52%),
    var(--color-brand);
  border-radius: 100% 0 100% 0;
  transform: translateX(-50%) rotate(-14deg);
}

.plant-card__visual--orchid,
.plant-card__visual--chlorophytum {
  background: var(--color-info-bg);
}

.plant-card__visual--orchid::after,
.plant-card__visual--chlorophytum::after {
  background: var(--color-info);
}

.plant-card__visual--zamioculcas,
.plant-card__visual--sansevieria {
  background: var(--color-accent-bg);
}

.plant-card__visual--zamioculcas::after,
.plant-card__visual--sansevieria::after {
  background: var(--color-accent);
}

.plant-card__body {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
}

.plant-card__body h3,
.plant-card__body p {
  margin-bottom: 0;
}

.plant-card__body p {
  color: var(--color-text-muted);
}

.plant-card__meta {
  display: grid;
  gap: var(--space-2);
  margin: 0;
}

.plant-card__meta div {
  display: grid;
  grid-template-columns: 4rem 1fr;
  gap: var(--space-2);
}

.plant-card__meta dt {
  color: var(--color-text-subtle);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
}

.plant-card__meta dd {
  margin: 0;
  color: var(--color-text-muted);
}

/* Plant passport */

.plant-passport {
  display: grid;
  overflow: hidden;
  margin-block: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.plant-passport__visual {
  min-height: 12rem;
}

.plant-passport__body {
  padding: var(--space-5);
}

.passport-grid,
.fact-strip {
  display: grid;
  gap: var(--space-3);
  margin: 0;
}

.passport-grid div,
.fact-strip div {
  padding: var(--space-3);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.passport-grid dt,
.fact-strip dt {
  margin-bottom: var(--space-1);
  color: var(--color-text-subtle);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0;
  text-transform: uppercase;
}

.passport-grid dd,
.fact-strip dd {
  margin: 0;
  color: var(--color-text);
  font-weight: var(--weight-medium);
}

.passport-grid__value + .badge {
  margin-left: var(--space-2);
}

.fact-strip {
  margin-top: var(--space-5);
}

/* Tables */

.cause-table {
  overflow-x: auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.cause-table table {
  min-width: 42rem;
}

.cause-table tbody tr:last-child td {
  border-bottom: 0;
}

/* Checklist */

.diagnosis-checklist ul,
.check-list {
  display: grid;
  gap: var(--space-3);
  padding: 0;
  margin: 0;
  list-style: none;
}

.diagnosis-checklist li,
.check-list li {
  margin: 0;
}

.diagnosis-checklist label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: start;
  min-height: var(--tap-target);
  padding: var(--space-3);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.diagnosis-checklist input {
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 0.2rem;
  accent-color: var(--color-brand);
}

.check-list--plain li {
  position: relative;
  padding-left: 1.4rem;
  color: var(--color-text-muted);
}

.check-list--plain li::before {
  content: "";
  position: absolute;
  top: 0.55rem;
  left: 0;
  width: 0.45rem;
  height: 0.45rem;
  background: var(--color-brand);
  border-radius: var(--radius-pill);
}

/* Steps */

.steps-list {
  display: grid;
  gap: var(--space-4);
  padding: 0;
  margin: 0;
  list-style: none;
  counter-reset: step;
}

.steps-list li {
  position: relative;
  min-width: 0;
  margin: 0;
  padding: var(--space-4);
  padding-left: calc(var(--space-4) + 2.75rem);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  counter-increment: step;
}

.steps-list li::before {
  content: counter(step);
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  display: grid;
  width: 2rem;
  height: 2rem;
  place-items: center;
  color: var(--color-brand-contrast);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  background: var(--color-brand);
  border-radius: var(--radius-pill);
}

.steps-list h3 {
  font-size: var(--text-md);
}

.steps-list p:last-child {
  margin-bottom: 0;
}

/* Boxes */

.warning-box,
.info-box {
  padding: var(--space-5);
  border: 1px solid;
  border-radius: var(--radius-lg);
}

.warning-box {
  color: var(--color-text);
  background: var(--color-danger-bg);
  border-color: var(--color-danger-border);
}

.info-box {
  color: var(--color-text);
  background: var(--color-info-bg);
  border-color: var(--color-info-border);
}

.warning-box h2,
.info-box h2 {
  font-size: var(--text-xl);
}

.warning-box p:last-child,
.info-box p:last-child,
.warning-box ul:last-child {
  margin-bottom: 0;
}

/* FAQ */

.faq-block {
  margin-top: var(--space-6);
  padding: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.faq-block details {
  padding: var(--space-4) 0;
  border-top: 1px solid var(--color-border);
}

.faq-block details:last-child {
  padding-bottom: 0;
}

.faq-block summary {
  color: var(--color-text);
  font-weight: var(--weight-semibold);
}

.faq-block details p {
  margin: var(--space-3) 0 0;
  color: var(--color-text-muted);
}

/* Related */

.related-card {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  padding: var(--space-4);
  color: var(--color-text);
  text-decoration: none;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.related-card:hover {
  color: var(--color-text);
  border-color: var(--color-brand);
  box-shadow: var(--shadow-card);
}

.related-card__type {
  color: var(--color-brand);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0;
  text-transform: uppercase;
}

.related-card span:last-child {
  color: var(--color-text-muted);
}

/* Tags and badges */

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: 0;
  margin: 0;
  list-style: none;
}

.tag-list li {
  margin: 0;
}

.tag-list a,
.tag-list span {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  text-decoration: none;
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
}

.tag-list a:hover {
  color: var(--color-text);
  background: var(--color-brand-soft);
}

.tag-list--filters span {
  color: var(--color-text);
  background: var(--color-accent-bg);
  border-color: var(--color-accent-border);
}

.badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
}

.badge--good {
  color: var(--color-good);
  background: var(--color-good-bg);
  border-color: var(--color-good-border);
}

.badge--warning {
  color: var(--color-warning);
  background: var(--color-warning-bg);
  border-color: var(--color-warning-border);
}

.badge--danger {
  color: var(--color-danger);
  background: var(--color-danger-bg);
  border-color: var(--color-danger-border);
}

/* TOC */

.toc ol {
  display: grid;
  gap: var(--space-2);
  padding: 0;
  margin: 0;
  list-style: none;
}

.toc li {
  margin: 0;
}

.toc a {
  display: block;
  min-height: 2.25rem;
  padding: var(--space-2);
  color: var(--color-text-muted);
  text-decoration: none;
  border-radius: var(--radius-md);
}

.toc a:hover {
  color: var(--color-text);
  background: var(--color-surface-soft);
}

@media (min-width: 40rem) {
  .search-panel {
    grid-template-columns: 1fr auto;
  }

  .passport-grid,
  .fact-strip,
  .mini-grid,
  .card-grid--two,
  .related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (min-width: 48rem) {
  .site-header__inner {
    width: min(100% - 3rem, var(--container-wide));
  }

  .hero-search__content,
  .page-hero,
  .answer-card,
  .section-block,
  .warning-box,
  .info-box,
  .faq-block {
    padding: var(--space-6);
  }

  .plant-passport {
    grid-template-columns: 16rem 1fr;
  }

  .plant-passport__visual {
    border-right: 1px solid var(--color-border);
    border-bottom: 0;
  }

  .card-grid--three,
  .mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .care-grid,
  .method-grid,
  .card-grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 64rem) {
  .site-header__inner {
    grid-template-columns: auto 1fr;
    align-items: center;
  }

  .site-nav {
    justify-content: end;
    flex-wrap: wrap;
    padding-bottom: 0;
    overflow-x: visible;
  }

  .hero-search__inner {
    grid-template-columns: minmax(0, 1fr) 22rem;
  }

  .content-layout {
    grid-template-columns: minmax(0, 1fr) 20rem;
  }

  .content-layout__aside {
    position: sticky;
    top: var(--space-6);
  }

  .plant-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .care-grid,
  .card-grid--four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .related-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .selection-panel {
    grid-template-columns: 1fr auto;
  }

  .site-footer__inner {
    grid-template-columns: 1fr auto;
    align-items: center;
  }
}
