@import "reset.css";

:root {
	--base-color: #2C1315;
	--primary-color: #944146;
	--highlight-color: var(--primary-color);
	--background-color: #FFF;
	
	--text-base: 19px;
	--text-base-uppercase: .95rem;
	--text-lg: clamp(1.2rem, 2.5vw, 1.5rem);
	
	--spacing-md: clamp(1.5rem, 6vw, 3.5rem);
	--spacing-lg: clamp(2rem, 10vw, 5rem);
	--spacing-xl: clamp(2rem, 15vw, 8rem);
	
	--column-spacing: clamp(1rem, 4vw, 2rem);
	
	--stroke: 1px dashed var(--highlight-color);
  --stroke-background: url(data:image/svg+xml,%3Csvg width='9' height='3' viewBox='0 0 9 3' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1.5' cy='1.5' r='1.5' fill='%23000'/%3E%3C/svg%3E%0A) repeat-x left top;
}

@media (max-width: 800px) {
	
	:root {
		--text-base: 18px;
	}
	
}

/* @group FONTS */

@font-face {
  font-family: 'PT Sans';
  src: url('../fonts/ptsans-regular-webfont.woff2') format('woff2'),
       url('../fonts/ptsans-regular-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'PT Sans';
  src: url('../fonts/ptsans-italic-webfont.woff2') format('woff2'),
       url('../fonts/ptsans-italic-webfont.woff') format('woff');
  font-weight: normal;
  font-style: italic;
}

@font-face {
  font-family: 'PT Sans';
  src: url('../fonts/ptsans-bold-webfont.woff2') format('woff2'),
       url('../fonts/ptsans-bold-webfont.woff') format('woff');
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'PT Sans';
  src: url('../fonts/ptsans-bolditalic-webfont.woff2') format('woff2'),
       url('../fonts/ptsans-bolditalic-webfont.woff') format('woff');
  font-weight: bold;
  font-style: italic;
}

/* @end */

/* @group GENERAL */

html,
body {
	min-width: 320px;
	background-color: var(--primary-color);
	color: var(--base-color);
	font-family: 'PT Sans', Helvetica, Arial, sans-serif;
	font-size: var(--text-base);
	line-height: 1.4em;
}

html {
	scroll-behavior: smooth;
}

body {
	min-height: 100vh;
	max-width: 1800px;
	margin-right: auto;
	margin-left: auto;
	background-repeat: no-repeat;
	background-size: 100% auto;
	background-position: top center;
}

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

strong {
	font-weight: bold;
}

h1,
.page-heading {
	color: var(--highlight-color);
	font-size: var(--text-lg);
	line-height: 1.2em;
	text-transform: uppercase;
	letter-spacing: 0.01em;
}

h1:not(:last-child) {
	margin-bottom: 1rem;
}

h2 {
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

h2:not(:first-child) {
	margin-top: 2rem;
}

h2:not(:last-child) {
	margin-bottom: 1rem;
}

h3 {
	font-weight: bold;
}

h3:not(:first-child) {
	margin-top: 2rem;
}

h2 + h3:not(:first-child) {
	margin-top: 1rem;
}

h3:not(:last-child) {
	margin-bottom: 1rem;
}

h4 {
	font-weight: bold;
}

h4:not(:first-child) {
	margin-top: 1rem;
}

h4:not(:last-child) {
	
}

p:not(:last-child) {
	margin-bottom: 1rem;
}

ol:not(:last-child) {
	margin-bottom: 1.5rem;
}

	ol li {
    display: table;
    counter-increment: counter;
	}
	
	ol li:not(:last-child) {
		margin-bottom: .5rem;
	}
	
		ol li::before {
	    content: counter(counter) ".";
	    display: table-cell;
	    width: 1em;
		}

ul:not(:last-child) {
	margin-bottom: 1.5rem;
}

	ul li {
		display: flex;
	}
	
	ul li:not(:last-child) {
		margin-bottom: .5rem;
	}
	
		ul li::before {
			content: "";
	    flex: 0 0 1em;
	    width: 1em;
	    height: 1em;
	    margin-right: 0.5em;
			background-color: var(--highlight-color);
	    -webkit-mask-image: url(../images/ico-leaf.svg);
	    mask-image: url(../images/ico-leaf.svg);
		}

/* @end */

/* @group LINKS */

a:hover {
	font-weight: bold;
}

.main a {
	color: var(--highlight-color);
}

.main a,
.footer a {
	text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.1em;
  transition: text-decoration .15s ease-in-out 0s;
}

.main a:hover,
.footer a:hover {
	text-decoration-thickness: 2px;
}

/* @end */

/* @group Container */

.container {
	max-width: 1280px;
	margin-right: auto;
	margin-left: auto;
}

/* @end */

/* @group Header */

.header {
	
}

	.header__banner {
		margin-bottom: var(--spacing-lg);
	}
	
	.header__claim {
		margin-bottom: var(--spacing-xl);
	}

/* @end */

/* @group Logo */

.banner {
	width: 8em;
	margin-right: auto;
	margin-left: auto;
	padding: 1rem;
	background-color: var(--primary-color);
	color: var(--background-color);
	font-size: var(--text-base-uppercase);
	line-height: 1.2em;
	text-transform: uppercase;
	text-align: center;
}

	.banner svg {
		width: 5em;
		height: auto;
		fill: var(--background-color);
	}
	
	.banner__subheading {
		font-weight: bold;
	  letter-spacing: 0.02em;
	}
	
/* @end */

/* @group Claim */

.claim {
	max-width: 16em;
	background-image: url(../images/semitransparent-background.webp);
	background-size: 100% 100%;
	padding: 1em;
	color: var(--background-color);
	font-size: var(--text-lg);
	line-height: 1.4em;
}

	@media (min-width: 1200px) {
		
		.claim {
			margin-left: 10%;
		}
		
	}

/* @end */

/* @group Menu */

.menu {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 4px;
	row-gap: 4px;
	padding: 4px;
	font-size: var(--text-base-uppercase);
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

	.menu > * {
		padding-top: .25em;
		padding-bottom: .2em;
		background-color: var(--primary-color);
	  color: var(--background-color);
		text-align: center;
	}
	
	.menu > *.active {
		font-weight: bold;
	}
	
	@media (min-width: 600px) and (max-width: 799px) {
		
		.menu {
			grid-template-columns: repeat(3, 1fr);
		}
		
	}
	
	@media (min-width: 800px) {
		
		.menu {
			grid-template-columns: repeat(6, 1fr);
		}
		
	}

/* @end */

/* @group Main */

.main {
	margin: 0 4px 4px;
	padding-bottom: 3rem;
	background-color: var(--background-color);
}

/* @end */

/* @group Page-heading */

.page-heading {
	padding-top: var(--column-spacing);;
	margin-bottom: var(--column-spacing);
	padding-right: var(--column-spacing);
	padding-left: var(--column-spacing);
}

/* @end */

/* @group Submenu */

.submenu {
	display: flex;
	flex-direction: column;
	padding: 0 var(--column-spacing) var(--column-spacing);
	border-bottom: var(--stroke);
}

	.submenu a {
		width: max-content;
		color: var(--highlight-color);
		text-decoration: unset;
	}
	
	.submenu a.active {
		font-weight: bold;
	}
	
		.submenu a::before {
			content: "> ";
		}

/* @end */

/* @group Page-subheading */

.page-subheading {
	margin-top: var(--column-spacing);
	margin-bottom: var(--column-spacing);
	padding-right: var(--column-spacing);
	padding-left: var(--column-spacing);
}

/* @end */

/* @group Block */

.block {
	padding-bottom: 2rem;
	padding-right: var(--column-spacing);
	padding-left: var(--column-spacing);
}

/* @end */

/* @group Quote-block */

.quote-block {
	margin-bottom: 2rem;
	padding: var(--spacing-md);
	border-bottom: var(--stroke);
	color: var(--primary-color);
}

	.quote-block__text {
		margin-bottom: 1rem;
		font-size: var(--text-lg);
		line-height: 1.4em;
	}

/* @end */

/* @group Text-image-block */

.text-image-block {
	display: grid;
	column-gap: var(--column-spacing);
	row-gap: 2rem;
}

	.text-image-block figure img {
		width: 100%;
	}

	.text-image-block figcaption {
		margin-top: .5rem;
	}
	
	@media (max-width: 999px) {
		
			.text-image-block figure {
				order: 2;
				max-width: 600px;
			}
		
	}

	@media (min-width: 1000px) {
		
		.text-image-block {
			grid-template-columns: 1fr 1fr;
		}
		
			.text-image-block--imageright figure {
				order: 2;
			}
		
	}

/* @end */

/* @group Text-block */

.text-block {
	display: grid;
	column-gap: var(--column-spacing);
	row-gap: 2rem;
}

	@media (min-width: 1000px) {
		
		.text-block {
			grid-template-columns: 1fr 1fr;
		}
		
	}

/* @end */

/* @group Gallery-block */

.gallery-block {
	display: grid;
	column-gap: var(--column-spacing);
	row-gap: var(--column-spacing);
}

	.gallery-block figcaption {
		margin-top: .5rem;
	}

	@media (min-width: 800px) {
		
		.gallery-block {
			grid-template-columns: 1fr 1fr;
		}
		
	}

/* @end */

/* @group Footer */

.footer {
	background-color: var(--primary-color);
	color: var(--background-color);
	margin-right: 4px;
	margin-left: 4px;
	padding: var(--column-spacing);
}

	.footer__colophon {
		margin-bottom: 2rem;
	}
	
	.footer__bottombar {
		margin-bottom: 2rem;
	}

/* @end */

/* @group Colophon */

.colophon {
	display: grid;
	column-gap: var(--column-spacing);
}

	.colophon h1 {
		color: var(--background-color);
	}

	@media (min-width: 600px) and (max-width: 1199px) {
		
		.colophon {
			grid-template-columns: 1fr 1fr;
		}
		
			.colophon h1 {
				grid-column: span 2;
			}
			
			.colophon > *:last-child {
				grid-column: span 2;
			}
		
	}

	@media (min-width: 1200px) {
		
		.colophon {
			grid-template-columns: 1fr 1fr calc(50% - var(--column-spacing) / 2);
		}
		
			.colophon h1 {
				grid-column: span 3;
			}
		
	}

/* @end */

/* @group Bottombar */

.bottombar {
	display: flex;
	column-gap: 2rem;
}

	.bottombar > * {
		
	}

/* @end */