@charset "utf-8";

/*
* CSS-Design
* Projekt Werbeatelier Schöpp
*/


/* Farbwerte
Grün 85%:
rgba(200,213,74,1)
#C8D54A

Grün 60%:
rgba(216,226,127,1)
#D8E27F

Grün 30%:
rgba(235,2240,191,1)
#EBF0BF

Dunkelgrau:
rgba(62,63,65,1)
#3E3F41

Mittelgrau:
rgba(65,66,68,1)
#414244

Hellgrau:
rgba(147,149,155,1)
#b3cad1

*/

/* Webfonts-Einbindung 
@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Jost:ital,wght@0,100..900;1,100..900&family=Nothing+You+Could+Do&family=Permanent+Marker&family=Reenie+Beanie&family=Square+Peg&display=swap');
*/

/* Font-Einbindung */

/* Jost italic latin */
@font-face{
	font-family: 'Jost';
	font-style: italic;
	font-weight: 100 900;
	src: url('../fonts/Jost-Italic-VariableFont_wght.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Jost latin */
@font-face{
	font-family: 'Jost';
	font-style: normal;
	font-weight: 100 900;
	src: url('../fonts/Jost-VariableFont_wght.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Nothing You Could Do latin */
@font-face{
	font-family: 'Nothing You Could Do';
	font-style: normal;
	font-weight: 400;
	src: url('../fonts/NothingYouCouldDo-Regular.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* Reset */
*{
	margin: 0;
	padding: 0;
	-mozbox-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}


html{ 
	scroll-behavior: smooth; 
}


/* Basisformatierung */

body{
	font: 400 1.25rem/1.5 'Jost', sans-serif; /* 20px */
	color: #000;
}

img{
	max-width: 100%;
	height: auto;
}

#logo{
	max-height: 130px;
}


/* Layout */

.wrapper{
	max-width: 1250px;
	padding: 0 25px;
	margin: 0 auto;
}

.column{
	float: left;
	margin: 20px 0 20px 5%;
}

.column:first-child{
	margin-left: 0;
}

section{
	padding: 50px 0;
}

.no-padding{
	padding: 0;
}

.no-gutter .column{
	margin: 0;
	padding: 35px;
}

.no-gutter .col_1_2{
	width: 50%;
}

.no-gutter .col_1_3{
	width: 33.33%;
}

.no-gutter .col_2_3{
	width: 66.66%;
}

.no-gutter .col_1_4{
	width: 25%;
}

.no-gutter .col_3_4{
	width: 75%;
}


/* Clearfix */

.row:before,
.row:after{
	content: " ";
	display: table;
}

.row:after{
	clear: both;
}


/* Rasterspalten */

.col_1{
	width: 100%;
}

.col_1_2{
	width: 47.5%;
}

.col_1_3{
	width: 30%;
}

.col_2_3{
	width: 65%;
}

.col_1_4{
	width: 21.25%;
}

.col_3_4{
	width: 73.75%;
}


/* Header */

header{
	top: 0;
	background: #fff;
	box-shadow: 3px 3px 10px 3px rgba(0,0,0,0.3);
	z-index: 9999;
	position: relative;
	position: sticky;
}

header img{
	margin-left: 100px;
	position: relative;
	z-index: 9999;
}

.container{
	background: #C8D54A;
	top: 65px;
	width: 100%;
	height: 43px;
	position: absolute;
	z-index: 8999;
}


/* Navigation */

#navigation{
	margin-top: 44px;
	padding: 7px 50px 7px 10px;
	top: 0;
	float: right;
	position: relative;
	z-index: 9999;
}

#navigation li{
	display: inline;
	list-style: none;
	margin-left: 60px;
}

#navigation li a{
	text-decoration: none;
	letter-spacing: 0.05rem;
	font-size: 1.125rem; /* 18px */
	font-weight: 450;
	color: #000;
	padding: 15px 0;
}

#navigation li a:hover,
#navigation li a.active{
	font-style: normal;
	font-weight: 500;
	text-decoration: underline;
}


/* Dropdown-Menü Navigation*/

#navigation ul{
	position: absolute;
	top: 33px;
	left: -20px;
	background: #EBF0BF;
	border-radius: 10px;
	box-shadow: 5px 5px 7px rgba(0,0,0,0.3);
	display: none;
	z-index: 9990;
}

#navigation li{
	position: relative;
}

#navigation ul li a{
	display: block;
	font-size: 1rem; /* 16px */
	font-weight: 400;
	padding: 10px 15px;
	border-bottom: 1px dotted #414244;
}

#navigation ul li{
	margin-left: 0;
}

#navigation li:hover ul{
	display: block;
}


/* Responsive Navigation */

.nav-toggle{
	display: none;
}

.nav-toggle{
	background: #C8D54A;
	padding: 12px;
	font-size: 1.125rem; /* 18px */
	color: #000;
}

.nav-toggle:hover{
	background: #EBF0BF;
	text-decoration: none;
}
	

