/* Rolnictwo page styles – lean, built on base.css */
:root {
  --rol-accent: #0fa97a;
  --rol-accent-2: #007f8a;
  --rol-bg-soft: linear-gradient(180deg, rgba(0,153,153,0.08) 0%, rgba(15,169,122,0.06) 100%);
}

.hero--rolnictwo {
  background: var(--rol-bg-soft);
  padding: clamp(2rem, 4vw, 4rem) 0;
}
.hero--rolnictwo .hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(1rem, 3vw, 2rem);
  align-items: center;
}
@media (max-width: 900px) {
  .hero--rolnictwo .hero__inner { grid-template-columns: 1fr; }
}
.hero--rolnictwo .hero__copy h1 { margin-bottom: .5rem; }
.hero--rolnictwo .hero__copy p { max-width: 60ch; }
.hero__cta { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 1rem; }
.hero__media img { width: 100%; height: auto; border-radius: 12px; object-fit: cover; }

.breadcrumb { padding: .5rem 1rem; }
.breadcrumb ol { display: flex; gap: .5rem; flex-wrap: wrap; }
.breadcrumb li+li::before { content: "/"; margin: 0 .5rem; opacity: .6; }

.toc { position: sticky; top: 0; z-index: 3; background: #fff; border-block: 1px solid rgba(0,0,0,.06); }
.toc__inner { display: grid; grid-template-columns: 1fr auto; gap: .75rem; align-items: center; padding: .5rem 0; }
.toc ul { display: flex; gap: .75rem; overflow-x: auto; padding: .25rem 0; scrollbar-width: thin; }
.toc a { white-space: nowrap; text-decoration: none; border-bottom: 2px solid transparent; padding-bottom: .15rem; }
.toc a:hover, .toc a:focus { border-color: var(--rol-accent); }
.toc__search { display: grid; grid-template-columns: 1fr; align-items: center; }
.toc__search input { padding: .5rem .75rem; border: 1px solid rgba(0,0,0,.12); border-radius: 8px; min-width: 240px; }
.search-status { font-size: .875rem; opacity: .8; padding-top: .25rem; }

.section { padding: clamp(1.5rem, 3vw, 2.5rem) 0; }
.section--alt { background: rgba(0,0,0,.02); }
.section__media { margin: 1rem 0; }
.section__media img { width: 100%; height: auto; border-radius: 12px; }
.section__media figcaption { font-size: .9rem; opacity: .8; margin-top: .25rem; }

.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
@media (max-width: 1100px) { .cards-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 780px)  { .cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .cards-grid { grid-template-columns: 1fr; } }
.card { border: 1px solid rgba(0,0,0,.08); border-radius: 12px; padding: 1rem; background: #fff; }
.card h3 { margin-top: 0; }

.tips-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
@media (max-width: 900px) { .tips-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tips-grid { grid-template-columns: 1fr; } }
.tip { border-left: 3px solid var(--rol-accent); background: #fff; border-radius: 8px; padding: 1rem; box-shadow: 0 0 0 1px rgba(0,0,0,.04); }

.calc { margin-top: 1rem; border: 1px dashed rgba(0,0,0,.15); padding: 1rem; border-radius: 12px; background: #fff; }
.calc__row { display: grid; gap: .5rem; margin-bottom: .75rem; }
.calc__row--inline { align-items: center; grid-template-columns: 1fr auto; }
.calc__result { display: block; margin-top: .5rem; font-weight: 600; color: var(--rol-accent-2); }

.switch { display: inline-flex; align-items: center; gap: .5rem; cursor: pointer; }

.checklist { list-style: none; padding-left: 0; }
.checklist li { position: relative; padding-left: 1.5rem; margin: .35rem 0; }
.checklist li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--rol-accent); }

.list { padding-left: 1.25rem; }
.tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.tags li { background: #fff; border: 1px solid rgba(0,0,0,.1); padding: .35rem .6rem; border-radius: 999px; font-size: .95rem; }

.glossary { margin-top: 1rem; border: 1px solid rgba(0,0,0,.08); border-radius: 12px; padding: .75rem 1rem; background: #fff; }
.glossary summary { font-weight: 600; cursor: pointer; color: var(--rol-accent-2); }
.glossary dt { font-weight: 700; }
.glossary dd { margin: 0 0 .75rem 0; }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 800px) { .split { grid-template-columns: 1fr; } }

.cta-wrap { display: flex; gap: .75rem; flex-wrap: wrap; }

.feedback { margin-top: 1rem; border-top: 1px solid rgba(0,0,0,.06); padding-top: .75rem; }
.feedback__buttons { display: flex; gap: .5rem; }
.feedback__thanks { color: var(--rol-accent-2); font-weight: 600; }

.note { font-size: .95rem; opacity: .9; border-top: 1px solid rgba(0,0,0,.06); padding-top: 1rem; }

/* Utilities possibly present in base.css are reused: .container, .btn, .btn-primary, .btn-secondary, .visually-hidden */
