body, .page-row-navigation {
  grid-template-rows: [page-top] max-content [contents-top] max-content [contents-bottom] max-content [page-bottom];
}

body {
	margin: 0 auto;
	max-width: 2560px;
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
}

#quarto-content {
	padding: 0;
	grid-column: screen-start/screen-end;
	grid-row: contents-top/contents-bottom;
}

body .sidebar.sidebar-navigation {
  grid-column: page-start/body-start;
  grid-row: content-top/page-bottom;
}

:root {
	--screen-margin       :   1.5rem;
	--screen-inset-width  :   5fr;
	--page-margin         :   3.5rem;
	--page-inset-left-min :   1.5rem;
	--page-inset-left-max :  10rem;
	--page-inset-right-min:   1.5rem;
	--page-inset-right-max:  10rem;
	--body-outset         :   3.5rem;
	--body-margin         :   3.5rem;
	--body-content-min    :  30rem;
	--body-content-max    :  75rem;
}

body .page-columns {
	display: grid;
	gap: 0;
	grid-template-columns:
		[screen-start] var(--screen-margin)
			[screen-start-inset] var(--screen-inset-width)
				[page-start] var(--page-margin)
					[page-start-inset] minmax( var(--page-inset-left-min), var(--page-inset-left-max) )

						[body-start-outset] var(--body-outset)
							[body-start] var(--body-margin)
								[body-content-start] minmax( var(--body-content-min), calc( var(--body-content-max) - 2 * var(--body-margin) )) [body-content-end]
							var(--body-margin) [body-end]
						var(--body-outset) [body-end-outset]

					minmax( var(--page-inset-right-min), var(--page-inset-right-max) ) [page-end-inset]
				var(--page-margin) [page-end]
			var(--screen-inset-width) [screen-end-inset]
		var(--screen-margin) [screen-end];
}



@media (max-width: 90rem) {
	body .page-columns {
		grid-template-columns:
			[screen-start] var(--screen-margin)
				[screen-inset-start page-start page-inset-start]
						minmax( var(--page-inset-left-min), var(--page-inset-left-max) )

						[body-outset-start]
							var(--body-outset)
							[body-start]
								var(--body-margin)
								[body-content-start]
									minmax(
										calc( var(--body-content-min) / 2 )
										,
										calc( ( var(--body-content-max) - 2 * var(--body-margin) ) / 2 )
									)
									[center-line]
									minmax(
										calc( var(--body-content-min) / 2 )
										,
										calc( ( var(--body-content-max) - 2 * var(--body-margin) ) / 2 )
									)
								[body-content-end]
							var(--body-margin)
							[body-end]
						var(--body-outset)
						[body-outset-end]

						minmax( var(--page-inset-right-min), var(--page-inset-right-max) )
					[page-inset-end page-end screen-inset-end]
			var(--screen-margin) [screen-end];
	}
}



@media (max-width: 40rem) {
	body .page-columns {
		grid-template-columns:
			[screen-start] var(--screen-margin)
				[screen-inset-start page-start page-inset-start body-outset-start body-start body-content-start] minmax(0px, 1fr) [body-content-end body-end body-outset-end page-inset-end page-end screen-inset-end]
			var(--screen-margin) [screen-end];
	}
}



.page-full {
  grid-column: screen-start/screen-end !important;
}

.page-columns > * {
	grid-column: body-content-start/body-content-end;
}

.page-columns .content {
	grid-column: body-content-start/body-content-end;
  grid-row: content-top/content-bottom;
  align-content: flex-start;
}

.layout-example {
  background: #adb5bd;
  color: #fff;
  text-align: center;
  margin-bottom: 1em;
  font-family: SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size: .875em;
  font-weight: 600;
  padding-top: 1em;
  border-radius: 3px;
}
.column-margin .layout-example {
	padding: 0;
}

.leaflet {
	background-color: #c8facc;
}


.page-columns .column-body {
  grid-column: body-content-start/body-content-end;
}

.page-columns .column-body-outset {
  grid-column: body-start-outset/body-end-outset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}

.page-columns .column-page {
  grid-column: page-start/page-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}