/* Typo */

h1,
h2,
h3,
h4,
h5,
h6{
	font-family: 'Times New Roman', Times, serif;
	line-height: 1.2;
	color: #000;
}

h1{
	font-weight: 400;
	font-size: 2.5rem; /* 40px */
	line-height: 1.2;
	margin-bottom: 40px;
}

h2{
	font-size: 2rem; /* 32px */
	font-weight: 400;
	margin-bottom: 25px;
}

h3{
	font-family: 'Jost', sans-serif;
	font-size: 1.5rem; /* 24px */
	font-weight: 500;
	font-style: italic;
	margin-bottom: 10px;
}

h4{
	font-size: 1.3125rem; /*21px */
	font-weight: 500;
}

h5{
	font-size: 1.1875rem; /*19px */
	font-weight: 500;
	font-style: italic;
}

h6{
	font-size: 1.0625rem; /*17px */
	font-weight: 600;
}

p{
	font-size: 1.25rem; /* 20px */
	font-weight: 400;
	margin-bottom: 15px;
}

a{
	color: #3E3F41;
	text-decoration: none;
	font-weight: 500;
}

a:hover{
	color: #3E3F41;
	text-decoration: underline;
	font-style: italic;
	font-weight: 500;
}

blockquote{
	font-family: 'Nothing You Could Do', cursive;
	font-weight: 600;
	font-size: 2.375rem; /*38px */
	line-height: 3rem;
	text-align: center;
	color: rgba(166,187,21,1);
	text-shadow: 2px 2px 2.5px rgba(0,0,0,0.25);
	margin: 60px auto;
}

blockquote:before{
	content: url('../img/Rakel.png');
	padding-right: 30px;
}

.bildunterschrift{
	font-size: 1rem; /* 16px */
}

.zentrieren{
	text-align: center;
}

.vertikal_zentrieren{
	display: flex;
	align-items: center;
}

.rechtsbuendig{
	text-align: right;
}

.teaser{
	font-size: 1.375rem; /* 22px */
	line-height: 2rem;
}

.absatz{
	margin-bottom: 50px;
}

.alignleft{
	float: left;
	margin: 6px 30px 30px 0;
}

.hr_links{
	border: 0;
	height: 10px;
	background-image: linear-gradient(to right, #C8D54A, rgba(200,213,74,0.3));
	margin: -10px auto;
	width: 100%;
}


/* Button */

.button{
	background: #C8D54A;
	padding: 9px 20px;
	color: #000;
	margin: 25px;
	display: inline-block;
	letter-spacing: 0.05rem;
	text-decoration: none;
	border-radius: 25px;
	border: 1px solid #fff;
	box-shadow: 3px 3px 5px rgba(0,0,0,0.3);
}

.button:hover{
	background: #414244;
	color: #fff;
	border: 2px solid #414244;
	text-decoration: none;
}


/* Auflistung */

.auflistung ul{
	font-size: 1.25rem;
	color: #000;
	padding: 0px 20px 30px 30px;
}

.auflistung li{
	list-style: square;
	margin-bottom: 7px;
}

.auflistung ul li::marker{
	color: #C8D54A;
}


/* Abstand Anker zu Header */

/*:target:before {
	content: "";
	display: block;
	height: 210px; /* same as your fixed header height 
	margin: -210px 0 0; /* negative fixed header height
}
 */
 
/* .anker-offset {
  display: block;
  height: 210px;       /* gleiche Höhe wie dein Sticky Header 
  margin-top: -210px;
  pointer-events: none; /* verhindert Klicks auf das Element 
}
*/

.anker-offset{
	scroll-margin-top: 200px;
}

/* Hero */

.hero h1{
	padding: 0 0 0 100px;
}

.hero p{
	padding: 0 0 0 100px;
}

.hero img{
	border-radius: 250px 0 0 250px;
	box-shadow: 4px 4px 5px rgba(0,0,0,0.3);
}

.hero .col_1_3{
	padding: 50px 0;
}

.hero .wrapper{
	padding: 50px 0;
}


/* Leistungen Schöpp */

.leistungen .column{
	background: #D8E27F;
	border-radius: 25px;
	box-shadow: 5px 5px 10px 2px rgba(0,0,0,0.3);
	margin: 25px 2% 25px 2%;
	padding: 15px;
	transition: all 0.25s ease-out 0s;
	flex-grow: 1;
	flex-shrink: 1;
	flex-basis: 340px;
}

.leistungen .column:hover{
	background: #EBF0BF;
	box-shadow: 0px 0px 40px rgba(0,0,0,0.2);
	transform: scale(1.04);
}

.leistungen .row{
	display: flex;
	flex-wrap: wrap;
}

.leistungen .col_1_3{
	position: relative;
}

.leistungen{
	text-align: center;
}

.leistungen img{
	margin-bottom: 10px;
}

.link:before{
	content: " ";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
} 


/* Leistungs-Seite */

.beschriftung img{
	max-height: 100%;
}

.image-grid {
  width: 560px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.image-grid img {
  width: 100%;
  height: auto;
  border-radius: 0 25px 0 25px;
  display: block;
}

.image-grid_1 {
  width: 560px;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 20px;
}

.image-grid_1 img {
  width: 100%;
  height: auto;
  border-radius: 0 20px 0 20px;
  display: block;
}


/* to top */

#totop{
	position: fixed;
	right: 25px;
	bottom: 25px;
	background: #fff;
	color: #C8D54A;
	font-size: 1.75rem;
	padding: 0 10px;
	border-radius: 30%;
	box-shadow: 2px 2px 3px 2px rgba(0,0,0,0.3);
	display: none;
}

#totop:hover{
	font-style: normal;
	background: #C8D54A;
	color: #fff;
}
	

/* Footer */

footer{
	background: #C8D54A;
	padding: 12px 0;
	margin-top: 50px;
}

footer a{
	color: #000;
	font-weight: 400;
}

footer a:hover{
	color: #fff;
	font-style: italic;
	text-decoration: none;
}

footer .col_1{
	text-align: center;
	font-size: 0.8rem;
	color: #fff;
	margin: 0;
}


/* Media Queries */


@media only screen and (max-width: 1260px){
	.col_1,
	.col_1_2,
	.col_1_3,
	.col_2_3,
	.col_1_4,
	.col_3_4,
	.no-gutter .col_1_2,
	.no-gutter .col_1_3,
	.no-gutter .col_2_3,
	.no-gutter .col_1_4,
	.no-gutter .col_3_4{
		width: 100%;
	
	}
	.column{
		margin-left:0;
	}
	
	.wrapper{
	max-width: 1200px;
	padding: 0 35px;
	margin: 0 auto;
}
			
	.hero .column{
		max-width: 720px;
		margin: 25px auto;
		float: none;
	}
	
	.hero h1{
		padding: 0 25px;
	}

	.hero p{
		padding: 0 25px;
	}
	
	footer .wrapper .column{
		max-width: 720px;
		margin: 25px auto;
		float:none;
	}
	
	header{
		position: static;
	}
	
	header img{
		margin-left: 50px;
	}
	
	.container{
		display: none;
	}

	.anker-offset{
		scroll-margin-top: 1350px;
	}
	
	.anker-offset1{
	position: relative;
	top: -1350px; /* passt du auf deine Menühöhe an */ 
	visibility: hidden;
	}

	
	/* Responsive Navigation */
	
	nav{
		height: 0;
		transition: height .2s ease-in-out;
		overflow: hidden;
	}
	
	.nav-toggle{
		display: block;
		padding-left: 30px;
	}
	
	#nav-open:target .nav-closed{
		display: block;
	}
	
	.nav-closed,
	#nav-closed:target .nav-closed,
	#nav-open:target .nav-open{
		display: none;
	}
	
	#nav-open:target nav{
		height: 1333px;
	}
	
	#navigation{
		margin-top: 0;
		background-color: #fff;
		float: none;
		border-bottom: 1px dotted #414244;
	}
	
	#navigation li{
		display: block;
		margin-left: 15px;
		text-align: left;
		border-top: 1px dotted #414244;
	}
	
	#navigation li a{
		margin-left: 0;
		display: block;
	}
	
	#navigation li a:hover,
	#navigation li a.active{
	font-style: italic;
	font-weight: 500;
	color: #414244;
}
	
	#navigation ul{
		position: relative;
		display: block;
		top: 0;
		left: 5px;
		box-shadow: 0 0 0 rgba(0,0,0,0);
		background-color: #fff;
		width: 100%;
		margin-bottom: 10px;
	}
	
	#navigation ul li a{
		border-bottom: 0;
		padding: 10px 10px 10px 30px;
	}
	
	#nav{
		display: none;
	}
}



@media only screen and (max-width: 950px){
		
	#logo{
		max-height: 100px;
	}

	footer .wrapper .column{
		max-width: 360px;
		margin: 25px auto;
		float: none;
	}

	.hero .column{
		min-width: 360px;
		margin: 25px auto;
		float: none;
	}
	
	.teaser{
		font-size: 1.25rem; /* 20px */
		line-height: 2rem;
	}

	.leistungen .column{
		max-width: 500px;
	}

	.image-grid{
		max-width: 560px;
		margin: 0 auto;
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
		gap: 20px;
	}

	.image-grid img{
		width: 100%;
		height: auto;
		display: block;
	}
	

}


@media only screen and (max-width: 500px){
	
	h1{
		font-size: 2rem; /* 32px */
	}
	
	h2{
		font-size: 1.5rem; /* 24px */
	}
	
	h3{
		font-size: 1.375rem; /* 22px */
	}
	
	blockquote{
		font-size: 2rem; /* 32 */
	}
	
		
	.hero .column{
		min-width: 320px;
	}
}