.page-columns .column-page-inset {
  grid-column: page-start-inset/page-end-inset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}

.page-columns .column-screen {
  grid-column: screen-start/screen-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}

.page-columns .column-screen-inset {
  grid-column: screen-start-inset/screen-end-inset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}

.page-columns .column-screen-inset.shaded {
  grid-column: screen-start/screen-end;
  padding: 1em;
  background: #009de4;
  z-index: 998;
  transform: translate3d(0, 0, 0);
  margin-bottom: 1em;
  overflow: hidden;
}
.page-columns .column-screen-inset.shaded {

}


.page-columns .bg-1 {
	grid-column: screen;
	background-color: #eaeaea;
	padding-block: 2.5rem;
	margin-block: 2.5rem;
}


@media (min-width: 992px) {
	.margin-caption,
	.aside,
	aside:not(.footnotes):not(.sidebar),
	.column-margin {
		grid-column: body-end/page-end;
		z-index: 998;
	}
	.column-before {
		grid-column: page-start/body-start;
		z-index: 998;
	}
}

.page-columns .column-body-outset-right {
  grid-column: body-content-start/body-end-outset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-page-inset-right {
  grid-column: body-content-start/page-end-inset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-page-right {
  grid-column: body-content-start/page-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-screen-inset-right {
  grid-column: body-content-start/screen-end-inset;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-screen-right {
  grid-column: body-content-start/screen-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.left {
  text-align: left;
  padding-left: 1em;
}

.page-columns .column-body-outset-left {
  grid-column: body-start-outset/body-content-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-page-inset-left {
  grid-column: page-start-inset/body-content-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-page-left {
  grid-column: page-start/body-content-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-screen-inset-left {
  grid-column: screen-start-inset/body-content-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.page-columns .column-screen-left {
  grid-column: screen-start/body-content-end;
  z-index: 998;
  transform: translate3d(0, 0, 0);
}
.right {
  text-align: right;
  padding-right: 1em;
}






.sidebar.margin-sidebar {
  grid-column: body-end/page-end;
  grid-row: content-top/page-bottom;
}
.sidebar {
  will-change: top;
  transition: top 200ms linear;
  position: sticky;
  overflow-y: auto;
  padding-top: 0;
  max-height: 100vh;
}

@media (max-width: 767.98px) {
	.sidebar.margin-sidebar {
		margin: 0 var(--screen-margin);
	}
}





img {
  max-width: 100%;
  height: auto;
}

.layout-row {
  display: flex;
  --min: 10ch;
  --gap: 0;

  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
  align-items: flex-start;
}

.layout-row > * {
  flex: 1 1 var(--min);
}
/*
.layout-row.two   > div { flex-basis: 50.0%; justify-content: center; }
.layout-row.three > div { flex-basis: 33.3%; justify-content: center; }
.layout-row.four  > div { flex-basis: 25.0%; justify-content: center; }
 */
.layout-row > div img {
	width: 100%;
}

.layout-valign-top {
  align-items: flex-start;
}

.txt-img { flex-direction: row-reverse; }

.layout-row.txt-img,
.layout-row.img-txt {
	align-items: center;
}
.txt-img div + div > *,
.img-txt div + div > * {
	padding: 5rem;
}

@media (max-width: 767.98px) {
	.layout-row.txt-img {
		flex-direction: column;
	}
	.layout-row.img-txt {
		flex-direction: column-reverse;
	}
}






/* Buckets section */

.buckets {
	padding: 2.5rem;
	background: #3E454C;
}

.buckets ul {
	margin: 0;
	padding: 0;
}

.buckets li {
	background: white;
	list-style-type: none;
}

.bucket {
	padding: 1.5em;
}

/* More section */

.more {
	padding: 2em;
}

@media screen and (min-width: 70rem) {
	@supports (display: flex) {

		.buckets ul {
			display: flex;
			gap: 1.5rem;
		}

		.buckets li {
			width: 33%;
		}

	}
}




.bg-img.fixed {
	background-attachment: fixed;
}
.bg-img {
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
.full-height {
	height: 100vh;
	display: grid;
	place-items: center;
	background-color: #eee;
}





